<div dir="ltr">Awesome, thanks! <br></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Mon, Jul 24, 2023 at 6:21 AM Michalis Kamburelis <<a href="mailto:michalis.kambi@gmail.com">michalis.kambi@gmail.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">John,<br>
<br>
The large number of warnings on LeifRevised.x3dv (you show<br>
command-line with it):<br>
<br>
- Are fixed already. I answered in<br>
<a href="https://github.com/castle-engine/view3dscene/issues/57" rel="noreferrer" target="_blank">https://github.com/castle-engine/view3dscene/issues/57</a> yesterday.<br>
<br>
- They are also not strictly related to this thread :) They are not on<br>
JoeKick example.<br>
<br>
Regards,<br>
Michalis<br>
<br>
pon., 24 lip 2023 o 13:12 John Carlson <<a href="mailto:yottzumm@gmail.com" target="_blank">yottzumm@gmail.com</a>> napisał(a):<br>
><br>
> I didn't want to show all the errors because there's over 60k lines:<br>
><br>
> $ ~/Downloads/view3dscene-4.3.0-win64-x86_64/view3dscene/tovrmlx3d.exe OutputDir/LeifRevised.x3dv 2>&1 |wc<br>
>   61667 1269587 10854162<br>
><br>
> I filed a feature request on GitHub, Michalis.  Reduce, Reuse, Recycle. Maybe a summary per joint?<br>
><br>
> John<br>
><br>
> On Mon, Jul 24, 2023 at 5:52 AM Michalis Kamburelis <<a href="mailto:michalis.kambi@gmail.com" target="_blank">michalis.kambi@gmail.com</a>> wrote:<br>
>><br>
>> I'm very sorry, by "Josh" -> I meant "John" naturally :)<br>
>><br>
>> Regards,<br>
>> Muchalis<br>
>><br>
>> pon., 24 lip 2023 o 12:51 Michalis Kamburelis<br>
>> <<a href="mailto:michalis.kambi@gmail.com" target="_blank">michalis.kambi@gmail.com</a>> napisał(a):<br>
>><br>
>> ><br>
>> > Thanks Don, I confirm that classic encoding version (<br>
>> > <a href="https://www.web3d.org/x3d/content/examples/HumanoidAnimation/Skin/JoeKick.x3dv" rel="noreferrer" target="_blank">https://www.web3d.org/x3d/content/examples/HumanoidAnimation/Skin/JoeKick.x3dv</a><br>
>> > ) is now equivalent to XML encoding version, so encoding conversions<br>
>> > are good.<br>
>> ><br>
>> > For testing from command-line, one can just process the model with<br>
>> > tovrmlx3d, as Josh notes, and see if any warnings or errors are<br>
>> > reported.<br>
>> ><br>
>> > Note that "HAnimJoint.skinCoord references not existing coordinate"<br>
>> > shown above by John are not related to this particular testcase. For<br>
>> > me now, both XML and classic versions of JoeKick only report the same<br>
>> > issue -- about texture coordinates lengths.<br>
>> ><br>
>> > Regards,<br>
>> > Michalis<br>
>> ><br>
>> > pon., 24 lip 2023 o 12:33 John Carlson <<a href="mailto:yottzumm@gmail.com" target="_blank">yottzumm@gmail.com</a>> napisał(a):<br>
>> > ><br>
>> > > You can get the same report from tovrmlx3d.exe, I think Don, see:<br>
>> > ><br>
>> > > tovrmlx3d.exe next to the view3dscene.exe<br>
>> > ><br>
>> > > Here is a small taste of what happens on a recent X3DV file:<br>
>> > ><br>
>> > > $ ~/Downloads/view3dscene-4.3.0-win64-x86_64/view3dscene/tovrmlx3d.exe OutputDir/LeifRevised.x3dv 2>&1 |head<br>
>> > > tovrmlx3d: Warning: HAnimHumanoid.joints list was empty, fixed to list all 54 joints<br>
>> > > tovrmlx3d: Warning: X3D: HAnimJoint.skinCoord references not existing coordinate index 9 (while we have only 0 skin coordinates in HAnimHumanoid.skin)<br>
>> > > tovrmlx3d: Warning: X3D: HAnimJoint.skinCoord references not existing coordinate index 10 (while we have only 0 skin coordinates in HAnimHumanoid.skin)<br>
>> > > tovrmlx3d: Warning: X3D: HAnimJoint.skinCoord references not existing coordinate index 11 (while we have only 0 skin coordinates in HAnimHumanoid.skin)<br>
>> > > tovrmlx3d: Warning: X3D: HAnimJoint.skinCoord references not existing coordinate index 12 (while we have only 0 skin coordinates in HAnimHumanoid.skin)<br>
>> > > tovrmlx3d: Warning: X3D: HAnimJoint.skinCoord references not existing coordinate index 13 (while we have only 0 skin coordinates in HAnimHumanoid.skin)<br>
>> > > tovrmlx3d: Warning: X3D: HAnimJoint.skinCoord references not existing coordinate index 14 (while we have only 0 skin coordinates in HAnimHumanoid.skin)<br>
>> > > tovrmlx3d: Warning: X3D: HAnimJoint.skinCoord references not existing coordinate index 15 (while we have only 0 skin coordinates in HAnimHumanoid.skin)<br>
>> > > tovrmlx3d: Warning: X3D: HAnimJoint.skinCoord references not existing coordinate index 16 (while we have only 0 skin coordinates in HAnimHumanoid.skin)<br>
>> > > tovrmlx3d: Warning: X3D: HAnimJoint.skinCoord references not existing coordinate index 17 (while we have only 0 skin coordinates in HAnimHumanoid.skin)<br>
>> > ><br>
>> > > Fills the bill.<br>
>> > ><br>
>> > > John<br>
>> > ><br>
>> > > On Mon, Jul 24, 2023 at 3:19 AM Brutzman, Donald (Don) (CIV) <<a href="mailto:brutzman@nps.edu" target="_blank">brutzman@nps.edu</a>> wrote:<br>
>> > >><br>
>> > >> 1. Michalis, thanks for a great trouble report.<br>
>> > >><br>
>> > >><br>
>> > >><br>
>> > >> I believe the conversion errors are now fixed in X3dToVrml.xslt stylesheet, updated model at<br>
>> > >><br>
>> > >><br>
>> > >><br>
>> > >> <a href="https://www.web3d.org/x3d/content/examples/HumanoidAnimation/Skin/JoeKick.x3dv" rel="noreferrer" target="_blank">https://www.web3d.org/x3d/content/examples/HumanoidAnimation/Skin/JoeKick.x3dv</a><br>
>> > >><br>
>> > >><br>
>> > >><br>
>> > >> Unfortunately I discovered that a lot of type checking within that stylesheet isn’t really effective due to a puzzling logic error, so there may well be other errors like this.  More work will likely be needed.<br>
>> > >><br>
>> > >><br>
>> > >><br>
>> > >> Wondering if you have a command-line mode for validating VRML/ClassicVRML models with view3dscene?  Perhaps I might be able to add that to our regression testing build scripts.<br>
>> > >><br>
>> > >><br>
>> > >><br>
>> > >> 2. Joe, it's your model, so please send any texture coordinate changes you may have and I will update the .x3d model in the archives.<br>
>> > >><br>
>> > >><br>
>> > >><br>
>> > >> <a href="https://www.web3d.org/x3d/content/examples/HumanoidAnimation/Skin/JoeKickIndex.html" rel="noreferrer" target="_blank">https://www.web3d.org/x3d/content/examples/HumanoidAnimation/Skin/JoeKickIndex.html</a><br>
>> > >> <a href="https://www.web3d.org/x3d/content/examples/HumanoidAnimation/Skin/JoeKick.x3d" rel="noreferrer" target="_blank">https://www.web3d.org/x3d/content/examples/HumanoidAnimation/Skin/JoeKick.x3d</a><br>
>> > >><br>
>> > >><br>
>> > >><br>
>> > >> Meanwhile there are plenty of warnings from Schematron.  They seem accurate.  The flagged parent-child relationships are either a problem in the model, or else (less likely) a problem in the diagnostics (which are autogenerated from X3DUOM).<br>
>> > >><br>
>> > >><br>
>> > >><br>
>> > >> I thought that possibly they are related to your use of loa=’3’ complexity, but diagnostics looked the same for loa=’4’.<br>
>> > >><br>
>> > >><br>
>> > >><br>
>> > >><br>
>> > >><br>
>> > >> --------- X3D Validator checks commenced for JoeKick.x3d ---------<br>
>> > >><br>
>> > >><br>
>> > >><br>
>> > >> Performing well-formed XML check...<br>
>> > >><br>
>> > >> Checking file:/C:/x3d-code/<a href="http://www.web3d.org/x3d/content/examples/HumanoidAnimation/Skin/JoeKick.x3d." rel="noreferrer" target="_blank">www.web3d.org/x3d/content/examples/HumanoidAnimation/Skin/JoeKick.x3d.</a>..<br>
>> > >><br>
>> > >> Well-formed XML check: pass<br>
>> > >><br>
>> > >><br>
>> > >><br>
>> > >> Performing DOCTYPE check...<br>
>> > >><br>
>> > >> [X3dDoctypeChecker] success: valid XML declaration found.[X3dDoctypeChecker] success: final X3D 4.0 DOCTYPE found.<br>
>> > >><br>
>> > >><br>
>> > >><br>
>> > >> Performing DTD validation...<br>
>> > >><br>
>> > >> Checking file:/C:/x3d-code/<a href="http://www.web3d.org/x3d/content/examples/HumanoidAnimation/Skin/JoeKick.x3d." rel="noreferrer" target="_blank">www.web3d.org/x3d/content/examples/HumanoidAnimation/Skin/JoeKick.x3d.</a>..<br>
>> > >><br>
>> > >> XML DTD validation: pass<br>
>> > >><br>
>> > >><br>
>> > >><br>
>> > >> Performing X3D schema validation...<br>
>> > >><br>
>> > >> Checking file:/C:/x3d-code/<a href="http://www.web3d.org/x3d/content/examples/HumanoidAnimation/Skin/JoeKick.x3d." rel="noreferrer" target="_blank">www.web3d.org/x3d/content/examples/HumanoidAnimation/Skin/JoeKick.x3d.</a>..<br>
>> > >><br>
>> > >> Referenced entity at <a href="http://www.w3.org/TR/2002/REC-xmldsig-core-20020212/xmldsig-core-schema.xsd" rel="noreferrer" target="_blank">http://www.w3.org/TR/2002/REC-xmldsig-core-20020212/xmldsig-core-schema.xsd</a>.<br>
>> > >><br>
>> > >> Referenced entity at <a href="http://www.w3.org/2001/XMLSchema.dtd" rel="noreferrer" target="_blank">http://www.w3.org/2001/XMLSchema.dtd</a>.<br>
>> > >><br>
>> > >> Referenced entity at <a href="http://www.w3.org/2001/datatypes.dtd" rel="noreferrer" target="_blank">http://www.w3.org/2001/datatypes.dtd</a>.<br>
>> > >><br>
>> > >> XML schema validation: pass<br>
>> > >><br>
>> > >><br>
>> > >><br>
>> > >> Performing X3D regular expression (regex) values check...<br>
>> > >><br>
>> > >> X3D regex check: complete<br>
>> > >><br>
>> > >><br>
>> > >><br>
>> > >> Performing X3dToX3dvClassicVrmlEncoding.xslt conversion check...<br>
>> > >><br>
>> > >><br>
>> > >><br>
>> > >> Performing X3D Schematron check...<br>
>> > >><br>
>> > >> X3D version 4.0 is approved by Web3D Consortium and focused on interoperability with HTML5, glTF2.0 Physically Based Rendering (PBR) and Web Audio API, undergoing final administrative review by ISO in 2023. [/X3D, diagnostic]<br>
>> > >><br>
>> > >> <meta name='TODO' content='Record information about skin coordinates (found in comment at end of scene) as a structured MetadataSet containing MetadataString nodes'/> [/X3D/head/meta[7], diagnostic]<br>
>> > >><br>
>> > >> <HAnimHumanoid DEF='Joe_Kick' name='Kick'/> version='2.0' with X3D version='4.0' [/X3D/Scene/Group[1]/HAnimHumanoid, diagnostic]<br>
>> > >><br>
>> > >> ==================================================================================================================== [/X3D/Scene/Group[1]/HAnimHumanoid, diagnostic]<br>
>> > >><br>
>> > >> <HAnimHumanoid DEF='Joe_Kick' name='Kick'/> node count(HAnimJoint)           within skeleton hierarchy        = 94[/X3D/Scene/Group[1]/HAnimHumanoid, diagnostic]<br>
>> > >><br>
>> > >> <HAnimHumanoid DEF='Joe_Kick' name='Kick'/> node count(HAnimSegment)         within skeleton hierarchy        = 1[/X3D/Scene/Group[1]/HAnimHumanoid, diagnostic]<br>
>> > >><br>
>> > >> <HAnimHumanoid DEF='Joe_Kick' name='Kick'/> node count(HAnimSite)            within HAnimHumanoid             = 1[/X3D/Scene/Group[1]/HAnimHumanoid, diagnostic]<br>
>> > >><br>
>> > >> <HAnimHumanoid DEF='Joe_Kick' name='Kick'/> node count(HAnimSite//Viewpoint) within skeleton hierarchy        = 1[/X3D/Scene/Group[1]/HAnimHumanoid, diagnostic]<br>
>> > >><br>
>> > >> <HAnimHumanoid DEF='Joe_Kick' name='Kick'/> node count(HAnimDisplacer)       within skeleton hierarchy        = 1[/X3D/Scene/Group[1]/HAnimHumanoid, diagnostic]<br>
>> > >><br>
>> > >> <HAnimHumanoid DEF='Joe_Kick' name='Kick'/> node count(<HAnimJoint   USE='*' containerField = 'joints'/>)     = 94[/X3D/Scene/Group[1]/HAnimHumanoid, diagnostic]<br>
>> > >><br>
>> > >> <HAnimHumanoid DEF='Joe_Kick' name='Kick'/> node count(<HAnimSegment USE='*' containerField = 'segments'/>)   = 1[/X3D/Scene/Group[1]/HAnimHumanoid, diagnostic]<br>
>> > >><br>
>> > >> <HAnimHumanoid DEF='Joe_Kick' name='Kick'/> node count(<HAnimSite    USE='*' containerField = 'sites'/>)      = 1[/X3D/Scene/Group[1]/HAnimHumanoid, diagnostic]<br>
>> > >><br>
>> > >> <HAnimHumanoid DEF='Joe_Kick' name='Kick'/> node count(<HAnimSite    DEF='*' name ends with '_view'/>)        = 0[/X3D/Scene/Group[1]/HAnimHumanoid, diagnostic]<br>
>> > >><br>
>> > >> ==================================================================================================================== [/X3D/Scene/Group[1]/HAnimHumanoid, diagnostic]<br>
>> > >><br>
>> > >> <HAnimSite DEF='Joe_RootFront_view' name='RootFront_view'/> is not a recognized name for HAnim2 HAnimSite [/X3D/Scene/Group[1]/HAnimHumanoid/HAnimJoint[1]/HAnimSegment/HAnimSite, info]<br>
>> > >><br>
>> > >> <HAnimJoint DEF='Joe_l_tarsometatarsal_2' name='l_tarsometatarsal_2'/> has parent HAnimJoint name='l_talocrural' rather than expected parent name='l_cuneonavicular_2', recommend checking model [/X3D/Scene/Group[1]/HAnimHumanoid/HAnimJoint[1]/HAnimJoint[1]/HAnimJoint[1]/HAnimJoint/HAnimJoint/HAnimJoint, warning]<br>
>> > >><br>
>> > >> <HAnimJoint DEF='Joe_l_tarsal_distal_interphalangeal_2' name='l_tarsal_distal_interphalangeal_2'/> has parent HAnimJoint name='l_metatarsophalangeal_2' rather than expected parent name='l_tarsal_proximal_interphalangeal_2', recommend checking model [/X3D/Scene/Group[1]/HAnimHumanoid/HAnimJoint[1]/HAnimJoint[1]/HAnimJoint[1]/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint, warning]<br>
>> > >><br>
>> > >> <HAnimJoint DEF='Joe_r_tarsometatarsal_2' name='r_tarsometatarsal_2'/> has parent HAnimJoint name='r_talocrural' rather than expected parent name='r_cuneonavicular_2', recommend checking model [/X3D/Scene/Group[1]/HAnimHumanoid/HAnimJoint[1]/HAnimJoint[1]/HAnimJoint[2]/HAnimJoint/HAnimJoint/HAnimJoint, warning]<br>
>> > >><br>
>> > >> <HAnimJoint DEF='Joe_r_tarsal_distal_interphalangeal_2' name='r_tarsal_distal_interphalangeal_2'/> has parent HAnimJoint name='r_metatarsophalangeal_2' rather than expected parent name='r_tarsal_proximal_interphalangeal_2', recommend checking model [/X3D/Scene/Group[1]/HAnimHumanoid/HAnimJoint[1]/HAnimJoint[1]/HAnimJoint[2]/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint, warning]<br>
>> > >><br>
>> > >> <HAnimJoint DEF='Joe_l_acromioclavicular'/> name field is required [/X3D/Scene/Group[1]/HAnimHumanoid/HAnimJoint[1]/HAnimJoint[2]/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint[2], error]<br>
>> > >><br>
>> > >> <HAnimJoint DEF='Joe_l_acromioclavicular' name=''/> is not a recognized name for HAnim2 HAnimJoint [/X3D/Scene/Group[1]/HAnimHumanoid/HAnimJoint[1]/HAnimJoint[2]/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint[2], warning]<br>
>> > >><br>
>> > >> <HAnimJoint DEF='Joe_l_sternoclavicular' name='l_acromioclavicular'/> DEF value does not contain correctly modified version of name value (for example, DEF='myPrefix_nameValue' e.g. DEF='myPrefix_l_acromioclavicular') - see HAnim section C.2 Humanoid, VRML Binding [/X3D/Scene/Group[1]/HAnimHumanoid/HAnimJoint[1]/HAnimJoint[2]/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint[2]/HAnimJoint, error]<br>
>> > >><br>
>> > >> <HAnimJoint DEF='Joe_l_sternoclavicular' name='l_acromioclavicular'/> has parent HAnimJoint name='' rather than expected parent name='l_sternoclavicular', recommend checking model [/X3D/Scene/Group[1]/HAnimHumanoid/HAnimJoint[1]/HAnimJoint[2]/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint[2]/HAnimJoint, warning]<br>
>> > >><br>
>> > >> <HAnimJoint DEF='Joe_l_carpometacarpal_1' name='l_carpometacarpal_1'/> has parent HAnimJoint name='l_radiocarpal' rather than expected parent name='l_midcarpal_1', recommend checking model [/X3D/Scene/Group[1]/HAnimHumanoid/HAnimJoint[1]/HAnimJoint[2]/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint[2]/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint[1], warning]<br>
>> > >><br>
>> > >> <HAnimJoint DEF='Joe_l_carpometacarpal_2' name='l_carpometacarpal_2'/> has parent HAnimJoint name='l_radiocarpal' rather than expected parent name='l_midcarpal_2', recommend checking model [/X3D/Scene/Group[1]/HAnimHumanoid/HAnimJoint[1]/HAnimJoint[2]/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint[2]/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint[2], warning]<br>
>> > >><br>
>> > >> <HAnimJoint DEF='Joe_l_carpometacarpal_3' name='l_carpometacarpal_3'/> has parent HAnimJoint name='l_radiocarpal' rather than expected parent name='l_midcarpal_3', recommend checking model [/X3D/Scene/Group[1]/HAnimHumanoid/HAnimJoint[1]/HAnimJoint[2]/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint[2]/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint[3], warning]<br>
>> > >><br>
>> > >> <HAnimJoint DEF='Joe_l_carpometacarpal_4' name='l_carpometacarpal_4'/> has parent HAnimJoint name='l_radiocarpal' rather than expected parent name='l_midcarpal_4_5', recommend checking model [/X3D/Scene/Group[1]/HAnimHumanoid/HAnimJoint[1]/HAnimJoint[2]/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint[2]/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint[4], warning]<br>
>> > >><br>
>> > >> <HAnimJoint DEF='Joe_l_carpometacarpal_5' name='l_carpometacarpal_5'/> has parent HAnimJoint name='l_radiocarpal' rather than expected parent name='l_midcarpal_4_5', recommend checking model [/X3D/Scene/Group[1]/HAnimHumanoid/HAnimJoint[1]/HAnimJoint[2]/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint[2]/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint[5], warning]<br>
>> > >><br>
>> > >> <HAnimJoint DEF='Joe_r_carpometacarpal_1' name='r_carpometacarpal_1'/> has parent HAnimJoint name='r_radiocarpal' rather than expected parent name='r_midcarpal_1', recommend checking model [/X3D/Scene/Group[1]/HAnimHumanoid/HAnimJoint[1]/HAnimJoint[2]/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint[3]/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint[1], warning]<br>
>> > >><br>
>> > >> <HAnimJoint DEF='Joe_r_carpometacarpal_2' name='r_carpometacarpal_2'/> has parent HAnimJoint name='r_radiocarpal' rather than expected parent name='r_midcarpal_2', recommend checking model [/X3D/Scene/Group[1]/HAnimHumanoid/HAnimJoint[1]/HAnimJoint[2]/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint[3]/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint[2], warning]<br>
>> > >><br>
>> > >> <HAnimJoint DEF='Joe_r_carpometacarpal_3' name='r_carpometacarpal_3'/> has parent HAnimJoint name='r_radiocarpal' rather than expected parent name='r_midcarpal_3', recommend checking model [/X3D/Scene/Group[1]/HAnimHumanoid/HAnimJoint[1]/HAnimJoint[2]/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint[3]/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint[3], warning]<br>
>> > >><br>
>> > >> <HAnimJoint DEF='Joe_r_carpometacarpal_4' name='r_carpometacarpal_4'/> has parent HAnimJoint name='r_radiocarpal' rather than expected parent name='r_midcarpal_4_5', recommend checking model [/X3D/Scene/Group[1]/HAnimHumanoid/HAnimJoint[1]/HAnimJoint[2]/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint[3]/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint[4], warning]<br>
>> > >><br>
>> > >> <HAnimJoint DEF='Joe_r_carpometacarpal_5' name='r_carpometacarpal_5'/> has parent HAnimJoint name='r_radiocarpal' rather than expected parent name='r_midcarpal_4_5', recommend checking model [/X3D/Scene/Group[1]/HAnimHumanoid/HAnimJoint[1]/HAnimJoint[2]/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint[3]/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint/HAnimJoint[5], warning]<br>
>> > >><br>
>> > >><br>
>> > >><br>
>> > >> --------- X3D Validator checks complete for JoeKick.x3d ---------<br>
>> > >><br>
>> > >><br>
>> > >><br>
>> > >><br>
>> > >><br>
>> > >> all the best, Don<br>
>> > >><br>
>> > >> --<br>
>> > >><br>
>> > >> Don Brutzman  Naval Postgraduate School, Code USW/Br        <a href="mailto:brutzman@nps.edu" target="_blank">brutzman@nps.edu</a><br>
>> > >><br>
>> > >> Watkins 270,  MOVES Institute, Monterey CA 93943-5000 USA    +1.831.656.2149<br>
>> > >><br>
>> > >> X3D graphics, virtual worlds, navy robotics <a href="https://faculty.nps.edu/brutzman" rel="noreferrer" target="_blank">https://faculty.nps.edu/brutzman</a><br>
>> > >><br>
>> > >><br>
>> > >><br>
>> > >> -----Original Message-----<br>
>> > >> From: x3d-public <<a href="mailto:x3d-public-bounces@web3d.org" target="_blank">x3d-public-bounces@web3d.org</a>> On Behalf Of Michalis Kamburelis<br>
>> > >> Sent: Sunday, July 23, 2023 1:44 PM<br>
>> > >> To: X3D Graphics public mailing list <<a href="mailto:x3d-public@web3d.org" target="_blank">x3d-public@web3d.org</a>><br>
>> > >> Subject: [x3d-public] JoeKick H-Anim example - error in X3D classic encoding<br>
>> > >><br>
>> > >><br>
>> > >><br>
>> > >> "Joe Kick" example linked from<br>
>> > >><br>
>> > >> <a href="https://www.web3d.org/x3d/content/examples/HumanoidAnimation/" rel="noreferrer" target="_blank">https://www.web3d.org/x3d/content/examples/HumanoidAnimation/</a> , <a href="https://www.web3d.org/x3d/content/examples/HumanoidAnimation/Skin/JoeKickIndex.html" rel="noreferrer" target="_blank">https://www.web3d.org/x3d/content/examples/HumanoidAnimation/Skin/JoeKickIndex.html</a><br>
>> > >><br>
>> > >> , 2 errors:<br>
>> > >><br>
>> > >><br>
>> > >><br>
>> > >> 1. The "ClassicVRML" encoding version (<br>
>> > >><br>
>> > >> <a href="https://www.web3d.org/x3d/content/examples/HumanoidAnimation/Skin/JoeKick.x3dv" rel="noreferrer" target="_blank">https://www.web3d.org/x3d/content/examples/HumanoidAnimation/Skin/JoeKick.x3dv</a><br>
>> > >><br>
>> > >> ) seems to be incorrectly converted from XML to classic encoding. It contains<br>
>> > >><br>
>> > >><br>
>> > >><br>
>> > >> """<br>
>> > >><br>
>> > >> DEF Joe_skull_tip_raiser_action HAnimDisplacer { coordIndex 0 1 2 3 4 5 6 7 8 9 displacements 0 0.15 0 0 ...<br>
>> > >><br>
>> > >> name "skull_tip_raiser_action"<br>
>> > >><br>
>> > >> }<br>
>> > >><br>
>> > >> """<br>
>> > >><br>
>> > >><br>
>> > >><br>
>> > >> so the coordIndex and displacements fields miss [ ] around their values.<br>
>> > >><br>
>> > >><br>
>> > >><br>
>> > >> "coordIndex" is MFInt32, "displacements" is MFVec3f, they both require [ ] in classic encoding if you want to have a list of arbitrary number of elements. If no [ ] are used, the classic encoding parsers have to assume they contain 1 item (1 integer on "coordIndex", 1 vector == 3 floats on "displacements"). Currently parsing this fails, as parser sees unexpected numbers in the middle of HAnimDisplacer.<br>
>> > >><br>
>> > >><br>
>> > >><br>
>> > >> This problem is not present in XML encoding, where no [ ] are used, the lists are in separate XML attributes.<br>
>> > >><br>
>> > >><br>
>> > >><br>
>> > >> 2. The XML encoding version contains invalid number of texture coordinates, we have discussed in previously on this list:<br>
>> > >><br>
>> > >><br>
>> > >><br>
>> > >> X3D: Invalid number of items in an attribute array for shape<br>
>> > >><br>
>> > >> "Joe_Humanoid/Joe_Kick/Joe_Shape/IndexedFaceSet(Joe_skin_IndexedFaceSet)":<br>
>> > >><br>
>> > >> Invalid index: 9, but we have 4 items in 2D texture coordinates<br>
>> > >><br>
>> > >><br>
>> > >><br>
>> > >> Regards,<br>
>> > >><br>
>> > >> Michalis<br>
>> > >><br>
>> > >><br>
>> > >><br>
>> > >> _______________________________________________<br>
>> > >><br>
>> > >> x3d-public mailing list<br>
>> > >><br>
>> > >> <a href="mailto:x3d-public@web3d.org" target="_blank">x3d-public@web3d.org</a><br>
>> > >><br>
>> > >> <a href="http://web3d.org/mailman/listinfo/x3d-public_web3d.org" rel="noreferrer" target="_blank">http://web3d.org/mailman/listinfo/x3d-public_web3d.org</a><br>
>> > >><br>
>> > >> _______________________________________________<br>
>> > >> x3d-public mailing list<br>
>> > >> <a href="mailto:x3d-public@web3d.org" target="_blank">x3d-public@web3d.org</a><br>
>> > >> <a href="http://web3d.org/mailman/listinfo/x3d-public_web3d.org" rel="noreferrer" target="_blank">http://web3d.org/mailman/listinfo/x3d-public_web3d.org</a><br>
</blockquote></div>