<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>Thursday would be okay, if I can stay awake.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>John<o:p></o:p></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><span style='font-size:12.0pt;font-family:"Times New Roman",serif'><o:p> </o:p></span></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>Sunday, July 3, 2016 11:10 AM<br><b>To: </b><a href="mailto:yottzumm@gmail.com">John Carlson</a>; <a href="mailto:roy.walmsley@ntlworld.com">Roy Walmsley</a><br><b>Cc: </b><a href="mailto:x3d-public@web3d.org">X3D Graphics public mailing list</a>; <a href="mailto:x3dom-developers@lists.sourceforge.net">x3dom-developers mailing list</a><br><b>Subject: </b>Re: Prototype Expander, Question on design of instance expansions</p></div><p class=MsoNormal><span style='font-size:12.0pt;font-family:"Times New Roman",serif'><o:p> </o:p></span></p><p class=MsoNormal>Just looked again at the other email thread; am replying here to keep related information together.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>                [x3d-public] What to do with ViewpointNode and NavigationInfoNode in prototype expander</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>                http://web3d.org/pipermail/x3d-public_web3d.org/2016-June/004951.html</p><p class=MsoNormal>                http://web3d.org/pipermail/x3d-public_web3d.org/2016-July/004982.html</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>The prototype expansion process certainly can get involved/convoluted, as your ViewFrustum conversion example there shows.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Recommendation: we need to walk through and describe suggested naming conventions for expanding fieldValues, fields, IS/connects and ROUTEs (both internal and external).  Probably we should start an HTML page going through all the details, illustrating alternatives and best-case approaches.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Further motivation: if you can show effective prototype expansion through these complex cases, and if i can write an expander with similar capabilities using an XSLT stylesheet, then we have general preprocessors that can provide Prototype capabilities to any X3D player.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>I think that most players will continue to want internal implementations for prototypes in order to achieve best efficiency of memory and speed.  Nevertheless it will be great to finally eliminate/minimize the question "does that player support prototypes" from the design tasks that each web author has to perform.  The workflow keeps getting better!  8)</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>So... maybe keep discussing via email, and have a 1-hour teleconference next Thursday to create/discuss an HTML page on X3D Prototype Expansion?</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>On 7/2/2016 2:09 PM, Don Brutzman wrote:</p><p class=MsoNormal>> Thank you for bringing up this really important issue John.  I think you have uncovered an excellent implementation challenge.</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> On 7/1/2016 1:36 PM, John Carlson wrote:</p><p class=MsoNormal>>><o:p> </o:p></p><p class=MsoNormal>>> I have an -material object in JSON which accepts a ProtoInstance. The ProtoBody has -children, the first of which is Material.  There are more nodes including Script nodes.  The question is, how do I create prototype expanded JSON?</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> Specifically, since the first node of a ProtoBody is what gets rendered, and the following top-level sibling nodes are active but non-rendered, how do they get handled when expanding the prototype?</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> X3D Tooltips: ProtoBody</p><p class=MsoNormal>> http://www.web3d.org/x3d/content/X3dTooltips.html#ProtoBody</p><p class=MsoNormal>> ===========================================================</p><p class=MsoNormal>> ProtoBody collects ProtoDeclare body nodes.</p><p class=MsoNormal>> Warning: only the first top-level node and its children are rendered, subsequent nodes (such as Scripts and ROUTEs) are active but are not drawn.</p><p class=MsoNormal>> ===========================================================</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> 4.4.4.3 PROTO definition semantics</p><p class=MsoNormal>> http://www.web3d.org/documents/specifications/19775-1/V3.3/Part01/concepts.html#PROTOdefinitionsemantics</p><p class=MsoNormal>> ===========================================================</p><p class=MsoNormal>> A prototype definition consists of one or more nodes, nested PROTO statements, and ROUTE statements. The first node type determines how instantiations of the prototype can be used in an X3D file. An instantiation is created by filling in the parameters of the prototype declaration and inserting copies of the first node (and its scene graph) wherever the prototype instantiation occurs.</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> EXAMPLE  If the first node in the prototype definition is a Material node, instantiations of the prototype can be used wherever a Material node can be used. Any other nodes and accompanying scene graphs are not part of the transformation hierarchy, but may be referenced by ROUTE statements or Script nodes in the prototype definition.</p><p class=MsoNormal>> ===========================================================</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> Important to note:  this challenge is not about the X3D JSON encoding per se.  We are able to produce a 1::1 correspondence between .json and .x3d .x3dv etc.</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> This implementation challenge is about how to implement the Prototype Expander so that ProtoInstance nodes might get replaced with cookie-cutter instantiations of a prototype declaration template.</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> This question was likely answered in similar but slightly different ways by each X3D player that has implemented Prototypes.  So there should be some good example implementations visible in Xj3D, freewrl, view3dscene, Cobweb ("Cobweb supports custom shaders, clip planes, reflection mapping, script nodes, prototyping capabilities"), etc.</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> Given their excellent implementation of prototypes in InstantReality, and their design of X3DOM, it would be a good thing if Fraunhofer might release their IR prototype implementation as an open-source fragment to facilitate these kinds of efforts.</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>>> Included are the original JSON and the JSON with the current expansion.  I can’t just take the first node, because then the script would be left off.  Ideas?  What most faithfully represents the original?  What about other cases (I have more)?</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> I saved your example conversions as MaterialModulatorPrototypeInstance.json and MaterialModulatorPrototypeExpanded.json, respectively.  Re-attached.</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>>> It would be really nice if JSON schema handled arrays for -material, -geometry and -appearance at least, so we can add the non-rendered nodes without invalidating the file.</p><p class=MsoNormal>>><o:p> </o:p></p><p class=MsoNormal>>> How would VRML handle this?</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> For the moment I think that we are mostly in implementation space, not language design.  Let's first work through with what we have already.  After that, gap analysis can tell us if additional specification support is needed.</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> So at present, a better question for integrating prototype capabilities in in X3DOM might be "How can a prototype expander be used as a preprocessor to generate internal X3DOM javascript source emulating the scene graph?"  That is certainly an appropriate goal for the x3dom-developer community (cc:ed).</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> Meanwhile, let's press ahead separately with also trying to produce a general-case solution with your expander.  Since the solution must work for any of the X3D encodings, likely no encoding-specific workarounds are needed.</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> First-pass design follows.  All review & improvement welcome:</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> 1. Goal: convert valid X3D with ProtoInstance nodes to corresponding valid X3D without ProtoInstance nodes, substituting nodes found in ProtoDeclare (possibly via ExternProtoDeclare).</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> 2. Requirements:</p><p class=MsoNormal>> a. Legal scene graph results which can pass all X3D validity tests.</p><p class=MsoNormal>> b. Maintain all ROUTE and IS/connect pathways for events correctly.  May require some renaming.</p><p class=MsoNormal>> c. Repeatable examples (MaterialModulator is a good place to start).</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> 3. Approach:</p><p class=MsoNormal>> a. Substitute the first node (along with contained scene subgraph) of Protobody as replacement for ProtoInstance.</p><p class=MsoNormal>> b. Handle follow-on nodes by also inserting them, in a scene-valid manner.</p><p class=MsoNormal>> b.1. When the first node in the ProtoBody is an X3DChildNode, any follow-on nodes can be wrapped in a Switch (with whichChoice="-1") to ensure they are non-rendering.</p><p class=MsoNormal>> b.2. When first node in the ProtoBody is not an X3DChildNode, any follow-on nodes are still wrapped in a Switch which follows at the closest subsequent point in the scene graph that can accept children nodes.</p><p class=MsoNormal>> c. External routing: field names within ROUTEs are modified, and DEF names adjusted if needed, and IS/connect statements are removed, to preserve event-passing semantics.</p><p class=MsoNormal>> d. External routing: field names within ROUTEs are modified, and DEF names adjusted if needed, to preserve event-passing semantics.</p><p class=MsoNormal>> e. Naming convention needed for steps c and d, which are quite similar.  Needs to be able to handle more than one copy of a ProtoInstance getting expanded.</p><p class=MsoNormal>> f. Assign initial values to field definitions where appropriate.</p><p class=MsoNormal>> g.Nice to have: possibility that an expanded ProtoInstance block of nodes might be reconverted later into the original ProtoInstance, perhaps simply by containing the original as a comment.</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> Looking at your MaterialModulatorPrototypeExpanded.json above, it appears that your approach accomplishes most of these steps already.  Only significant difference would be step b.2, handling incompatible follow-on nodes within a Shape.</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> Next attachment is original scene with ProtoDeclare and ProtoInstance: MaterialModulator.x3d</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> Attached please find an attempt MaterialModulatorExpanded that follows a quite similar pattern to yours.  Only intended difference is to put the hiding Switch following the Shape node - thus it includes restructuring for step b.2.  This expansion works in BS Contact, Instant Reality, FreeWrl, Octaga, Cobweb.</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> There is still a bit more trickiness to sort out here with the renaming, but it looks like a general pattern is possible.</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> Am also optimistic that we might be able to create an XSLT stylesheet that accomplishes the identical task of converting ProtoInstance nodes into expanded nodes.</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> ... so, seems pretty promising.  A few more rocks and shoals to navigate but appears that we can get there from here.  What do you think?</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>