<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>Please see inline remarks.</p><p class=MsoNormal>Thanks, </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><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>Saturday, May 19, 2018 6:54 AM<br><b>To: </b><a href="mailto:Leonard.Daly@realism.com">Leonard Daly</a>; <a href="mailto:h-anim@web3d.org">Humanoid Animation (H-Anim) Working Group</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] [x3d] Spec Comment by on 19774-1: H-AnimArchitecture - V1.0</p></div><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Forwarded to HAnim Working Group for consideration. Thanks for your review and these comments.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>On 5/17/2018 10:00 PM, Spec Feedback wrote:</p><p class=MsoNormal>> -- Submitter indicates that this comment may be public: *Yes* --</p><p class=MsoNormal>> </p><p class=MsoNormal>> Comment on 19774-1: H-Anim Architecture - V1.0</p><p class=MsoNormal>> All sections</p><p class=MsoNormal>> </p><p class=MsoNormal>> </p><p class=MsoNormal>> -----------------</p><p class=MsoNormal>> These comments were collected from the entire specification document. They</p><p class=MsoNormal>> are divided into 2 sections - General and Specific. Each numbered item is a</p><p class=MsoNormal>> separate comment.</p><p class=MsoNormal>> </p><p class=MsoNormal>> </p><p class=MsoNormal>> General Comments</p><p class=MsoNormal>> </p><p class=MsoNormal>> 1: The fonts for the fixed-width text elements appear to be significantly</p><p class=MsoNormal>> smaller than that surroiuding text. For eample see 4.2.3</p><p class=MsoNormal>> 2: The text appears to be responsive (viewable in a variety of browser</p><p class=MsoNormal>> widths); however, this was not confirmed using multiple devices. The images</p><p class=MsoNormal>> are not responsive, either by rearranging multiple images across the page or</p><p class=MsoNormal>> reducing the size of the image. This may not be a desired feature of the</p><p class=MsoNormal>> document, but should be mentioned.</p><p class=MsoNormal>> 3: This document does not define industry-standard practice, </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>It comepletly docoments industry-standard practices. </p><p class=MsoNormal>The ‘standard’ type data structures for this skeleton-based animation are the same as used in every one of the multiple character animation systems in use. The data structures are transportagble to all the oldest and the latest. In some case, data like rotations are ‘industry-standard’ notations are 0010 instead of 1000 but that is an HAnim opportunity, not a departure from ’industry-standard’ ways to animate. This is shown in the built-in and demonstrated capability for data from an ‘industry-standard’ mocap animation data to be directly used in HAnim ‘standard’ character. </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Basically, anyone who says HAnim is not the same as current systems for the basic hierarchy and animation capabilities has not looked under the covers. </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>For hecks-sake, When you into any modelling system and ask for the basic biped, you get what is preactivcally almost an LOA2 like HAnim Annex A and can find skins and yes even export to HAnim. Really, the backup for this idea that X3D HAnim is not a comprehensive and human-readable and executable form of ‘industry-standard’ skeleton-based character animation styles has not tried to discover the hidden forms and structures in the oldest and the newest character animation authoring systems. </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>> but either</p><p class=MsoNormal>> defines a separate means or a more general means of h-anim design. </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Yes, it is the most general means of documenting the structures and the data required for hanim design. </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>> This extends from concepts (individual components vs. single mesh skin) </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>HAnim does either or both, with the same data used by any character authoring system. Namely space-time and coordinates of important features like like joints, sites, and geometry. </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>When anyone looks into this they will be very pleased to find that segment, or bone, orientation is the same as joint rotation. They would be happy to find that when the data in some authoring or execution system is the same as documented in x3D HAnim. </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>> terminology. </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>(For example, rigging is defined in section 3, but never used in</p><p class=MsoNormal>> section 4.) As a result the document is not easy to read or comprehed for</p><p class=MsoNormal>> someone use to industry-style humanoid anmiation.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>The spec does not teach whatever category of ‘rigging’ you are concerned with. The ‘rigging’ is obvious: make skeleton hierarchy then bind ‘skin’ vertices and weight joint interactions with individual vertices. If anyone looks at most any authoring system this is the same data they use. </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>It gets easier when you understand ‘industry standard’ for humanoid animation. It is easy to be involved in industry standard skeletal animation while seeing it from behind a dashboard that hides some of the interfaces with the data. </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Look deep enough to see that HAnim truly captures the basics of it all. Most any authoring system may have variations. For example the system may allow definition of a non-linear interpolation of the deformable skin instead of HAnim any specifies linear. And have features extending the HAnim basic capablilities. But look close and you will find the same skeleton, geometries, and means to animate. </p><p class=MsoNormal> </p><p class=MsoNormal>All general use models are based on a hierarchy of joints and segments (bones). Motion is achieved by hierarchal rotation of individual joints, or by translation/rotation of the humanoid root joint. Either individual geometries are children of the segments in which case the geometry is animated by rotation of the parent joint , or a skin is constructed to be a child of the humanoid and individual vertices of the skin are animated by a weighted displacement that depends on the rotation of specified joints.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>That is all there is. If you study various authoring systems, some names are different but these are the basics. </p><p class=MsoNormal> </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>> a: For reference, industry-style process requires a single-mesh skin that</p><p class=MsoNormal>> is then rigged (skeleton creation with skin weighted-attachment to bones).</p><p class=MsoNormal>> “Bones” are used more frequently than “joints”, but both terms are</p><p class=MsoNormal>> understood.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Joints are not bones. Joints are joints and segments are bones. Please notice that the industry-style process using a single mesh skin with weighted attachments between associated joints for each vertex. The way that HAnim does it is exactly the same. Look in different authoring systems and you will find the name data underneath the covers. </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>> b: For rendering purposes, skin vertices are generally restricted to being</p><p class=MsoNormal>> weighted to no more than 4 joints. This is not a hard requirement, but based</p><p class=MsoNormal>> on practicality and performance, especially real-time performance.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Yes, ok. It just happens to be a bit more ‘efficient’ for typical processors to always use 4 joints/vertex bindings even if some are zero due to processor/GPU specs. Some may try to bind 8 if it ends up rendering faster. </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>> 4: For a document that is labeld “Humanoid Animation”, there is very</p><p class=MsoNormal>> little (and perhaps no) discussion of animatation techniques of how the skin</p><p class=MsoNormal>> is animated based on joint motion. </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Wow, please read the part about how the ‘skin’ vertices are bound to the joints by index and weight. You may find another system that appears to bind the skin to the segments, but again, look under the covers. But again, the objective is not to teach this prat of the ‘rigging’ but instead to document the data structures and parameters that document the skin binding and animation. </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>> 19774-2 (minimally reviewed) appears to</p><p class=MsoNormal>> relate how to relate motion capture to joint animation of H-Anim characters.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>The spec is not a tutorial for prospective animators, it is spec for the HAnim interfaces with some examples. </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>> </p><p class=MsoNormal>> Specific Comments</p><p class=MsoNormal>> 1: It is not clear from the text in 4.2.3 exactly what is required. The</p><p class=MsoNormal>> paragraph states both of the items below. It is not clear if a skeletal</p><p class=MsoNormal>> structure that meets (b), but uses something else besides a joint object to</p><p class=MsoNormal>> the end effector of each appendage qualifies as a H-Anim compliant figure.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>The end-effector is called a Site. It is a child of a Segment. For the appendages, fingers and toes, the last (distal) segment is parent of a Site that indicates the end of the segment. All other segments in the skeleton have at one joint at each end.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>> a: “The skeletal description of the H-Anim figure consists of a tree of</p><p class=MsoNormal>> Joint objects that define the transformations from the humanoid_root Joint to</p><p class=MsoNormal>> the end effector of each appendage of the humanoid.”</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Right, we see a very detailed example in Annex A. We define the skeleton using a root joint and joint centers. </p><p class=MsoNormal>Annex A shows the transformations from 0 0 0 (between the feet) in a human scale. </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>> b: “The only requirement of this International Standard for the</p><p class=MsoNormal>> definition of the skeletal hierarchy is that it shall have a humanoid_root</p><p class=MsoNormal>> Joint object defined. All of the other Joint objects are optional and are not</p><p class=MsoNormal>> required for a humanoid figure to be H-Anim compliant.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Right, LOA0 only has the root joint along with the segment to parent other features such as site objects. </p><p class=MsoNormal> </p><p class=MsoNormal>> 2: It is not clear if the LOAs and other skeletal definitions are normative</p><p class=MsoNormal>> or not. There is material in the early part of Section 4 that state or imply</p><p class=MsoNormal>> that they are optional or not even relevant (for non-human like figures);</p><p class=MsoNormal>> then later in the section (especially when skeletalConfiguration is</p><p class=MsoNormal>> “Basic”) that the definitions are required. The text needs to be</p><p class=MsoNormal>> rewritten to make these distinctions clearer.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>I think in this spec there should be no doubt that this is for a ‘standard’ humanoid. </p><p class=MsoNormal>The ‘standard’ humanoid must have one of the given hierarchies. </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>This is so that animations for a given hierarchy, or higher or even lower, can be used directly with any ‘standard’ skeleton. Transporting animations is the important part</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>> 3: Section 4.8.1, 3rd paragraph defines what it means for two skeletons to be</p><p class=MsoNormal>> of the same configuration without defining what “identical” means. </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Identical means similar and compatible in order to transport animations.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Identical, maybe not the best word, refers to the hierarchy and the loa. The actual dimensions of the skeleton matter, but if the hierarchy is ‘standard’ then the animation is mostly transportable. </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Suggesting that someone building a character might start designing it using human-scale stuffs is ok by me even though a statement like this would certainly not be absolutely needed in a ‘standard’ describing the exact documentation and runtime needed for humanoid character modeling. </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>> Does</p><p class=MsoNormal>> identical mean that all of the transforms are the same? </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>No.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>> Is a reclining figure</p><p class=MsoNormal>> in the standard pose the same as one arranged on its head? </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>For easy import of animations it is best if the initial pose (all joints 0 0 1 0) is the recommended ‘semi-attention’ pose described in the standard. If the base pose for animation is different, then the animation data will probably not produce the desired result. It may be possible to adjust the animation data for different initial pose but it may be hard to do. That is why, for transporting animations, HAnim defines an initial pose. Any skeleton model in any animation system can be set the initial pose then ‘zero’ the thing (all joints 0010). </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>> Does scaling matter? </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Yes it can if it doesn’t match other humanoids. In detail, the skin can be scaled to the ‘standard’ humanoid configuration, or even vise-versa. But why not follow a standard that offers transportable animations? </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>> If the idea is that two skeletons are identical if all transforms</p><p class=MsoNormal>> from the root node are the same, then that should be stated more clearly.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Please understand that each humanoid model can have realistic or comic dimensions, meaning joint center locations. This allows anyone to build an dimensionally accurate model of, well, even themselves. If they use a ‘standard’ loa then animations is other similar characters can be reused. </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>> 4: Section 4.8.4 appears to meet the requirements of 4.8.2 and not 4.8.3. It</p><p class=MsoNormal>> should be a sub-clause of 4.8.2 as it pertains specifically to human-like</p><p class=MsoNormal>> figures. If not moved to a sub-clause, it needs to be made clear in 4.8.2 and</p><p class=MsoNormal>> 4.8.4 that these sections only apply to human-like.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Actually any skeleton-based character can be created. </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>> 5: Section 4.9 also appears to apply specifically to human-like figures.</p><p class=MsoNormal>> There is no obvious statement about the connection and cross-requirements</p><p class=MsoNormal>> with this section.</p><p class=MsoNormal>> 6: Section 4.9.5 (and probably others) refers to facial anomation by</p><p class=MsoNormal>> animation of joints to move facial features. There is no discussion of the</p><p class=MsoNormal>> (not exclusive) industry standard of using morph targets to handle facial</p><p class=MsoNormal>> expression changes and combinations.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Please understand that skin bound to the joints is primary, like for when you move the jaw, then you move the associated skin. There is a ‘joint’ for the eyebrows but an author may wish to use morph targets, or a combination of joint-driven and morph targets to get the effect. There is not much doubt that an author would rather base eyelid movement on a joint motion than a morph target (unless the authoring system makes it easy) but most would use both – the joint to get the basic motion, then a morph target for detail. </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Next, please understand how the HAnim Displacer is comparable to Morph targets. Look under the covers and you will see the same data used for the same thing. </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>> 7: Section 4.9.8 appears to conflict with statements made in section 4.2.3.</p><p class=MsoNormal>> This conflict needs to be removed or clarified that certain restrictions only</p><p class=MsoNormal>> apply to certain kinds of models.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Thanks, the group can look more closely at that. </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>> a: 4.2.3: “This hierarchy may include any number of optional model</p><p class=MsoNormal>> specific Joint objects, which may be dispersed among the standard H-Anim</p><p class=MsoNormal>> Joint objects. As long as the ancestral ordering of the standard Joint</p><p class=MsoNormal>> objects is preserved, model specific Joint objects may be inserted between</p><p class=MsoNormal>> the standard Joint objects in the hierarchy.”</p><p class=MsoNormal>> b: 4.9.8: “No new Joint objects are allowed within the chain of the</p><p class=MsoNormal>> standard Joint hierarchy. These non-standard Joint objects may be children of</p><p class=MsoNormal>> either standard Joint objects or other non-standard Joint objects.”</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Good, that is a common understanding. The idea is that you can add stuff as long as the additions do not interfere with a standard animation. The idea here is that an author might use a special joint that moves to show a detail, like muscle covering skin displacements, but this addition should not interfere with the ‘standard’ hierarchy of the arm, for instance. This wording should be improved but and implementer will basically understand and this is mainly guidance for the author in constructing a ‘standard’ very transportable humanoid.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>> 8: Section 7.3 specifies the minimum support requirements for VRML/X3D. It is</p><p class=MsoNormal>> not clear why X3D nodes not related to creating (e.g., IFS), positioning</p><p class=MsoNormal>> (e.g., Transform), or texturing (e.g., TextureTransform) models are included;</p><p class=MsoNormal>> especially in light of Section 7.4 that only requires the above three</p><p class=MsoNormal>> capabilities plus a viewing requirement. For example, there is no requirement</p><p class=MsoNormal>> in section 7.4 for lighting, navigation, or general information.</p><p class=MsoNormal>> Suggest fix: Define the general requirements first, then indicate the minimum</p><p class=MsoNormal>> VRML/X3D requirements, and lastly the recommended capabilities.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>OK, that seems reasonable. </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>> 9: Annex F is listed as informative; however, the first sentence of F.2</p><p class=MsoNormal>> indicates that certain things shall be done. Earlier in the document it was</p><p class=MsoNormal>> indicated that the various LOA definitions only applied to human-like</p><p class=MsoNormal>> cahracters. The intent of this section needs to be determine and the text and</p><p class=MsoNormal>> perhaps other places in the document needs to be made consistent.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Yes. </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>> 10: The industry-style for creating animated characters is to model the skin</p><p class=MsoNormal>> first, then rig it (create the skeleton and assign skin vertex weights). This</p><p class=MsoNormal>> is not the process described in Annex F. It should be made clear that this is</p><p class=MsoNormal>> different from industry and educatuional practice for US-style animation.</p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Not so true, I think. Maybe the first thing the commercials wan to sell you is a skin, then texture it, then you find out you need a skeleton to animate it unless you want to morph everything. You will find it best to work by defining your skeleton first. I say pick the LOA4 because it is ok to have joint you don’t animate, learn how to operate it, then figure out what skin, at what density of vertices, you really need to do realtime interactions. </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>There are several items that make it hard to understand character animation. X3D HAnim interfaces give you the keys to the vault. And, it’s just like the big guys do it but don’t show you it, and don’t be too shocked, it is the ‘same’ data used by the latest and greatest forms to transport data and it is designed for readability (relative to most commercial authortime/runtime). </p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Thanks and Best, </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>> </p><p class=MsoNormal>> -----------------</p><p class=MsoNormal>> </p><p class=MsoNormal>> Submitted on Thursday, 2018, May 17 - 10:00pm</p><p class=MsoNormal>> by (Leonard Daly )</p><p class=MsoNormal>> IP: 174.237.6.109</p><p class=MsoNormal>> </p><p class=MsoNormal>> See: http://www.web3d.org/node/1694/submission/2675</p><p class=MsoNormal>> </p><p class=MsoNormal>> </p><p class=MsoNormal>> _______________________________________________</p><p class=MsoNormal>> x3d mailing list</p><p class=MsoNormal>> x3d@web3d.org</p><p class=MsoNormal>> http://web3d.org/mailman/listinfo/x3d_web3d.org</p><p class=MsoNormal><o:p> </o:p></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><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>_______________________________________________</p><p class=MsoNormal>x3d-public mailing list</p><p class=MsoNormal>x3d-public@web3d.org</p><p class=MsoNormal>http://web3d.org/mailman/listinfo/x3d-public_web3d.org</p><p class=MsoNormal><o:p> </o:p></p></div></body></html>