Difference between revisions of "Collaborative Protege"

From Protege Wiki
Jump to: navigation, search
(User Guide)
 
(43 intermediate revisions by 4 users not shown)
Line 1: Line 1:
 
{{Plugin
 
{{Plugin
|Description=Collaborative Protégé is an extension of the existing Protégé system that supports collaborative ontology editing as well as annotation of both ontology components and ontology changes.
+
|Description=Collaborative Protege is an extension of the existing Protege system that supports collaborative ontology editing as well as annotation of both ontology components and ontology changes.
 
|PluginType=Project
 
|PluginType=Project
 
|ForApplication1=Protege-Frames
 
|ForApplication1=Protege-Frames
 
|ForApplication2=Protege-OWL
 
|ForApplication2=Protege-OWL
 
|ForApplication3=Protege Client-Server
 
|ForApplication3=Protege Client-Server
|Screenshot=collab-protege.jpg
+
|Screenshot=collabProtege_entityNotes.png
|HomepageURL=http://protege.stanford.edu/doc/collab-protege/
+
|HomepageURL=http://protegewiki.stanford.edu/index.php/Collaborative_Protege
 
|DeveloperID1=Tania Tudorache
 
|DeveloperID1=Tania Tudorache
|LastUpdated=October 20, 2008
+
|LastUpdated=February 13, 2009
 
|Topic1=Project Management
 
|Topic1=Project Management
 
|License=Mozilla Public License
 
|License=Mozilla Public License
|Affiliation1=Stanford Medical Informatics
+
|Affiliation1=Stanford Center for Biomedical Informatics Research
 
|Affiliation2=Stanford University
 
|Affiliation2=Stanford University
 
}}
 
}}
 
<div style="display:block; float:left; width:100%;">
 
<div style="display:block; float:left; width:100%;">
  
