<html 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"><head><meta http-equiv=Content-Type content="text/html; charset=utf-8"><meta name=Generator content="Microsoft Word 15 (filtered medium)"><style><!--
/* Font Definitions */
@font-face
{font-family:Wingdings;
panose-1:5 0 0 0 0 0 0 0 0 0;}
@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;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
{margin:0in;
margin-bottom:.0001pt;
font-size:11.0pt;
font-family:"Calibri",sans-serif;}
a:link, span.MsoHyperlink
{mso-style-priority:99;
color:blue;
text-decoration:underline;}
p.MsoListParagraph, li.MsoListParagraph, div.MsoListParagraph
{mso-style-priority:34;
margin-top:0in;
margin-right:0in;
margin-bottom:0in;
margin-left:.5in;
margin-bottom:.0001pt;
font-size:11.0pt;
font-family:"Calibri",sans-serif;}
.MsoChpDefault
{mso-style-type:export-only;}
@page WordSection1
{size:8.5in 11.0in;
margin:1.0in 1.0in 1.0in 1.0in;}
div.WordSection1
{page:WordSection1;}
/* List Definitions */
@list l0
{mso-list-id:1665474298;
mso-list-type:hybrid;
mso-list-template-ids:372277338 -1 67698691 67698693 67698689 67698691 67698693 67698689 67698691 67698693;}
@list l0:level1
{mso-level-start-at:0;
mso-level-number-format:bullet;
mso-level-text:\F0D8;
mso-level-tab-stop:none;
mso-level-number-position:left;
text-indent:-.25in;
font-family:Wingdings;
mso-fareast-font-family:"Times New Roman";
mso-bidi-font-family:"Times New Roman";}
@list l0:level2
{mso-level-number-format:bullet;
mso-level-text:o;
mso-level-tab-stop:none;
mso-level-number-position:left;
text-indent:-.25in;
font-family:"Courier New";}
@list l0:level3
{mso-level-number-format:bullet;
mso-level-text:\F0A7;
mso-level-tab-stop:none;
mso-level-number-position:left;
text-indent:-.25in;
font-family:Wingdings;
mso-bidi-font-family:Wingdings;}
@list l0:level4
{mso-level-number-format:bullet;
mso-level-text:\F0B7;
mso-level-tab-stop:none;
mso-level-number-position:left;
text-indent:-.25in;
font-family:Symbol;
mso-bidi-font-family:Symbol;}
@list l0:level5
{mso-level-number-format:bullet;
mso-level-text:o;
mso-level-tab-stop:none;
mso-level-number-position:left;
text-indent:-.25in;
font-family:"Courier New";}
@list l0:level6
{mso-level-number-format:bullet;
mso-level-text:\F0A7;
mso-level-tab-stop:none;
mso-level-number-position:left;
text-indent:-.25in;
font-family:Wingdings;
mso-bidi-font-family:Wingdings;}
@list l0:level7
{mso-level-number-format:bullet;
mso-level-text:\F0B7;
mso-level-tab-stop:none;
mso-level-number-position:left;
text-indent:-.25in;
font-family:Symbol;
mso-bidi-font-family:Symbol;}
@list l0:level8
{mso-level-number-format:bullet;
mso-level-text:o;
mso-level-tab-stop:none;
mso-level-number-position:left;
text-indent:-.25in;
font-family:"Courier New";}
@list l0:level9
{mso-level-number-format:bullet;
mso-level-text:\F0A7;
mso-level-tab-stop:none;
mso-level-number-position:left;
text-indent:-.25in;
font-family:Wingdings;
mso-bidi-font-family:Wingdings;}
ol
{margin-bottom:0in;}
ul
{margin-bottom:0in;}
--></style></head><body lang=EN-US link=blue vlink="#954F72"><div class=WordSection1><ul style='margin-top:0in' type=disc><li class=MsoListParagraph style='margin-left:0in;mso-list:l0 level1 lfo1'>It would be good to get accessTypeChoices represented in X3D Ontology</li></ul><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Yes, one of the most basic operations of the event system. </p><p class=MsoNormal> Must know complete field type access, variable, value range, node name, def/use names, from what and when, along with to what and when in order to identify an animation. </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><o:p> </o:p></p><div style='mso-element:para-border-div;border:none;border-top:solid #E1E1E1 1.0pt;padding:3.0pt 0in 0in 0in'><p class=MsoNormal style='border:none;padding:0in'><b>From: </b><a href="mailto:brutzman@nps.edu">Don Brutzman</a><br><b>Sent: </b>Wednesday, April 22, 2020 10:14 AM<br><b>To: </b><a href="mailto:x3d-public@web3d.org">X3D Graphics public mailing list</a><br><b>Subject: </b>Re: [x3d-public] X3D Semantic Web minutes: event-animation chainsand representing accessType</p></div><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Continuing with the examination of accessType.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>The <field> element includes an attribute for accessType. This is found in the ontology as an owl:toDataProperty with range SFString.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>The X3DUOM includes enumerations for accessType: there are only 4 possible values.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal> <SimpleType name="accessTypeChoices"</p><p class=MsoNormal> baseType="xs:NMTOKEN"</p><p class=MsoNormal> appinfo="accessTypeChoices are strictly allowed enumeration values for accessType. Prior names in VRML97 were eventIn, eventOut, field, exposedField respectively."</p><p class=MsoNormal> documentation="https://www.web3d.org/documents/specifications/19775-1/V3.3/Part01/concepts.html#FieldSemantics"></p><p class=MsoNormal> <enumeration value="initializeOnly"</p><p class=MsoNormal> appinfo="A field with accessType initializeOnly can be initialized, but cannot send or receive events."/></p><p class=MsoNormal> <enumeration value="inputOnly"</p><p class=MsoNormal> appinfo="A field with accessType inputOnly cannot be initialized or included in a scene file, but can receive input event values via a ROUTE."/></p><p class=MsoNormal> <enumeration value="outputOnly"</p><p class=MsoNormal> appinfo="A field with accessType outputOnly cannot be initialized or included in a scene file, but can send output event values via a ROUTE."/></p><p class=MsoNormal> <enumeration value="inputOutput"</p><p class=MsoNormal> appinfo="A field with accessType inputOutput can be initialized, and can also send or receive events."/></p><p class=MsoNormal> </SimpleType></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>It would be good to get accessTypeChoices represented in X3D Ontology. We might then add other enumeration SimpleType defintions as well.)</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>We looked at</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>[1] OWL Web Ontology Language Reference: 6.2 Enumerated datatype</p><p class=MsoNormal> https://www.w3.org/TR/owl-ref/#EnumeratedDatatype</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>"In addition to the RDF datatypes, OWL provides one additional construct for defining a range of data values, namely an enumerated datatype. This datatype format makes use of the owl:oneOf construct, that is also used for describing an enumerated class. In the case of an enumerated datatype, the subject of owl:oneOf is a blank node of class owl:DataRange and the object is a list of literals." etc.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>"NOTE: Enumerated datatypes are not part of OWL Lite."</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>[2] PrimerExampleTurtle</p><p class=MsoNormal> https://www.w3.org/2007/OWL/wiki/PrimerExampleTurtle</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>=================</p><p class=MsoNormal># Emily</p><p class=MsoNormal>_:x35 rdf:type owl2:DataRange ;</p><p class=MsoNormal> owl:oneOf ("39"^^xsd:integer "49"^^xsd:integer) .</p><p class=MsoNormal>=================</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>[3] Bob DuCharme's weblog, RDF lists and SPARQL</p><p class=MsoNormal> http://www.snee.com/bobdc.blog/2014/04/rdf-lists-and-sparql.html</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>=================</p><p class=MsoNormal>d:myList d:contents ("one" "two" "three" "four" "five")</p><p class=MsoNormal>=================</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>So... first datatype property.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>:accessTypeChoices rdf:type owl:DataRange ;</p><p class=MsoNormal> owl:oneOf ("inputOutput","inputOnly","outputOnly","initializeOnly") .</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>This didn't work in Protege - more investigation needed.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Meanwhile we did find a useful refinement, replacing type :SFString with more-restricted type xsd:NMTOKEN as follows:</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>================================</p><p class=MsoNormal>:DEF a owl:DatatypeProperty ;</p><p class=MsoNormal> rdfs:label "X3DNode field DEF is implemented by multiple nodes" ;</p><p class=MsoNormal> rdfs:domain [ owl:unionOf ( :X3DNode # etc. long list of nodes and types</p><p class=MsoNormal> rdfs:range :SFString .</p><p class=MsoNormal>================================</p><p class=MsoNormal>:DEF a owl:DatatypeProperty ;</p><p class=MsoNormal> rdfs:label "X3DNode field DEF is implemented by multiple nodes" ;</p><p class=MsoNormal> rdfs:domain [ owl:unionOf ( :X3DNode # etc. long list of nodes and types</p><p class=MsoNormal> rdfs:range xsd:NMTOKEN .</p><p class=MsoNormal>================================</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>I will work on rippling this improvement throughout X3D Ontology.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Next step. Starting with Transform field 'translation' as defined in X3D Ontology:</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>:translation a owl:DatatypeProperty ;</p><p class=MsoNormal> rdfs:domain :Transform ;</p><p class=MsoNormal> rdfs:range :SFVec3f .</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Jakub will look further on how datatype properties might be integrated, adding information to each field definition.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>We meet again next Monday.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>On 4/20/2020 10:38 AM, Don Brutzman wrote:</p><p class=MsoNormal>> Jakub and I had a useful meeting today. We looked at X3D Ontology completeness to diagnose event animation chains.</p><p class=MsoNormal>> </p><p class=MsoNormal>> A design pattern for representing animation chains is described in detail as part of the following chapter slideset. Single-page checklist also attached as a convenience.</p><p class=MsoNormal>> </p><p class=MsoNormal>> * X3D Graphics for Web Authors: Chapter 7, Event Animation Interpolation</p><p class=MsoNormal>> http://x3dgraphics.com/slidesets/X3dForWebAuthors/Chapter07EventAnimationInterpolation.pdf</p><p class=MsoNormal>> http://x3dgraphics.com/examples/X3dForWebAuthors/Chapter07EventAnimationInterpolation/</p><p class=MsoNormal>> </p><p class=MsoNormal>> slide 11. "Event-animation design pattern. X3D can be imposing, there are many nodes. Nevertheless a simple design pattern is used for nearly every kind of animation. his consistent event ROUTE pattern enables you to expertly animate most X3D scene behaviors."</p><p class=MsoNormal>> </p><p class=MsoNormal>> * Event-animation design pattern:</p><p class=MsoNormal>> Trigger node (optional) -> TimeSensor -> Interpolator/Sequencer/Script -> Target node's field</p><p class=MsoNormal>> </p><p class=MsoNormal>> A 10-step algorithm for author creation of this design pattern is provided and has proven helpful. Keeping a consistent pattern let's you avoid thinking that the various animation nodes are “really different” when they are not. It also helps you avoid skipping steps and making mistakes that are hard to debug afterwards.</p><p class=MsoNormal>> </p><p class=MsoNormal>> Example diagram also attached that illustrates the following model.</p><p class=MsoNormal>> </p><p class=MsoNormal>> * X3D Example Archives: X3D for Web Authors, Chapter 07 Event Animation Interpolation, Dolphin Morpher</p><p class=MsoNormal>> https://x3dgraphics.com/examples/X3dForWebAuthors/Chapter07EventAnimationInterpolation/DolphinMorpherIndex.html</p><p class=MsoNormal>> </p><p class=MsoNormal>> So, for X3D ontology, we want to see if we can write rules/queries to (a) illustrate event chains, and (b) diagnose whether any problems exist.</p><p class=MsoNormal>> </p><p class=MsoNormal>> Example problems:</p><p class=MsoNormal>> - mismatched ROUTE DEF or field-name values</p><p class=MsoNormal>> - mismatched data types,</p><p class=MsoNormal>> - mismatched accessType values,</p><p class=MsoNormal>> - missing pieces.</p><p class=MsoNormal>> </p><p class=MsoNormal>> So next step is to check X3D ontology for completeness of information provided. As an example, let's look at Transform in X3D Ontology. Excerpt:</p><p class=MsoNormal>> </p><p class=MsoNormal>> http://www.web3d.org/specifications/X3dOntology4.0</p><p class=MsoNormal>> ##################################################</p><p class=MsoNormal>> :Transform a owl:Class ;</p><p class=MsoNormal>> rdfs:subClassOf :X3DGroupingNode ;</p><p class=MsoNormal>> rdfs:label "Transform is a Grouping node that can contain most nodes." .</p><p class=MsoNormal>> # bboxCenter field inheritedFrom=X3DGroupingNode with accessType=initializeOnly, type=SFVec3f, default=0 0 0</p><p class=MsoNormal>> # bboxSize field inheritedFrom=X3DGroupingNode with accessType=initializeOnly, type=SFVec3f, default=-1 -1 -1, baseType=bboxSizeType</p><p class=MsoNormal>> :center a owl:DatatypeProperty ;</p><p class=MsoNormal>> rdfs:domain :Transform ;</p><p class=MsoNormal>> rdfs:range :SFVec3f .</p><p class=MsoNormal>> # children field inheritedFrom=X3DGroupingNode with accessType=inputOutput, type=MFNode</p><p class=MsoNormal>> # displayBBox field inheritedFrom=X3DGroupingNode with accessType=inputOutput, type=SFBool, default=false</p><p class=MsoNormal>> :rotation a owl:DatatypeProperty ;</p><p class=MsoNormal>> rdfs:domain :Transform ;</p><p class=MsoNormal>> rdfs:range :SFRotation .</p><p class=MsoNormal>> :scale a owl:DatatypeProperty ;</p><p class=MsoNormal>> rdfs:domain :Transform ;</p><p class=MsoNormal>> rdfs:range :SFVec3f .</p><p class=MsoNormal>> :scaleOrientation a owl:DatatypeProperty ;</p><p class=MsoNormal>> rdfs:domain :Transform ;</p><p class=MsoNormal>> rdfs:range :SFRotation .</p><p class=MsoNormal>> :translation a owl:DatatypeProperty ;</p><p class=MsoNormal>> rdfs:domain :Transform ;</p><p class=MsoNormal>> rdfs:range :SFVec3f.</p><p class=MsoNormal>> ##################################################</p><p class=MsoNormal>> </p><p class=MsoNormal>> So, our prior effort was not complete. Looks like we need to come up with a proper representation for accessType and defaultValue field to achieve full expressive power in X3D Ontology that already exists in X3DUOM.</p><p class=MsoNormal>> </p><p class=MsoNormal>> rdfs:TBD1 accessType inputOutput;</p><p class=MsoNormal>> rdfs:TBD2 defaultValue 0;</p><p class=MsoNormal>> </p><p class=MsoNormal>> ... so that is how far we got. More thinking and likely additions to to X3D Ontology will follow.</p><p class=MsoNormal>> </p><p class=MsoNormal>> all the best, Don</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>all the best, Don</p><p class=MsoNormal>-- </p><p class=MsoNormal>Don Brutzman Naval Postgraduate School, Code USW/Br brutzman@nps.edu</p><p class=MsoNormal>Watkins 270, MOVES Institute, Monterey CA 93943-5000 USA +1.831.656.2149</p><p class=MsoNormal>X3D graphics, virtual worlds, navy robotics http://faculty.nps.edu/brutzman</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>_______________________________________________</p><p class=MsoNormal>x3d-public mailing list</p><p class=MsoNormal>x3d-public@web3d.org</p><p class=MsoNormal>http://web3d.org/mailman/listinfo/x3d-public_web3d.org</p><p class=MsoNormal><o:p> </o:p></p></div></body></html>