<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;
        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;
        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:1279218930;
        mso-list-type:hybrid;
        mso-list-template-ids:1112470858 -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;}
@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;}
@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;}
@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;}
@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;}
ol
        {margin-bottom:0in;}
ul
        {margin-bottom:0in;}
--></style></head><body lang=EN-US link=blue vlink="#954F72" style='word-wrap:break-word'><div class=WordSection1><p class=MsoNormal>OK, I will study more.  </p><p class=MsoNormal><o:p> </o:p></p><ul style='margin-top:0in' type=disc><li class=MsoListParagraph style='margin-left:0in;mso-list:l0 level1 lfo1'>Of course you can animate bones at runtime and have them affect<o:p></o:p></li></ul><p class=MsoNormal>the skin correctly in glTF.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Yes, it is important to provide a ‘standard’ skeleton hierarchy, with a ‘standard’ skin, with ‘standard’ surface feature site/sensor/viewpoint locations, with ‘standard’ skin vertex bindings and weights, along with ‘standard’ transportable realistic animations and interactions, (which is the point of the entire Hanim effort). </p><p class=MsoNormal><o:p> </o:p></p><ul style='margin-top:0in' type=disc><li class=MsoListParagraph style='margin-left:0in;mso-list:l0 level1 lfo1'>your general opinion is that "H-Anim is a better<o:p></o:p></li></ul><p class=MsoNormal>solution than glTF skinned animation".<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 is important to follow the spec motion system where skeleton-driven and Displacer-driven mesh animations are accumulated per frame. Level 1 hanim does not consider a deformable skin, only segment geometry. How to add deformable skin that is under control of joints and displacers to that model so the browser has truly level 2 hanim? That is the (set of) gltf files we need for x3d hanim, finally.</p><p class=MsoNormal>It is important that this information be presented in form where the skeleton joint center locations and hierarchy can be modified, the skin vertex base locations changed, surface feature treatments changed, and conserved, in short, to be transportable to some ‘standard’ environments, like geo and other human-scale simulations. </p><p class=MsoNormal><o:p> </o:p></p><ul style='margin-top:0in' type=disc><li class=MsoListParagraph style='margin-left:0in;mso-list:l0 level1 lfo1'>You mention 3dsMax as</li></ul><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Just sayin’ that when you find the primate, or human button, it gives you close to Hanim loa2. Believe me, they were there when HAnim was born. </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Thanks Again, your advancements are welcome and would really help to further define gltf nodes with respect to x3d Hanim.</p><p class=MsoNormal>JOe</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal> </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><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:michalis.kambi@gmail.com">Michalis Kamburelis</a><br><b>Sent: </b>Thursday, March 31, 2022 2:51 PM<br><b>To: </b><a href="mailto:joedwil@earthlink.net">Joseph D Williams</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] PBR in X3D4 using glTF and import as Inline</p></div><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Joe,</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>You focused on the "Skinned mesh animation" section (</p><p class=MsoNormal>https://github.com/michaliskambi/x3d-tests/wiki/Converting-glTF-to-X3D#skinned-mesh-animation</p><p class=MsoNormal>) and I understand your general opinion is that "H-Anim is a better</p><p class=MsoNormal>solution than glTF skinned animation".</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>I'm a bit hesitant to write this, as I understand this can turn into a</p><p class=MsoNormal>heated debate, but I have to say I disagree. That is, IMO glTF</p><p class=MsoNormal>approach to skinned animations is (for me, for my use-case) much</p><p class=MsoNormal>better than H-Anim in X3D.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Reasons:</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>1. glTF skinned animation has much simpler spec. And it still gives me</p><p class=MsoNormal>all the power I expect from a skinned animation system (to express</p><p class=MsoNormal>skinned animation, to play a prepared animation or to modify bones in</p><p class=MsoNormal>any other way at runtime e.g. for inverse kinematics at runtime).</p><p class=MsoNormal>Skinned animation is just a regular section within glTF spec. This is</p><p class=MsoNormal>much simpler than H-Anim spec attached to even larger X3D spec.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>2. glTF skinned animation has obvious efficient implementation on GPU.</p><p class=MsoNormal>glTF skinned animation can be explained in just 1.5 pages, on</p><p class=MsoNormal>https://www.khronos.org/files/gltf20-reference-guide.pdf , and the</p><p class=MsoNormal>efficient implementation of it is obvious.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>3. glTF has much wider adoption in practice than X3D.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>     I understand that this may depend on your use-case, or where one</p><p class=MsoNormal>is looking at. Of course there are communities focused on X3D, just</p><p class=MsoNormal>like communities focused on glTF.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>     But, from my point of view (making CGE game engine, making games</p><p class=MsoNormal>in both CGE and Unity and Unreal Engine, making 3D general</p><p class=MsoNormal>visualization) glTF just got more popular and it has more support</p><p class=MsoNormal>across tools.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>     E.g. Blender, 3dsMax, Maya, support glTF with animations. They</p><p class=MsoNormal>don't support H-Anim. Most of them (except Blender) don't even support</p><p class=MsoNormal>X3D.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>    The authoring software you mention ("BSContact? VIZX3D, xite") has</p><p class=MsoNormal>much smaller user-base. At least in my domain (again, I understand</p><p class=MsoNormal>this may be different for different domains), regular 3D artists don't</p><p class=MsoNormal>even know about them. OTOH every 3D artist knows either Blender or</p><p class=MsoNormal>3dsMax, usually both. It's not just my opinion -- look at the</p><p class=MsoNormal>documentation of Unity, Unreal Engine, or Babylon: they list how to</p><p class=MsoNormal>make models for their engines in Blender, 3dsMax, Maya. They don't</p><p class=MsoNormal>list BSContact etc.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>    (You mention 3dsMax as if it supported H-Anim. It doesn't, up to</p><p class=MsoNormal>my knowledge. Latest 3dsMax cannot export to X3D or VRML at all. Older</p><p class=MsoNormal>3dsMax used to be able to export to VRML 97.)</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>To address the particular points you make about the text on</p><p class=MsoNormal>https://github.com/michaliskambi/x3d-tests/wiki/Converting-glTF-to-X3D#skinned-mesh-animation</p><p class=MsoNormal>:</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>4. "… For making videos" - No. The approach I describe there works for</p><p class=MsoNormal>real-time 3D animation. Even with cross-fading animations.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>    But, as I wrote there explicitly, this is A. just the</p><p class=MsoNormal>implementation of CGE (don't draw conclusions from it about what glTF</p><p class=MsoNormal>can or cannot do), B. I do not think it's the optimal implementation</p><p class=MsoNormal>-- it will change (to make skinned animation on GPU). I explicitly</p><p class=MsoNormal>mention the drawbacks of my implementation on that page.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>    In general, that part of the page, saying "In Castle Game Engine</p><p class=MsoNormal>...", describes just that -- the current implementation in CGE, and</p><p class=MsoNormal>I'm open there about the fact that I want to improve it. Don't make</p><p class=MsoNormal>judgements about glTF skinned animation spec based on it.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>5. "So, the gltf folks aren’t telling us how they recommend to setup a</p><p class=MsoNormal>gltf file for realtime skeleton-driven skin animations?"</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>    Of course they do. You seem to misunderstood that part of the</p><p class=MsoNormal>page. It just describes current CGE implementation and the drawbacks</p><p class=MsoNormal>of it. Of course you can animate bones at runtime and have them affect</p><p class=MsoNormal>the skin correctly in glTF.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Regards,</p><p class=MsoNormal>Michalis</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>czw., 31 mar 2022 o 21:47 Joseph D Williams <joedwil@earthlink.net> napisał(a):</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> TODO. Work in-progress.</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> into TimeSensor + CoordinateInterpolator. This means that at runtime, we just do CoordinateInterpolator animation, not skinned mesh animation anymore. This is not the final solution. Although in practice it works very nicely:</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>> … For making videos</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>> Still, there are some big drawbacks:</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> You can no longer transform bones (just Transform nodes) to modify skin at runtime</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> So, the gltf folks aren’t telling us how they recommend to setup a gltf file for realtime skeleton-driven skin animations? They are only storing data showing something that allows a fixed interpolator displacements for the skin?  Not surprising because the real animations hidden in the delivery of this type of interpolated skin gltf is some of the hardest to develop and stuff most wanted to keep hidden.</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> I hope all can sidestep this skeleton-driven skin animation deficit of the current gltf and get all browsers doing Hanim. Actual implementation of animation technique designed to produce realltime anytime interactive animation of shapes and skins.</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> The memory use of long-running animation is significant</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> Lots better than just outputting complete frames of pixels for the video, which was once the best we could get.</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> In CGE we have also implemented H-Anim, which is X3D way of doing skinned mesh animation.</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> I think it is just the x3d way of encoding skeleton-driven skin animations as proven by years of implementations driving this technique for realtime, and really, also the Displacer animations. When this is mastered, I think it will give clues to how to encode a gltf example humanoid. For example, when storing a file for a humanoid using gltf, it might include the matrix at issue that was computed by the author tool and used directly by the runtime tool. Otherwise, doing the level2 skeleton-driven skin animation has always been heavy learning for every x3d browser maker willing to take the step.</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> To me this also shows that we need to turn this around a bit an develop some gltf tuned for x3d. How much easier it is to read and organize user code when I can just reference a json file to hold data and thus clean up my listing.</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> If any major 3D authoring software becomes capable of exporting to H-Anim,</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> BSContact? VIZX3D, xite? 3dsmax? You mean if any major authoring software extends themselves from making videos and moves towards realtime interactive live scenegraph simulations?</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> Thanks,,</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> Joe</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>><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>> From: Michalis Kamburelis</p><p class=MsoNormal>> Sent: Wednesday, March 30, 2022 4:19 PM</p><p class=MsoNormal>> To: Joseph D Williams</p><p class=MsoNormal>> Cc: X3D Graphics public mailing list</p><p class=MsoNormal>> Subject: Re: [x3d-public] PBR in X3D4 using glTF and import as Inline</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>> This is all documented on</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> https://github.com/michaliskambi/x3d-tests/wiki/Converting-glTF-to-X3D</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> .</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 is linked from the bottom of</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> https://github.com/michaliskambi/x3d-tests/wiki/2022-Talk-About-X3D-PBR-glTF</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> :)</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>> Regards,</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> Michalis</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>> czw., 31 mar 2022 o 00:05 Joseph D Williams <joedwil@earthlink.net> napisał(a):</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> ></p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> ></p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> ></p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> ></p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> ></p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> > HI All, Thanks Michalis, for the show. PBR stuff very impressive and looking usable. For the gltf files imported as Inlines, I hope you will show more about how you  extract the data from tha gltf node file to create the model as an Inline. Which fields of the gltf node file are used to create what at least must be a Shape with some sort of geometry and colors? Where does the mesh and color come from and how to use this to create the vizualized model? Also the animations. How to generate the behavior model from what is in the gltf file(s)?</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> ></p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> ></p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> ></p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> > Thanks Again for the presentation.</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> ></p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> > Joe</p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> ></p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> ></p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> ></p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> ></p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> ></p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> ></p><p class=MsoNormal>><o:p> </o:p></p><p class=MsoNormal>> ></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></div></body></html>