<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:"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;}
a:visited, span.MsoHyperlinkFollowed
        {mso-style-priority:99;
        color:#954F72;
        text-decoration:underline;}
.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;}
--></style></head><body lang=EN-US link=blue vlink="#954F72"><div class=WordSection1><p class=MsoNormal>One thing we might consider is generating schemas for profiles and components from X3DJSAIL.  Just a thought. I think separate tools may be better.  UNIX philosophy.  Getting a good metamodel into Java might be good too.  That is, supporting profiles as first class objects.  Idk, need to see Java 9 modules more.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>John</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Sent from <a href="https://go.microsoft.com/fwlink/?LinkId=550986">Mail</a> for Windows 10</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, August 30, 2017 12:47 PM<br><b>To: </b><a href="mailto:yottzumm@gmail.com">John Carlson</a><br><b>Cc: </b><a href="mailto:x3d-public@web3d.org">X3D Graphics public mailing list</a>; <a href="mailto:roy.walmsley@ntlworld.com">Roy Walmsley</a><br><b>Subject: </b>Re: More Object Model Work: indicating nodes and statements for eachprofile within object model and X3DJSAIL</p></div><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>OK, have amended X3D XML Schema to include allowed nodes under each profile.  Also added allowed X3D statements under Core profile.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Documentation at</p><p class=MsoNormal>http://www.web3d.org/specifications/X3dSchemaDocumentation3.3/x3d-3.3_profileNames.html#LinkDC</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Next: have extracted these node and statement lists for inclusion in the X3D Unified Object Model profile information.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Result excerpt follows.  Please look at syntax, hope it looks OK.  As this gets integrated, will next apply by generating profile-validation tests in source code for X3DJSAIL.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>       <SimpleType name="profileNames"</p><p class=MsoNormal>                   baseType="SFString"</p><p class=MsoNormal>                   appinfo="profileName enumeration constants are used to identify the profile for each scene-graph node, and also utilized by X3D element to identify the profile of a contained Scene."</p><p class=MsoNormal>                   documentation="http://www.web3d.org/documents/specifications/19775-1/V3.3/Part01/concepts.html#Profiles"></p><p class=MsoNormal>          <enumeration value="Core"</p><p class=MsoNormal>                       appinfo="Core Profile includes no nodes and is provided as the basis for custom componentization. Allowed X3D statements for all profiles are: connect ExternProtoDeclare EXPORT field fieldValue IMPORT IS ProtoBody ProtoDeclare ProtoInterface ProtoInstance ROUTE X3D. Allowed X3D nodes for this profile are: MetadataBoolean MetadataDouble MetadataFloat MetadataInteger MetadataSet MetadataString."></p><p class=MsoNormal>             <allowedElement>MetadataBoolean</allowedElement></p><p class=MsoNormal>             <allowedElement>MetadataDouble</allowedElement></p><p class=MsoNormal>             <allowedElement>MetadataFloat</allowedElement></p><p class=MsoNormal>             <allowedElement>MetadataInteger</allowedElement></p><p class=MsoNormal>             <allowedElement>MetadataSet</allowedElement></p><p class=MsoNormal>             <allowedElement>MetadataString</allowedElement></p><p class=MsoNormal>             <allowedElement>connect</allowedElement></p><p class=MsoNormal>             <allowedElement>ExternProtoDeclare</allowedElement></p><p class=MsoNormal>             <allowedElement>EXPORT</allowedElement></p><p class=MsoNormal>             <allowedElement>field</allowedElement></p><p class=MsoNormal>             <allowedElement>fieldValue</allowedElement></p><p class=MsoNormal>             <allowedElement>IMPORT</allowedElement></p><p class=MsoNormal>             <allowedElement>IS</allowedElement></p><p class=MsoNormal>             <allowedElement>ProtoBody</allowedElement></p><p class=MsoNormal>             <allowedElement>ProtoDeclare</allowedElement></p><p class=MsoNormal>             <allowedElement>ProtoInterface</allowedElement></p><p class=MsoNormal>             <allowedElement>ProtoInstance</allowedElement></p><p class=MsoNormal>             <allowedElement>ROUTE</allowedElement></p><p class=MsoNormal>             <allowedElement>X3D</allowedElement></p><p class=MsoNormal>          </enumeration></p><p class=MsoNormal>          <enumeration value="Interchange"</p><p class=MsoNormal>                       appinfo="Interchange Profile equals the minimum subset of nodes needed to display lightweight compelling content. Allowed X3D nodes for this profile are: Appearance Background Box Color ColorInterpolator ColorRGBA Cone Coordinate CoordinateInterpolator Cylinder DirectionalLight Group ImageTexture IndexedFaceSet IndexedLineSet IndexedTriangleFanSet IndexedTriangleSet IndexedTriangleStripSet LineSet Material MetadataBoolean MetadataDouble MetadataFloat MetadataInteger MetadataSet MetadataString MultiTexture MultiTextureCoordinate MultiTextureTransform NavigationInfo Normal NormalInterpolator OrientationInterpolator PixelTexture PointSet PositionInterpolator ScalarInterpolator Shape Sphere TextureCoordinate TextureCoordinateGenerator TextureTransform TimeSensor Transform TriangleFanSet TriangleSet TriangleStripSet Viewpoint WorldInfo."></p><p class=MsoNormal>             <allowedElement>Appearance</allowedElement></p><p class=MsoNormal>             <allowedElement>Background</allowedElement></p><p class=MsoNormal>             <allowedElement>Box</allowedElement></p><p class=MsoNormal>             <allowedElement>Color</allowedElement></p><p class=MsoNormal>             <allowedElement>ColorInterpolator</allowedElement></p><p class=MsoNormal>             <allowedElement>ColorRGBA</allowedElement></p><p class=MsoNormal>             <allowedElement>Cone</allowedElement></p><p class=MsoNormal>             <allowedElement>Coordinate</allowedElement></p><p class=MsoNormal>             <allowedElement>CoordinateInterpolator</allowedElement></p><p class=MsoNormal>             <allowedElement>Cylinder</allowedElement></p><p class=MsoNormal>             <allowedElement>DirectionalLight</allowedElement></p><p class=MsoNormal>             <allowedElement>Group</allowedElement></p><p class=MsoNormal>             <allowedElement>ImageTexture</allowedElement></p><p class=MsoNormal>             <allowedElement>IndexedFaceSet</allowedElement></p><p class=MsoNormal>             <allowedElement>IndexedLineSet</allowedElement></p><p class=MsoNormal>             <allowedElement>IndexedTriangleFanSet</allowedElement></p><p class=MsoNormal>             <allowedElement>IndexedTriangleSet</allowedElement></p><p class=MsoNormal>             <allowedElement>IndexedTriangleStripSet</allowedElement></p><p class=MsoNormal>             <allowedElement>LineSet</allowedElement></p><p class=MsoNormal>             <allowedElement>Material</allowedElement></p><p class=MsoNormal>             <allowedElement>MetadataBoolean</allowedElement></p><p class=MsoNormal>             <allowedElement>MetadataDouble</allowedElement></p><p class=MsoNormal>             <allowedElement>MetadataFloat</allowedElement></p><p class=MsoNormal>             <allowedElement>MetadataInteger</allowedElement></p><p class=MsoNormal>             <allowedElement>MetadataSet</allowedElement></p><p class=MsoNormal>             <allowedElement>MetadataString</allowedElement></p><p class=MsoNormal>             <allowedElement>MultiTexture</allowedElement></p><p class=MsoNormal>             <allowedElement>MultiTextureCoordinate</allowedElement></p><p class=MsoNormal>             <allowedElement>MultiTextureTransform</allowedElement></p><p class=MsoNormal>             <allowedElement>NavigationInfo</allowedElement></p><p class=MsoNormal>             <allowedElement>Normal</allowedElement></p><p class=MsoNormal>             <allowedElement>NormalInterpolator</allowedElement></p><p class=MsoNormal>             <allowedElement>OrientationInterpolator</allowedElement></p><p class=MsoNormal>             <allowedElement>PixelTexture</allowedElement></p><p class=MsoNormal>             <allowedElement>PointSet</allowedElement></p><p class=MsoNormal>             <allowedElement>PositionInterpolator</allowedElement></p><p class=MsoNormal>             <allowedElement>ScalarInterpolator</allowedElement></p><p class=MsoNormal>             <allowedElement>Shape</allowedElement></p><p class=MsoNormal>             <allowedElement>Sphere</allowedElement></p><p class=MsoNormal>             <allowedElement>TextureCoordinate</allowedElement></p><p class=MsoNormal>             <allowedElement>TextureCoordinateGenerator</allowedElement></p><p class=MsoNormal>             <allowedElement>TextureTransform</allowedElement></p><p class=MsoNormal>             <allowedElement>TimeSensor</allowedElement></p><p class=MsoNormal>             <allowedElement>Transform</allowedElement></p><p class=MsoNormal>             <allowedElement>TriangleFanSet</allowedElement></p><p class=MsoNormal>             <allowedElement>TriangleSet</allowedElement></p><p class=MsoNormal>             <allowedElement>TriangleStripSet</allowedElement></p><p class=MsoNormal>             <allowedElement>Viewpoint</allowedElement></p><p class=MsoNormal>             <allowedElement>WorldInfo</allowedElement></p><p class=MsoNormal>             <allowedElement>connect</allowedElement></p><p class=MsoNormal>             <allowedElement>ExternProtoDeclare</allowedElement></p><p class=MsoNormal>             <allowedElement>EXPORT</allowedElement></p><p class=MsoNormal>             <allowedElement>field</allowedElement></p><p class=MsoNormal>             <allowedElement>fieldValue</allowedElement></p><p class=MsoNormal>             <allowedElement>IMPORT</allowedElement></p><p class=MsoNormal>             <allowedElement>IS</allowedElement></p><p class=MsoNormal>             <allowedElement>ProtoBody</allowedElement></p><p class=MsoNormal>             <allowedElement>ProtoDeclare</allowedElement></p><p class=MsoNormal>             <allowedElement>ProtoInterface</allowedElement></p><p class=MsoNormal>             <allowedElement>ProtoInstance</allowedElement></p><p class=MsoNormal>             <allowedElement>ROUTE</allowedElement></p><p class=MsoNormal>             <allowedElement>X3D</allowedElement></p><p class=MsoNormal>          </enumeration></p><p class=MsoNormal>etc.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>On 8/23/2017 11:53 AM, Don Brutzman wrote:</p><p class=MsoNormal>> On 8/22/2017 9:30 PM, John Carlson wrote:</p><p class=MsoNormal>>> I would like to validate the contents of a JSON document against the profile without translating to XML.   Thus profile to components or profile to node information is required, but may be derived from what you suggest when it will appear in the object model.</p><p class=MsoNormal>>><o:p> </o:p></p><p class=MsoNormal>>> Please plan to provide this in the object model.   I believe it exists somewhat in the XML schema.</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> First try.</p><p class=MsoNormal>> </p><p class=MsoNormal>> The existing information in X3D XML Schema follows.</p><p class=MsoNormal>> </p><p class=MsoNormal>>      http://www.web3d.org/specifications/x3d-3.3.xsd</p><p class=MsoNormal>> </p><p class=MsoNormal>> <xs:simpleType name="profileNames"></p><p class=MsoNormal>>          <xs:annotation></p><p class=MsoNormal>>              <xs:appinfo>profileName enumeration constants are used to identify the profile for each scene-graph node, and also utilized by X3D element to identify the profile of a contained Scene.</xs:appinfo></p><p class=MsoNormal>>              <xs:documentation source="http://www.web3d.org/documents/specifications/19775-1/V3.3/Part01/concepts.html#Profiles"/></p><p class=MsoNormal>>          </xs:annotation></p><p class=MsoNormal>>          <xs:restriction base="xs:string"></p><p class=MsoNormal>>              <xs:enumeration value="Core"></p><p class=MsoNormal>>                  <xs:annotation></p><p class=MsoNormal>>                      <xs:appinfo>Core Profile includes no nodes and is provided as the basis for custom componentization.</xs:appinfo></p><p class=MsoNormal>>                      <xs:documentation source="http://www.web3d.org/documents/specifications/19775-1/V3.3/Part01/coreprofile.html"/></p><p class=MsoNormal>>                  </xs:annotation></p><p class=MsoNormal>>              </xs:enumeration></p><p class=MsoNormal>>              <xs:enumeration value="Interchange"></p><p class=MsoNormal>>                  <xs:annotation></p><p class=MsoNormal>>                      <xs:appinfo>Interchange Profile equals the minimum subset of nodes needed to display lightweight compelling content.</xs:appinfo></p><p class=MsoNormal>>                      <xs:documentation source="http://www.web3d.org/documents/specifications/19775-1/V3.3/Part01/interchange.html"/></p><p class=MsoNormal>>                  </xs:annotation></p><p class=MsoNormal>>              </xs:enumeration></p><p class=MsoNormal>>              <xs:enumeration value="CADInterchange"></p><p class=MsoNormal>>                  <xs:annotation></p><p class=MsoNormal>>                      <xs:appinfo>CADInterchange Profile adds support for CADGeometry component nodes to Interchange Profile.</xs:appinfo></p><p class=MsoNormal>>                      <xs:documentation source="http://www.web3d.org/documents/specifications/19775-1/V3.3/Part01/CADInterchange.html"/></p><p class=MsoNormal>>                  </xs:annotation></p><p class=MsoNormal>>              </xs:enumeration></p><p class=MsoNormal>>              <xs:enumeration value="Interactive"></p><p class=MsoNormal>>                  <xs:annotation></p><p class=MsoNormal>>                      <xs:appinfo>Interactive Profile adds interaction nodes (Anchor, KeySensor) to the minimum subset of nodes needed to display lightweight compelling content.</xs:appinfo></p><p class=MsoNormal>>                      <xs:documentation source="http://www.web3d.org/documents/specifications/19775-1/V3.3/Part01/interactive.html"/></p><p class=MsoNormal>>                  </xs:annotation></p><p class=MsoNormal>>              </xs:enumeration></p><p class=MsoNormal>>              <xs:enumeration value="Immersive"></p><p class=MsoNormal>>                  <xs:annotation></p><p class=MsoNormal>>                      <xs:appinfo>Immersive Profile equals all of the nodes in the VRML 97 Specification, plus various X3D node additions including KeySensor, StringSensor and Scene.</xs:appinfo></p><p class=MsoNormal>>                      <xs:documentation source="http://www.web3d.org/documents/specifications/19775-1/V3.3/Part01/immersive.html"/></p><p class=MsoNormal>>                  </xs:annotation></p><p class=MsoNormal>>              </xs:enumeration></p><p class=MsoNormal>>              <xs:enumeration value="MedicalInterchange"></p><p class=MsoNormal>>                  <xs:annotation></p><p class=MsoNormal>>                      <xs:appinfo>The MedicalInterchange profile adds support for VolumeRendering component to Interchange profile.</xs:appinfo></p><p class=MsoNormal>>                      <xs:documentation source="http://www.web3d.org/documents/specifications/19775-1/V3.3/Part01/MedInterchange.html"/></p><p class=MsoNormal>>                  </xs:annotation></p><p class=MsoNormal>>              </xs:enumeration></p><p class=MsoNormal>>              <xs:enumeration value="MPEG4Interactive"></p><p class=MsoNormal>>                  <xs:annotation></p><p class=MsoNormal>>                      <xs:appinfo>MPEGInteractive Profile defines base interoperability with MPEG4 standards to a small subset of nodes needed to display lightweight compelling content.</xs:appinfo></p><p class=MsoNormal>>                      <xs:documentation source="http://www.web3d.org/documents/specifications/19775-1/V3.3/Part01/MPEG4interactive.html"/></p><p class=MsoNormal>>                  </xs:annotation></p><p class=MsoNormal>>              </xs:enumeration></p><p class=MsoNormal>>              <xs:enumeration value="Full"></p><p class=MsoNormal>>                  <xs:annotation></p><p class=MsoNormal>>                      <xs:appinfo>The Full Profile corresponds to all Immersive X3D nodes plus all approved/implemented extensions.  Full may get renamed Integrated.</xs:appinfo></p><p class=MsoNormal>>                      <xs:documentation source="http://www.web3d.org/documents/specifications/19775-1/V3.3/Part01/fullProfile.html"/></p><p class=MsoNormal>>                  </xs:annotation></p><p class=MsoNormal>>              </xs:enumeration></p><p class=MsoNormal>>          </xs:restriction></p><p class=MsoNormal>>      </xs:simpleType></p><p class=MsoNormal>> </p><p class=MsoNormal>> Note that we are not producing a tagset but rather providing documentation.  Also note that if this information in the following data structure, it would have to be part of the corresponding appinfo entries, since no other xs: elements are allowed inside the <xs:enumeration> definitions.</p><p class=MsoNormal>> </p><p class=MsoNormal>> Currently the corresponding object model has</p><p class=MsoNormal>> </p><p class=MsoNormal>>      http://www.web3d.org/specifications/X3DObjectModel-3.3.xml</p><p class=MsoNormal>> </p><p class=MsoNormal>> <SimpleType name="profileNames"</p><p class=MsoNormal>>              baseType="SFString"</p><p class=MsoNormal>>              appinfo="profileName enumeration constants are used to identify the profile for each scene-graph node, and also utilized by X3D element to identify the profile of a contained Scene."</p><p class=MsoNormal>>              documentation="http://www.web3d.org/documents/specifications/19775-1/V3.3/Part01/concepts.html#Profiles"></p><p class=MsoNormal>>     <enumeration value="Core"</p><p class=MsoNormal>>                  appinfo="Core Profile includes no nodes and is provided as the basis for custom componentization."/></p><p class=MsoNormal>>     <enumeration value="Interchange"</p><p class=MsoNormal>>                  appinfo="Interchange Profile equals the minimum subset of nodes needed to display lightweight compelling content."/></p><p class=MsoNormal>>     <enumeration value="CADInterchange"</p><p class=MsoNormal>>                  appinfo="CADInterchange Profile adds support for CADGeometry component nodes to Interchange Profile."/></p><p class=MsoNormal>>     <enumeration value="Interactive"</p><p class=MsoNormal>>                  appinfo="Interactive Profile adds interaction nodes (Anchor, KeySensor) to the minimum subset of nodes needed to display lightweight compelling content."/></p><p class=MsoNormal>>     <enumeration value="Immersive"</p><p class=MsoNormal>>                  appinfo="Immersive Profile equals all of the nodes in the VRML 97 Specification, plus various X3D node additions including KeySensor, StringSensor and Scene."/></p><p class=MsoNormal>>     <enumeration value="MedicalInterchange"</p><p class=MsoNormal>>                  appinfo="The MedicalInterchange profile adds support for VolumeRendering component to Interchange profile."/></p><p class=MsoNormal>>     <enumeration value="MPEG4Interactive"</p><p class=MsoNormal>>                  appinfo="MPEGInteractive Profile defines base interoperability with MPEG4 standards to a small subset of nodes needed to display lightweight compelling content."/></p><p class=MsoNormal>>     <enumeration value="Full"</p><p class=MsoNormal>>                  appinfo="The Full Profile corresponds to all Immersive X3D nodes plus all approved/implemented extensions. Full may get renamed Integrated."/></p><p class=MsoNormal>> </SimpleType></p><p class=MsoNormal>> </p><p class=MsoNormal>> </p><p class=MsoNormal>> Not very structured but reasonably parsable might be something added manually to the schema like:</p><p class=MsoNormal>> </p><p class=MsoNormal>> <xs:appinfo></p><p class=MsoNormal>>      Immersive Profile equals all of the nodes in the VRML 97 Specification, plus various X3D node additions including KeySensor, StringSensor and Scene.</p><p class=MsoNormal>>      *Allowed nodes include AnchorAppearanceAudioClip etc.*</p><p class=MsoNormal>> </xs:appinfo></p><p class=MsoNormal>> </p><p class=MsoNormal>> The corresponding construct in the unified object model (which itself has a modifiable schema of our own design) might then become</p><p class=MsoNormal>> </p><p class=MsoNormal>>   <enumeration value="Immersive" appinfo="Immersive Profile equals all of the nodes in the VRML 97 Specification, plus various X3D node additions including KeySensor, StringSensor and Scene."></p><p class=MsoNormal>>      <value>Anchor</value></p><p class=MsoNormal>>      <value>Appearance</value></p><p class=MsoNormal>>      <value>AudioClip</value></p><p class=MsoNormal>>      <value>...</value></p><p class=MsoNormal>>   <enumeration></p><p class=MsoNormal>> </p><p class=MsoNormal>> </p><p class=MsoNormal>> all the best, Don</p><p class=MsoNormal><o:p> </o:p></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></div></body></html>