<div dir="ltr">Don,<div><br>I don't understand why for Script fields, while some SFVec* values have brackets [] and some do not.</div><div><br></div><div>Particularly 5.17 and 5.21.</div><div><br></div><div>The script in 5.22 just looks wrong, not enough numbers, and a difference of no brackets.</div><div><br></div><div>If 5.17, 5.21 and 5.22 all agreed on SFVec*, that would be great.</div><div><br></div><div>I'm not sure if SFVec* should have brackets or not in VRML, that's for the implementers to decide.</div><div><br></div><div>John</div></div><br><div class="gmail_quote gmail_quote_container"><div dir="ltr" class="gmail_attr">On Mon, Dec 23, 2024 at 7:19 PM Brutzman, Donald (Don) (CIV) via x3d-public <<a href="mailto:x3d-public@web3d.org">x3d-public@web3d.org</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"><div class="msg73646704836422047">
<div dir="ltr">
<div style="font-family:Aptos,Aptos_EmbeddedFont,Aptos_MSFontService,Calibri,Helvetica,sans-serif;font-size:11pt;color:rgb(0,0,0)">
It took several days of effort but this clause is now fixed up.  Review and comments welcome.</div>
<ul style="list-style-type:disc">
<li style="font-family:Aptos,Aptos_EmbeddedFont,Aptos_MSFontService,Calibri,Helvetica,sans-serif;font-size:11pt;color:rgb(0,0,0)">
<div>Mantis 1484: ClassicVRML Encoding of Fields clause does not include proper SFVec examples</div>
</li><li style="font-family:Aptos,Aptos_EmbeddedFont,Aptos_MSFontService,Calibri,Helvetica,sans-serif;font-size:11pt;color:rgb(0,0,0)">
<div><a href="https://mantis.web3d.org/view.php?id=1484" target="_blank">https://mantis.web3d.org/view.php?id=1484</a></div>
<div style="font-family:Aptos,Aptos_EmbeddedFont,Aptos_MSFontService,Calibri,Helvetica,sans-serif;font-size:11pt;color:rgb(0,0,0)">
<div><br>
</div>
</div>
</li><li style="font-family:Aptos,Aptos_EmbeddedFont,Aptos_MSFontService,Calibri,Helvetica,sans-serif;font-size:11pt;color:rgb(0,0,0)">
<div>X3D encodings Part 2: Classic VRML encoding, 5 Encoding of fields</div>
</li><li style="font-family:Aptos,Aptos_EmbeddedFont,Aptos_MSFontService,Calibri,Helvetica,sans-serif;font-size:11pt;color:rgb(0,0,0)">
<div><a href="https://www.web3d.org/specifications/X3Dv4Draft/ISO-IEC19776-2v4.0-WD1/Part02/EncodingOfFields.html" target="_blank">https://www.web3d.org/specifications/X3Dv4Draft/ISO-IEC19776-2v4.0-WD1/Part02/EncodingOfFields.html</a></div>
</li></ul>
<div style="font-family:Aptos,Aptos_EmbeddedFont,Aptos_MSFontService,Calibri,Helvetica,sans-serif;font-size:11pt;color:rgb(0,0,0)">
Happy holidays with X3D and VRML!  🙂</div>
<div id="m_73646704836422047Signature">
<p style="margin:0in;font-family:Calibri,sans-serif;font-size:11pt"><span style="font-family:"Courier New";font-size:9pt"><br>
</span></p>
<p style="margin:0in;font-family:Calibri,sans-serif;font-size:11pt"><span style="font-family:"Courier New";font-size:9pt">all the best, Don</span></p>
<p style="margin:0in;font-family:Calibri,sans-serif;font-size:11pt"><span style="font-family:"Courier New";font-size:9pt">--</span></p>
<p style="margin:0in;font-family:Calibri,sans-serif;font-size:11pt"><span style="font-family:"Courier New";font-size:9pt">Don Brutzman  Naval Postgraduate School, Code USW/Br        <a href="mailto:brutzman@nps.edu" target="_blank">brutzman@nps.edu</a></span></p>
<p style="margin:0in;font-family:Calibri,sans-serif;font-size:11pt"><span style="font-family:"Courier New";font-size:9pt">Watkins 270,  MOVES Institute, Monterey CA 93943-5000 USA    +1.831.656.2149</span></p>
<p style="margin:0in;font-family:Calibri,sans-serif;font-size:11pt"><span style="font-family:"Courier New";font-size:9pt">X3D graphics, virtual worlds, navy robotics <a href="https://faculty.nps.edu/brutzman" target="_blank">https://faculty.nps.edu/brutzman</a></span></p>
<p style="margin:0in;font-family:Calibri,sans-serif;font-size:11pt"><span style="font-family:"Courier New";font-size:9pt"> </span></p>
</div>
<div id="m_73646704836422047appendonsend"></div>
<div style="font-family:Aptos,Aptos_EmbeddedFont,Aptos_MSFontService,Calibri,Helvetica,sans-serif;font-size:11pt;color:rgb(0,0,0)">
<br>
</div>
<hr style="display:inline-block;width:98%">
<div dir="ltr" id="m_73646704836422047divRplyFwdMsg"><span style="font-family:Calibri,sans-serif;font-size:11pt;color:rgb(0,0,0)"><b>From:</b> x3d-public <<a href="mailto:x3d-public-bounces@web3d.org" target="_blank">x3d-public-bounces@web3d.org</a>> on behalf of Brutzman, Donald (Don) (CIV) via x3d-public <<a href="mailto:x3d-public@web3d.org" target="_blank">x3d-public@web3d.org</a>><br>
<b>Sent:</b> Thursday, December 19, 2024 10:43 AM<br>
<b>To:</b> Michalis Kamburelis <<a href="mailto:michalis.kambi@gmail.com" target="_blank">michalis.kambi@gmail.com</a>><br>
<b>Cc:</b> Brutzman, Donald (Don) (CIV) <<a href="mailto:brutzman@nps.edu" target="_blank">brutzman@nps.edu</a>>; Extensible 3D (X3D) Graphics public discussion <<a href="mailto:x3d-public@web3d.org" target="_blank">x3d-public@web3d.org</a>>; <a href="mailto:khyoo@chungbuk.ac.kr" target="_blank">khyoo@chungbuk.ac.kr</a> <<a href="mailto:khyoo@chungbuk.ac.kr" target="_blank">khyoo@chungbuk.ac.kr</a>>; Myeong Won Lee <<a href="mailto:myeongwonlee@gmail.com" target="_blank">myeongwonlee@gmail.com</a>><br>
<b>Subject:</b> Re: [x3d-public] X3D 4.0 specification problem: ClassicVRML Encoding, clause 5 Encoding of fields</span>
<div> </div>
</div>
<div style="direction:ltr;font-family:Aptos,Aptos_EmbeddedFont,Aptos_MSFontService,Calibri,Helvetica,sans-serif;font-size:11pt;color:rgb(0,0,0)">
[changed subject line to reflect changed focus]</div>
<div style="direction:ltr;font-family:Aptos,Aptos_EmbeddedFont,Aptos_MSFontService,Calibri,Helvetica,sans-serif;font-size:11pt;color:rgb(0,0,0)">
<br>
</div>
<div style="direction:ltr;font-family:Aptos,Aptos_EmbeddedFont,Aptos_MSFontService,Calibri,Helvetica,sans-serif;font-size:11pt;color:rgb(0,0,0)">
Thanks again for your patient explanations Michalis, totally helpful.  We have finally zoomed in on the real problem.</div>
<div style="direction:ltr;font-family:Aptos,Aptos_EmbeddedFont,Aptos_MSFontService,Calibri,Helvetica,sans-serif;font-size:11pt;color:rgb(0,0,0)">
<br>
</div>
<div style="direction:ltr;font-family:Aptos,Aptos_EmbeddedFont,Aptos_MSFontService,Calibri,Helvetica,sans-serif;font-size:11pt;color:rgb(0,0,0)">
It is surprising (and maybe a little disappointing) that we have had such egregious and misleading omissions in the ClassicVRML field descriptions clause, unreported for so many years (since VRML97 apparently).  That was the cause of my mistaken thinking that
 encoding of values were similar.  Nevertheless, it is a nice holiday present that we have finally identified this source of confusion so that it might finally get fixed.</div>
