<META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=iso-8859-1">
<html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40" xmlns:ns0="urn:schemas-microsoft-com:office:smarttags"><head><meta name=Generator content="Microsoft Word 12 (filtered medium)"><style><!--
/* Font Definitions */
@font-face
        {font-family:Helvetica;
        panose-1:2 11 6 4 2 2 2 2 2 4;}
@font-face
        {font-family:"Cambria Math";
        panose-1:2 4 5 3 5 4 6 3 2 4;}
@font-face
        {font-family:Calibri;
        panose-1:2 15 5 2 2 2 4 3 2 4;}
@font-face
        {font-family:Tahoma;
        panose-1:2 11 6 4 3 5 4 4 2 4;}
@font-face
        {font-family:Monaco;
        panose-1:0 0 0 0 0 0 0 0 0 0;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
        {margin:0cm;
        margin-bottom:.0001pt;
        font-size:12.0pt;
        font-family:"Times New Roman","serif";}
a:link, span.MsoHyperlink
        {mso-style-priority:99;
        color:blue;
        text-decoration:underline;}
a:visited, span.MsoHyperlinkFollowed
        {mso-style-priority:99;
        color:purple;
        text-decoration:underline;}
p
        {mso-style-priority:99;
        mso-margin-top-alt:auto;
        margin-right:0cm;
        mso-margin-bottom-alt:auto;
        margin-left:0cm;
        font-size:12.0pt;
        font-family:"Times New Roman","serif";}
p.MsoAcetate, li.MsoAcetate, div.MsoAcetate
        {mso-style-priority:99;
        mso-style-link:"Balloon Text Char";
        margin:0cm;
        margin-bottom:.0001pt;
        font-size:8.0pt;
        font-family:"Tahoma","sans-serif";}
span.apple-style-span
        {mso-style-name:apple-style-span;}
span.apple-tab-span
        {mso-style-name:apple-tab-span;}
span.apple-converted-space
        {mso-style-name:apple-converted-space;}
span.EmailStyle21
        {mso-style-type:personal-reply;
        font-family:"Calibri","sans-serif";
        color:#1F497D;}
span.BalloonTextChar
        {mso-style-name:"Balloon Text Char";
        mso-style-priority:99;
        mso-style-link:"Balloon Text";
        font-family:"Tahoma","sans-serif";}
.MsoChpDefault
        {mso-style-type:export-only;
        font-size:10.0pt;}
@page WordSection1
        {size:612.0pt 792.0pt;
        margin:72.0pt 72.0pt 72.0pt 72.0pt;}
div.WordSection1
        {page:WordSection1;}
--></style><!--[if gte mso 9]><xml>
<o:shapedefaults v:ext="edit" spidmax="1026" />
</xml><![endif]--><!--[if gte mso 9]><xml>
<o:shapelayout v:ext="edit">
<o:idmap v:ext="edit" data="1" />
</o:shapelayout></xml><![endif]--></head><body lang=EN-AU link=blue vlink=purple><div class=WordSection1><div><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'>Thanks Paul – all useful…<o:p></o:p></span></p><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'><o:p> </o:p></span></p><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'>Cheers - Tony</span><span style='font-size:10.0pt;font-family:"Arial","sans-serif";color:#1F497D'><o:p></o:p></span></p></div><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'><o:p> </o:p></span></p><div style='border:none;border-left:solid blue 1.5pt;padding:0cm 0cm 0cm 4.0pt'><div><div style='border:none;border-top:solid #B5C4DF 1.0pt;padding:3.0pt 0cm 0cm 0cm'><p class=MsoNormal><b><span lang=EN-US style='font-size:10.0pt;font-family:"Tahoma","sans-serif"'>From:</span></b><span lang=EN-US style='font-size:10.0pt;font-family:"Tahoma","sans-serif"'> Paul Murray [mailto:pmurray@anbg.gov.au] <br><b>Sent:</b> Friday, 2 November 2012 2:35 PM<br><b>To:</b> Rees, Tony (CMAR, Hobart)<br><b>Cc:</b> Pigot, Simon (CMAR, Hobart); TDWG TAG; Whitbread, Greg (ANBG) - Contact<br><b>Subject:</b> Re: [tdwg-tag] Any TCS users with experiences to report? [SEC=UNCLASSIFIED]<o:p></o:p></span></p></div></div><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><o:p> </o:p></p><div><div><p class=MsoNormal>On 02/11/2012, at 12:57 PM, <<a href="mailto:Tony.Rees@csiro.au">Tony.Rees@csiro.au</a>> <<a href="mailto:Tony.Rees@csiro.au">Tony.Rees@csiro.au</a>> wrote:<o:p></o:p></p></div><p class=MsoNormal><br><br><o:p></o:p></p><div><div><div><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'>Thanks, Paul, for the detailed response.</span><o:p></o:p></p></div><div><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'> </span><o:p></o:p></p></div><div><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'>So in the document I am writing, I will be able to say that the present Australian NSLs as a resource do *<b>not</b>* use TCS although arguably it might not be too difficult to transform specific elements to TCS if the full native richness of the information is not required for our use case?</span><o:p></o:p></p></div></div></div><div><p class=MsoNormal><o:p> </o:p></p></div><div><p class=MsoNormal>At this stage, yes. We are influenced by TCS, we have copied and extended some of the TCS enumerations, but they aren't TCS and there has been enough water under the bridge that I cannot say with confidence that the values that do match TCS values mean the same thing in all cases.<o:p></o:p></p></div><p class=MsoNormal><br><br><o:p></o:p></p><div><div><div><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'> </span><o:p></o:p></p></div><div><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'>For example in our planned use case (extension of ISO metadata) we could still define elements using TCS schema if we wished, and suck/re-render just those from relevant NSL services?</span><o:p></o:p></p></div></div></div><div><p class=MsoNormal><o:p> </o:p></p></div><div><p class=MsoNormal>Perhaps I spoke too soon.<o:p></o:p></p></div><div><p class=MsoNormal><o:p> </o:p></p></div><div><p class=MsoNormal>The problem is that if you pull out TCS elements and use them, then the result will not be valid XML. This:<o:p></o:p></p></div><div><p class=MsoNormal><o:p> </o:p></p></div><div><div><p class=MsoNormal><?xml version="1.0" encoding="UTF-8"?><o:p></o:p></p></div><div><p class=MsoNormal><somedata<o:p></o:p></p></div><div><p class=MsoNormal> xmlns="<a href="http://myschema">http://myschema</a>" <o:p></o:p></p></div><div><p class=MsoNormal> xmlns:tcs="<a href="http://www.tdwg.org/schemas/tcs/1.01">http://www.tdwg.org/schemas/tcs/1.01</a>"<o:p></o:p></p></div><div><p class=MsoNormal>><o:p> </o:p></p></div><div><p class=MsoNormal><myname><o:p></o:p></p></div><div><p class=MsoNormal> <tcs:ScientificName><o:p></o:p></p></div><div><p class=MsoNormal> <tcs:CanonicalName><o:p></o:p></p></div><div><p class=MsoNormal> <tcs:Simple>Canis</tcs:Simple><o:p></o:p></p></div><div><p class=MsoNormal> <tcs:CanonicalName><o:p></o:p></p></div><div><p class=MsoNormal> </tcs:ScientificName><o:p></o:p></p></div><div><p class=MsoNormal></myname><o:p></o:p></p></div><div><p class=MsoNormal></somedata><o:p></o:p></p></div><div><p class=MsoNormal><o:p> </o:p></p></div><div><p class=MsoNormal>Is not valid xml - tcs:ScientificName element is not an element definition in tcs.<o:p></o:p></p></div></div><div><p class=MsoNormal><o:p> </o:p></p></div><div><p class=MsoNormal>However: TCS does expose some element *types*, notably CanonicalName, ScientificName - the type, not the element. (it would have been nice for them to prepend 'type' to their element types, but pressing on:)<o:p></o:p></p></div><div><p class=MsoNormal><o:p> </o:p></p></div><div><p class=MsoNormal>So you could define your own schema, your own type, and have it extend TCS CanonicalName. Or you could simply define a XML element as having type canonical name. Either way, this element could not be inserted into a TCS DataSet, but it would still be valid to use it.<o:p></o:p></p></div><div><p class=MsoNormal><o:p> </o:p></p></div><div><p class=MsoNormal>Give me a moment, and I'll see if I can make it happen …<o:p></o:p></p></div><div><p class=MsoNormal><o:p> </o:p></p></div><div><p class=MsoNormal>Ok! Success!<o:p></o:p></p></div><div><p class=MsoNormal><o:p> </o:p></p></div><div><p class=MsoNormal>If you define your own schema like so (I'm doing it all in the one directory to make things easier):<o:p></o:p></p></div><div><p class=MsoNormal><o:p> </o:p></p></div><div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#508E92'><?</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#678E91'>xml</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'> </span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#7F3191'>version</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>=</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#393FFD'>"1.0"</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'> </span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#7F3191'>encoding</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>=</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#393FFD'>"UTF-8"</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#508E92'>?></span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#7F3191'><o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#508E92'><</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#678E91'>xs:schema</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'> </span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#678E91'><o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'> </span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#7F3191'>xmlns:xs</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>=</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#393FFD'>"<a href="http://www.w3.org/2001/XMLSchema">http://www.w3.org/2001/XMLSchema</a>"</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'> </span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#393FFD'><o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'> </span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#7F3191'>targetNamespace</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>=</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#393FFD'>"<a href="http://www.example.org/MySchema">http://www.example.org/MySchema</a>"<o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif"'> <span style='color:#7F3191'>xmlns:tcs</span><span style='color:black'>=</span><span style='color:#393FFD'>"<a href="http://www.tdwg.org/schemas/tcs/1.01">http://www.tdwg.org/schemas/tcs/1.01</a>"</span><span style='color:black'> </span><o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif"'> <span class=apple-style-span><span style='color:#7F3191'>elementFormDefault</span><span style='color:black'>=</span><span style='color:#393FFD'>"qualified"</span></span><o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#508E92'>><o:p> </o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif"'> <span style='color:#508E92'><</span><span style='color:#678E91'>xs:import</span><span style='color:black'> </span><span style='color:#7F3191'>namespace</span><span style='color:black'>=</span><span style='color:#393FFD'>"<a href="http://www.tdwg.org/schemas/tcs/1.01">http://www.tdwg.org/schemas/tcs/1.01</a>" </span><span style='color:#7F3191'>schemaLocation</span><span class=apple-style-span><span style='color:black'>=</span><span style='color:#393FFD'>"TCSv101.xsd"</span><span style='color:black'> </span><span style='color:#508E92'>/></span></span><o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif"'><o:p> </o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif"'> <span style='color:#508E92'><</span><span style='color:#678E91'>xs:element</span><span style='color:black'> </span><span style='color:#7F3191'>name</span><span style='color:black'>=</span><span style='color:#393FFD'>"MyData"</span><span style='color:#508E92'>></span><o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif"'> <span style='color:#508E92'><</span><span style='color:#678E91'>xs:complexType</span><span style='color:#508E92'>></span><o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif"'> <span style='color:#508E92'><</span><span style='color:#678E91'>xs:sequence</span><span style='color:#508E92'>></span><o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif"'> <span style='color:#508E92'><</span><span style='color:#678E91'>xs:element</span><span style='color:black'> </span><span style='color:#7F3191'>name</span><span style='color:black'>=</span><span style='color:#393FFD'>"Name"</span><span style='color:black'> </span><span style='color:#7F3191'>type</span><span style='color:black'>=</span><span style='color:#393FFD'>"tcs:CanonicalName"</span><span style='color:black'> </span><span style='color:#7F3191'>maxOccurs</span><span style='color:black'>=</span><span style='color:#393FFD'>"unbounded"</span><span style='color:black'> </span><span style='color:#7F3191'>minOccurs</span><span style='color:black'>=</span><span style='color:#393FFD'>"0"</span><span style='color:#508E92'>/></span><o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif"'> <span style='color:#508E92'></</span><span style='color:#678E91'>xs:sequence</span><span style='color:#508E92'>></span><o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif"'> <span style='color:#508E92'></</span><span style='color:#678E91'>xs:complexType</span><span style='color:#508E92'>></span><o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif"'> <span style='color:#508E92'></</span><span style='color:#678E91'>xs:element</span><span style='color:#508E92'>></span><o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#508E92'></</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#678E91'>xs:schema</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#508E92'>></span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#678E91'><o:p></o:p></span></p></div><div><p class=MsoNormal><o:p> </o:p></p></div></div><div><p class=MsoNormal>Then you can use the TCS elements like so:<o:p></o:p></p></div><div><p class=MsoNormal><o:p> </o:p></p></div><div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#929292'><?</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>xml </span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#929292'>version=</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#4E8B0D'>"1.0" </span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#929292'>encoding=</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#4E8B0D'>"UTF-8"</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#929292'>?><o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'><</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>mydata</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>:</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>MyData<o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'> </span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>xmlns:tcs=</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#4E8B0D'>"<a href="http://www.tdwg.org/schemas/tcs/1.01">http://www.tdwg.org/schemas/tcs/1.01</a>"<o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#4E8B0D'> </span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>xmlns:xsi=</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#4E8B0D'>"<a href="http://www.w3.org/2001/XMLSchema-instance">http://www.w3.org/2001/XMLSchema-instance</a>" <o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#4E8B0D'> </span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>xmlns:mydata=</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#4E8B0D'>"<a href="http://www.example.org/MySchema">http://www.example.org/MySchema</a>"<o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#4E8B0D'> </span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>></span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#4E8B0D'><o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif"'><o:p> </o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'> <</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>mydata</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>:</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>Name</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>></span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'><o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif"'> <<span style='color:#0C1F91'>tcs</span>:<span style='color:#0C1F91'>Simple</span>>CANIDAE</<span style='color:#0C1F91'>tcs</span>:<span style='color:#0C1F91'>Simple</span>><o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'> </</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>mydata</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>:</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>Name</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>></span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'><o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'> <</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>mydata</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>:</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>Name</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>></span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'><o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif"'> <<span style='color:#0C1F91'>tcs</span>:<span style='color:#0C1F91'>Simple</span>>CANIDAE</<span style='color:#0C1F91'>tcs</span>:<span style='color:#0C1F91'>Simple</span>><o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'> <</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>tcs</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>:</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>Uninomial</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>>CANIDAE</</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>tcs</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>:</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>Uninomial</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>></span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'><o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'> </</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>mydata</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>:</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>Name</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>></span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'><o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'> <</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>mydata</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>:</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>Name</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>></span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'><o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'> <</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>tcs</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>:</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>Simple</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>>Canis</</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>tcs</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>:</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>Simple</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>></span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'><o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'> <</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>tcs</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>:</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>Uninomial</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>>Canis</</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>tcs</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>:</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>Uninomial</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>></span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'><o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'> </</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>mydata</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>:</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>Name</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>></span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'><o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'> <</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>mydata</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>:</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>Name</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>></span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'><o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif"'> <<span style='color:#0C1F91'>tcs</span>:<span style='color:#0C1F91'>Simple</span>>Canis familiaris</<span style='color:#0C1F91'>tcs</span>:<span style='color:#0C1F91'>Simple</span>><o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif"'> <<span style='color:#0C1F91'>tcs</span>:<span style='color:#0C1F91'>Genus</span>>Canis</<span style='color:#0C1F91'>tcs</span>:<span style='color:#0C1F91'>Genus</span>><o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'> <</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>tcs</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>:</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>SpecificEpithet</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>>familiaris</</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>tcs</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>:</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>SpecificEpithet</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>></span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'><o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'> </</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>mydata</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>:</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>Name</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>></span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'><o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'></</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>mydata</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>:</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>MyData</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>></span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'><o:p></o:p></span></p></div><div><p class=MsoNormal><o:p> </o:p></p></div><div><p class=MsoNormal><span style='color:black'>and it validates when I use the command</span><o:p></o:p></p></div><div><p class=MsoNormal><o:p> </o:p></p></div><div><p class=MsoNormal><span class=apple-tab-span><span style='color:black'> </span></span><span style='color:black'>xmllint --nonet --schema MySchema.xsd MyXml.xml</span><o:p></o:p></p></div><div><p class=MsoNormal><o:p> </o:p></p></div></div><div><p class=MsoNormal>Most importantly, this:<o:p></o:p></p></div><div><p class=MsoNormal><o:p> </o:p></p></div><div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#929292'><?</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>xml </span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#929292'>version=</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#4E8B0D'>"1.0" </span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#929292'>encoding=</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#4E8B0D'>"UTF-8"</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#929292'>?><o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'><</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>mydata</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>:</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>MyData<o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'> </span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>xmlns:tcs=</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#4E8B0D'>"<a href="http://www.tdwg.org/schemas/tcs/1.01">http://www.tdwg.org/schemas/tcs/1.01</a>"<o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#4E8B0D'> </span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>xmlns:xsi=</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#4E8B0D'>"<a href="http://www.w3.org/2001/XMLSchema-instance">http://www.w3.org/2001/XMLSchema-instance</a>" <o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#4E8B0D'> </span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>xmlns:mydata=</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#4E8B0D'>"<a href="http://www.example.org/MySchema">http://www.example.org/MySchema</a>"<o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif"'> ><o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif"'><o:p> </o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'> <</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>mydata</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>:</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>Name</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>></span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'><o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'> <</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>tcs</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>:</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>Simple</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>>Canis</</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>tcs</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>:</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>Simple</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>></span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'><o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif"'> <<span style='color:#0C1F91'>tcs</span>:<span style='color:#0C1F91'>Genus</span>>Canis</<span style='color:#0C1F91'>tcs</span>:<span style='color:#0C1F91'>Genus</span>><o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'> </</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>mydata</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>:</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>Name</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>></span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'><o:p></o:p></span></p></div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'></</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>mydata</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>:</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'>MyData</span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'>></span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#0C1F91'><o:p></o:p></span></p></div><div><p class=MsoNormal><o:p> </o:p></p></div></div><div><p class=MsoNormal><o:p> </o:p></p></div><div><p class=MsoNormal>Does *not* validate, as it shouldn't. In TCS, you do not use "Genus" except as part of a more than uninomial name.<o:p></o:p></p></div><div><p class=MsoNormal><o:p> </o:p></p></div><div><p class=MsoNormal>TCS exposes several types that can be used in this way, and quite possibly I should have looked at doing this in the IBIS xml schemas, particularly as you can extend these types in your own schemas. 20/20 hindsight and all that.<o:p></o:p></p></div><div><div><p class=MsoNormal><o:p> </o:p></p></div></div><blockquote style='margin-top:5.0pt;margin-bottom:5.0pt'><div><div><div><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'>I am thinking at this stage we might only use scientific name, LSID, authorship, rank, common names as available; and possibly a navigable parent tree to generate a taxonomic hierarchy, either as separate elements, or a concatenated string. Synonyms are also a possible area of interest but possibly more trouble than they will be worth in this use case.</span><o:p></o:p></p></div></div></div></blockquote><div><p class=MsoNormal><o:p> </o:p></p></div><div><p class=MsoNormal>TCS Types of interest might be:<o:p></o:p></p></div><div><p class=MsoNormal>ScientificName<o:p></o:p></p></div><div><p class=MsoNormal>NameCitation<o:p></o:p></p></div><div><p class=MsoNormal>AgentNames (for authors)<o:p></o:p></p></div><div><p class=MsoNormal>RelationshipType<o:p></o:p></p></div><div><p class=MsoNormal>AccordingToType<o:p></o:p></p></div><div><p class=MsoNormal><o:p> </o:p></p></div><blockquote style='margin-top:5.0pt;margin-bottom:5.0pt'><div><div><div><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'> </span><o:p></o:p></p></div><div><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'>I guess there are attractions to using a globally defined rather than locally defined schema where possible (although maybe not if it’s one no other clients support…)</span><o:p></o:p></p></div></div></div></blockquote><div><p class=MsoNormal><o:p> </o:p></p></div><div><p class=MsoNormal><o:p> </o:p></p></div><div><p class=MsoNormal>very much so. But to correctly leverage TCS in a way that can be validated, your will need your own schema. But this can be as simple as exposing each of the types as your own element:<o:p></o:p></p></div><div><p class=MsoNormal><o:p> </o:p></p></div><div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif"'> <span style='color:#508E92'><</span><span style='color:#678E91'>xs:element</span><span style='color:black'> </span><span style='color:#7F3191'>name</span><span style='color:black'>=</span><span style='color:#393FFD'>"CanonicalName"</span><span style='color:black'> </span><span style='color:#7F3191'>type</span><span style='color:black'>=</span><span style='color:#393FFD'>"tcs:CanonicalName"</span><span style='color:black'> </span><span style='color:#7F3191'>maxOccurs</span><span style='color:black'>=</span><span style='color:#393FFD'>"unbounded"</span><span style='color:black'> </span><span style='color:#7F3191'>minOccurs</span><span style='color:black'>=</span><span style='color:#393FFD'>"0"</span><span style='color:#508E92'>/></span><o:p></o:p></span></p></div><div><p class=MsoNormal><o:p> </o:p></p></div></div><div><p class=MsoNormal>and so on.<o:p></o:p></p></div><div><p class=MsoNormal><o:p> </o:p></p></div><div><p class=MsoNormal>It might be worth revisiting this for the <a href="http://biodiversity.org.au">biodiversity.org.au</a> data at some stage when we are ready to do a fairly major revision of the structure of the output.<o:p></o:p></p></div><div><p class=MsoNormal><o:p> </o:p></p></div><div><p class=MsoNormal><o:p> </o:p></p></div><blockquote style='margin-top:5.0pt;margin-bottom:5.0pt'><div><div><div><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'> </span><o:p></o:p></p></div><div><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'>Cheers - Tony</span><o:p></o:p></p></div></div><div><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'> </span><o:p></o:p></p></div><div style='border:none;border-left:solid blue 1.5pt;padding:0cm 0cm 0cm 4.0pt;border-width:initial;border-color:initial;z-index:auto'><div><div style='border:none;border-top:solid #B5C4DF 1.0pt;padding:3.0pt 0cm 0cm 0cm;border-width:initial;border-color:initial'><div><p class=MsoNormal><b><span lang=EN-US style='font-size:10.0pt;font-family:"Tahoma","sans-serif"'>From:</span></b><span class=apple-converted-space><span lang=EN-US style='font-size:10.0pt;font-family:"Tahoma","sans-serif"'> </span></span><span lang=EN-US style='font-size:10.0pt;font-family:"Tahoma","sans-serif"'>Paul Murray [<a href="mailto:pmurray@anbg.gov.au">mailto:pmurray@anbg.gov.au</a>]<span class=apple-converted-space> </span><br><b>Sent:</b><span class=apple-converted-space> </span>Friday, 2 November 2012 12:31 PM<br><b>To:</b><span class=apple-converted-space> </span>Rees, Tony (CMAR, Hobart)<br><b>Cc:</b><span class=apple-converted-space> </span>TDWG TAG; Pigot, Simon (CMAR, Hobart); Whitbread, Greg (ANBG) - Contact<br><b>Subject:</b><span class=apple-converted-space> </span>Re: [tdwg-tag] Any TCS users with experiences to report? [SEC=UNCLASSIFIED]</span><o:p></o:p></p></div></div></div><div><p class=MsoNormal> <o:p></o:p></p></div><div><div><p class=MsoNormal>Firstly, the XML schema:<o:p></o:p></p></div></div><div><div><p class=MsoNormal> <o:p></o:p></p></div></div><div><div><div><p class=MsoNormal><span style='font-size:9.0pt;font-family:"Helvetica","sans-serif"'><a href="http://biodiversity.org.au/xml/ibis">http://biodiversity.org.au/xml/ibis</a><span class=apple-converted-space> </span>is an xml namespace, which works a bit differently to RDF namespaces.</span><o:p></o:p></p></div></div><div><div><p class=MsoNormal><span style='font-size:9.0pt;font-family:"Helvetica","sans-serif"'> </span><o:p></o:p></p></div></div><div><div><p class=MsoNormal><span style='font-size:9.0pt;font-family:"Helvetica","sans-serif"'>RDF does not have an explicit mechanism for finding schema metadata. By convention (and it is just a convention), we usually find the schema for a namespace by assuming that the namespace URI will work as a URL that can be fetched, and that fetching it will pull back a schema description (possibly in any one of several formats, using HTTP content negotiation).</span><o:p></o:p></p></div></div><div><div><p class=MsoNormal><span style='font-size:9.0pt;font-family:"Helvetica","sans-serif"'> </span><o:p></o:p></p></div></div><div><div><p class=MsoNormal><span style='font-size:9.0pt;font-family:"Helvetica","sans-serif"'>In XML, however, namespaces are explicitly linked to schema documents by the xsi:schemaLocation attribute.</span><o:p></o:p></p></div></div></div><div><div><p class=MsoNormal><span style='font-size:9.0pt;font-family:"Helvetica","sans-serif"'> </span><o:p></o:p></p></div></div><div><div><p class=MsoNormal><span style='font-size:9.0pt;font-family:"Helvetica","sans-serif"'>The xml generated by<span class=apple-converted-space> </span><a href="http://biodiversity.org.au/">biodiversity.org.au</a></span><o:p></o:p></p></div></div><div><div><p class=MsoNormal><span style='font-size:9.0pt;font-family:"Helvetica","sans-serif"'> </span><o:p></o:p></p></div></div><div><div><p class=MsoNormal><span class=apple-tab-span><span style='font-size:9.0pt;font-family:"Helvetica","sans-serif"'> </span></span><span class=apple-converted-space><span style='font-size:9.0pt;font-family:"Helvetica","sans-serif"'> </span></span><span style='font-size:9.0pt;font-family:"Helvetica","sans-serif"'><a href="http://biodiversity.org.au/apni.taxon/54321.xml">http://biodiversity.org.au/apni.taxon/54321.xml</a></span><o:p></o:p></p></div></div><div><div><p class=MsoNormal> <o:p></o:p></p></div></div><div><div><p class=MsoNormal>Comes back with the declaration <o:p></o:p></p></div></div><div><div><p class=MsoNormal> <o:p></o:p></p></div></div><div><div><div><p class=MsoNormal><span style='font-size:9.0pt;font-family:"Helvetica","sans-serif"'><app:documents xmlns:app="<a href="http://biodiversity.org.au/xml/servicelayer/content">http://biodiversity.org.au/xml/servicelayer/content</a>" xmlns:ibis="<a href="http://biodiversity.org.au/xml/ibis">http://biodiversity.org.au/xml/ibis</a>" xmlns:rdf="<a href="http://www.w3.org/1999/02/22-rdf-syntax-ns">http://www.w3.org/1999/02/22-rdf-syntax-ns#</a>" xmlns:cfg="<a href="http://biodiversity.org.au/xml/servicelayer/configuration">http://biodiversity.org.au/xml/servicelayer/configuration</a>" xmlns:xsi="<a href="http://www.w3.org/2001/XMLSchema-instance">http://www.w3.org/2001/XMLSchema-instance</a>" xsi:schemaLocation="<span class=apple-converted-space> </span><a href="http://purl.org/dc/elements/1.1/">http://purl.org/dc/elements/1.1/</a><span class=apple-converted-space> </span><a href="http://dublincore.org/schemas/xmls/qdc/dc.xsd">http://dublincore.org/schemas/xmls/qdc/dc.xsd</a><span class=apple-converted-space> </span><a href="http://purl.org/dc/terms/">http://purl.org/dc/terms/</a><span class=apple-converted-space> </span><a href="http://dublincore.org/schemas/xmls/qdc/dcterms.xsd">http://dublincore.org/schemas/xmls/qdc/dcterms.xsd</a><span class=apple-converted-space> </span><a href="http://purl.org/dc/dcmitype/">http://purl.org/dc/dcmitype/</a><a href="http://dublincore.org/schemas/xmls/qdc/dcmitype.xsd">http://dublincore.org/schemas/xmls/qdc/dcmitype.xsd</a><span class=apple-converted-space> </span><a href="http://biodiversity.org.au/xml/servicelayer/content">http://biodiversity.org.au/xml/servicelayer/content</a><span class=apple-converted-space> </span><a href="http://anbg.gov.au/ala/schemas/xml/app.xsd">http://anbg.gov.au/ala/schemas/xml/app.xsd</a><span class=apple-converted-space> </span><a href="http://biodiversity.org.au/xml/ibis">http://biodiversity.org.au/xml/ibis</a><span class=apple-converted-space> </span><a href="http://biodiversity.org.au/xml/ibis-20120706.xsd">http://biodiversity.org.au/xml/ibis-20120706.xsd</a><span class=apple-converted-space> </span><a href="http://biodiversity.org.au/xml/apni">http://biodiversity.org.au/xml/apni</a><a href="http://biodiversity.org.au/xml/apni-20120706.xsd">http://biodiversity.org.au/xml/apni-20120706.xsd</a><span class=apple-converted-space> </span><a href="http://biodiversity.org.au/xml/afd">http://biodiversity.org.au/xml/afd</a><span class=apple-converted-space> </span><a href="http://biodiversity.org.au/xml/afd-20120706.xsd">http://biodiversity.org.au/xml/afd-20120706.xsd</a><span class=apple-converted-space> </span><a href="http://biodiversity.org.au/xml/col">http://biodiversity.org.au/xml/col</a><span class=apple-converted-space> </span><a href="http://biodiversity.org.au/xml/col-20110615.xsd">http://biodiversity.org.au/xml/col-20110615.xsd</a><span class=apple-converted-space> </span>"></span><o:p></o:p></p></div></div></div><div><div><p class=MsoNormal> <o:p></o:p></p></div></div><div><div><p class=MsoNormal>Although it's a bit buried in there, XML parsers can see from this that the xml namespace "<span class=apple-style-span><span style='font-size:9.0pt'><a href="http://biodiversity.org.au/xml/ibis">http://biodiversity.org.au/xml/ibis</a>" has a location of "<a href="http://biodiversity.org.au/xml/ibis-20120706.xsd">http://biodiversity.org.au/xml/ibis-20120706.xsd</a>". All of our XML is supposed to validate, and last time I checked it did.</span></span><o:p></o:p></p></div></div><div><div><p class=MsoNormal> <o:p></o:p></p></div></div><div><div><p class=MsoNormal>By the way - note the date on the filename. We have changed the schema from time to time. Another change is upcoming: the addition of an "excluded" flag for concepts that have been considered for APC and have been explicitly excluded (for a variety of reasons). This will be managed by a new schema document being available on our server and the generated xsi:schemaLocation attribute being changed.<o:p></o:p></p></div></div><div><div><p class=MsoNormal> <o:p></o:p></p></div></div><div><div><p class=MsoNormal><span class=apple-style-span><span style='font-size:9.0pt'>Secondly, TCS:</span></span><o:p></o:p></p></div></div><div><div><p class=MsoNormal> <o:p></o:p></p></div></div><div><div><p class=MsoNormal><span class=apple-style-span><span style='font-size:9.0pt'>The issue with TCS is that it is very difficult to extend. To use a bit of TCS in some other schema, you would import the element types and extend them. But TCS mostly does not expose its element types as named types that can be referenced externally - it's all done inline. This means that the only place a TCS "ScientificName" or "Rank" element can appear is somewhere inside a TCS DataSet element. This is not in itself a show-stopper: we could simply generate a DataSet wrapper when we produce output in response to fetches.</span></span><o:p></o:p></p></div></div><div><div><p class=MsoNormal> <o:p></o:p></p></div></div><div><div><p class=MsoNormal><span class=apple-style-span><span style='font-size:9.0pt'>But there were other issues such as (and I can only recall one or two at the moment - this mail is not a full defence of our decision to not go with TCS):</span></span><o:p></o:p></p></div></div><div><div><p class=MsoNormal> <o:p></o:p></p></div></div><div><div><p class=MsoNormal><span class=apple-style-span><span style='font-size:9.0pt'>A TaxonConcepts element may have multiple TaxonRelationships element. We would like to attach additional data to each relationship to capture information that TCS cannot. There is a ProviderSpecificData element, but this is at the end of the TaxonConcept element, and I could not work out a way to stuff the extra data for each relationship into that ProviderSpecificData element in such a way as it was attached to the correct relationship - although re-looking at it now I see a "ref" attribute and perhaps that is meant to do the job.</span></span><o:p></o:p></p></div></div><div><div><p class=MsoNormal> <o:p></o:p></p></div></div><div><div><p class=MsoNormal><span class=apple-style-span><span style='font-size:9.0pt'>There are multiple TCS "relationship types", but these did not quite match the data we had. It is not possible to put anything but a TCS relationship type enum into the "type" attribute of a TaxonRelationship element, so we wind up having to provide two fields - the "real" type and the nearest TCS equivalent. The "real" type needs to go in the ProviderSpecificData section - miles away (in the document) from what is supposed to be the primary place where the relationship is described. It's ugly. Furthermore, some of our relationships don't really match the TCS ones at all well - to the point that using a TCS type would be misleading. The TCS enumeration does not have a "other" value, so there was a bit of an impasse.</span></span><o:p></o:p></p></div></div><div><div><p class=MsoNormal> <o:p></o:p></p></div></div><div><div><p class=MsoNormal><span class=apple-style-span><span style='font-size:9.0pt'>In any event, we were looking at either putting some relationships in the TCS array, and some in the PSD array, or putting corresponding arrays in each. Of course, in the provider specific data section we cannot use any of the TCS elements, because the element types are not exposed and can only appear in a TCS DataSet at the correct spot. It just got to the point where the ProviderSpecificData section was bigger and more interesting than the TCS, so we broke it out into a separate XML document (which was bundles with the TCS using an ibis:documents wrapper), at which point we couldn't help but ask "Can some one explain again why we are trying to do this?". After more discussions with both the zoologists and the botanists, attempting to work out which TCS enumerated values I should use for what, we gave up.</span></span><o:p></o:p></p></div></div><div><div><p class=MsoNormal> <o:p></o:p></p></div></div><div><div><p class=MsoNormal>TCS does an admirable job of being watertight. If you have any valid XML document with any TCS element, then you know that it will be enclosed in a DataSet element and come bundled with enough context to make sense of it. It's a model for shifting around entire, self-contained *sets* of data. Entire taxonomies, sitting as big files on a disk (or in an xml store). But our service layer serves up fragments - one or several taxa in response to a request, and TCS turned out to not be a good model for what we do. The history of trying to use it has left us with a legacy of having multiple relationship-type fields (relationship "description" and relationship "category") whose product does not form a sensible set of values.<o:p></o:p></p></div></div><div><div><p class=MsoNormal> <o:p></o:p></p></div></div><div><div><p class=MsoNormal>What we have now is a site-specific schema that captures and exposes the data we have. Admittedly, this means that the grand goal we are all trying to accomplish - a consistent worldwide net of data - is not as far down the track as we were hoping to go. It means that the problem of working out how data set 1 matches data set 2 is pushed off onto aggregators, a job that is in general impossible for an aggregator to accomplish. If we could have fitted our data into TCS, if everyone else could also have done so, then that would have been wonderful. We were reluctant to abandon it, but to get our data out the door we eventually did.<o:p></o:p></p></div></div><div><div><p class=MsoNormal> <o:p></o:p></p></div></div><div><p class=MsoNormal> <o:p></o:p></p></div><div><div><div><p class=MsoNormal>On 02/11/2012, at 9:41 AM, <<a href="mailto:Tony.Rees@csiro.au">Tony.Rees@csiro.au</a>> <<a href="mailto:Tony.Rees@csiro.au">Tony.Rees@csiro.au</a>> wrote:<o:p></o:p></p></div></div><div><div><p class=MsoNormal> <o:p></o:p></p></div></div><div><div><p class=MsoNormal> <o:p></o:p></p></div></div><div><p class=MsoNormal><br><br><br><o:p></o:p></p></div><div><div><div><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'>Hi TDWG persons,</span><o:p></o:p></p></div></div><div><div><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'> </span><o:p></o:p></p></div></div><div><div><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'>I am involved in an activity here to set a local standard for storing taxonomic name, identifier and (probably) hierarchy information in metadata records using our profile of ISO 19115 for the latter, and the question will come up as to whether to use elements from TCS, DwC, EML, NCBII extension to ISO 19115, or other. By default I would expect the front runner to be TCS but it appears few if any major systems have ever gone that route – I have looked at ITIS, COL, TROPICOS, WoRMS, IPNI, GBIF, AFD/APNI, more… the nearest would perhaps be AFD/APNI (hence copying Paul on this email) however their “ibis” schema, though apparently based originally on TCS,<a href="http://biodiversity.org.au/xml/ibis-20120909.xsd">http://biodiversity.org.au/xml/ibis-20120909.xsd</a><span class=apple-converted-space> </span>, does not make any explicit reference to the TCS schema so far as I can see. (Note also the cited schema definition<span class=apple-converted-space> </span><a href="http://biodiversity.org.au/xml/ibis">http://biodiversity.org.au/xml/ibis</a><span class=apple-converted-space> </span>[or presumably<a href="http://biodiversity.org.au/xml/ibis.xsd">http://biodiversity.org.au/xml/ibis.xsd</a>] does not seem to exist, but maybe I am missing something).</span><o:p></o:p></p></div></div><div><div><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'> </span><o:p></o:p></p></div></div><div><div><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'>I am in the interesting position of also wishing to make apps which both publish and consume taxonomic name information so *<b>could</b>* implement TCS for these, but if no-one else is doing so maybe that is not a path to future data harmonisation, and something like DwC might be better.</span><o:p></o:p></p></div></div><div><div><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'> </span><o:p></o:p></p></div></div><div><div><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'>It does seem odd that we have a standard endorsed in 2005 by TDWG which is apparently unused by any current major players in the real world. Any thoughts?</span><o:p></o:p></p></div></div><div><div><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'> </span><o:p></o:p></p></div></div><div><div><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'>Regards - Tony</span><o:p></o:p></p></div></div><div><div><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'> </span><o:p></o:p></p></div></div><div><div><div><p class=MsoNormal><span lang=EN-US style='font-size:10.0pt;font-family:"Arial","sans-serif";color:#1F497D'>Tony Rees<br>Manager, Divisional Data Centre,<br>CSIRO Marine and Atmospheric Research,<br>GPO<span class=apple-converted-space> </span>Box<span class=apple-converted-space> </span>1538,<br>Hobart,<span class=apple-converted-space> </span>Tasmania<span class=apple-converted-space> </span>7001,<span class=apple-converted-space> </span>Australia<br>Ph: 0362 325318 (Int: +61 362 325318)<br>Fax: 0362 325000 (Int: +61 362 325000)</span><o:p></o:p></p></div></div><div><div><p class=MsoNormal><span lang=EN-US style='font-size:10.0pt;font-family:"Arial","sans-serif";color:#1F497D'>e-mail:<span class=apple-converted-space> </span><a href="mailto:Tony.Rees@csiro.au" title="mailto:Tony.Rees@csiro.au">Tony.Rees@csiro.au</a><br>Manager, OBIS Australia regional node,<span class=apple-converted-space> </span><a href="http://www.obis.org.au/">http://www.obis.org.au/</a><br>Biodiversity informatics research activities:<span class=apple-converted-space> </span><a href="http://www.cmar.csiro.au/datacentre/biodiversity.htm">http://www.cmar.csiro.au/datacentre/biodiversity.htm</a><br>Personal info: <a href="http://www.fishbase.org/collaborators/collaboratorsummary.cfm?id=1566" title="http://www.fishbase.org/collaborators/collaboratorsummary.cfm?id=1566">http://www.fishbase.org/collaborators/collaboratorsummary.cfm?id=1566</a></span><o:p></o:p></p></div></div><div><div><p class=MsoNormal><span lang=EN-US style='font-size:10.0pt;font-family:"Arial","sans-serif";color:#1F497D'>LinkedIn profile:<span class=apple-converted-space> </span></span><span style='font-size:10.0pt;font-family:"Arial","sans-serif";color:#1F497D'><a href="http://www.linkedin.com/pub/tony-rees/18/770/36">http://www.linkedin.com/pub/tony-rees/18/770/36</a></span><o:p></o:p></p></div></div></div><div><div><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'> </span><o:p></o:p></p></div></div><div style='border:none;border-left:solid windowtext 3.0pt;padding:0cm 0cm 0cm 4.0pt;border-width:initial;border-color:initial;border-width:initial;border-color:initial;z-index:auto'><div><div style='border:none;border-top:solid windowtext 3.0pt;padding:3.0pt 0cm 0cm 0cm;border-width:initial;border-color:initial;border-width:initial;border-color:initial'><div><div><p class=MsoNormal><b><span lang=EN-US style='font-size:10.0pt;font-family:"Tahoma","sans-serif"'>From:</span></b><span class=apple-converted-space><span lang=EN-US style='font-size:10.0pt;font-family:"Tahoma","sans-serif"'> </span></span><span lang=EN-US style='font-size:10.0pt;font-family:"Tahoma","sans-serif"'><a href="mailto:tdwg-tag-bounces@lists.tdwg.org">tdwg-tag-bounces@lists.tdwg.org</a><span class=apple-converted-space> </span>[<a href="mailto:tdwg-tag-bounces@lists.tdwg.org">mailto:tdwg-tag-bounces@lists.tdwg.org</a>]<span class=apple-converted-space> </span><b>On Behalf Of<span class=apple-converted-space> </span></b>Paul Murray<br><b>Sent:</b><span class=apple-converted-space> </span>Wednesday, 7 March 2012 12:52 PM<br><b>To:</b><span class=apple-converted-space> </span>Steve Baskauf<br><b>Cc:</b><span class=apple-converted-space> </span>"Éamonn Ó Tuama (GBIF)"; TDWG TAG<br><b>Subject:</b><span class=apple-converted-space> </span>Re: [tdwg-tag] Creating a TDWG standard for documenting Data Standards [SEC=UNCLASSIFIED]</span><o:p></o:p></p></div></div></div></div><div><div><p class=MsoNormal> <o:p></o:p></p></div></div><div><div><p class=MsoNormal> <o:p></o:p></p></div></div><div><div><div><div><p class=MsoNormal>On 07/03/2012, at 3:11 AM, Steve Baskauf wrote:<o:p></o:p></p></div></div></div><div><div><p class=MsoNormal><br><br><br><br><o:p></o:p></p></div></div><div><div><div><p class=MsoNormal>Dag and Éamonn,<br><br>In the context of the discussion which has been going on in the TDWG RDF mailing list, I have been thinking more about the issue of how to deal with DwC terms which state "Recommended best practice is to use a controlled vocabulary...". That would be dcterms:type, dwc:language, dwc:basisOfRecord, dwc:sex, dwc:lifeStage, dwc:reproductiveCondition, dwc:behavior, dwc:establishmentMeans, dwc:occurrenceStatus, dwc:disposition, dwc:continent, dwc:waterBody, dwc:islandGroup, dwc:island, dwc:country, dwc:verbatimCoordinateSystem, dwc:georeferenceVerificationStatus, dwc:identificationVerificationStatus, dwc:taxonRank; dwc:nomenclaturalCode, dwc:taxonomicStatus, dwc:relationshipOfResource, and dwc:measurementType .<o:p></o:p></p></div></div></div><div><div><p class=MsoNormal> <o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal> <o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal>We here have had all sorts of problems using other people's vocabularies - they never quite match the data we have. Our solution has been to use the standard terms where possible, but to mint our own where needed. We create RDF objects and to declare them as being the correct type.<o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal> <o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal>For instance, <o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal><span class=apple-tab-span> </span><span class=apple-converted-space> </span><span class=apple-style-span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#3834FF'><a href="http://biodiversity.org.au/voc/afd/AFD">http://biodiversity.org.au/voc/afd/AFD</a>#RelationshipTypeTerm</span></span><o:p></o:p></p></div></div></div><div><div><div><div><p class=MsoNormal> <o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal>Is declared to be a subclass of<o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal><span class=apple-tab-span> </span><span class=apple-converted-space> </span><span class=apple-style-span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#4DAC72'><a href="http://rs.tdwg.org/ontology/voc/TaxonConcept">http://rs.tdwg.org/ontology/voc/TaxonConcept#</a></span></span><span class=apple-style-span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#3834FF'>TaxonRelationshipTerm</span></span><o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal> <o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal>And we have a few specific items of that type:<o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal><span class=apple-style-span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'> </span></span><span class=apple-style-span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#3834FF'><a href="http://biodiversity.org.au/voc/afd/RelationshipTypeTerm">http://biodiversity.org.au/voc/afd/RelationshipTypeTerm</a>#has-emendation</span></span><o:p></o:p></p></div></div></div><div><div><div><div><div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'> </span><span class=apple-style-span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#3834FF'><a href="http://biodiversity.org.au/voc/afd/RelationshipTypeTerm">http://biodiversity.org.au/voc/afd/RelationshipTypeTerm</a></span></span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#3834FF'>#has-invalid-name</span><o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'> </span><span class=apple-style-span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#3834FF'><a href="http://biodiversity.org.au/voc/afd/RelationshipTypeTerm">http://biodiversity.org.au/voc/afd/RelationshipTypeTerm</a></span></span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#3834FF'>#has-junior-homonym</span><o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal><span style='font-size:8.5pt;font-family:"Monaco","serif";color:black'> </span><span class=apple-style-span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#3834FF'><a href="http://biodiversity.org.au/voc/afd/RelationshipTypeTerm">http://biodiversity.org.au/voc/afd/RelationshipTypeTerm</a></span></span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#3834FF'>#has-miscellaneous-literature-name</span><o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal><span style='font-size:13.5pt;font-family:"Helvetica","sans-serif";color:black'> </span><o:p></o:p></p></div></div></div></div><div><div><div><p class=MsoNormal><span style='font-size:13.5pt;font-family:"Helvetica","sans-serif";color:black'>These individuals are therefore correctly typed to be legitimately be used as a TDWG </span><span class=apple-style-span><span style='font-size:8.5pt;font-family:"Monaco","serif";color:#3834FF'>relationshipCategory</span></span><span style='font-size:13.5pt;font-family:"Helvetica","sans-serif";color:black'>. </span><o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal><span style='font-size:13.5pt;font-family:"Helvetica","sans-serif";color:black'> </span><o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal><span style='font-size:13.5pt;font-family:"Helvetica","sans-serif";color:black'>Your lists of dwc:disposition values does not need to be exhaustive. It's legitimate (from a machine point of view) for a site to create their own terms. However, this does mean that the world becomes fragmented into a number of site-specific vocabularies that cannot be machine-reasoned over. The underlying reason for this is that that is in fact the way the world actually is at the moment, and there's not a lot of help for it.</span><o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal><span style='font-size:13.5pt;font-family:"Helvetica","sans-serif";color:black'> </span><o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal><span style='font-size:13.5pt;font-family:"Helvetica","sans-serif"'>-------------------------------------------------------------</span><o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal><span style='font-size:13.5pt;font-family:"Helvetica","sans-serif";color:black'> </span><o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal><span style='font-size:13.5pt;font-family:"Helvetica","sans-serif";color:black'>There are two or three approaches to using a standard vocabulary when your own data does not quite match it.</span><o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal><span style='font-size:13.5pt;font-family:"Helvetica","sans-serif";color:black'> </span><o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal><span style='font-size:13.5pt;font-family:"Helvetica","sans-serif";color:black'>You can use the standard term that is *closest in meaning* to your own term. The difficulty here is that if the meaning of the standard term implies things that are not true of your data, using it means that you are asserting things that are in fact not true, and for that reason I suggest that it's not the way to go.</span><o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal><span style='font-size:13.5pt;font-family:"Helvetica","sans-serif";color:black'> </span><o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal><span style='font-size:13.5pt;font-family:"Helvetica","sans-serif";color:black'>You can use the standard term whose definition encompasses your term. The difficulty here is that some vocabularies (notably Taxon Concept Schema) don't have "other" or "unspecified" values for their enumerations - they are not exhaustive.</span><o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal><span style='font-size:13.5pt;font-family:"Helvetica","sans-serif";color:black'> </span><o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal><span style='font-size:13.5pt;font-family:"Helvetica","sans-serif";color:black'>In either of these cases, you will want to supplement the standard term with another value specific to your own data set, whose definition you make available. There are a few ways to do that.</span><o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal><span style='font-size:13.5pt;font-family:"Helvetica","sans-serif";color:black'> </span><o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal><span style='font-size:13.5pt;font-family:"Helvetica","sans-serif";color:black'>You can use the "define your own term" mechanism and assert both</span><o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal><span style='font-size:13.5pt;font-family:"Helvetica","sans-serif";color:black'> _:_ tdwg:has_relationship_type tdwg:is-subtaxon-of .</span><o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal><span style='font-size:13.5pt;font-family:"Helvetica","sans-serif";color:black'> _:_ tdwg:has_relationship_type my-voc:is-recently-declared-subtaxon-of .</span><o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal><span style='font-size:13.5pt;font-family:"Helvetica","sans-serif";color:black'> </span><o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal><span style='font-size:13.5pt;font-family:"Helvetica","sans-serif";color:black'>You can have a completely separate predicate:</span><o:p></o:p></p></div></div></div><div><div><div><div><p class=MsoNormal><span style='font-size:13.5pt;font-family:"Helvetica","sans-serif";color:black'> _:_ tdwg:has_relationship_type tdwg:is-subtaxon-of .</span><o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal><span style='font-size:13.5pt;font-family:"Helvetica","sans-serif";color:black'> _:_ myvoc:has_relationship_type my-voc:is-recently-declared-subtaxon-of .</span><o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal><span style='font-size:13.5pt;font-family:"Helvetica","sans-serif";color:black'> </span><o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal><span style='font-size:13.5pt;font-family:"Helvetica","sans-serif";color:black'>You can also be terribly clever and declare your own predicate to be a super-property of the TDWG predicate, one whose range is a union. This isn't terribly useful to people using your data unless the tdwg triple is also asserted.</span><o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal><span style='font-size:13.5pt;font-family:"Helvetica","sans-serif";color:black'> </span><o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal><span style='font-size:13.5pt;font-family:"Helvetica","sans-serif";color:black'>Another alternative is to create an OWL rule that says </span><o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal><span style='font-size:13.5pt;font-family:"Helvetica","sans-serif";color:black'>"if a thing has relationship-type my-voc:is-recently-declared-subtaxon-of, then it also has relationship-type tdwg:is-subtaxon-of"</span><o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal><span style='font-size:13.5pt;font-family:"Helvetica","sans-serif";color:black'> </span><o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal><span style='font-size:13.5pt;font-family:"Helvetica","sans-serif";color:black'>But this creates a performance hit.</span><o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal><span style='font-size:13.5pt;font-family:"Helvetica","sans-serif";color:black'> </span><o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal><span style='font-size:13.5pt;font-family:"Helvetica","sans-serif";color:black'>-------------------------------------------------------------</span><o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal><span style='font-size:13.5pt;font-family:"Helvetica","sans-serif";color:black'> </span><o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal><span style='font-size:13.5pt;font-family:"Helvetica","sans-serif";color:black'>That little discussion aside, my main concern is that you don't get mired in attempting to exhaustively list all the different island types (etc) as part of the vocabulary that you are creating. It's a never-ending job. It might be an idea to have the design guideline that no enumeration class defined by the vocabulary shall have more than 10 values. It's arbitrary, but it will keep people from being carried away subdividing types into a hierarchy that they think is a good idea, but which doesn't match the data people already have.</span><o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal><span style='font-size:13.5pt;font-family:"Helvetica","sans-serif";color:black'> </span><o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal><span style='font-size:13.5pt;font-family:"Helvetica","sans-serif";color:black'>I'd also suggest that that every enumeration (ie, ist of individuals) include two special values:</span><o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal><span style='font-size:13.5pt;font-family:"Helvetica","sans-serif";color:black'> </span><o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal><span style='font-size:13.5pt;font-family:"Helvetica","sans-serif";color:black'>NOT_SPECIFIED. This value is not present in the source, underlying data. It isn't in the database, the respondent didn't fill out the form fully. Perhaps "NULL" might be a better name - assuming people at this level know what it means.</span><o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal><span style='font-size:13.5pt;font-family:"Helvetica","sans-serif";color:black'>OTHER. This means the value is some specific value, but it's not covered in the TDWG list. I am not sure if this value should be explicitly used if you are publishing your own vocabulary and using terms from that. I'm inclined to say it should not be, because doing that would result in two values for predicates that naturally should be functional.</span><o:p></o:p></p></div></div></div><div><div><div><div><p class=MsoNormal><span style='font-size:13.5pt;font-family:"Helvetica","sans-serif";color:black'> </span><o:p></o:p></p></div></div></div></div><div><div><div><p class=MsoNormal><span style='font-size:13.5pt;font-family:"Helvetica","sans-serif";color:black'>These special values *can* be done as a single instance, which means you could easily pull all "not specifieds" out of a dataset, but that means that either the ranges would have to be declared as a union, which is messy, or the individuals would have to be declared as having all possible types, which would break disjoint class declarations.</span><o:p></o:p></p></div></div></div><div><div><div><p class=MsoNormal><span style='font-size:13.5pt;font-family:"Helvetica","sans-serif";color:black'> </span><o:p></o:p></p></div></div></div></div></div></div></div><p>If you have received this transmission in error please notify us immediately by return e-mail and delete all copies. If this e-mail or any attachments have been sent to you in error, that error does not constitute waiver of any confidentiality, privilege or copyright in respect of information in the e-mail or attachments. Please consider the environment before printing this email.<o:p></o:p></p></div><div><p class=MsoNormal>_______________________________________________<br>tdwg-tag mailing list<br><a href="mailto:tdwg-tag@lists.tdwg.org">tdwg-tag@lists.tdwg.org</a><br><a href="http://lists.tdwg.org/mailman/listinfo/tdwg-tag">http://lists.tdwg.org/mailman/listinfo/tdwg-tag</a><o:p></o:p></p></div></div></div><div><p class=MsoNormal> <o:p></o:p></p></div><p>If you have received this transmission in error please notify us immediately by return e-mail and delete all copies. If this e-mail or any attachments have been sent to you in error, that error does not constitute waiver of any confidentiality, privilege or copyright in respect of information in the e-mail or attachments. Please consider the environment before printing this email.<o:p></o:p></p></div></div></blockquote></div><p class=MsoNormal><o:p> </o:p></p><p>If you have received this transmission in error please notify us immediately by return e-mail and delete all copies. If this e-mail or any attachments have been sent to you in error, that error does not constitute waiver of any confidentiality, privilege or copyright in respect of information in the e-mail or attachments. Please consider the environment before printing this email.<o:p></o:p></p></div></div></body></html>