note.html
13.8 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
<!DOCTYPE html>
<html xmlns:foaf="http://xmlns.com/foaf/0.1/" xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
<head>
<meta name="generator" content="Emacs 22" />
<title>Term-centric Semantic Web Vocabulary Annotations</title>
<!--
<link rel="stylesheet" type="text/css" href="http://www.w3.org/StyleSheets/TR/W3C-IG-NOTE" />
-->
</head>
<body>
<div class="head">
<p><a href="http://www.w3.org/"><img src="http://www.w3.org/Icons/w3c_home" alt="W3C" height="48" width="72" /></a></p>
<h1 id="main">Term-centric Semantic Web Vocabulary Annotations</h1>
<h2 class="no-num no-toc" id="w3c-doctype">(Editor's Draft of a potential) W3C Interest Group Note 31 December 2009</h2>
<dl>
<dt>This version:</dt>
<dd><a href="http://www.w3.org/TR/2009/NOTE-vocabstatus-2009@@@/">http://www.w3.org/TR/2009/NOTE-vocabstatus-2009@@/</a></dd>
<dt>Latest version:</dt>
<dd><a href="http://www.w3.org/TR/vocabstatus/">http://www.w3.org/TR/vocabstatus/</a></dd>
<dt>Editor:</dt>
<dd><a href="http://danbri.org/">Dan Brickley</a>, Vrije Universiteit Amsterdam <danbri@danbri.org></dd>
<dt>Contributors:</dt>
<dd>Leigh Dodds, Talis</dd>
<dd>Libby Miller, BBC</dd>
</dl>
</div>
<p class="copyright"><a href="http://www.w3.org/Consortium/Legal/ipr-notice#Copyright">Copyright</a> © 2009 <a href="http://www.w3.org/"><acronym title="World Wide Web Consortium">W3C</acronym></a><sup>®</sup> (<a href="http://www.csail.mit.edu/"><acronym title="Massachusetts Institute of Technology">MIT</acronym></a>, <a href="http://www.ercim.org/"><acronym title="European Research Consortium for Informatics and Mathematics">ERCIM</acronym></a>, <a href="http://www.keio.ac.jp/">Keio</a>), All Rights Reserved. W3C <a href="http://www.w3.org/Consortium/Legal/ipr-notice#Legal_Disclaimer">liability</a>, <a href="http://www.w3.org/Consortium/Legal/ipr-notice#W3C_Trademarks">trademark</a> and <a href="http://www.w3.org/Consortium/Legal/copyright-documents">document use</a> rules apply.</p>
<hr title="Separator for header" />
<h2 class="notoc" id="abstract">Abstract</h2>
<p>
Many Semantic Web vocabularies (dictionaries of terms expressed using RDFS or OWL technology) evolve gradually, based on implementor feedback, deployment dynamics and a desire to start by
solving small problems first. This Note describes and documents a basic vocabulary - initiated in the FOAF project - that was created to provide a way of annotating RDF terms (classes and properties) with simple information about their status.
</p>
<h2 id="status">Status of This Document</h2>
<p><strong>This is a pre-draft from Dan Brickley</strong>, attempting to capture something of the thinking behind the vocab-status-ns work. Not yet reviewed by Leigh and Libby, and changing at random.</p>
<p><em>This section describes the status of this document at the time of its publication. Other documents may supersede this document. A list of current W3C publications and the latest revision of this technical report can be found in the <a href="http://www.w3.org/TR/">W3C technical reports index</a> at http://www.w3.org/TR/.</em></p>
<p>This W3C Interest Group Note was created to document a vocabulary that has been used for several years in documenting the status of RDF vocabulary terms.</p>
<p>The document was produced by participants of the W3C <a href="http://www.w3.org/2001/sw/interest/">Semantic Web Interest Group</a> part of the <a href="http://www.w3.org/2001/sw/">W3C Semantic Web Activity</a> (<a href="http://www.w3.org/2006/07/swig-charter.html">see charter</a>). Comments may be sent to the <a href="http://lists.w3.org/Archives/Public/semantic-web/">publicly archived</a> <a href="mailto:semantic-web@w3.org">semantic-web@w3.org</a> mailing list. While it does not represent the consensus of all members of the Interest Group, it does improve the documentation of a namespace used to annotate a very widely used vocabulary, ie. FOAF. As such it is offered here for wider discussion and potential improvements.
</p>
<p>Publication as an Interest Group Note does not imply endorsement by the W3C Membership. This is a draft document and may be updated, replaced or obsoleted by other documents at any time. It is inappropriate to cite this document as other than work in progress.</p>
<hr />
<div class="toc">
<h2 id="contents">Table of Contents</h2>
<ul class="toc">
<li class="tocline1"><a href="#introduction">1 Introduction</a></li>
</ul>
</div>
<h3 id="appendices">Appendices</h3>
<ul class="toc">
<li class="tocline2"><a href="#references">A References</a></li>
<li class="tocline2"><a href="#acknowledgements">B Acknowledgements</a></li>
</ul>
<hr />
<h2 id="introduction">1 Introduction</h2>
<p>
The evolution of descriptive computer languages within the World-Wide Web is an ongoing challenge. W3C's RDF technology does not attempt to solve such problems, but it does present a distinctive environment for deploying
descriptive vocabularies. This Note documents some specific documentation and versioning techniques originated in the Friend of a Friend (FOAF) project, and which have subsequently been adopted for other RDF/OWL vocabularies. The basic idea is that RDF vocabularies can be versioned "in-place", rather than moving to a new namespace URI every time a vocabulary is extended or improved, we can tag each term in the vocabulary with information indicating its status.
</p>
<h2 id="history">2 History</h2>
<p>
The earliest RDF representations of <a href="http://www.dublin-core.org/">Dublin Core</a> metadata embedded a version number in their URI: initially "1.0" (at http://purl.org/dc/elements/1.0/) and after some modest changes, "1.1" (at http://purl.org/dc/elements/1.1/). The earliest FOAF (originally as "RDFWebRing", and then "RDFWeb") experiments also included a version number "0.1" in the namespace URI - i.e. http://xmlns.com/foaf/0.1/ - where the low number was intended to indicate the tentative and exploratory nature of this early work. Other early RDF vocabularies including <a href="http://web.resource.org/rss/1.0/spec">RSS 1.0</a> - at http://purl.org/rss/1.0/ - also adopted a similar approach to selecting namespace URIs. In each case, there are lessons to be learned from the approach taken to modularity and versioning.
</p>
<p>
The early RDF representations of Dublin Core, RSS 1.0 and FOAF all began by treating the entire vocabulary as the primary unit of versioning, and with a general assumption
that any major changes would involve a wholesale move to a new namespace URI. With Dublin Core, this assumption was tested in practice: changes to some of the original
definitions were considered at the time significant enough to justify moving to a new identifier for the entire set of terms. The awkward practicalities of migrating from DC "1.0" to
"1.1" in a global, distributed and decentralised environment were one of the major considerations that led to the RDFWeb/FOAF adoption of 'in-place' updates. Unfortunately this
was not fully appreciated at the time FOAF's original namespace URI was selected, and the vocabulary has retained the "0.1" version number in its URI ever since. RSS1, by contrast,
has never evolved its RDF representation: the rss-dev group that produced it was effectively disbanded shortly afterwards, and the RSS syndication community remained divided
between a non-RDF RSS 2.0, the subsequently-undeveloped RSS1 work and the IETF-standard Atom initiative. The RSS1 initial design however did emphasise a particular approach to
modularity: that of using numerous namespaces together, rather than having a more monolithic approach in which a variety of problems are addressed through a single integrated vocabulary.
The RSS 1.0 documents list <a href="http://web.resource.org/rss/1.0/modules/proposed.html">over twenty</a> proposed modules; in addition to the general background assumption that
arbitrary RDF vocabularies could be mixed-in as necessary.
</p>
<p>
The earliest FOAF vocabulary was offered as a "utility vocabulary" within the RDFWeb project, and its documentation was heavily driven by implementation experiments. In fact
many of the spelling and stylistic inconsistencies in the names for FOAF terms came from the habit of testing things in real published RDF/XML files before documenting them in the central specification.
The FOAF spec was as a result always framed in the role of a dictionary, documenting the terms used in published FOAF files. The vocabulary defined here was designed to serve
a practical need: that of documenting work-in-progress vocabulary without confusing users and implying stability merely by some term appearing in the FOAF spec.
</p>
<h2 id="vocab"><b>B </b>Vocab</h2>
<p>The 'Vocabulary Status Vocabulary', as it is informally known, contained only three properties (from 2003-2009). And of these, only one was widely used: vs:term_status, vs:moreinfo, and vs:userdocs.</p>
<p>
The main property, vs:termstatus takes simple string values. From 2003-2009 these were documented as being 'unstable', 'testing' and 'stable'. Values of 'deprecated' were
also noted "in the wild". In 2009 the vocabulary documentation was updated to introduce a new value, 'archaic', and to indicate that the value space for the property is open-ended.
</p>
<h3>vs:term_status</h3>
<p>
The vs:term_status property is designed to provide a simple, intuitive labelling of an RDF class or property into one of a few limited categories. As such it might more
properly have been modelled using URI values rather than strings. The following definitions are ad-hoc, but should broadly correspond to their deployed usage.
</p>
<p>
The exact meaning of stable/unstable/testing/archaic will vary from project to project, since the maintainers of RDF vocabularies may have quite varied maintainance and
vocabulary development models. Other annotations might capture more detail; these term_status values serve to give a general overview. The values described here have a
bias towards their use with FOAF, but are also fairly general.
</p>
<dl>
<dt>'unstable'</dt>
<dd>The meaning, deployment practices, documentation (or important associated software/services) associated with this term are liable to change arbitrarily at some point in the future. They may not, but stability is not guaranteed. Use with caution.</dd>
<dt>'testing'</dt>
<dd>The meaning, deployment practices, documentation and general understanding of this term are approaching some stability, but changes are still possible due to implementation experience or other unanticipated factors.</dd>
<dt>'stable'</dt>
<dd>The term is relatively stable, and its documentation and meaning are not expected to change substantially.</dd>
<dt>'archaic'</dt>
<dd>This term is marked as old-fashioned; although used, it is not considered typical of current best practice and alternative expressions may be preferable.</dd>
</dl>
<h2 id="usage">Example Usage</h2>
<p>An unsorted collection of usage examples follow.</p>
<pre>
http://dbtune.org/onto/doc/event.rdf (defines vs:term_status as AnnotationProperty)
http://uriplay.org/spec/ontology/latest.rdf
http://motools.sourceforge.net/doc/last-fm.rdf
http://digitalbazaar.com/media/video (in RDFa syntax)
http://digitalbazaar.com/media
http://digitalbazaar.com/commerce
http://sw.deri.org/2005/08/conf/cfp.owl
http://www.mindswap.org/2003/owl/foaf (OWLier version of FOAF?)
http://vamp-plugins.org/rdf/
http://www.bbc.co.uk/ontologies/programmes/2008-02-28.rdf
http://xam.de/ns/os/opensource.rdfs
http://data.semanticweb.org/ns/swc/swc_2009-02-27.rdf (uses 'deprecated')
http://scot-project.org/scot/ns
http://xmlns.com/wot/0.1/index.rdf
http://vocab.org/review/terms.rdf (actually has some 'stable'; pretty rare!)
http://danja.talis.com/xmlns/rev_2007-11-09/review.rdf (related?)
http://www.w3.org/ns/auth/rsa.rdf
http://www.w3.org/ns/auth/cert.rdf
http://motools.sourceforge.net/doc/audio_features.rdf
http://www.foafrealm.org/xfoaf/0.1/index.rdf
http://www.w3.org/2004/02/skos/extensions.rdf
http://bibotools.googlecode.com/svn/bibo-ontology/tags/1.2/bibo.xml
http://musicontology.com/musicontology.rdfs
http://www.ldodds.com/schemas/book/
http://b4mad.net/ns/foaf-ext/index.rdf
http://www.xs4all.nl/~foz/enclosures.rdf (also has 'deprecated')
http://umbel.org/umbel/umbel.rdf (no content currently)
http://projects.mi.fu-berlin.de/semweb/webrdf/ (server error)
http://www.holygoat.co.uk/owl/redwood/0.1/tags/
http://www.madore.org/~david/meta.rdf
http://schemacache.test.talis.com/Properties/.rdf (reminds me - can
you get some stats from schemacache?)
http://www.kanzaki.com/ns/dliser.rdf ('An OWL DLiser. Declarations of
Classes and Properties that would be used in some ontologies for
documentation purpose. With owl:imports this file, the parent ontology
will be valid OWL DL/Lite.')
http://www.kanzaki.com/ns/wordmap
http://www.kanzaki.com/ns/sitemap.rdf
http://ccdb.ucsd.edu/SAO/1.0/SAO.owl (defined but not used)
</pre>
<h2 id="usage">Open Issues</h2>
<p>Issues with this document, and with the underlying vocabulary.</p>
<ul>
<li>todo: add RDFa to this note, so that the rdf/xml for the namespace can be derrived from it</li>
<li>propose a successor to vs:term_status that takes URI values</li>
<li>investigate adding AnnotationProperty construct, and note other mechanisms from OWL eg. deprecated property / class</li>
<li>Use footnotes / references rather than direct links?</li>
<li>Propose dropping the un-used properties?</li>
<li>Check for other values for term_status 'in the wild'</li>
<li>Organize and write the 'usage examples' section better, rather than giving ugly url dump</li>
<li>Better DC ref and discussion - check with Tom Baker</li>
</ul>
<h2 id="acknowledgements"><b>B </b>Acknowledgements</h2>
<p>@@@</p>
<!-- <div class="nav"><a href="http://validator.w3.org/check/referer">
<img src="http://www.w3.org/Icons/valid-xhtml10" alt="Valid XHTML 1.0!" height="31" width="88" /></a>
</div> -->
<hr></hr>
</body>
</html>