<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>Great effort Don, I hope I helped in some small way (heh, heh, waiting for a replacement computer now).  I am anxious to look at your output Java code/X3dToJava.xslt to see how I can fix the runtime bugs I encountered.  Are you differencing the output of Java against original XML yet?  That would certainly be good test to add.</p><p class=MsoNormal><br>Thanks,</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>Tuesday, April 18, 2017 1:36 AM<br><b>To: </b><a href="mailto:x3d-public@web3d.org">X3D Graphics public mailing list</a><br><b>Cc: </b><a href="mailto:yottzumm@gmail.com">John Carlson</a>; <a href="mailto:roy.walmsley@ntlworld.com">Roy Walmsley</a>; <a href="mailto:ak@alexkern.de">Alexander Kern</a><br><b>Subject: </b>Re: second release: X3DJSAIL Java translations, javadoc in X3DExamples Archives</p></div><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>With some effort, have added two more of the X3D Example Archives to include Java support using X3DJSAIL.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>                VRML 2 Sourcebook (415 Models)</p><p class=MsoNormal>                http://www.web3d.org/x3d/content/examples/Vrml2Sourcebook</p><p class=MsoNormal>                http://www.web3d.org/x3d/content/examples/Vrml2Sourcebook/javadoc</p><p class=MsoNormal>                http://www.web3d.org/x3d/content/examples/Vrml2Sourcebook/build.java.out.txt</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>                Conformance Nist (732 Models)</p><p class=MsoNormal>                http://www.web3d.org/x3d/content/examples/ConformanceNist/</p><p class=MsoNormal>                http://www.web3d.org/x3d/content/examples/ConformanceNist/javadoc</p><p class=MsoNormal>                http://www.web3d.org/x3d/content/examples/ConformanceNist/build.java.out.txt</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>The biggest task was to ensure that directory names and scene names met naming conventions for Java packages and classes.  In other words no hyphens, cannot start with a numeral, etc.  More on those rules can be found at</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>                X3D Scene Authoring Hints: Naming Conventions</p><p class=MsoNormal>                http://www.web3d.org/x3d/content/examples/X3dSceneAuthoringHints.html#NamingConventions</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Some improvements made and posted to X3dToJava.xslt stylesheet and X3DJSAIL library.  Testing and upgrades are continuing.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>                X3D Java Scene Access Interface Library (X3DJSAIL)</p><p class=MsoNormal>                http://www.web3d.org/specifications/java/X3DJSAIL.html</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>On 4/9/2017 2:07 PM, Don Brutzman wrote:</p><p class=MsoNormal>> Am happy to report that second release of more than a thousand published X3DJSAIL Java translations for X3D programs is now online in the Web3D Example Archives.</p><p class=MsoNormal>> </p><p class=MsoNormal>>      http://www.web3d.org/specifications/java/X3DJSAIL.html</p><p class=MsoNormal>>      http://www.web3d.org/x3d/content/examples/X3dResources.html#Examples</p><p class=MsoNormal>> </p><p class=MsoNormal>> Current support includes Basic Examples, X3dForWebAuthors and X3dForAdvancedModeling archives.  Also included are console logs when building the java versions of each example.</p><p class=MsoNormal>> </p><p class=MsoNormal>>      http://www.web3d.org/x3d/content/examples/Basic (776 Models)</p><p class=MsoNormal>>      http://www.web3d.org/x3d/content/examples/Basic/javadoc</p><p class=MsoNormal>>      http://www.web3d.org/x3d/content/examples/Basic/build.out.java.txt</p><p class=MsoNormal>> </p><p class=MsoNormal>>      http://x3dgraphics.com/examples/X3dForWebAuthors (260 Models)</p><p class=MsoNormal>>      http://x3dgraphics.com/examples/X3dForWebAuthors/javadoc</p><p class=MsoNormal>>      http://x3dgraphics.com/examples/X3dForWebAuthors/build.java.out.txt</p><p class=MsoNormal>> </p><p class=MsoNormal>>      http://x3dgraphics.com/examples/X3dForAdvancedModeling (83 Models)</p><p class=MsoNormal>>      http://x3dgraphics.com/examples/X3dForAdvancedModeling/javadoc</p><p class=MsoNormal>>      http://x3dgraphics.com/examples/X3dForAdvancedModeling/build.java.out.txt</p><p class=MsoNormal>> </p><p class=MsoNormal>> As described in the X3DJSAIL documentation, the archives build process uses the X3dToJava.xslt stylesheet for conversions.  Each index page for each example model has links to corresponding java and javadoc (as well as .x3d .x3dv .json x3dom cobweb html etc. of course) for comparison.</p><p class=MsoNormal>> </p><p class=MsoNormal>> Of note: in addition to compilation, the build process also executes each java version to reveal execution success or executions.  In other words we are *producing unit tests that also test themselves* - pretty cool!  Run-time testing isn't often a part of automated graphics testing, so this appears to be a significant step forward. The capabilities demonstrated by each example really help us with ongoing testing and improvement of X3DJSAIL API and X3D Java programs.  Rephrased: we are certainly finding and fixing a lot of bugs!  The latest greatest bugs can be found in the build logs above.</p><p class=MsoNormal>> </p><p class=MsoNormal>>      X3D Java Scene Access Interface Library (X3DJSAIL)</p><p class=MsoNormal>>      http://www.web3d.org/specifications/java/X3DJSAIL.html</p><p class=MsoNormal>> </p><p class=MsoNormal>> A lot of improvements have been made to the X3dToJava.xslt stylesheet as part of debugging efforts - plus a few touchups for X3dToJson.xslt as well.</p><p class=MsoNormal>> </p><p class=MsoNormal>> Let's again look at one model as an example, the BoxSwitch.x3d scene:</p><p class=MsoNormal>> </p><p class=MsoNormal>>      http://x3dgraphics.com/examples/X3dForAdvancedModeling/Animation/BoxSwitchIndex.html</p><p class=MsoNormal>>      http://x3dgraphics.com/examples/X3dForAdvancedModeling/Animation/BoxSwitch.java</p><p class=MsoNormal>>      http://x3dgraphics.com/examples/X3dForAdvancedModeling/javadoc/index.html?X3dForAdvancedModeling/Animation/BoxSwitch.html</p><p class=MsoNormal>>      http://x3dgraphics.com/examples/X3dForAdvancedModeling/Animation/BoxSwitch.json</p><p class=MsoNormal>> </p><p class=MsoNormal>> Console excerpt:</p><p class=MsoNormal>> ================</p><p class=MsoNormal>> C:\x3d-code\www.web3d.org\x3d\content\examples\X3dForAdvancedModeling/Animation/BoxSwitch.java produced from BoxSwitch.x3d</p><p class=MsoNormal>> [Large tuple found: PositionInterpolator keyValue, $tupleCount=37, $tupleSplitSize=10, string-length=480]</p><p class=MsoNormal>> Compiling 1 source file to C:\x3d-code\www.web3d.org\x3d\content\examples\X3dForAdvancedModeling\classes</p><p class=MsoNormal>> now run and validate the java model</p><p class=MsoNormal>> java -classpath classes;../../../stylesheets/java/jars/X3DJSAIL.3.3.full.jar;C:\x3d-code\www.web3d.org\x3d\tools\jar/saxon9he.jar X3dForAdvancedModeling.Animation.BoxSwitch</p><p class=MsoNormal>> BoxSwitch self-validation test results: success</p><p class=MsoNormal>> ================</p><p class=MsoNormal>> </p><p class=MsoNormal>> Java coders can look at the main() and validateSelf() methods in the .java source to see how each autogenerated class is internally checking for correctness when run.  Most functionality (such as strong-typing checks for attribute values and allowed child nodes) is built into X3DJSAIL for generality, and the per-scene exemplar code simply shows how to invoke it.</p><p class=MsoNormal>> </p><p class=MsoNormal>> As before, one challenge encountered during this process was the need to rename directories and file names to omit hyphen and period characters - those are not allowed as Java package or class names.  A number of rename fixes were made for Basic archive as well.  Next up is the VRML 2 Sourcebook, lots of renaming is necessary for this to work.  Naming conventions can be found in the X3D Scene Authoring Hints at</p><p class=MsoNormal>> </p><p class=MsoNormal>>      http://www.web3d.org/x3d/content/examples/X3dSceneAuthoringHints.html#NamingConventions</p><p class=MsoNormal>> </p><p class=MsoNormal>> As an example of debugging strength, this publishing process revealed a number of utilization problems that are independent of X3DJSAIL codebase itself.  All discovered deficiencies fixed in the converter, no major new bugs have been found on X3DJSAIL, changes are deployed every 1-2 days and checked in steadily, further progress expected.</p><p class=MsoNormal>> </p><p class=MsoNormal>> A table summary of different conversion capabilities (available and planned) is now found at</p><p class=MsoNormal>> </p><p class=MsoNormal>>      http://www.web3d.org/specifications/java/X3DJSAIL.html#Conversions</p><p class=MsoNormal>> </p><p class=MsoNormal>> Finally, have improved documentation further and am highlighting X3dToJava.xslt issues with a TODO subsection on the web page:</p><p class=MsoNormal>> </p><p class=MsoNormal>> ====================================</p><p class=MsoNormal>> X3DJSAIL: TODO Planned Work</p><p class=MsoNormal>> http://www.web3d.org/specifications/java/X3DJSAIL.html#TODO</p><p class=MsoNormal>> </p><p class=MsoNormal>> * Continued testing and improvement with conversion of .x3d source models in the X3D Examples Archive.</p><p class=MsoNormal>> * Continued resolution of issue reports on x3d-public@web3d.org mailing list (_archives_).</p><p class=MsoNormal>> * Handle too-large initialization methods (greater than 64K compiled) by splitting off arrays portions as separate data structures, when needed, rather than pipelined functional-style instantiations.</p><p class=MsoNormal>> * Prototypes: check IS/connect support, improve ProtoInstance handling without needing containerField</p><p class=MsoNormal>> ====================================</p><p class=MsoNormal>> </p><p class=MsoNormal>> Special thanks still for continuing superlative efforts by John Carlson in testing and debugging this codebase, as well as innovative design patterns for usage.  We'll continue highlighting issues of interest on the x3d-public mail list, those mails represent just a portion of much work going on in the background.</p><p class=MsoNormal>> </p><p class=MsoNormal>> Looking ahead:  "Object Model for X3D (OM4X3D) and Scene Access Interface (SAI) for X3D, including JSONLD and X3DJSAIL" by John, Roy and myself was accepted to the tutorial program of Web3D 2017.  Looking forward to showing people how to use these production-ready X3D codebases there.</p><p class=MsoNormal>> </p><p class=MsoNormal>>      Web3D 2017 Conference</p><p class=MsoNormal>>      Brisbane Australia, 3-5 June 2017</p><p class=MsoNormal>>      http://web3d2017.web3d.org</p><p class=MsoNormal>> </p><p class=MsoNormal>> So, onward we continue.  Have fun with X3D Java!  8)</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>