<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>Yeah, that jar in the X3DJSAIL repo is ancient, and not kept up-to-date.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>The one here is 2 months old:</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><a href="https://github.com/coderextreme/pythonSAI">https://github.com/coderextreme/pythonSAI</a><o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>You can build your own X3DJSAIL with this repository, if you like something simple:<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><a href="https://github.com/coderextreme/JavaSceneAuthoringInterfaceLibrary">https://github.com/coderextreme/JavaSceneAuthoringInterfaceLibrary</a><o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>But it’s not a “fat” jar.  For that, you need Don’s build of the full jar below, or from Don’s X3DJSAIL web page.<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Otherwise, you have to use the ant target create.X3DJSAIL in <a href="http://www.web3d.org/x3d/stylesheets/">www.web3d.org/x3d/stylesheets/</a> (sourceforge download). Jars are found in java/jars below that.<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>I’ve been seduced by the dark-side, Don and X3DJSAIL, and have not been maintaining my projects.  X3DPSAIL is a happy medium, and now thanks to you, a nearly publishable medium.<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Are you by chance, working on a Anaconda package so we can import x3dpsail (the first script on your page) into jupyter?  I have a way to generate python application scripts (second script on page) with leading x3dpsail. in front of the constructor calls.   This is to reduce namespace pollution.  Do we just need to install <a href="https://github.com/andreasplesch/conda">https://github.com/andreasplesch/conda</a>?  Could you provide instructions on how to install  into our own docker or jupyter enviroments?  Looks like <a href="https://mybinder.org/">https://mybinder.org/</a> leads the way. Or do you want to support everyone’s development with your docker?  …could get kind of crowded.  I think the best solution is to create a conda package for x3dpysail which includes the python and the jar.  I saw one issue on it, but it was VERY long, and closed, so I assume there’s documentation on how to include a jar in a conda package somewhere, just not sure where yet.<o:p></o:p></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:andreasplesch@gmail.com">Andreas Plesch</a><br><b>Sent: </b>Tuesday, May 21, 2019 11:10 AM<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><br><b>Subject: </b>Re: [x3d-public] jupyter notebook</p></div><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Hi John,</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>thanks for the quick response. I had provided an older X3DJSAIL.jar</p><p class=MsoNormal>from https://github.com/coderextreme/X3DJSAIL which had the advantage</p><p class=MsoNormal>of being small.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Now, that I found the more up to date</p><p class=MsoNormal>http://www.web3d.org/specifications/java/jars/X3DJSAIL.3.3.full.jar</p><p class=MsoNormal>and use that instead, things start to work (!). [Most links to the jar</p><p class=MsoNormal>on the page need to be updated].</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Try again, the same link:</p><p class=MsoNormal>https://mybinder.org/v2/gh/andreasplesch/conda/master?filepath=sphere.ipynb</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>The errors are gone when you execute the cells.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>The generated xml looks good.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>But the IPython.display HTML function does not display anything. Does</p><p class=MsoNormal>that work locally for you ? HTML(data='<h1>Title</h1>') works. Maybe</p><p class=MsoNormal>an iframe is necessary.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>-Andreas</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 Tue, May 21, 2019 at 11:20 AM John Carlson <yottzumm@gmail.com> wrote:</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> Hi Andreas.</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>> Summary:  I don’t think the X3DJSAIL .jar was found in .</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>> I tried a very similar script to yours, putting the jar in the home folder.  I suspect that you don’t have access to your home folder, or the jar was uploaded as unreadable. Once I put my X3DJSAIL.3.3.full.jar in my local environment home, the classpath started working.</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>> I tried without the jar in place, and got similar issues with PointProperties.</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>> I tried running your remote jupyter and got similar results.</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>> I suspect readability issues or something configured with your classpath/jar.</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>> We need to get the jar into the x3dpsail conda package, I think.  An unsolved problem.</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>> It should run okay with a local anaconda.  I realize you want to run remote.  We understand, and will attempt to deliver a conda package in the next month or so.</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>> If you would like to help, we’re working on creating an x3dpsail package which includes all dependencies.  We have the start of a pip package, but so far, it won’t upload.   A Jupyter conda package is probably more acceptable to most people.</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>> It might be instructive to issue the first script with a single Java class, to see if it can find one Java class.  That will direct you to the smoking gun.  If it can’t load one class, then the classpath isn’t working.</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>> If you set a CLASSPATH environmental variable (java’s classpath) in your docker image, it might work better, give it a try. I am staying away from docker for now.   Ensure that OpenJDK or similar is deployed with jnius.</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>> Conclusion:</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>> X3dpsail has been shown to work with an absolute path or the jar on a local system.  Try to use an absolute path in conda in the short term (within your sandbox), until we get a conda package for x3dpsail.</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>> John</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>> Sent from Mail for Windows 10</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>> From: Andreas Plesch</p><p class=MsoNormal>> Sent: Tuesday, May 21, 2019 9:22 AM</p><p class=MsoNormal>> To: X3D Graphics public mailing list</p><p class=MsoNormal>> Subject: [x3d-public] jupyter notebook</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>> Hi John,</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>> I was curious and gave Pyjnius+X3DJSAIL.3.3 from your repo a try with</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> your sphere.ipynb, using online jupyter with mybinder.org:</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>> https://github.com/andreasplesch/conda</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>> Use this link</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>> https://mybinder.org/v2/gh/andreasplesch/conda/master?filepath=sphere.ipynb</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>> and wait until the server starts with the mybinder built docker image</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> (takes a bit).</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>> Executing then the first cell with all the autoclass generation does</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> something until there is an error:</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>> JavaException                             Traceback (most recent call last)</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> <ipython-input-1-149e86182885> in <module></p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>>      87 HAnimHumanoid =</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> autoclass('org.web3d.x3d.jsail.HAnim.HAnimHumanoidObject')</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>>      88 HAnimJoint = autoclass('org.web3d.x3d.jsail.HAnim.HAnimJointObject')</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> ---> 89 HAnimMotion = autoclass('org.web3d.x3d.jsail.HAnim.HAnimMotionObject')</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>>      90 HAnimSegment = autoclass('org.web3d.x3d.jsail.HAnim.HAnimSegmentObject')</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>>      91 HAnimSite = autoclass('org.web3d.x3d.jsail.HAnim.HAnimSiteObject')</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>> /srv/conda/envs/notebook/lib/python3.7/site-packages/jnius/reflect.py</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> in autoclass(clsname)</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>>     157</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>>     158     # c = Class.forName(clsname)</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> --> 159     c = find_javaclass(clsname)</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>>     160     if c is None:</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>>     161         raise Exception('Java class {0} not found'.format(c))</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>> jnius/jnius_export_func.pxi in jnius.find_javaclass()</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>> JavaException: Class not found b'org/web3d/x3d/jsail/HAnim/HAnimMotionObject'</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>> The good news is that the online jupyter notebook seems to work in</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> principle, eg. Pyjnius and java is installed, and the X3DJSAIL.3.3.jar</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> seems to be found as well.</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>> Have you seen problems with the HAnimMotion before ?</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>> Commenting out HAnimMotion, uncovers similar errors for PointProperties and X3D.</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>> JavaException                             Traceback (most recent call last)</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> <ipython-input-1-f7be65079716> in <module></p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>>     255 Scene = autoclass('org.web3d.x3d.jsail.Core.SceneObject')</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>>     256 unit = autoclass('org.web3d.x3d.jsail.Core.unitObject')</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> --> 257 X3D = autoclass('org.web3d.x3d.jsail.Core.X3DObject')</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>>     258 SFBool = autoclass('org.web3d.x3d.jsail.fields.SFBoolObject')</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>>     259 MFBool = autoclass('org.web3d.x3d.jsail.fields.MFBoolObject')</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>> /srv/conda/envs/notebook/lib/python3.7/site-packages/jnius/reflect.py</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> in autoclass(clsname)</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>>     157</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>>     158     # c = Class.forName(clsname)</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> --> 159     c = find_javaclass(clsname)</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>>     160     if c is None:</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>>     161         raise Exception('Java class {0} not found'.format(c))</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>> jnius/jnius_export_func.pxi in jnius.find_javaclass()</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>> JavaException: Class not found b'org/web3d/x3d/jsail/Core/X3DObject'</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>> Is there another Pyjnius or X3DJSAIL.jar to try ?</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>> Pyjnius is installed with conda and a pyjnius line in environment.yml.</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>> -Andreas</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>><o:p> </o:p></p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> --</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> Andreas Plesch</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> Waltham, MA 02453</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>> _______________________________________________</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> x3d-public mailing list</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> x3d-public@web3d.org</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> http://web3d.org/mailman/listinfo/x3d-public_web3d.org</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><o:p> </o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>-- </p><p class=MsoNormal>Andreas Plesch</p><p class=MsoNormal>Waltham, MA 02453</p><p class=MsoNormal><o:p> </o:p></p></div></body></html>