== Overview ==
+
<div style="color:#555555;font-weight:bold;">The format of the Changes and Annotation ontology (ChAO) has changed in Protege 3.4.2 release. If have an existing ChAO project created with an earlier version of Protege and would like to take advantage of the new features, please follow the upgrade instructions from [[Changes_Tab#Upgrade_instructions_for_ChAO_ontology_for_Protege_3.4.2_release|here]].</div>
  
Collaborative Protégé is an extension of the existing [http://protege.stanford.edu/ Protégé] system that supports collaborative ontology editing. In addition to the common ontology editing operations, it enables annotation of both ontology components and ontology changes. It supports the searching and filtering of user annotations based on different criteria. We have implemented two types of voting mechanisms that can be used for voting of change proposals. Multiple users may edit the same ontology at the same time. In multi-user mode, all changes made by one user are seen immediately by other users.There are two working modes available for Collaborative Protégé. Both modes support multiple users working on an ontology:
 
  
# '''The multi-user mode''' - allows multiple clients to edit simultaneously the same ontology hosted on a Protégé server. All changes made by one client are immediately visible by other clients. This mode is also referred to as ''client-server mode'', or ''concurrent mode'' and requires a client-server setup. This mode is based on the implementation of the [http://protegewiki.stanford.edu/index.php/Protege_Client-Server_Tutorial multi-user Protégé] and is the preferred mode in which Collaborative Protégé should be run.
+
= Overview =
 +
 
 +
Collaborative Protege is an extension of the existing [http://protege.stanford.edu/ Protege] system that supports '''collaborative ontology editing'''. In addition to the common ontology editing operations, it enables annotation of both ontology components and ontology changes. It supports the searching and filtering of user annotations, also known as '''notes''', based on different criteria. We have implemented two types of voting mechanisms that can be used for voting of change proposals. Multiple users may edit the same ontology at the same time. In [[Protege_Client-Server_Tutorial|multi-user mode]], all changes made by one user are seen immediately by other users. There are two working modes available for Collaborative Protege. Both modes support multiple users working on an ontology:
 +
 
 +
# '''The multi-user mode''' - allows multiple clients to edit simultaneously the same ontology hosted on a Protege server. All changes made by one client are immediately visible by other clients. This mode is also referred to as ''client-server mode'', or ''concurrent mode'' and requires a client-server setup. This mode is based on the implementation of the [[Protege_Client-Server_Tutorial|multi-user Protege]] and is the preferred mode in which Collaborative Protege should be run.
 
# '''The standalone mode''' - allows multiple users to access the same ontology in succession. The ontology can be stored on a shared network drive and all clients will access the same project files. However, simultaneous access is not possible. This mode is also referred to as the consecutive mode.
 
# '''The standalone mode''' - allows multiple users to access the same ontology in succession. The ontology can be stored on a shared network drive and all clients will access the same project files. However, simultaneous access is not possible. This mode is also referred to as the consecutive mode.
  
This user guide applies to both multi-user and standalone mode of Collaborative Protégé.
+
This user guide applies to both multi-user and standalone mode of Collaborative Protege.
 +
 
 +
 
 +
= Installation Guide =
  
== Installation Guide ==
+
Collaborative Protege is distributed with the full installation of Protege. You may use Collaborative Protege both in stand-alone mode and in multi-user mode. The installation guide will use as an example the ''Newspaper'' project distributed in the ''examples/newspaper'' folder in the Protege installation directory.
  
Collaborative Protégé is distributed with the full installation of Protégé starting with '''Protégé version 3.3 beta399'''. You may use Collaborative Protégé both in stand-alone mode and in multi-user mode. The installation guide will use as an example the ''Newspaper'' project distributed in the ''examples/newspaper'' folder in the Protégé installation directory.
 
  
'''Stand-alone mode'''
+
== Stand-alone mode ==
  
# Install the full distribution of the latest version of [http://protege.stanford.edu/download/download.html Protégé].
+
# Install the full distribution of the latest version of [http://protege.stanford.edu/download/download.html Protege 3.*].  Note, Protege 4.* is not compatible with collaborative Protege yet.
# Start Protégé.
+
# Start Protege.
# Open the ''newspaper.pprj'' project from the ''examples/newspaper'' folder in the Protégé installation directory.
+
# Open the ''newspaper.pprj'' project from the ''examples/newspaper'' folder in the Protege installation directory.
# Enable the ''ChangesTab'' from the ''Project -> Configure'' menu.
+
# '''In the ''Collaboration'' menu, click on ''Show Collaboration Panel'''''
# In the ''Project -> Configure -> Options'' panel enable the ''Track changes'' checkbox. Click on ''OK'' and exit the ''Configuration'' panel.
+
# A dialog will come up that asks what type of Changes and Annotations ontology (ChAO) to create. You may choose between RDF(S) file, database backend, or existing ChAO knowledgebase. See below the screenshot of the ChAO creation dialog.<br/><br/>[[Image:ChAO_CreationDialog.png]]<br/><br/>If you want to track changes, please enable the ''Enable change tracking'' checkbox. If the checkbox is enabled, change tracking will be started right away. If this checkbox is not enabled, changes will not be tracked.<br> The Change tracking can be restored later in the ''Project menu -> Configure -> Options -> Track Changes'' (Protege restared required).<br><br>After the ChAO project is created, the collaboration panel should come up. You should see something like this:<br/><br/>[[Image:Chao_Newspaper.png]]<br/><br/>
# Disable the ''ChangesTab'' from the ''Project -> Configure'' menu.
+
# Save the project. In the ''examples/newspaper'' folder, a project ''annotation_newspaper.pprj'' was created that contains the ChAO knowledgebase.
# Save the project. Check in the ''examples/newspaper'' folder that a project ''annotation_newspaper.pprj'' was created.
 
# Close the project and reopen it. You should see the collaborative panel.
 
  
'''Multi-user mode'''
+
== Multi-user mode ==
  
If you want to use Collaborative Protégé in multi-user mode, you will need to do some additional steps.
+
If you want to use Collaborative Protege in multi-user mode, you will need to do some additional steps.
  
# Do all the steps for the installation in [http://protege.stanford.edu/doc/collab-protege/#InstallationStandAlone Stand-alone mode].
+
# Do all the steps for the installation in [[Collaborative_Protege#Stand-alone_mode|Stand-alone mode]].
# Open the ''metaproject.pprj'' project from the ''examples/server'' folder in the Protégé installation directory.
+
# Open the ''metaproject.pprj'' project from the ''examples/server'' folder in the Protege installation directory.
# In the ''ClsesTab'', select the class ''Project'' and create a new template slot called ''annotationProject''. The slot should have value type ''Instance'' and allowed classes ''Project''.
 
 
# In the ''InstanceTab'', create a new instance of ''Project'' for the ''annotation_newspaper.pprj''. The name of the instance is not important. The ''location'' slot should point to the location of the annotation project. For this example, the value of the ''location'' slot should be: ''examples/newspaper/annotation_newspaper.pprj''.
 
# In the ''InstanceTab'', create a new instance of ''Project'' for the ''annotation_newspaper.pprj''. The name of the instance is not important. The ''location'' slot should point to the location of the annotation project. For this example, the value of the ''location'' slot should be: ''examples/newspaper/annotation_newspaper.pprj''.
 
# Select the ''Newspaper'' instance and set as value of ''annotationProject'' slot the ''Project'' instance created in the previous step.
 
# Select the ''Newspaper'' instance and set as value of ''annotationProject'' slot the ''Project'' instance created in the previous step.
# Save the project and close Protégé.
+
# Save the project and close Protege.
  
'''Test the Protégé server and client:'''
 
  
# Start the Protégé server by using the ''run_protege_server'' start script.
+
In the multi-user mode, you may also configure the '''access policies''' of the ontology users in the metaproject as described [http://protegewiki.stanford.edu/wiki/Protege_Client_Server_Tutorial_Configuration here].
# Start a Protégé client: Start Protégé and select the Server mode in the ''Open Project'' dialog.
+
 
 +
 
 +
== Test the Protege server and client ==
 +
 
 +
# Start the Protege server by using the ''run_protege_server'' start script. Detailed information about starting the Protege server can be found in the [[Protege_Client-Server_Tutorial|Protege Client-Server Tutorial]].
 +
# Start a Protege client: Start Protege and select the Server mode in the ''Open Project'' dialog.
 
# In the ''Server'' panel, leave all the default entries like they are.    ''(Hostname: localhost, User: Guest, Password: guest)''. Click on ''OK''.
 
# In the ''Server'' panel, leave all the default entries like they are.    ''(Hostname: localhost, User: Guest, Password: guest)''. Click on ''OK''.
 
# In the ''Select Project'' panel, select the ''Newspaper'' project. When the project is displayed, you should see also the collaborative panel.
 
# In the ''Select Project'' panel, select the ''Newspaper'' project. When the project is displayed, you should see also the collaborative panel.
  
== User Guide ==
 
  
The following guide gives a brief description of the main functionalities of Collaborative Protégé, which are:
+
= User Guide =
  
# Annotation of classes, properties and instances
+
The main feature of Collaborative Protege is the ability to '''create notes attached to different things'''. This is the same idea as if someone would read an article and would add marginal notes on the paper. In the same way, the notes mechanism of Collaborative Protege allows a user to create his own remarks about a certain part of the ontology. This feature can also be used to discuss the ontology with other users either in stand-alone or multi-user mode. The notes are also called '''annotation''' and we will use these two words interchangeably. However, we do prefer the word ''notes'' because ''annotation'' is overloaded with too many meanings. The notes types together with the icons used to represent them in the user interface are shown below:
# Annotation of changes (for example, class creation, renaming, etc.)
 
# General discussion threads
 
# Proposals and voting
 
# Searching and filtering of annotations by different criteria
 
# Live discussion (chat) with other users connected to the same server
 
  
==== The collaborative panel ====
+
 
 +
[[Image:CollabProtege_noteTypes.png]]
 +
 
 +
 
 +
Another important feature of Collaborative Protege is the ability to '''track changes as they happen''', that is to show the '''change history''' of an entity in the ontology. We will talk about the change history in the Change tracking section from below.
 +
 
 +
 
 +
This user guide gives a brief description of the main functionalities of Collaborative Protege, which are:
 +
 
 +
* Annotation of classes, properties and instances with different types of notes (e.g., ''Comment'', ''Advice'', ''Example'', etc.)
 +
* Annotation of changes (for example, class creation, renaming, etc.) with different types of notes
 +
* Notes on the ontology itself
 +
* Proposals and voting
 +
* Searching and filtering the notes using different criteria
 +
* Live discussion (chat) with other users connected to the same server
 +
 
 +
 
 +
== The collaboration menu ==
 +
 
 +
The ''Collaboration menu'' is shown each time you start Protege, even if you do not have the collaboration panel enabled:
 +
 
 +
 
 +
[[Image:CollabProtege_collabMenu.png]]
 +
 
 +
 
 +
The following items are shown in the ''Collaboration menu'':
 +
* '''Show Collaboration Panel''' - this item allows the showing/hiding of the collaboration panel, which can be done anytime during a Protege working session. The first time you enable the collaboration panel, Protege will ask you to create the changes and annotations ontology (ChAO) which is used to store all notes and annotations attached to entities in the domain ontology. The ChAO creation dialog is shown in the [[Collaborative_Protege#Stand-alone_mode|Stand-alone installation]] section.
 +
* '''Collaboration User's Guide''' - will open a browser with this wiki page
 +
* '''Configure...''' - you may configure what collaboration tabs you want to see in the user interface, which is disscussed in the [[Collaborative_Protege#Configuring_the_collaboration_tabs|Configuring the collaboration tabs section]].
 +
 
 +
 
 +
== The collaboration panel ==
  
 
The main panel of the graphical user interface has been divided in two main panels (see image from below):
 
The main panel of the graphical user interface has been divided in two main panels (see image from below):
  
# The classical Protégé display (classes, properties and instances view) on the left side, and
+
* The classical Protege display (classes, properties and instances view) on the left side, and
# The collaborative panel on the right side.
+
* The collaboration panel on the right side.
 +
 
 +
The classical Protege display shows the details of the different ontology components, such as classes, properties (slots) and instances. The collaboration panel adds functionality to support the collaborative development of ontologies.
 +
 
 +
 
 +
The '''collaboration panel''' is made up of two types of tabs.
 +
 
 +
* The ''Entity notes'' and ''Changes'' tabs show information related to the selected item in the class tree (or property tree, etc.). For example, if you select in the class tree the class ''Person'', you will see in these tabs the notes related to the class ''Person''. In the ''InstancesTab'' of the main Protege display, the collaboration panel will show the notes attached to instances.
 +
* The ''Ontology notes, All notes, Search'' and ''Chat'' tabs are generic tabs that are not attached to a particular entity in the ontology, so they are "global" in nature.
 +
 
 +
 
 +
The tabs in the collaboration panel are made up of a top component, which shows a notes tree. The notes tree corresponds to discussion threads in Internet forums. The bottom component shows the details of the selected note in the notes tree.
 +
 
 +
It is possible to '''search the notes''' by using the search component at the bottom of the annotations tree panel. You may use the * wildcard character for your search. The searching is done in the text of the notes.
 +
 
 +
Another feature is the '''filtering of notes and changes''', which may be done by using the Filter component from the top of the annotations tree. You may choose between different types of filters that will be applied to the annotations tree: filtering by author, by annotation text, by annotation type or by creation date. The class tree in the main Protege display shows a little call-out icon next to the class name if the class has any annotations or change annotations attached to it. In the ''Slots Tab'' and ''Instance Tab'' in the main Protege display you will also see the call-out icon if a property (slot) or an instance have annotations attached to them.
 +
 
 +
 
 +
== Annotating classes, properties and instances with different types of notes ==
 +
 
 +
A user may add notes attached to a specific ontology component in the ''Entity Notes''. By ontology component, we mean classes, properties (or slots) and instances. See image below.
 +
 
 +
 
 +
[[Image:collabProtege_entityNotes.png|800px]]
 +
 
 +
 
 +
The image shows an example of note attached to the ''DomainConcept'' class. The number of notes attached directly to ''DomainConcept'' is shown next to the Notes icon (in this case, 2); in paranthesis, we show the number of notes attached to the children (3), so that the user can easier navigate to the notes found very deep in the tree hierarchy.
 +
 
 +
To create a new top level note, first select the note type from the combo-box, and then click on the ''New thread'' button. A dialog will come up in which you may enter the text of your note. It is possible to use different types of fonts (bold, italic, underline, etc.), to highlight text, or to insert '''internal links to entities in the ontology'''. Such a dialog is shown in the image below:
 +
 
 +
 
 +
[[Image:CollabProtege_Comment.png]]
 +
 
 +
 
 +
An internal link is a link to a entity in the ontology. When the user clicks on the link, the class editor of that particular entity (e.g, class) will pop up. In the example above, the inserted link was: ''@'http://www.co-ode.org/ontologies/pizza/2005/10/18/pizza.owl#Pizza' ''. When a user clicks on this link, the ''Pizza'' class editor will show up.
 +
 
 +
A note can be '''Archived''' by checking the ''archived'' check-box. For example, a note can be archived, if the issue has already been addressed, and it is no longer needed to show it in the user interface. To hide the archived note, go to the ''Collaboration Menu'' -> ''Configure'' -> ''Options'' -> ''Hide archived notes''. The display of the notes and the notes count will be updated.
 +
 
 +
Notes, changes and ontology components can also have a '''Status'''. The prefilled values of the status drop-down list come from the ChAO ontology as instance of Status. For example, if you would like to have as possible statuses for notes: ''Active'' and ''Deprecated'', then edit the ChAO ontology: delete all existing instances of ''AnnotationStatus'', and create two new instances, ''Active'' and ''Deprecated''.
 +
 
 +
To '''reply''' to an existing note, select the note, and click on the ''Reply'' button. You may also choose the type of note you would like to use as your reply. Predefined notes type are:''Comment'', ''Advice'', ''Example'', ''SeeAlso'', ''Vote'', etc.
 +
 
 +
To '''view''' the details of an existing note, you may click on the ''magnifier icon'' on top of the notes tree. To '''refresh''' the display of the notes (maybe another user has added meanwhile a reply to a note), click on the ''Refresh icon'' on top of the notes tree.
 +
 
 +
 
 +
== Annotating changes with different note types ==
 +
 
 +
Collaborative Protege is continuously tracking the changes that users are making. You can see the change history of a certain ontology component (for example, a class) in the ''Changes'' tab of the collaboration panel.
 +
 
 +
Besides annotating ontology components themselves, you may also annotate changes to the ontology using different note types. For example, you may comment on a class rename operation or on the addition of a property to a class. Notes on changes are made in the ''Changes'' Tab (see image below). The user interface of the notes tree is identical to the one of the ''Entity Notes'' tab. Please read that section for more information.
 +
 
 +
 
 +
[[Image:collabProtege_changes.png|800px]]
 +
 
 +
 
 +
To create a note on a change, first select a note type from the combo-box at the top of the ''Changes'' tab. Then, select a change in the changes list and click on the ''Reply'' button.
 +
 
 +
 
 +
== Ontology notes ==
 +
 
 +
The ''Ontology Notes'' tab allows you to attach notes to the ontology itself, rather than to a specific ontology component. The user interface of the notes tree is identical to the one of the ''Entity Notes'' tab. Please read that section for more information. The ''Ontology Notes'' tab is show in the image below.
 +
 
 +
 
 +
[[Image:collabProtege_ontologyNotes.png|800px]]
 +
 
 +
 
 +
Ontology notes do not respond to the selection in the class tree (or other trees). In this sense, they are more "generic" type of notes. For example, an ontology note may describe naming conventions that should be kept throughout the entire ontology, or design guidelines for the ontology.
 +
 
 +
 
 +
== Browsing all entity and ontology notes ==
 +
 
 +
Very often, discussions about different ontology classes (or other entities) go on in parallel threads and are attached to the classes. There is no easy way of figuring out which classes have notes attached to them. The ''All Notes Tab'' shows all the ontology notes together with all the entity notes. It is an integrated view that gives the user an overview of what is going on in the ontology. As with the ''Ontology Notes'', this tab is not dependent on the selection in the class tree (or other trees). The ''All Notes Tab'' is shown in the image below:
 +
 
 +
 
 +
[[Image:CollabProtege_AllNotes.png]]
 +
 
 +
 
 +
== Proposals and Voting ==
 +
 
 +
Collaborative Protege supports two different types of proposals and voting:
 +
 
 +
* ''Agree / Disagree'' proposals, which users may vote with a ''Agree / Disagree'' vote
 +
* ''Five Stars'' Vote proposals and the corresponding ''Five Star'' voting.
 +
 
 +
The current version does not support workflows for proposals (such as starting and closing a proposal), but we intend to add this feature in the near future.
 +
 
 +
You may start a proposal in one of the ''Entity Notes, Ontology Notes, All Notes or Changes'' tabs. You may start a proposal related to a certain ontology component, for example, a class. In this case, you should create the proposal in the ''Entity notes'' tab, after selecting the class in the Protege classes tree. Then, select in the notes type combo-box one of the ''AgreeDisagreeProposal'' or the ''FiveStarVoteProposal'' and click on the ''New thread'' button. You will see in the notes tree a new node that has as an icon containing the "p" letter.
 +
 
 +
It is also possible to start a proposal related to a change in the ''Changes'' tab of the collaboration panel. If you want to start a generic proposal not related to a particular ontology component, you may do this in the ''Ontology Notes'' tab.
 +
 
 +
After you have created a proposal, other users may vote for it by selecting in the notes type combo-box the corresponding vote type. Users may also add comments to their votes.
 +
 
 +
 
 +
== Searching the notes ==
 +
 
 +
Besides the simple search functionality available in all the tabs of the collaborative panel, users may also do complex searches in the ''Search'' tab.
 +
 
 +
 
 +
[[Image:collabProtege_search.png|800px]]
 +
 
 +
 
 +
You may specify in the ''Search'' tabs different types of search criteria that can be combined by an ''AND'' or ''OR'' condition:
  
The classical Protégé display shows the details of the different ontology components, such as classes, properties (slots) and instances. The collaborative panel adds functionality to support the collaborative development of ontologies.
+
* Author name
 +
* Note text
 +
* Note type
 +
* Status
 +
* Date
  
The '''collaborative panel''' is made up of two types of tabs.
+
Once you click on the ''Search'' button, the results of the search are shown in the ''Search Results'' panel. You may see details on a certain result either in the bottom details panel or by clicking on the view icon from the top of the ''Search Results'' pane. If a note is attached to an ontology component, you may click on the second icon on top of the ''Results panel'' to browse the details of the annotated ontology component.
  
# The ''Annotations, Changes'' and ''All'' tabs show information related to the selected item in the class tree. For example, if you select in the class tree the class ''Person'', you will see in these tabs the annotations related to the class ''Person''. In the ''InstanceTab'' of the main Protégé display, the collaborative panel is listening to the selection of the instances list (not the class tree). In this way, you may add annotations to the instances.
 
# The ''Discussion Threads, Search'' and ''Chat'' tabs are generic tabs that do not listen to the selection of classes in the class tree.
 
  
The tabs in the collaborative panel are made up of a top component, which shows an annotation tree and a bottom component which shows the details of the selected annotation in the annotations tree.
+
== Chat with other users ==
  
It is possible to '''search''' in the annotations tree by using the search component at the bottom of the annotations tree panel. You may use the * wildcard character for your search. The searching is done on the annotation texts.
+
You may chat with other users that are connected to the Protege server. Chat messages are broad casted to all users. You may see the users that are connected to the server in the task bar at the bottom of the main Protege display.  
  
Another feature is the '''filtering''' of annotations or changes, which may be done by using the Filter component from the top of the annotations tree. You may choose between different types of filters that will be applied to the annotations tree: filtering by author, by annotation text, by annotation type or by creation date. The class tree in the main Protégé display shows a little call-out icon next to the class name if the class has any annotations or change annotations attached to it. In the ''Slots Tab'' and ''Instance Tab'' in the main Protégé display you will also see the call-out icon if a property (slot) or an instance have annotations attached to them.
 
  
==== Annotating classes, properties and instances ====
+
[[Image:collabProtege_chat.png|800px]]
  
The ''Annotations'' tab in the collaborative panel, allows you to annotate the currently selected ontology component. By ontology component, we mean classes, properties (or slots) and instances. See image below.
 
  
[[Image:CollabProtege1.jpg|800px]]
+
If a chat message is received, while you are browsing another tab, the icon and font of the chat tab will change in red so that it attracts your attention (see image above). If there are no new messages in the ''Chat'' tab, you will see a smiley icon next to the ''Chat'' tab title. Just as in the notes text, you may send '''internal links to entities in the ontology'''. The other users receiving the chat message will be able to click on the link and a class browser will pop up showing the corresponding class. (The internal links work also with properties and individuals).
  
The image shows an example of annotations attached to the ''Publication'' class. You may create discussion threads related to a particular ontology component (in the example, ''Publication'' class). There are different types of annotations that may be attached to an ontology component, such as comments, questions, examples, etc. It is also possible to create proposals and to allow other users to vote. Proposals and voting are described in the section below.
 
  
In order to create a new annotation, you have to first select an annotation type from the combo-box at the top of the ''Annotations'' tab. Then, you may choose to reply to an existing annotation by clicking on the call-out icon near the combo-box, or you may start a new discussion thread by clicking on the second icon (little rectangle). The third icon allows you to see the details of the annotation, such as the text of the annotation, the author and creation date.
+
== Configuration ==
  
==== Annotating changes ====
+
The ''Collaboration'' -> ''Configure'' menu allows different types of configuration of the collaboration features. For example, it is possible to configure which collaborative tabs should be shown in the user interface. Another thing that can be configured is the hiding of archived notes from the ''Options'' tab.
  
Collaborative Protégé is continuously tracking the changes that users are doing. You can see the changes related to a certain ontology component (for example, a class) in the ''Changes'' tab of the collaborative panel.
+
To '''enable and/or disable''' the collaborative tabs, go to the ''Collaboration'' menu. After clicking on ''Configure'', you will get the panel from below:
  
Besides annotating ontology components themselves, you may also annotate changes of the ontology. For example, you may comment on a class rename operation or on the addition of a property to a class, as show in the image below. Annotation of changes may be done in the ''Changes'' Tab in the collaborative panel (see image below).
 
  
[[Image:changes.jpg|800px]]
+
[[Image:collabProtege_configure.png]]
  
If you want to create an annotation on a change, you have to first select an annotation type from the combo-box at the top of the ''Changes'' tab. Then, select a change in the annotations tree and click on the call-out icon next to the combo-box. The second icon allows you to see the details of the selected changes and annotations.
 
  
The ''All (Ann. & Chg.)'' tab allows you to see both the annotations and the changes related to a certain ontology component in an integrated view.
+
In this panel, enable the checkboxes corresponding to the tabs that you would like to see and disable the ones that you would like to hide. In the example from the screenshot, the user enabled the ''All notes'' and the ''Chat'' tab and disabled the rest. After the configuration, the Protege display will look like in the figure below:
  
==== Discussion threads ====
 
  
The ''Discussion Threads'' tab allows you to create generic discussion threads that are not necessarily related to a certain ontology component. The ''Discussion Threads'' tab is show in the image below.  
+
[[Image:collabProtege_afterConfiguration.png|800px]]
  
[[Image:discussionThreads.jpg|800px]]
 
  
First you need to select an annotation type from the combo-box at the top of the ''Discussion threads'' tab. If you want to start a new discussion thread, please use the ''Create'' icon at the top of the annotations tree (little rectangle icon). If you would rather reply to an existing message, please select first the annotation you would like to reply to and then click on the call-out icon. The view icon allows you to see the details of a certain message.  
+
To '''hide the archived notes''' in the user interface, go to the ''Collaboration'' menu -> ''Configure'' -> ''Options'' and enable the check-box for ''Hide archived notes''. The user interface of the collaboration panels will be refreshed, as well as the note counts shown next to the Notes icon in the class tree. The filters and search will also take into account this configuration.
  
==== Proposals and Voting ====
 
  
Collaborative Protégé supports two different types of proposals and voting:
+
== Adding your own note type ==
  
# ''Agree / Disagree'' proposals, which users may vote with a ''Agree / Disagree'' vote
+
The notes type that you see in Collaborative Protege are read dynamically from the changes and annotations ontology (ChAO). The '''note types are actually subclasses of the ''Annotation'' class in the ChAO ontology'''. It is very easy to customize the note types available in Collaborative Protege by just editing the ChAO ontology directly. Let's say we want to add a new note type "ToDo". The steps are easy: in the corresponding ChAO ontology, create a subclass of ''Annotation'' called ''ToDo'', add properties to it or whatever is necessary (optional), configure the form of the ''ToDo'' instances in the FormsTab (optional), and save the ChAO ontology. The next time you start Collaborative Protege, you will see in the combo-box of notes type the 'ToDo' type. Below is a step by step guide with screenshots.
# ''Five Stars'' Vote proposals and the corresponding ''Five Star'' voting.
 
  
Currently the prototype does not support workflows for proposals (such as starting and closing a proposal), but we intend to add this feature in the near future.
 
  
If you want to start a proposal, you can do this in one of the ''Annotations, Changes, All'' or ''Discussion Threads'' tabs. It is possible to start a proposal related to a certain ontology component, for example, a class. For this case, please create a proposal in the ''Annotations'' tab, after selecting the class in the Protégé classes tree. Then, select in the annotations type combo-box one of the ''AgreeDisagreeProposal'' or the ''FiveStarVoteProposal'' and click on the create annotation icon (little rectangle icon). You will see in the annotations tree a new node that has as an icon a little text file icon. You can see a screenshot of a proposal [http://protege.stanford.edu/doc/collab-protege/images/collab-protege.jpg here].
+
The example uses the ''Collaborative Pizza'' project that has the ''annotation_collaborativePizza.pprj'' project associated to it. We want to add a ''ToDo'' type of note to Collaborative Pizza. Below are the steps.
  
It is also possible to start a proposal related to a change, which you can do in the ''Changes'' tab of the collaborative panel. If you want to start a generic proposal not related to a particular ontology component, you can do this in the ''Discussion Threads'' tab.
+
1. Open ''annotation_collaborativePizza.pprj'' in Protege. Create a subclass ''ToDo'' of ''Annotation'' class. Add two template slots, ''priority'' and ''deadline'' to the ''ToDo'' class. It should look like this:
  
After you have created a proposal, other users may vote for it by selecting in the annotations type combo-box the corresponding vote type. Users may also comment their votes in the vote details pane at the bottom of the collaborative panel.
 
  
==== Searching ====
+
[[Image:CollabProtege_ChaoToDo.png]]
  
Besides the simple search functionality available in all the tabs of the collaborative panel, user may also do complex searches in the ''Search'' tab.
 
  
[[Image:search.jpg|800px]]
+
In the Forms tab, we have also configured the form of the 'ToDo' class. This form is used when creating a new ToDo instance in Collaborative Protege. We have also changed the browser slot pattern of the ''ToDo'' class.
 +
Save the project.
  
The ''Search'' tabs allows you to specify different types of searches that can be combined by an ''AND'' or ''OR'' condition:
 
  
# Author name
+
2. Open Collaborative Pizza project. In the notes type combo-box you will see the ''ToDo'' note type:
# Annotation text
 
# Annotation type
 
# Date
 
  
Once you click on the ''Search'' button, the results of the search are shown in the ''Search Results'' panel. You may see details on a certain result either in the bottom details panel or by clicking on the view icon from the top of the ''Search Results'' pane.
 
  
==== Chat with other users ====
+
[[Image:CollabProtege_TodoType.png]]
  
You may chat with other users that are connected at the same time on the Protégé server. All the chat messages are broadcasted to all the users. You can see the users that are connected to the server in the task bar at the bottom of the main Protégé display.
 
  
[[Image:chat.jpg|800px]]
+
3. Create a new ToDo attached to the ''ValuePartition'' class by selecting in the note types combo-box the ''ToDo'' type. After creating the to do note, you should see something like this:
  
If a chat message is received, while you are browsing another tab, the icon and font of the chat tab will change so that it attracts your attention. You can see this in the image from above. If there are no new messages in the ''Chat'' tab, you will see a smiley icon next to the ''Chat'' tab title, like [http://protege.stanford.edu/doc/collab-protege/images/collab-protege.jpg here].
 
  
==== Configuring the collaborative components ====
+
[[Image:CollabProtege_ToDoNote.png]]
  
Starting with Protege 3.4 beta 109, it is possible to configure the collaborative tabs that will be displayed in Protégé. This can be done from the ''Collaboration'' menu -> ''Configure''. In this way it is possible to enable and disable the collaborative tabs. After clicking on ''Configure'', you will get the panel from below:
 
  
[[Image:configCollabTabsPanel.jpg]]
+
As you notice, the form of the to do note is different than the form of other note types. The form is the one that we have configured in the previous step in the ChAO project. In this way it is extremely easy to customize Collaborative Protege to the specific needs of a project without requiring any software change.
  
In this panel, enable the checkboxes corresponding to the tabs that you would like to see and disable the ones that you would like to hide. In the example from the screenshot, the user enabled the ''Annotations'' and the ''Chat'' tab and disabled the rest. After the configuration, the Protege display may look like in the figure below:
 
  
[[Image:configCollabTabs.jpg|800px]]
+
= Contact and support =
  
== Contact and support ==
+
Collaborative Protege is actively developed and supported. It is currently just a prototype that we intend to extend into a full-fledged web-based application for collaborative ontology development. All your feedback is welcome! Please send comments, questions and bug-reports to ''tudorache at stanford.edu.''
  
Collaborative Protégé is actively developed and supported. It is currently just a prototype that we intend to extend into a full-fledged web-based application for collaborative ontology development. All your feedback is welcome! Please send comments, questions and bug-reports to ''tudorache at stanford.edu.''
 
  
== Resources ==
+
= Resources =
  
 
For more information, please see the following links:
 
For more information, please see the following links:
  
# [http://protege.stanford.edu/doc/collab-protege/doc/collabProtege_demo.pdf A short paper describing Collaborative Protégé]
+
# [[CollabProtege_Tutorial_2009_Conference|The collaborative ontology development with Protege tutorial]] at the Protege Conference 2009 in Amsterdam
# [http://protege.stanford.edu/doc/collab-protege/doc/collabProtegeShortPresentation.pdf A short presentation of Collaborative Protégé]
+
# [http://bmir.stanford.edu/publications/view.php/supporting_collaborative_ontology_development_in_protege ISWC 2008 Paper about Collaborative Protege]
# [http://protegewiki.stanford.edu/index.php/Protege_Client-Server_Tutorial Protégé Client-Server Tutorial]
+
# [http://protege.stanford.edu/doc/collab-protege/doc/collabProtege_demo.pdf A short paper describing Collaborative Protege]
# [http://protege.stanford.edu/doc/users.html Protégé user guides]
+
# [http://protege.stanford.edu/doc/collab-protege/doc/collabProtegeShortPresentation.pdf A short presentation of Collaborative Protege]
 +
# [[Protege_Client-Server_Tutorial|Protege Client-Server Tutorial]]
 +
# [http://protege.stanford.edu/doc/users.html Protege user guides]
  
 
</div>
 
</div>

Latest revision as of 12:05, February 12, 2011

Collaborative Protege

by Tania Tudorache

Screenshot

Type Project
Author(s) Tania Tudorache
Last Update February 13, 2009
License Mozilla Public License
Homepage Collaborative Protege website
For Application
Topic(s)
Affiliation

Collaborative Protege is an extension of the existing Protege system that supports collaborative ontology editing as well as annotation of both ontology components and ontology changes.

Versions & Compatibility

This section lists available versions of Collaborative Protege.

No version information available.

If you click on the button below to add a new version of Collaborative Protege, you will be asked to define a page title for the new version. Please adhere to the naming convention of Collaborative Protege X.X.X when you define the new page!

Changelog

No version information available.


The format of the Changes and Annotation ontology (ChAO) has changed in Protege 3.4.2 release. If have an existing ChAO project created with an earlier version of Protege and would like to take advantage of the new features, please follow the upgrade instructions from here.


Overview

Collaborative Protege is an extension of the existing Protege system that supports collaborative ontology editing. In addition to the common ontology editing operations, it enables annotation of both ontology components and ontology changes. It supports the searching and filtering of user annotations, also known as notes, based on different criteria. We have implemented two types of voting mechanisms that can be used for voting of change proposals. Multiple users may edit the same ontology at the same time. In multi-user mode, all changes made by one user are seen immediately by other users. There are two working modes available for Collaborative Protege. Both modes support multiple users working on an ontology:

  1. The multi-user mode - allows multiple clients to edit simultaneously the same ontology hosted on a Protege server. All changes made by one client are immediately visible by other clients. This mode is also referred to as client-server mode, or concurrent mode and requires a client-server setup. This mode is based on the implementation of the multi-user Protege and is the preferred mode in which Collaborative Protege should be run.
  2. The standalone mode - allows multiple users to access the same ontology in succession. The ontology can be stored on a shared network drive and all clients will access the same project files. However, simultaneous access is not possible. This mode is also referred to as the consecutive mode.

This user guide applies to both multi-user and standalone mode of Collaborative Protege.


Installation Guide

Collaborative Protege is distributed with the full installation of Protege. You may use Collaborative Protege both in stand-alone mode and in multi-user mode. The installation guide will use as an example the Newspaper project distributed in the examples/newspaper folder in the Protege installation directory.


Stand-alone mode

  1. Install the full distribution of the latest version of Protege 3.*. Note, Protege 4.* is not compatible with collaborative Protege yet.
  2. Start Protege.
  3. Open the newspaper.pprj project from the examples/newspaper folder in the Protege installation directory.
  4. In the Collaboration menu, click on Show Collaboration Panel
  5. A dialog will come up that asks what type of Changes and Annotations ontology (ChAO) to create. You may choose between RDF(S) file, database backend, or existing ChAO knowledgebase. See below the screenshot of the ChAO creation dialog.

    ChAO CreationDialog.png

    If you want to track changes, please enable the Enable change tracking checkbox. If the checkbox is enabled, change tracking will be started right away. If this checkbox is not enabled, changes will not be tracked.
    The Change tracking can be restored later in the Project menu -> Configure -> Options -> Track Changes (Protege restared required).

    After the ChAO project is created, the collaboration panel should come up. You should see something like this:

    Chao Newspaper.png

  6. Save the project. In the examples/newspaper folder, a project annotation_newspaper.pprj was created that contains the ChAO knowledgebase.

Multi-user mode

If you want to use Collaborative Protege in multi-user mode, you will need to do some additional steps.

  1. Do all the steps for the installation in Stand-alone mode.
  2. Open the metaproject.pprj project from the examples/server folder in the Protege installation directory.
  3. In the InstanceTab, create a new instance of Project for the annotation_newspaper.pprj. The name of the instance is not important. The location slot should point to the location of the annotation project. For this example, the value of the location slot should be: examples/newspaper/annotation_newspaper.pprj.
  4. Select the Newspaper instance and set as value of annotationProject slot the Project instance created in the previous step.
  5. Save the project and close Protege.


In the multi-user mode, you may also configure the access policies of the ontology users in the metaproject as described here.


Test the Protege server and client

  1. Start the Protege server by using the run_protege_server start script. Detailed information about starting the Protege server can be found in the Protege Client-Server Tutorial.
  2. Start a Protege client: Start Protege and select the Server mode in the Open Project dialog.
  3. In the Server panel, leave all the default entries like they are. (Hostname: localhost, User: Guest, Password: guest). Click on OK.
  4. In the Select Project panel, select the Newspaper project. When the project is displayed, you should see also the collaborative panel.


User Guide

The main feature of Collaborative Protege is the ability to create notes attached to different things. This is the same idea as if someone would read an article and would add marginal notes on the paper. In the same way, the notes mechanism of Collaborative Protege allows a user to create his own remarks about a certain part of the ontology. This feature can also be used to discuss the ontology with other users either in stand-alone or multi-user mode. The notes are also called annotation and we will use these two words interchangeably. However, we do prefer the word notes because annotation is overloaded with too many meanings. The notes types together with the icons used to represent them in the user interface are shown below:


CollabProtege noteTypes.png


Another important feature of Collaborative Protege is the ability to track changes as they happen, that is to show the change history of an entity in the ontology. We will talk about the change history in the Change tracking section from below.


This user guide gives a brief description of the main functionalities of Collaborative Protege, which are:

  • Annotation of classes, properties and instances with different types of notes (e.g., Comment, Advice, Example, etc.)
  • Annotation of changes (for example, class creation, renaming, etc.) with different types of notes
  • Notes on the ontology itself
  • Proposals and voting
  • Searching and filtering the notes using different criteria
  • Live discussion (chat) with other users connected to the same server


The collaboration menu

The Collaboration menu is shown each time you start Protege, even if you do not have the collaboration panel enabled:


CollabProtege collabMenu.png


The following items are shown in the Collaboration menu:

  • Show Collaboration Panel - this item allows the showing/hiding of the collaboration panel, which can be done anytime during a Protege working session. The first time you enable the collaboration panel, Protege will ask you to create the changes and annotations ontology (ChAO) which is used to store all notes and annotations attached to entities in the domain ontology. The ChAO creation dialog is shown in the Stand-alone installation section.
  • Collaboration User's Guide - will open a browser with this wiki page
  • Configure... - you may configure what collaboration tabs you want to see in the user interface, which is disscussed in the Configuring the collaboration tabs section.


The collaboration panel

The main panel of the graphical user interface has been divided in two main panels (see image from below):

  • The classical Protege display (classes, properties and instances view) on the left side, and
  • The collaboration panel on the right side.

The classical Protege display shows the details of the different ontology components, such as classes, properties (slots) and instances. The collaboration panel adds functionality to support the collaborative development of ontologies.


The collaboration panel is made up of two types of tabs.

  • The Entity notes and Changes tabs show information related to the selected item in the class tree (or property tree, etc.). For example, if you select in the class tree the class Person, you will see in these tabs the notes related to the class Person. In the InstancesTab of the main Protege display, the collaboration panel will show the notes attached to instances.
  • The Ontology notes, All notes, Search and Chat tabs are generic tabs that are not attached to a particular entity in the ontology, so they are "global" in nature.


The tabs in the collaboration panel are made up of a top component, which shows a notes tree. The notes tree corresponds to discussion threads in Internet forums. The bottom component shows the details of the selected note in the notes tree.

It is possible to search the notes by using the search component at the bottom of the annotations tree panel. You may use the * wildcard character for your search. The searching is done in the text of the notes.

Another feature is the filtering of notes and changes, which may be done by using the Filter component from the top of the annotations tree. You may choose between different types of filters that will be applied to the annotations tree: filtering by author, by annotation text, by annotation type or by creation date. The class tree in the main Protege display shows a little call-out icon next to the class name if the class has any annotations or change annotations attached to it. In the Slots Tab and Instance Tab in the main Protege display you will also see the call-out icon if a property (slot) or an instance have annotations attached to them.


Annotating classes, properties and instances with different types of notes

A user may add notes attached to a specific ontology component in the Entity Notes. By ontology component, we mean classes, properties (or slots) and instances. See image below.


CollabProtege entityNotes.png


The image shows an example of note attached to the DomainConcept class. The number of notes attached directly to DomainConcept is shown next to the Notes icon (in this case, 2); in paranthesis, we show the number of notes attached to the children (3), so that the user can easier navigate to the notes found very deep in the tree hierarchy.

To create a new top level note, first select the note type from the combo-box, and then click on the New thread button. A dialog will come up in which you may enter the text of your note. It is possible to use different types of fonts (bold, italic, underline, etc.), to highlight text, or to insert internal links to entities in the ontology. Such a dialog is shown in the image below:


CollabProtege Comment.png


An internal link is a link to a entity in the ontology. When the user clicks on the link, the class editor of that particular entity (e.g, class) will pop up. In the example above, the inserted link was: @'http://www.co-ode.org/ontologies/pizza/2005/10/18/pizza.owl#Pizza' . When a user clicks on this link, the Pizza class editor will show up.

A note can be Archived by checking the archived check-box. For example, a note can be archived, if the issue has already been addressed, and it is no longer needed to show it in the user interface. To hide the archived note, go to the Collaboration Menu -> Configure -> Options -> Hide archived notes. The display of the notes and the notes count will be updated.

Notes, changes and ontology components can also have a Status. The prefilled values of the status drop-down list come from the ChAO ontology as instance of Status. For example, if you would like to have as possible statuses for notes: Active and Deprecated, then edit the ChAO ontology: delete all existing instances of AnnotationStatus, and create two new instances, Active and Deprecated.

To reply to an existing note, select the note, and click on the Reply button. You may also choose the type of note you would like to use as your reply. Predefined notes type are:Comment, Advice, Example, SeeAlso, Vote, etc.

To view the details of an existing note, you may click on the magnifier icon on top of the notes tree. To refresh the display of the notes (maybe another user has added meanwhile a reply to a note), click on the Refresh icon on top of the notes tree.


Annotating changes with different note types

Collaborative Protege is continuously tracking the changes that users are making. You can see the change history of a certain ontology component (for example, a class) in the Changes tab of the collaboration panel.

Besides annotating ontology components themselves, you may also annotate changes to the ontology using different note types. For example, you may comment on a class rename operation or on the addition of a property to a class. Notes on changes are made in the Changes Tab (see image below). The user interface of the notes tree is identical to the one of the Entity Notes tab. Please read that section for more information.


CollabProtege changes.png


To create a note on a change, first select a note type from the combo-box at the top of the Changes tab. Then, select a change in the changes list and click on the Reply button.


Ontology notes

The Ontology Notes tab allows you to attach notes to the ontology itself, rather than to a specific ontology component. The user interface of the notes tree is identical to the one of the Entity Notes tab. Please read that section for more information. The Ontology Notes tab is show in the image below.


CollabProtege ontologyNotes.png


Ontology notes do not respond to the selection in the class tree (or other trees). In this sense, they are more "generic" type of notes. For example, an ontology note may describe naming conventions that should be kept throughout the entire ontology, or design guidelines for the ontology.


Browsing all entity and ontology notes

Very often, discussions about different ontology classes (or other entities) go on in parallel threads and are attached to the classes. There is no easy way of figuring out which classes have notes attached to them. The All Notes Tab shows all the ontology notes together with all the entity notes. It is an integrated view that gives the user an overview of what is going on in the ontology. As with the Ontology Notes, this tab is not dependent on the selection in the class tree (or other trees). The All Notes Tab is shown in the image below:


CollabProtege AllNotes.png


Proposals and Voting

Collaborative Protege supports two different types of proposals and voting:

  • Agree / Disagree proposals, which users may vote with a Agree / Disagree vote
  • Five Stars Vote proposals and the corresponding Five Star voting.

The current version does not support workflows for proposals (such as starting and closing a proposal), but we intend to add this feature in the near future.

You may start a proposal in one of the Entity Notes, Ontology Notes, All Notes or Changes tabs. You may start a proposal related to a certain ontology component, for example, a class. In this case, you should create the proposal in the Entity notes tab, after selecting the class in the Protege classes tree. Then, select in the notes type combo-box one of the AgreeDisagreeProposal or the FiveStarVoteProposal and click on the New thread button. You will see in the notes tree a new node that has as an icon containing the "p" letter.

It is also possible to start a proposal related to a change in the Changes tab of the collaboration panel. If you want to start a generic proposal not related to a particular ontology component, you may do this in the Ontology Notes tab.

After you have created a proposal, other users may vote for it by selecting in the notes type combo-box the corresponding vote type. Users may also add comments to their votes.


Searching the notes

Besides the simple search functionality available in all the tabs of the collaborative panel, users may also do complex searches in the Search tab.


CollabProtege search.png


You may specify in the Search tabs different types of search criteria that can be combined by an AND or OR condition:

  • Author name
  • Note text
  • Note type
  • Status
  • Date

Once you click on the Search button, the results of the search are shown in the Search Results panel. You may see details on a certain result either in the bottom details panel or by clicking on the view icon from the top of the Search Results pane. If a note is attached to an ontology component, you may click on the second icon on top of the Results panel to browse the details of the annotated ontology component.


Chat with other users

You may chat with other users that are connected to the Protege server. Chat messages are broad casted to all users. You may see the users that are connected to the server in the task bar at the bottom of the main Protege display.


CollabProtege chat.png


If a chat message is received, while you are browsing another tab, the icon and font of the chat tab will change in red so that it attracts your attention (see image above). If there are no new messages in the Chat tab, you will see a smiley icon next to the Chat tab title. Just as in the notes text, you may send internal links to entities in the ontology. The other users receiving the chat message will be able to click on the link and a class browser will pop up showing the corresponding class. (The internal links work also with properties and individuals).


Configuration

The Collaboration -> Configure menu allows different types of configuration of the collaboration features. For example, it is possible to configure which collaborative tabs should be shown in the user interface. Another thing that can be configured is the hiding of archived notes from the Options tab.

To enable and/or disable the collaborative tabs, go to the Collaboration menu. After clicking on Configure, you will get the panel from below:


CollabProtege configure.png


In this panel, enable the checkboxes corresponding to the tabs that you would like to see and disable the ones that you would like to hide. In the example from the screenshot, the user enabled the All notes and the Chat tab and disabled the rest. After the configuration, the Protege display will look like in the figure below:


CollabProtege afterConfiguration.png


To hide the archived notes in the user interface, go to the Collaboration menu -> Configure -> Options and enable the check-box for Hide archived notes. The user interface of the collaboration panels will be refreshed, as well as the note counts shown next to the Notes icon in the class tree. The filters and search will also take into account this configuration.


Adding your own note type

The notes type that you see in Collaborative Protege are read dynamically from the changes and annotations ontology (ChAO). The note types are actually subclasses of the Annotation class in the ChAO ontology. It is very easy to customize the note types available in Collaborative Protege by just editing the ChAO ontology directly. Let's say we want to add a new note type "ToDo". The steps are easy: in the corresponding ChAO ontology, create a subclass of Annotation called ToDo, add properties to it or whatever is necessary (optional), configure the form of the ToDo instances in the FormsTab (optional), and save the ChAO ontology. The next time you start Collaborative Protege, you will see in the combo-box of notes type the 'ToDo' type. Below is a step by step guide with screenshots.


The example uses the Collaborative Pizza project that has the annotation_collaborativePizza.pprj project associated to it. We want to add a ToDo type of note to Collaborative Pizza. Below are the steps.

1. Open annotation_collaborativePizza.pprj in Protege. Create a subclass ToDo of Annotation class. Add two template slots, priority and deadline to the ToDo class. It should look like this:


CollabProtege ChaoToDo.png


In the Forms tab, we have also configured the form of the 'ToDo' class. This form is used when creating a new ToDo instance in Collaborative Protege. We have also changed the browser slot pattern of the ToDo class. Save the project.


2. Open Collaborative Pizza project. In the notes type combo-box you will see the ToDo note type:


CollabProtege TodoType.png


3. Create a new ToDo attached to the ValuePartition class by selecting in the note types combo-box the ToDo type. After creating the to do note, you should see something like this:


CollabProtege ToDoNote.png


As you notice, the form of the to do note is different than the form of other note types. The form is the one that we have configured in the previous step in the ChAO project. In this way it is extremely easy to customize Collaborative Protege to the specific needs of a project without requiring any software change.


Contact and support

Collaborative Protege is actively developed and supported. It is currently just a prototype that we intend to extend into a full-fledged web-based application for collaborative ontology development. All your feedback is welcome! Please send comments, questions and bug-reports to tudorache at stanford.edu.


Resources

For more information, please see the following links:

  1. The collaborative ontology development with Protege tutorial at the Protege Conference 2009 in Amsterdam
  2. ISWC 2008 Paper about Collaborative Protege
  3. A short paper describing Collaborative Protege
  4. A short presentation of Collaborative Protege
  5. Protege Client-Server Tutorial
  6. Protege user guides