<ul style="direction:ltr;list-style-type:disc">
<li style="font-family:Aptos,Aptos_EmbeddedFont,Aptos_MSFontService,Calibri,Helvetica,sans-serif;font-size:11pt;color:rgb(0,0,0)">
<div style="direction:ltr">X3D 3.3 ClassicVRML Encoding, clause 5 Encoding of fields</div>
</li><li style="font-family:Aptos,Aptos_EmbeddedFont,Aptos_MSFontService,Calibri,Helvetica,sans-serif;font-size:11pt;color:rgb(0,0,0)">
<div style="direction:ltr"><a href="https://www.web3d.org/documents/specifications/19776-2/V3.3/Part02/EncodingOfFields.html" target="_blank">https://www.web3d.org/documents/specifications/19776-2/V3.3/Part02/EncodingOfFields.html</a></div>
</li></ul>
<div style="direction:ltr;font-family:Aptos,Aptos_EmbeddedFont,Aptos_MSFontService,Calibri,Helvetica,sans-serif;font-size:11pt;color:rgb(0,0,0)">
Have checked X3dToClassicVRML.xslt and X3dToVRML97.xslt stylesheet converters, X3DJSAIL export, and our many many X3D Example Archives scenes.  They match what you are saying (thank goodness).</div>
<div style="direction:ltr;font-family:Aptos,Aptos_EmbeddedFont,Aptos_MSFontService,Calibri,Helvetica,sans-serif;font-size:11pt;color:rgb(0,0,0)">
<br>
</div>
<div style="direction:ltr;font-family:Aptos,Aptos_EmbeddedFont,Aptos_MSFontService,Calibri,Helvetica,sans-serif;font-size:11pt;color:rgb(0,0,0)">
I am adding this problem to the issue tracker.  Dick and I will work on a revision for community review.</div>
<ul style="direction:ltr;list-style-type:disc">
<li style="font-family:Aptos,Aptos_EmbeddedFont,Aptos_MSFontService,Calibri,Helvetica,sans-serif;font-size:11pt;color:rgb(0,0,0)">
<div style="direction:ltr">Mantis 1484: ClassicVRML field reference does not include proper SFVec examples</div>
</li><li style="font-family:Aptos,Aptos_EmbeddedFont,Aptos_MSFontService,Calibri,Helvetica,sans-serif;font-size:11pt;color:rgb(0,0,0)">
<div style="direction:ltr"><a href="https://mantis.web3d.org/view.php?id=1484" target="_blank">https://mantis.web3d.org/view.php?id=1484</a></div>
</li></ul>
<div style="direction:ltr;font-family:Aptos,Aptos_EmbeddedFont,Aptos_MSFontService,Calibri,Helvetica,sans-serif;font-size:11pt;color:rgb(0,0,0)">
Future revisions will appear in github and as follows.  Let's watch for similar unintended errors in the specification, the ripples from spec errors spread a wide wake.</div>
<ul style="direction:ltr;list-style-type:disc">
<li style="font-family:Aptos,Aptos_EmbeddedFont,Aptos_MSFontService,Calibri,Helvetica,sans-serif;font-size:11pt;color:rgb(0,0,0)">
<div style="direction:ltr;margin:0px">X3D 4.0 ClassicVRML Encoding, clause 5 Encoding of fields</div>
</li><li style="font-family:Aptos,Aptos_EmbeddedFont,Aptos_MSFontService,Calibri,Helvetica,sans-serif;font-size:11pt;color:rgb(0,0,0)">
<div style="direction:ltr"><a href="https://www.web3d.org/specifications/X3Dv4Draft/ISO-IEC19776-2v4.0-WD1/Part02/EncodingOfFields.html" target="_blank">https://www.web3d.org/specifications/X3Dv4Draft/ISO-IEC19776-2v4.0-WD1/Part02/EncodingOfFields.html</a></div>
</li></ul>
<div style="direction:ltr;font-family:Aptos,Aptos_EmbeddedFont,Aptos_MSFontService,Calibri,Helvetica,sans-serif;font-size:11pt;color:rgb(0,0,0)">
Of course I also agree that fast efficient rigorous parsing holds essential importance.  Your castle-model-viewer and castle-model-converter continue to be essential in our sustained efforts to get ClassicVRML exactly right.</div>
<ul style="direction:ltr;list-style-type:disc">
<li style="font-family:Aptos,Aptos_EmbeddedFont,Aptos_MSFontService,Calibri,Helvetica,sans-serif;font-size:11pt;color:rgb(0,0,0)">
<div style="direction:ltr">Castle Model Converter (formerly tovrmlx3d))</div>
</li><li style="font-family:Aptos,Aptos_EmbeddedFont,Aptos_MSFontService,Calibri,Helvetica,sans-serif;font-size:11pt;color:rgb(0,0,0)">
<div style="direction:ltr"><a href="https://castle-engine.io/castle-model-converter" id="m_73646704836422047OWAa70cc587-ebce-8fb4-faec-a9c752982d07" target="_blank">https://castle-engine.io/castle-model-converter</a></div>
</li></ul>
<div style="direction:ltr;font-family:Aptos,Aptos_EmbeddedFont,Aptos_MSFontService,Calibri,Helvetica,sans-serif;font-size:11pt;color:rgb(0,0,0)">
Looking forward to continuing relentless progress with ClassicVRML and X3D!  🙂</div>
<div id="m_73646704836422047x_Signature">
<p style="margin:0in;font-family:Calibri,sans-serif;font-size:11pt"><span style="font-family:"Courier New";font-size:9pt"><br>
</span></p>
<p style="margin:0in;font-family:Calibri,sans-serif;font-size:11pt"><span style="font-family:"Courier New";font-size:9pt">all the best, Don</span></p>
<p style="margin:0in;font-family:Calibri,sans-serif;font-size:11pt"><span style="font-family:"Courier New";font-size:9pt">--</span></p>
<p style="margin:0in;font-family:Calibri,sans-serif;font-size:11pt"><span style="font-family:"Courier New";font-size:9pt">Don Brutzman  Naval Postgraduate School, Code USW/Br        <a href="mailto:brutzman@nps.edu" target="_blank">brutzman@nps.edu</a></span></p>
<p style="margin:0in;font-family:Calibri,sans-serif;font-size:11pt"><span style="font-family:"Courier New";font-size:9pt">Watkins 270,  MOVES Institute, Monterey CA 93943-5000 USA    +1.831.656.2149</span></p>
<p style="margin:0in;font-family:Calibri,sans-serif;font-size:11pt"><span style="font-family:"Courier New";font-size:9pt">X3D graphics, virtual worlds, navy robotics <a href="https://faculty.nps.edu/brutzman" target="_blank">https://faculty.nps.edu/brutzman</a></span></p>
<p style="margin:0in;font-family:Calibri,sans-serif;font-size:11pt"><span style="font-family:"Courier New";font-size:9pt"> </span></p>
</div>
<div id="m_73646704836422047x_appendonsend"></div>
<div style="direction:ltr;font-family:Aptos,Aptos_EmbeddedFont,Aptos_MSFontService,Calibri,Helvetica,sans-serif;font-size:11pt;color:rgb(0,0,0)">
<br>
</div>
<hr style="direction:ltr;display:inline-block;width:98%">
<div dir="ltr" id="m_73646704836422047x_divRplyFwdMsg"><span style="font-family:Calibri,sans-serif;font-size:11pt;color:rgb(0,0,0)"><b>From:</b> Michalis Kamburelis <<a href="mailto:michalis.kambi@gmail.com" target="_blank">michalis.kambi@gmail.com</a>><br>
<b>Sent:</b> Wednesday, December 18, 2024 8:38 PM<br>
<b>To:</b> Brutzman, Donald (Don) (CIV) <<a href="mailto:brutzman@nps.edu" target="_blank">brutzman@nps.edu</a>><br>
<b>Cc:</b> Extensible 3D (X3D) Graphics public discussion <<a href="mailto:x3d-public@web3d.org" target="_blank">x3d-public@web3d.org</a>>; <a href="mailto:khyoo@chungbuk.ac.kr" target="_blank">khyoo@chungbuk.ac.kr</a> <<a href="mailto:khyoo@chungbuk.ac.kr" target="_blank">khyoo@chungbuk.ac.kr</a>>; Myeong Won Lee <<a href="mailto:myeongwonlee@gmail.com" target="_blank">myeongwonlee@gmail.com</a>><br>
<b>Subject:</b> Re: [x3d-public] X3D 4.0 specification problem: TextureProjectorparallel.fieldOfView</span>
<div> </div>
</div>
<div style="direction:ltr;font-size:11pt">NPS WARNING: *external sender* verify before acting.<br>
<br>
<br>
Hi Don,<br>
<br>
AD A -<br>
<br>
No, when writing the SFVec4f in X3D classic encoding, the square<br>
brackets "[ ... ]" cannot be used. I believe my understanding matches<br>
both the spec and all existing X3D implementations.<br>
<br>
1. The example you noticed (on<br>
<a href="https://www.web3d.org/documents/specifications/19776-2/V3.3/Part02/EncodingOfFields.html#SFVec4f" id="m_73646704836422047OWAf7289fe9-2afd-f73d-6854-8cd14629043e" target="_blank">https://www.web3d.org/documents/specifications/19776-2/V3.3/Part02/EncodingOfFields.html#SFVec4f</a><br>
) ... shows MFVec4f, not SFVec4f .<br>
<br>
    It's indeed a bit misleading, as the spec section titled "5.20<br>
SFVec3f and MFVec3f" describes both MF- and SF- variants. And the<br>
example "fooVec3d [ 1.000000000001 42 666.35357878 32.6, 7 94<br>
0.100000000007 143.998 ]" lacks any annotation. Adding there a<br>
description would help: "This is an example of MFVec4f in classic<br>
encoding, fooVec3d contains here two 4-dimensional vectors." .<br>
<br>
2. On the same page, the text higher makes it clear that "square<br>
brackets" are used for multiple-value fields: """Multiple-valued<br>
fields are written as an ordered list of values enclosed in square<br>
brackets and separated by whitespace."""<br>
<br>
3. The grammar on<br>
<a href="https://www.web3d.org/documents/specifications/19776-2/V3.3/Part02/grammar.html" id="m_73646704836422047OWAa34ea030-86eb-8ce2-d623-dca8ae2ad99e" target="_blank">https://www.web3d.org/documents/specifications/19776-2/V3.3/Part02/grammar.html</a><br>
confirms it:<br>
<br>
"""<br>
mffloatValue ::=<br>
    sffloatValue |<br>
    [ ] |<br>
    [ sffloatValues ] ;<br>
<br>
....<br>
<br>
sfvec4fValue ::=float float float float ;<br>
""""<br>
<br>
No square brackets for sfvec4fValue . (And that's good I think; square<br>
brackets are consistently used in X3D classic encoding for lists of<br>
values.)<br>
<br>
I do find the grammar very helpful to resolve such questions :) It's<br>
unambiguous, and implementations (using my own) follow it literally.<br>
<br>
So, I think my concern still stands. Changing<br>
OrthoViewport.fieldOfView type (MFFloat -> SFVec4f) would break<br>
parsing of all the models in X3D classic encoding (and VRML 2.0) that<br>
specify value of this field. They use right now square brackets [ .. ]<br>
(necessary for MFFloat with > 1 value), which are not allowed for<br>
SFVec4f.<br>
<br>
I honestly don't think there's a way to avoid it, except reverting<br>
this spec change. I cannot change in our implementation<br>
OrthoViewport.fieldOfView to SFVec4f -- I have users using classic<br>
encoding, and VRML 2.0 too, we cannot really break it. And maintaining<br>
exceptional treatment in the parser (to allow both MFFloat and<br>
SFVec4f) is not maintainable, we cannot have special rules like this<br>
(that depend on node and field name) at the parser level.<br>
<br>
I know that we could change the grammar (to allow [ ... ] in SFVec4f)<br>
but IMHO we should not change the grammar (which will complicate<br>
parsing) just to account this one single exceptional change to one<br>
field in one node.<br>
<br>
AD B - No, I didn't describe any special handling in our parser. And<br>
such exceptions during parsing would be really hard to maintain, I<br>
deliberately don't want them. Parser should not have any special rules<br>
for specific nodes or fields -- this makes parser code more obvious.<br>
<br>
   On the contrary -- we parse OrthoViewport.fieldOfView as MFFloat<br>
now. Only later (after parsing) we just look at the count of MFFloat.<br>
When it's less than 4, we treat the remaining numbers as if they were<br>
default. But this is nice "local" code near OrthoViewport.fieldOfView<br>
logic. It's *not* part of the parser.<br>
<br>
Regards,<br>
Michalis<br>
<br>
czw., 19 gru 2024 o 03:06 Brutzman, Donald (Don) (CIV)<br>
<<a href="mailto:brutzman@nps.edu" target="_blank">brutzman@nps.edu</a>> napisał(a):<br>
><br>
> Thanks for looking at this Michalis.<br>
><br>
> A. Sorry but I'm not clear about what you are saying...  Went to look at the existing ClassicVRML encoding and it is showing [square brackets] for SFVec4f:<br>
><br>
> X3D Classic VRML encoding, clause 5 encoding of fields, 5.22 SFVec4f and MFVec4f<br>
> <a href="https://www.web3d.org/documents/specifications/19776-2/V3.3/Part02/EncodingOfFields.html#SFVec4f" id="m_73646704836422047OWA0ae6015f-7668-cf0c-4380-5648ca15907c" target="_blank">
https://www.web3d.org/documents/specifications/19776-2/V3.3/Part02/EncodingOfFields.html#SFVec4f</a><br>
><br>
> The SFVec4f field specifies a four-dimensional (4D) single-precision vector. An MFVec4f field specifies zero or more 4D single-precision vectors. SFVec4f's and MFVec4f's are encoded as four ISO C floating point values (see ISO/IEC 9899) separated by whitespace.<br>
> EXAMPLE<br>
> fooVec3f [ 1 42 666 -43.8, 7 94 0 0.0001 ]<br>
><br>
> ... And so am expecting your SFVec4f example would look the same, with  [square brackets] around numeric values.  Please advise what you think.<br>
><br>
> OrthoViewpoint { fieldOfView [ -1 -1 1 1 ] }<br>
><br>
><br>
> B.  Depending on that, am next wondering... you describe how the current MFFloat approach already requires additional special handling by your parser if an incorrect number of values is encountered.  If there is a difference regarding [square brackets] for
 SFVec4f then maybe a parser adjustment for that might be possible too... Or, even if they are the same, maybe just keeping your error-handling parser for v3.3 content the same (also for backwards reliability) is a good idea also.<br>
><br>
> C. We are currently working on ClassicVRML Encoding spec for v4.0 now, so if any problems are found then we can resolve them.<br>
><br>
> D.  I found several problems with the Grammar... Dick and I also discussed them yesterday.  When time permits, will post about that soon.<br>
><br>
> Have fun with X3D ClassicVRML Encoding!  🙂<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" id="m_73646704836422047OWAaf54feac-e0fc-f22e-69a7-c1b0f5f40886" target="_blank">
https://faculty.nps.edu/brutzman</a><br>
><br>
><br>
><br>
><br>
> ________________________________<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 via x3d-public <<a href="mailto:x3d-public@web3d.org" target="_blank">x3d-public@web3d.org</a>><br>
> Sent: Wednesday, December 18, 2024 5:37 PM<br>
> To: Extensible 3D (X3D) Graphics public discussion <<a href="mailto:x3d-public@web3d.org" target="_blank">x3d-public@web3d.org</a>><br>
> Cc: Michalis Kamburelis <<a href="mailto:michalis.kambi@gmail.com" target="_blank">michalis.kambi@gmail.com</a>>; <a href="mailto:khyoo@chungbuk.ac.kr" target="_blank">khyoo@chungbuk.ac.kr</a> <<a href="mailto:khyoo@chungbuk.ac.kr" target="_blank">khyoo@chungbuk.ac.kr</a>>; Myeong Won Lee <<a href="mailto:myeongwonlee@gmail.com" target="_blank">myeongwonlee@gmail.com</a>><br>
> Subject: Re: [x3d-public] X3D 4.0 specification problem: TextureProjectorparallel.fieldOfView<br>
><br>
> The change of OrthoViewpoint.fieldOfView from MFFloat to SFVec4f<br>
> breaks compatibility (badly) for X3D classic encoding, from what I can<br>
> see.<br>
><br>
> Previously (when OrthoViewpoint.fieldOfView is MFFloat, so in X3D <=<br>
> 4.0 and VRML 2.0) this was valid:<br>
><br>
>     OrthoViewpoint { fieldOfView [ -1 -1 1 1 ] }<br>
><br>
> And this was "undefined how it works (spec doesn't say what happens<br>
> for < 4 values), but at least parsing was OK" (CGE made some effort to<br>
> tolerate it):<br>
><br>
>     OrthoViewpoint { fieldOfView [ -1 -1 ] }<br>
><br>
> Now (when OrthoViewpoint.fieldOfView is SFVec4f) both above are<br>
> invalid, at parsing. One has to write this:<br>
><br>
>     OrthoViewpoint { fieldOfView -1 -1 1 1 }<br>
><br>
> ... but the new form is invalid if loaded into a browser that expects<br>
> OrthoViewpoint.fieldOfView to be old MFFloat.<br>
><br>
> And, before anyone suggests this: It's not reasonable for X3D browsers<br>
> to define OrthoViewpoint.fieldOfView with one type for X3D >= 4.1, and<br>
> another type for older X3D versions. At least I cannot imagine<br>
> maintaining this exceptional behavior throughout the codebase :) We<br>
> need to have a one definition of OrthoViewpoint with one type for<br>
> fieldOfView, otherwise we cause a big complication (also for<br>
> developers using our API).<br>
><br>
> So, I'm a bit baffled what to do. If I change<br>
> OrthoViewpoint.fieldOfView to SFVec4f, I *will* break some X3D models<br>
> for users and I will get bugreports about it. If I don't, I will not<br>
> be compatible with X3D 4.1. For now, I choose the latter.<br>
><br>
> Regards,<br>
> Michalis<br>
><br>
> czw., 19 gru 2024 o 01:42 John Carlson via x3d-public<br>
> <<a href="mailto:x3d-public@web3d.org" target="_blank">x3d-public@web3d.org</a>> napisał(a):<br>
><br>
><br>
><br>
> ><br>
> > I’m imagining there will be changes to C++ SAI.  Once new types are in place I can attempt to test.  I suggest getting an X3DUOM out soon, so I can regenerate my fieldTypes.js file, which affects all my serializers.<br>
> ><br>
> > No one is using my serializers that I know of, so this particular change won’t probably affect anyone.  They would have to update, and I don’t currently recommend that.<br>
> ><br>
> > Bug reports are welcome:<br>
> ><br>
> > <a href="https://github.com/coderextreme/X3DJSONLD/issues" id="m_73646704836422047OWA3dcc1ce2-5494-5adb-9828-69cd03a5ce05" target="_blank">
https://nam10.safelinks.protection.outlook.com/?url=https%3A%2F%2Fgithub.com%2Fcoderextreme%2FX3DJSONLD%2Fissues&data=05%7C02%7Cbrutzman%40nps.edu%7C98ebb53e439741334cb708dd1fe70c37%7C6d936231a51740ea9199f7578963378e%7C0%7C0%7C638701800556379299%7CUnknown%7CTWFpbGZsb3d8eyJFbXB0eU1hcGkiOnRydWUsIlYiOiIwLjAuMDAwMCIsIlAiOiJXaW4zMiIsIkFOIjoiTWFpbCIsIldUIjoyfQ%3D%3D%7C80000%7C%7C%7C&sdata=sNGbCXeuSBEnFH2Mnp8RVNttmB%2FqDIKHhbv6YaxdOjE%3D&reserved=0</a><br>
> ><br>
> ><br>
> > AFAIK, this does not affect X3D JSON, since MFFloat and SFVec4f are represented by arrays.<br>
> ><br>
> > If you recommend tweaking X3DUOM before your release, I can see what I can do, but it’s not currently a priority for me.  Reading the X_ITE component into Blender is higher priority.<br>
> ><br>
> > Someone speaking up can change the priority.<br>
> ><br>
> > John<br>
> ><br>
> > On Wed, Dec 18, 2024 at 6:00 PM Brutzman, Donald (Don) (CIV) via x3d-public <<a href="mailto:x3d-public@web3d.org" target="_blank">x3d-public@web3d.org</a>> wrote:<br>
> >><br>
> >> During a specification editors' meeting yesterday, Dick and I made another step forward.<br>
> >><br>
> >> Mantis 1398: OrthoViewpoint fieldOfView type needs to be SFVec4f, not MFFloat<br>
> >> <a href="https://mantis.web3d.org/view.php?id=1398" id="m_73646704836422047OWAf972cd7f-a47a-0a5d-a6d2-3d7685a8a3fe" target="_blank">
https://mantis.web3d.org/view.php?id=1398</a><br>
> >><br>
> >> namely<br>
> >><br>
> >> If specialty methods for homogeneous transformations (or other operations) are needed by SAI implementations, they can receive specialized definitions to match.<br>
> >> It is important to remember that (a) no nodes currently use homogenous coordinates, and (b) ClipPlane definition of a half-plane is different than the two parallel-projection extents.<br>
> >> A graceful approach not requiring implementation changes might be adding prose to Clause 5 field definitions noting alternate usages may occur. For example, appended to the fist sentence, "or other usage of a 4-tuple."<br>
> >><br>
> >> We applied that change in draft X3D 4.1 Architecture, also committed into git and pushed online.<br>
> >><br>
> >> 5.3.20 SFVec4d and MFVec4d<br>
> >> <a href="https://www.web3d.org/specifications/X3Dv4Draft/ISO-IEC19775-1v4.1-CD//Part01/fieldTypes.html#SFVec4dAndMFVec4d" id="m_73646704836422047OWA262c1830-4e6f-3442-5fa9-9b661fce40fe" target="_blank">
https://www.web3d.org/specifications/X3Dv4Draft/ISO-IEC19775-1v4.1-CD//Part01/fieldTypes.html#SFVec4dAndMFVec4d</a><br>
> >> 5.3.21 SFVec4f and MFVec4f<br>
> >> <a href="https://www.web3d.org/specifications/X3Dv4Draft/ISO-IEC19775-1v4.1-CD//Part01/fieldTypes.html#SFVec4fAndMFVec4f" id="m_73646704836422047OWAead4665c-3a95-bd67-cc33-7c00b8579909" target="_blank">
https://www.web3d.org/specifications/X3Dv4Draft/ISO-IEC19775-1v4.1-CD//Part01/fieldTypes.html#SFVec4fAndMFVec4f</a><br>
> >><br>
> >> ==========================<br>
> >> 5.3.20 SFVec4d and MFVec4d<br>
> >> The SFVec4d field or event specifies a three-dimensional (3D) homogeneous vector, or other usage of a 4-tuple. An MFVec4d field or event specifies zero or more SFVec4d values. 3D homogeneous vectors. SFVec4d's and MFVec4d's are represented as a 4-tuple
 of double-precision floating point values (see 5.3.4 SFDouble and MFDouble). The allowable form for a double-precision floating point number is defined in the specific encoding.<br>
> >> The default value of an uninitialized SFVec4d field is (0 0 0 1). The default value of an MFVec4d field is the empty list.<br>
> >> 5.3.21 SFVec4f and MFVec4f<br>
> >> The SFVec4f field or event specifies a three-dimensional (3D) homogeneous vector, or other usage of a 4-tuple. An MFVec4f field or event specifies zero or more SFVec4f values. 3D homogeneous vectors. SFVec4f's and MFVec4f's are represented as a 4-tuple
 of single-precision floating point values (see 5.3.5 SFFloat and MFFloat). The allowable form for a single-precision floating point number is defined in the specific encoding.<br>
> >> The default value of an uninitialized SFVec4f field is (0 0 0 1). The default value of an MFVec4f field is the empty list.<br>
> >> ==========================<br>
> >><br>
> >> If anyone can think of any reason not to restrict validation of OrthoViewpoint fieldOfView to SFVec4f, instead of an MFFloat array of length 4, please speak up.  Am hoping to apply this change next to validation tools next, improving quality assurance
 and author confidence that a model is valid.  Avoiding run-time errors and maintaining consistency, with no harm to existing X3D models or implementations, is important.<br>
> >><br>
> >> Have fun with high-quality X3D!  🙂<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" id="m_73646704836422047OWAea11f5bb-106b-b796-c727-6dc5e61ecbb9" target="_blank">
https://faculty.nps.edu/brutzman</a><br>
> >><br>
> >><br>
> >><br>
> >><br>
> >> ________________________________<br>
> >> From: Brutzman, Donald (Don) (CIV) <<a href="mailto:brutzman@nps.edu" target="_blank">brutzman@nps.edu</a>><br>
> >> Sent: Friday, December 13, 2024 1:14 PM<br>
> >> To: Holger Seelig <<a href="mailto:holger.seelig@yahoo.de" target="_blank">holger.seelig@yahoo.de</a>>; X3D <<a href="mailto:x3d-public@web3d.org" target="_blank">x3d-public@web3d.org</a>><br>
> >> Cc: <a href="mailto:khyoo@chungbuk.ac.kr" target="_blank">khyoo@chungbuk.ac.kr</a> <<a href="mailto:khyoo@chungbuk.ac.kr" target="_blank">khyoo@chungbuk.ac.kr</a>>; Myeong Won Lee <<a href="mailto:myeongwonlee@gmail.com" target="_blank">myeongwonlee@gmail.com</a>><br>
> >> Subject: Re: [x3d-public] X3D 4.0 specification problem: TextureProjectorparallel.fieldOfView<br>
> >><br>
> >> Excellent question, thanks for asking Holger.<br>
> >><br>
> >> This issue has been carefully tracked and regularly revisited since July 2022.<br>
> >><br>
> >> Mantis 1398: OrthoViewpoint fieldOfView type needs to be SFVec4f, not MFFloat<br>
> >> <a href="https://mantis.web3d.org/view.php?id=1398" id="m_73646704836422047OWA61e39e92-bfd0-8ec8-ad4d-6381b82a732e" target="_blank">
https://mantis.web3d.org/view.php?id=1398</a><br>
> >> Mantis 1468: must SFVec4f/SFVec4d fields be homogeneous?<br>
> >> <a href="https://mantis.web3d.org/view.php?id=1468" id="m_73646704836422047OWAfd76f26a-9856-511c-6816-f935b58e42a4" target="_blank">
https://mantis.web3d.org/view.php?id=1468</a><br>
> >><br>
> >> The X3D Working Group was unable to reach consensus on this issue prior to conclusion of version 4.0, unfortunately.  Dick Puk and I took a close look at this recently too. Here is a synopsis of the Mantis issues.<br>
> >><br>
> >> I advocate use of SFVec4f for all parallel fieldOfView values because it is the strictest appropriate datatype that can validate content. Retaining the legacy MFFloat type definition for fieldOfView allows 3d models (produced by humans or tools) to define
 arrays of illegal length, making failures mysterious.  Conceptual consistency is important too.<br>
> >><br>
> >> Reviewing the Mantis issues, additional concerns included:<br>
> >><br>
> >> Incompatibility with prior X3D implementations.  Since a 4-tuple content value is a valid MFFloat array, I'm not seeing any backwards incompatibility if a prior X3D 3.3 implementation encounters the four values of a SFVec4f array.  There are no representation
 problems since value syntax is compatible for our various encodings as well.<br>
> >><br>
> >> SFVec4f fields are actually not homogenous coordinates.  The spec uses the word "homogenous" when referring to<br>
> >><br>
> >>  X3D4 Architecture, Clause 5 Field type reference, 5.3.20 SFVec4d and MFVec4d<br>
> >> <a href="https://www.web3d.org/specifications/X3Dv4/ISO-IEC19775-1v4-IS/Part01/fieldTypes.html#SFVec4dAndMFVec4d" id="m_73646704836422047OWA611a0ae0-2f26-1792-b5a7-c0342960f0b3" target="_blank">
https://www.web3d.org/specifications/X3Dv4/ISO-IEC19775-1v4-IS/Part01/fieldTypes.html#SFVec4dAndMFVec4d</a><br>
> >> "The SFVec4f field or event specifies a three-dimensional (3D) homogeneous vector." (and similarly for SFVec4d, SFVec4f and MFVec4f).<br>
> >> However none of these fields are mathematically homogeneous, see<br>
> >> <a href="https://en.wikipedia.org/wiki/Homogeneous_coordinates" id="m_73646704836422047OWAbf352435-e291-ad77-551a-6ceebe107027" target="_blank">
https://nam10.safelinks.protection.outlook.com/?url=https%3A%2F%2Fen.wikipedia.org%2Fwiki%2FHomogeneous_coordinates&data=05%7C02%7Cbrutzman%40nps.edu%7C98ebb53e439741334cb708dd1fe70c37%7C6d936231a51740ea9199f7578963378e%7C0%7C0%7C638701800556398488%7CUnknown%7CTWFpbGZsb3d8eyJFbXB0eU1hcGkiOnRydWUsIlYiOiIwLjAuMDAwMCIsIlAiOiJXaW4zMiIsIkFOIjoiTWFpbCIsIldUIjoyfQ%3D%3D%7C80000%7C%7C%7C&sdata=%2F3CZD9IDEdkAZaIJ9BWi4dKFk0mblQfkBstpx0lEsg0%3D&reserved=0</a><br>
> >> <a href="https://en.wikipedia.org/wiki/Homogeneous_coordinates#/media/File:RationalBezier2D.svg" id="m_73646704836422047OWA29b8d64b-3c0c-9f89-6123-43f3fb289a94" target="_blank">
https://nam10.safelinks.protection.outlook.com/?url=https%3A%2F%2Fen.wikipedia.org%2Fwiki%2FHomogeneous_coordinates%23%2Fmedia%2FFile%3ARationalBezier2D.svg&data=05%7C02%7Cbrutzman%40nps.edu%7C98ebb53e439741334cb708dd1fe70c37%7C6d936231a51740ea9199f7578963378e%7C0%7C0%7C638701800556410503%7CUnknown%7CTWFpbGZsb3d8eyJFbXB0eU1hcGkiOnRydWUsIlYiOiIwLjAuMDAwMCIsIlAiOiJXaW4zMiIsIkFOIjoiTWFpbCIsIldUIjoyfQ%3D%3D%7C80000%7C%7C%7C&sdata=Q%2BWMcMy2W%2FYzedb2wd7Efsgd28M1of%2FFy3pO2GKRTF4%3D&reserved=0</a><br>
> >> Of related note is that ClipPlane 4-tuple "plane" field is also SFVec4f.<br>
> >> <a href="https://www.web3d.org/specifications/X3Dv4/ISO-IEC19775-1v4-IS/Part01/components/rendering.html#ClipPlane" id="m_73646704836422047OWA269de62d-adbf-ff12-db92-fdf3507271c9" target="_blank">
https://www.web3d.org/specifications/X3Dv4/ISO-IEC19775-1v4-IS/Part01/components/rendering.html#ClipPlane</a><br>
> >><br>
> >> All review welcome, hopefully I have correctly synopsized all concerns.<br>
> >><br>
> >> I think it would be beneficial to resolve this issue by reaching consensus and applying remedies as follow.<br>
> >><br>
> >> Omitting the over-strict word "homogenous" from the four SF/MF Vec 4f/4d definitions in future X3D 4.1 prose,<br>
> >> Updating future X3D 4.1 prose to use SFVec4f for TextureProjectorParallel fieldOfView,<br>
> >> Using SFVec4f in X3D 4.0 DTD, Schema, X3DUOM validation and X3D Tooltips, since that type strictly confirms fieldOfView correctness with no backwards compatibility problems.<br>
> >><br>
> >> Is consensus now possible?  Thanks for all careful consideration.<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" id="m_73646704836422047OWAc1c429e1-87b7-f991-be19-520b77a4e3b3" target="_blank">
https://faculty.nps.edu/brutzman</a><br>
> >><br>
> >><br>
> >><br>
> >><br>
> >> ________________________________<br>
> >> From: Holger Seelig <<a href="mailto:holger.seelig@yahoo.de" target="_blank">holger.seelig@yahoo.de</a>><br>
> >> Sent: Friday, December 13, 2024 11:29 AM<br>
> >> To: X3D <<a href="mailto:x3d-public@web3d.org" target="_blank">x3d-public@web3d.org</a>><br>
> >> Cc: Brutzman, Donald (Don) (CIV) <<a href="mailto:brutzman@nps.edu" target="_blank">brutzman@nps.edu</a>>; <a href="mailto:khyoo@chungbuk.ac.kr" target="_blank">khyoo@chungbuk.ac.kr</a> <<a href="mailto:khyoo@chungbuk.ac.kr" target="_blank">khyoo@chungbuk.ac.kr</a>>; Myeong Won Lee <<a href="mailto:myeongwonlee@gmail.com" target="_blank">myeongwonlee@gmail.com</a>><br>
> >> Subject: Re: [x3d-public] X3D 4.0 specification problem: upVector field for TextureProjector, TextureProjectorParallel<br>
> >><br>
> >> I just realised that TextureProjectorparallel.fieldOfView is of type SFVec4f, but OrthoViewpoint.fieldOfView is of type MFFloat.<br>
> >><br>
> >> Which of the two is better?<br>
> >><br>
> >> OrthoViewpoint is definitely older.<br>
> >><br>
> >> I think of SFVec4f as a mathematical 4d vector.<br>
> >><br>
> >> <a href="https://www.web3d.org/documents/specifications/19775-1/V4.0/Part01/components/textureProjection.html#TextureProjectorParallel" id="m_73646704836422047OWAa97a41c2-e009-5828-55f7-e4a2a27f9d1f" target="_blank">
https://www.web3d.org/documents/specifications/19775-1/V4.0/Part01/components/textureProjection.html#TextureProjectorParallel</a><br>
> >> <a href="https://www.web3d.org/documents/specifications/19775-1/V4.0/Part01/components/navigation.html#OrthoViewpoint" id="m_73646704836422047OWA62c1bc5b-5923-1eab-0f33-7fa3d4607e50" target="_blank">
https://www.web3d.org/documents/specifications/19775-1/V4.0/Part01/components/navigation.html#OrthoViewpoint</a><br>
> >><br>
> >> Best regards,<br>
> >> Holger<br>
> >><br>
> >> --<br>
> >> Holger Seelig<br>
> >> Leipzig, Germany<br>
> >><br>
> >> <a href="mailto:holger.seelig@yahoo.de" target="_blank">holger.seelig@yahoo.de</a><br>
> >> <a href="https://create3000.github.io/x_ite/" id="m_73646704836422047OWA86c8b645-f0d0-8d32-98f2-be23ca7b20a7" target="_blank">
https://nam10.safelinks.protection.outlook.com/?url=https%3A%2F%2Fcreate3000.github.io%2Fx_ite%2F&data=05%7C02%7Cbrutzman%40nps.edu%7C98ebb53e439741334cb708dd1fe70c37%7C6d936231a51740ea9199f7578963378e%7C0%7C0%7C638701800556422280%7CUnknown%7CTWFpbGZsb3d8eyJFbXB0eU1hcGkiOnRydWUsIlYiOiIwLjAuMDAwMCIsIlAiOiJXaW4zMiIsIkFOIjoiTWFpbCIsIldUIjoyfQ%3D%3D%7C80000%7C%7C%7C&sdata=EyAy636i6iNSYFBrRDdqg178Wi93D3sVzQJQ%2FqGIxDc%3D&reserved=0</a><br>
> >><br>
> >> Am 08.12.2024 um 05:21 schrieb Brutzman, Donald (Don) (CIV) via x3d-public <<a href="mailto:x3d-public@web3d.org" target="_blank">x3d-public@web3d.org</a>>:<br>
> >><br>
> >> However<br>
> >><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" id="m_73646704836422047OWA2ee18750-e9d5-eaa5-de45-c156b10a8dd9" 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" id="m_73646704836422047OWA979b0172-021e-fbe1-2591-bccb1c724a94" 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" id="m_73646704836422047OWAbc35ad90-0a27-5091-0e8f-853c53d025c0" target="_blank">
http://web3d.org/mailman/listinfo/x3d-public_web3d.org</a></div>
</div>
_______________________________________________<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>
</div></blockquote></div>