<html><body><html o="urn:schemas-microsoft-com:office:office" w="urn:schemas-microsoft-com:office:word" m="http://schemas.microsoft.com/office/2004/12/omml"><head><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;}
@font-face
 {font-family:Verdana;
 panose-1:2 11 6 4 3 5 4 4 2 4;}
@font-face
 {font-family:"Segoe UI Emoji";
 panose-1:2 11 5 2 4 2 4 2 2 3;}
/* 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;}
p.MsoListParagraph, li.MsoListParagraph, div.MsoListParagraph
 {mso-style-priority:34;
 mso-margin-top-alt:auto;
 margin-right:0in;
 mso-margin-bottom-alt:auto;
 margin-left:0in;
 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:846671215;
 mso-list-type:hybrid;
 mso-list-template-ids:-1840903146 -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;}
@list l1
 {mso-list-id:2057075698;
 mso-list-template-ids:-1;}
@list l1:level1
 {mso-level-number-format:bullet;
 mso-level-text:\F0B7;
 mso-level-tab-stop:.5in;
 mso-level-number-position:left;
 text-indent:-.25in;
 mso-ansi-font-size:10.0pt;
 font-family:Symbol;}
@list l1:level2
 {mso-level-number-format:bullet;
 mso-level-text:\F0B7;
 mso-level-tab-stop:1.0in;
 mso-level-number-position:left;
 text-indent:-.25in;
 mso-ansi-font-size:10.0pt;
 font-family:Symbol;}
@list l1:level3
 {mso-level-number-format:bullet;
 mso-level-text:\F0B7;
 mso-level-tab-stop:1.5in;
 mso-level-number-position:left;
 text-indent:-.25in;
 mso-ansi-font-size:10.0pt;
 font-family:Symbol;}
@list l1:level4
 {mso-level-number-format:bullet;
 mso-level-text:\F0B7;
 mso-level-tab-stop:2.0in;
 mso-level-number-position:left;
 text-indent:-.25in;
 mso-ansi-font-size:10.0pt;
 font-family:Symbol;}
@list l1:level5
 {mso-level-number-format:bullet;
 mso-level-text:\F0B7;
 mso-level-tab-stop:2.5in;
 mso-level-number-position:left;
 text-indent:-.25in;
 mso-ansi-font-size:10.0pt;
 font-family:Symbol;}
@list l1:level6
 {mso-level-number-format:bullet;
 mso-level-text:\F0B7;
 mso-level-tab-stop:3.0in;
 mso-level-number-position:left;
 text-indent:-.25in;
 mso-ansi-font-size:10.0pt;
 font-family:Symbol;}
@list l1:level7
 {mso-level-number-format:bullet;
 mso-level-text:\F0B7;
 mso-level-tab-stop:3.5in;
 mso-level-number-position:left;
 text-indent:-.25in;
 mso-ansi-font-size:10.0pt;
 font-family:Symbol;}
@list l1:level8
 {mso-level-number-format:bullet;
 mso-level-text:\F0B7;
 mso-level-tab-stop:4.0in;
 mso-level-number-position:left;
 text-indent:-.25in;
 mso-ansi-font-size:10.0pt;
 font-family:Symbol;}
@list l1:level9
 {mso-level-number-format:bullet;
 mso-level-text:\F0B7;
 mso-level-tab-stop:4.5in;
 mso-level-number-position:left;
 text-indent:-.25in;
 mso-ansi-font-size:10.0pt;
 font-family:Symbol;}
ol
 {margin-bottom:0in;}
ul
 {margin-bottom:0in;}
--></style><meta name="viewport" content="width=device-width" /><meta http-equiv="Content-Type" content="text/vnd.ui.insecure+html;charset=utf-8" /></head><body lang="EN-US" link="blue" vlink="#954F72" style="overflow-wrap:break-word; word-break: break-word;"><div class="mail_android_message" style="line-height: 1; padding: 0.5em">>>>>>>>>This must be a tough part, where a scene has multiple inputs, your scene which is sharing some state with other scenes as well as your ‘external’ SAI traffic. Some goes to the networksensor as just another node where the SAI accepts external events as usual then routing some to networksensor(s) and maybe some to other nodes. The network sensor accepts/generates only internal SAI events and sending them to SAI external interface to send out. I wasn’t thinking that the ns would assign ‘internal’ time stamps.<br>
<br>
 My statement about the Network Sensor assigning timestamps was a hypothetic statement. Since I am currently using the native implementation of the NS by Bitmanagement for my hobby project, I do not need to care about timestamps.   <br>
<br>
<br>
-- <br>
Diese Nachricht wurde von meinem Android Mobiltelefon mit GMX Mail gesendet.</div><div class="mail_android_quote" style="line-height: 1; padding: 0.3em">Am 16.03.19, 09:37, Joseph D Williams <joedwil@earthlink.net> schrieb:<blockquote class="gmail_quote" style="margin: 0.8ex 0pt 0pt 0.8ex; border-left: 1px solid rgb(204, 204, 204); padding-left: 1ex;">
<div class="WordSection1"><ul type="disc"><li class="MsoListParagraph" style="mso-list:l0 level1 lfo2"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">But I do NOT understand, what this means with respect to the RT capability of the network protocols.</span></li></ul><p class="MsoNormal">Hi Christoph, maybe nothing, just making a statement about how the ‘internal’ SAI works internally responding to ‘internal’ events and what should happen as events from ‘external’ are converted to ‘internal’ events. Your representation of the scene, meaning the one that is your local platform, gets to decide the time stamp of the one or more external events when the external tells you when the events to be processed together is complete. (beginupdate/endupdate). </p><p class="MsoNormal" style="margin-left:.5in;text-indent:-.5in"></p><p> </p><p class="MsoNormal" style="margin-left:.5in;text-indent:-.5in"></p><p> </p><p class="MsoNormal" style="margin-left:.5in;text-indent:-.5in">This must be a tough part, where a scene has multiple inputs, your scene which is sharing some state with other scenes as well as your ‘external’ SAI traffic. Some goes to the networksensor as just another node where the SAI accepts external events as usual then routing some to networksensor(s) and maybe some to other nodes. The network sensor accepts/generates only internal SAI events and sending them to SAI external interface to send out. I wasn’t thinking that the ns would assign ‘internal’ time stamps.</p><p class="MsoNormal"></p><p> </p><ul type="disc"><li class="MsoListParagraph" style="mso-list:l0 level1 lfo2"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">while the network sensor assigns the time stamps from receiving the network traffic instead of the timestamp of the event cascade it releases the event to.<p></p></span></li></ul><p class="MsoNormal"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">I would like to see the source system tell me when they think the group of events they sent is complete and should all be processed using the same time stamp, that will be assigned by the sink system according to its local time. I was thinking the ns would get events from external same as any other node and they would already have an ‘internal’ timestamp. Maybe I better read up<p></p></span></p><ul type="disc"><li class="MsoListParagraph" style="mso-list:l0 level1 lfo2"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">impossible to send traffic over the network, process remotely and receive again within the SAME event cascade</span></li></ul><p class="MsoNormal">That might be a way to demonstrate scene entanglement – synchronization at a distance. Each scene has the same time, but it is different in each one. I want the essentials of this because I really may need to know when all networked scenes are synchronized at some common time. Or some animation gets started at some time and I need to know it is running everywhere. If your scene sends an event to another then the sink scene can send back the timestamp of completion. </p><p></p><p class="MsoNormal"></p><p> </p><p class="MsoNormal">Thanks and Best, </p><p></p><p class="MsoNormal">Joe</p><p></p><p class="MsoNormal"></p><p> </p><p class="MsoNormal"></p><p> </p><p class="MsoNormal"></p><p> </p><p class="MsoNormal"></p><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:christoph.valentin@gmx.at">Christoph Valentin</a><br /><b>Sent: </b>Friday, March 15, 2019 1:17 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-public@web3d.org</a><br /><b>Subject: </b>Aw: RE: [x3d-public] Netw. Sens. Protocol - WAS: 3d-publicDigest,Vol120, Issue 34</p></div><p class="MsoNormal"></p><p> </p><p class="MsoNormal"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">Joseph,<p></p></span></p><div><p class="MsoNormal"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"> <p></p></span></p></div><div><p class="MsoNormal"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">I understand your explanation, and I see an issue, if a scene author relies on the time stamps of one event cascade (one frame) being all the same, while the network sensor assigns the time stamps from receiving the network traffic instead of the timestamp of the event cascade it releases the event to.<p></p></span></p></div><div><p class="MsoNormal"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"> <p></p></span></p></div><div><p class="MsoNormal"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">But I do NOT understand, what this means with respect to the RT capability of the network protocols. The network traffic must be decoupled from the framing anyway, as far as I think to understand.<p></p></span></p></div><div><p class="MsoNormal"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"> <p></p></span></p></div><div><p class="MsoNormal"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">I think it is impossible to send traffic over the network, process remotely and receive again within the SAME event cascade, anyway.<p></p></span></p></div><div><p class="MsoNormal"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"> <p></p></span></p></div><div><p class="MsoNormal"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">KR,<p></p></span></p></div><div><p class="MsoNormal"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">Christoph<p></p></span></p></div><div><p class="MsoNormal"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">  <p></p></span></p><div style="border:none;border-left:solid #C3D9E5 1.5pt;padding:0in 0in 0in 8.0pt;margin-left:7.5pt;margin-top:7.5pt;margin-right:3.75pt;margin-bottom:3.75pt;word-wrap: break-word;-webkit-nbsp-mode: space;-webkit-line-break: after-white-space" name="quote"><div style="margin-bottom:7.5pt"><p class="MsoNormal"><b><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">Gesendet:</span></b><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"> Freitag, 15. März 2019 um 18:04 Uhr<br /><b>Von:</b> "Joseph D Williams" <joedwil@earthlink.net><br /><b>An:</b> "Christoph Valentin" <christoph.valentin@gmx.at>, "x3d-public@web3d.org" <x3d-public@web3d.org><br /><b>Betreff:</b> RE: [x3d-public] Netw. Sens. Protocol - WAS: 3d-public Digest,Vol120, Issue 34<p></p></span></p></div><div name="quoted-content"><div><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"> <p></p></span></p><ul type="disc"><li class="MsoListParagraph" style="mso-list:l1 level1 lfo1"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">REST is a paradigm (which can e.g. be achieved when using http) which afaik does not specify whether the system behaviour will be RT or NRT.<br /> <p></p></span></li></ul><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">The most important item in x3d realtime is that there is the idea that there can exist a ‘cascade’ of related events that are represented as being executed instantaneously, like all at the same time, so that the simulation is accurately represented at the specified frame time.  The initial event will be created with a unique time stamp and may result in a cascade of events having the same time stamp. When all events have executed, then the frame for that time can be produced.  We don’t want the cascade broken by presenting a frame where all related events have not been completed.<p></p></span></p><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">When an x3d scene receives an external event, then the author of the external event can choose to inform the scene to either assign a time stamp then execute each event as an internal event with a unique and honest time stamp as it is received, or to buffer one or more events until released with a single time stamp.<p></p></span></p><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"> <p></p></span></p><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">Joe<p></p></span></p><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"> <p></p></span></p><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"> <p></p></span></p><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"> <p></p></span></p><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"> <p></p></span></p><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"> <p></p></span></p><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"> <p></p></span></p><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"> <p></p></span></p><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"> <p></p></span></p><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"> <p></p></span></p><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"> <p></p></span></p><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"> <p></p></span></p><div style="border:none;border-top:solid #E1E1E1 1.0pt;padding:3.0pt 0in 0in 0in"><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><b><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">From: </span></b><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"><a href="mailto:christoph.valentin@gmx.at" target="_blank">Christoph Valentin</a><br /><b>Sent: </b>Friday, March 15, 2019 2:21 AM<br /><b>To: </b><a href="mailto:x3d-public@web3d.org" target="_blank">x3d-public@web3d.org</a><br /><b>Subject: </b>Re: [x3d-public] Netw. Sens. Protocol - WAS: 3d-public Digest,Vol120, Issue 34<p></p></span></p></div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"> <p></p></span></p><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">John,<br />You addressed me directly therefore I answer to my best knowledge. If someone can improve my answer please do it.<br /><br />REST is a paradigm (which can e.g. be achieved when using http) which afaik does not specify whether the system behaviour will be RT or NRT.<br /><br />Question: Why do you ask for RT?<br /><br />Sorry, don't know the differences between WebRTC 1.0 and ORTC. Can someone else help?<br /><br />All the best<br />Christoph<br />--<br />Diese Nachricht wurde von meinem Android Mobiltelefon mit GMX Mail gesendet.<p></p></span></p><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">Am 15.03.19, 02:32, John Carlson <yottzumm@gmail.com> schrieb:<p></p></span></p><blockquote style="border:none;border-left:solid #CCCCCC 1.0pt;padding:0in 0in 0in 6.0pt;margin-left:4.8pt;margin-top:4.8pt;margin-right:0in;margin-bottom:5.0pt"><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:4.8pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">Is REST applicable in a real-time environment?<p></p></span></p><p><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"> <p></p></span></p><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:4.8pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">Should we consider ORTC?  Or WebRTC 1.0?<p></p></span></p><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:4.8pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">?<p></p></span></p><p><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"> <p></p></span></p><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:4.8pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">John<p></p></span></p><p><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"> <p></p></span></p><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:4.8pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">Sent from <a href="https://go.microsoft.com/fwlink/?LinkId=550986" target="_blank">Mail</a> for Windows 10<p></p></span></p><p><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"> <p></p></span></p><div style="border:none;border-top:solid #E1E1E1 1.0pt;padding:3.0pt 0in 0in 0in"><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:4.8pt"><b><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">From: </span></b><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"><a href="mailto:christoph.valentin@gmx.at" target="_blank">Christoph Valentin</a><br /><b>Sent: </b>Thursday, March 14, 2019 7:44 PM<br /><b>To: </b><a href="mailto:gpugroup@gmail.com" target="_blank">Doug Sanden</a><br /><b>Cc: </b><a href="mailto:x3d-public@web3d.org" target="_blank">X3D Graphics public mailing list</a><br /><b>Subject: </b>Re: [x3d-public] Netw. Sens. Protocol - WAS: 3d-public Digest,Vol120, Issue 34<p></p></span></p></div><p><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"> <p></p></span></p><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:4.8pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">>>>>>>>> such as XMPP, SIP, RTP, TCP, UDP, SCTP, MSRP, 3GPP MCX, ............<p></p></span></p><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:4.8pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"> <p></p></span></p></div><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:4.8pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">as long as it complies with the decision of the consortium to use WebRTC + AJAX, of course........<p></p></span></p></div><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:4.8pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">  <p></p></span></p><div style="border:none;border-left:solid #C3D9E5 1.5pt;padding:0in 0in 0in 8.0pt;margin-left:7.5pt;margin-top:7.5pt;margin-right:3.75pt;margin-bottom:3.75pt"><div style="margin-bottom:7.5pt"><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:12.3pt"><b><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">Gesendet:</span></b><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"> Donnerstag, 14. März 2019 um 20:46 Uhr<br /><b>Von:</b> "Christoph Valentin" <christoph.valentin@gmx.at><br /><b>An:</b> "GPU Group" <gpugroup@gmail.com><br /><b>Cc:</b> "X3D Graphics public mailing list" <x3d-public@web3d.org><br /><b>Betreff:</b> Re: [x3d-public] Netw. Sens. Protocol - WAS: 3d-public Digest, Vol120, Issue 34<p></p></span></p></div><div><div><div><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:12.3pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">Gina-Lauren, Doug,<p></p></span></p></div><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:12.3pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"> <p></p></span></p></div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:12.3pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">I know, I do not know the consortium very well and I apologize, when I mix somebody up, but AFAIK you - Doug - are the "head behind FreeWrl". <p></p></span></p><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:12.3pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"> <p></p></span></p></div><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:12.3pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">So if I address you, then I have to talk, as if I talked to a browser creator, true?<p></p></span></p></div><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:12.3pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"> <p></p></span></p></div><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:12.3pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">Why did you decide to "go for VRML/X3D"? I guess it has something to do with belief :-) , but there are reasonable pros and cons, too. I believe in VRML/X3D, because it is easy to use and very efficient. Just a few lines of definitions in a text file - and you have a box, a sphere, some light sources, and so on.<p></p></span></p></div><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:12.3pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"> <p></p></span></p></div><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:12.3pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">And you don't need to learn a programming language (thanks to declarative principle stolen :) from HTML).<p></p></span></p></div><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:12.3pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"> <p></p></span></p></div><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:12.3pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">And it is an ISO standard.<p></p></span></p></div><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:12.3pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"> <p></p></span></p></div><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:12.3pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">So if my browser supports VRML/X3D, then I can promise to my users that their work will be preserved for decades, I could even promise them they can leave me without harm, because there are enough other browsers that support the same standard (I won't do that of course).<p></p></span></p></div><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:12.3pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"> <p></p></span></p></div><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:12.3pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">The meaning of VRML/X3D is to create trust. Trust in the future of authoring of 3D scenes (which causes still a lot of efforts that we do not want to waste).<p></p></span></p></div><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:12.3pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"> <p></p></span></p></div><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:12.3pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">Now coming to the idea with the Hyper Scene and to Gina-Lauren's suggestions. I think the idea with the Hyper scene that cares for the networking is a good idea<p></p></span></p></div><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:12.3pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">   - as long as the shared state is not too complex (each value has to be transported via the "?")<p></p></span></p></div><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:12.3pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">   - as long as the Hyperscene sticks to a standard (which would need to be defined, too)<p></p></span></p></div><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:12.3pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"> <p></p></span></p></div><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:12.3pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">If the scene becomes too complex or if the scene is compiled from different sources, e.g. "module by module" and "model by model", then I would rather prefer to "bury" a network sensor within each model, just broadcasting the "network connection" to every model by an SFNode and defining the "streamName" for the network sensor, the rest would be done by the model internally.<p></p></span></p></div><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:12.3pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"> <p></p></span></p></div><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:12.3pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">Now to the misunderstaning which I have with Gina-Lauren. I often used the term "network protocol" in a wrong manner. Of course I do NOT mean a "network LAYER protocol", such as IPv4 or IPv6, but of course I mean an "application LAYER protocol".<p></p></span></p></div><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:12.3pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"> <p></p></span></p></div><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:12.3pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">I think this application layer protocol could be sketched by message flow charts and by textual description. Just which messages are defined, how are the messages combined to procedures and which parameters can the messages carry. How are the messages routed?<p></p></span></p></div><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:12.3pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"> <p></p></span></p></div><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:12.3pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">This application layer protocol should be open to (m)any transport protocol(s), such as XMPP, SIP, RTP, TCP, UDP, SCTP, MSRP, 3GPP MCX, ............<p></p></span></p></div><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:12.3pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"> <p></p></span></p></div><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:12.3pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">Such a stable description and the promise to support any transport protocol would create trust in X3D MU.<p></p></span></p></div><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:12.3pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"> <p></p></span></p></div><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:12.3pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">All the Best<p></p></span></p></div><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:12.3pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">Christoph<p></p></span></p></div><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:12.3pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">  <p></p></span></p><div style="border:none;border-left:solid #C3D9E5 1.5pt;padding:0in 0in 0in 8.0pt;margin-left:7.5pt;margin-top:7.5pt;margin-right:3.75pt;margin-bottom:3.75pt"><div style="margin-bottom:7.5pt"><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:19.8pt"><b><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">Gesendet:</span></b><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"> Donnerstag, 14. März 2019 um 17:53 Uhr<br /><b>Von:</b> "GPU Group" <gpugroup@gmail.com><br /><b>An:</b> "X3D Graphics public mailing list" <x3d-public@web3d.org><br /><b>Betreff:</b> Re: [x3d-public] Netw. Sens. Protocol - WAS: 3d-public Digest, Vol120, Issue 34<p></p></span></p></div><div><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:19.8pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">One very fuzzy idea: HyperScene (HS) <p></p></span></p><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:19.8pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">- one layer above scene<p></p></span></p></div><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:19.8pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">- networking would/could work on this layer ie <p></p></span></p></div><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:19.8pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">Scene -?- HS - network - HS - ? - Scene<p></p></span></p></div><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:19.8pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">- with the ? being maybe EAI/SAI and/or DISTransform-like node updater<p></p></span></p></div><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:19.8pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">- the LayeringComponent - some have been asking if it could/should be dropped or fixed, and maybe if fixing, it might relate to a layer above scene also<p></p></span></p></div><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:19.8pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">HS - Layering - Scene<p></p></span></p></div><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:19.8pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">And maybe 2 scene instances rendering on the same web page or side-by-side in one desktop browser instance might be on some layer above scene, such as Layering or HyperLayering.<p></p></span></p></div><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:19.8pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">But sorry I can't explain any deeper. Its all fuzzy thinking.<p></p></span></p></div><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:19.8pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">-Doug Sanden<p></p></span></p></div></div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:19.8pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">  <p></p></span></p><div><div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:19.8pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">On Tue, Mar 12, 2019 at 2:37 PM GL <<a href="mailto:info@3dnetproductions.com" target="_blank">info@3dnetproductions.com</a>> wrote:<p></p></span></p></div><blockquote style="border:none;border-left:solid #CCCCCC 1.0pt;padding:0in 0in 0in 6.0pt;margin-left:4.8pt;margin-top:5.0pt;margin-right:0in;margin-bottom:5.0pt"><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:24.6pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"><br /><br />Christoph,<br /><br />Personally, I don't think the NS should impose a network protocol standard at all. Instead, it should allow for as much flexibility as possible, remembering that we don't necessarily work within a web browser, and that present and future applications may involve different types of hardware and/or protocols not thought of, yet widely in use, or available today. We don't have to define implementations, but just leave the door open so to speak, so that vendors and authors may build what they need without the standard getting in the way.<br /><br />However, at a higher level, if we want different 3D implementations to be able to communicate with each other, there would be a need to have a standard way of making worlds, avatars, objects, etc. compatible at the network level. In that case, we could envision an X3D application layer protocol (perhaps thinking of ftp, smtp, http, etc, but explicit to X3D), independently of the network transport layer, while the emphasis remains on flexibility. That being said, provide a set of mechanisms, a structure for conduits and data tunnels, but what passes through it should probably largely be left undefined as far as a standard is concerned, as long as the format is true to X3D form.<br /><br />It would be nice to have data transmissions more defined, but the world being what it is and constantly evolving, I doubt we'd ever get there. I'd say "let the market forces play and the chips fall where they may".<br /><br />So I am not too sure how to answer your question. I think that is what we are trying to figure out. Cheerz<br /><br />GL<br /><br /><br />________________________________________________________<br />* * * Interactive Multimedia - Internet Management * * *<br />  * *  Virtual Reality -- Application Programming  * *<br />    *   3D Net Productions  <a href="http://3dnetproductions.com" target="_blank">3dnetproductions.com</a>   *<br /><br /><br /><br /><br />From: x3d-public [mailto:<a href="mailto:x3d-public-bounces@web3d.org" target="_blank">x3d-public-bounces@web3d.org</a>] On Behalf Of Christoph Valentin<br />Sent: Monday, March 11, 2019 4:21 AM<br />To: <a href="mailto:x3d-public@web3d.org" target="_blank">x3d-public@web3d.org</a><br />Subject: Re: [x3d-public] Netw. Sens. Protocol - WAS: 3d-public Digest, Vol120, Issue 34<br /><br />Hi Gina-Lauren, Hi John<br /><br />>>>>>>But yeah, whatever the browser vendors support as a standard would be OK with me.<br /><br />John, You speak as a scene author, don't you? So you don't care, which Network Protocol the browser uses.<br /><br />I understand that, because I am a scene author, too.<br /><br />Now, what is the position of the Browser vendor?<br /><br />Wouldn't the Browser vendor say the same? "Whatever the server Vendor supports as standard, would be Ok with me?"<br /><br />@Gina-Lauren: What would you like to support as standard? Just to have an example.<br /><br />Just my 2c<br /><br />:-) Christoph<br /><br /><br /><br />--<br />Diese Nachricht wurde von meinem Android Mobiltelefon mit GMX Mail gesendet.<br />Am 11.03.19, 08:09, Christoph Valentin <<a href="mailto:christoph.valentin@gmx.at" target="_blank">christoph.valentin@gmx.at</a>> schrieb:<br />Hi Gina-Lauren, John, Andreas,<br /><br />Now seriously.<br /><br />Given the Network Sensor (or however it would be called), i.e. the syntax of how to instantiate the related nodes in a Web3D scene , was specified sufficiently (e.g. in X3Dv4)<br /><br />there would still be a lot to be defined regarding how to connect to the server, connect to a server at all, use a star topology or support server hierarchy and so on.<br /><br />If those decisions were left to the implementors of Web3D browsers (and libraries), then the market would fall apart again, as soon as it starts to bloom.<br /><br />The standard doesn&apos;t need to be technically perfect, but it must be well regarded.<br /><br />Just philosophy:-)<br /><br />Just my personal opinion :-)<br /><br />(And meanwhile we can use open-dis ;-) )<br />--<br />Diese Nachricht wurde von meinem Android Mobiltelefon mit GMX Mail gesendet.<br />Am 11.03.19, 07:41, John Carlson <<a href="mailto:yottzumm@gmail.com" target="_blank">yottzumm@gmail.com</a>> schrieb:<br />I wish there was a reviewing site for open source software.  With both developer and end-user reviews (separate).<br /><br />John<br /><br />Sent from Mail for Windows 10<br /><br />From: Christoph Valentin<br />Sent: Monday, March 11, 2019 12:36 AM<br />To: John Carlson; <a href="mailto:x3d-public@web3d.org" target="_blank">x3d-public@web3d.org</a><br />Subject: RE: [x3d-public] Netw. Sens. Protocol - WAS: 3d-public Digest, Vol120, Issue 34<br /><br /><!-- /* 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;} --><br /><br />>>>>>>May I suggest a CSV-like protocol across the https or TLS/SSL network, similar to:<br /><br /><br /><br />(SSL-initiation)<br /><br />COMMAND1,TIME1,PARAMETER1,PARAMETER2,..\r\n<br /><br />COMMAND2,TIME2,PARAMETER3,PARAMETER4,…\r\n<br /><br />…<br /><br />[Christoph:] I think it depends on the KIND of state/event you want to transmit. If the state does not change very often (let's say every second), then a text based protocol will be the right choice. If you had a state that changed in real time (position of a jet plane) , then I'd think about somthing like an RTP stream (real time protocol). Anyway, the first step is to agree THAT the protocol should be standardized.<br /><br /><br /><br /><br />>>>>>>Will that satisfy the network nazis?<br /><br /> [Christoph] I always thought the term Network Sensor (NS) was a bad choice :-)<br /><br /><br /><br />>>>>>>>What type of constrictions do we have to jump through to satisfy network ops?  Should we make the protocol look just like an Excel file? </span><span style="font-size:9.0pt;font-family:"Segoe UI Emoji",sans-serif">😊😊</span><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">  Just wait until the first executive gets his excel file stopped by a network filter </span><span style="font-size:9.0pt;font-family:"Segoe UI Emoji",sans-serif">😊</span><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">.<br /><br /> [Christoph]: I'd suggest to use SIP as signaling protocol, but this is my personal opinion. I'm not supported by my employer nor by my former employer.<br /><br /><br />--<br />Diese Nachricht wurde von meinem Android Mobiltelefon mit GMX Mail gesendet.<br /><br />Am 11.03.19, 06:07, John Carlson <<a href="mailto:yottzumm@gmail.com" target="_blank">yottzumm@gmail.com</a>> schrieb:<br /><br />May I suggest a CSV-like protocol across the https or TLS/SSL network, similar to:<br /><br /><br /><br />(SSL-initiation)<br /><br />COMMAND1,TIME1,PARAMETER1,PARAMETER2,..\r\n<br /><br />COMMAND2,TIME2,PARAMETER3,PARAMETER4,…\r\n<br /><br />…<br /><br /><br /><br />Will that satisfy the network nazis?<br /><br /><br /><br />Also, we might use a STEP/EXPRESS-like format, if we want a hierarchical format.<br /><br /><br /><br />Can we leverage X3DUOM-style XSD and our tools to create APIs?<br /><br /><br /><br />What type of constrictions do we have to jump through to satisfy network ops?  Should we make the protocol look just like an Excel file? </span><span style="font-size:9.0pt;font-family:"Segoe UI Emoji",sans-serif">😊</span><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"> </span><span style="font-size:9.0pt;font-family:"Segoe UI Emoji",sans-serif">😊</span><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">  Just wait until the first executive gets his excel file stopped by a network filter </span><span style="font-size:9.0pt;font-family:"Segoe UI Emoji",sans-serif">😊</span><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">.<br /><br /><br /><br />Maybe not, huh?<br /><br /><br /><br />What types of interactions do we want to support?<br /><br /><br /><br />John<br /><br /><br /><br /><br /><br />Sent from Mail for Windows 10<br /><br /><br /><br />From: Christoph Valentin<br />Sent: Sunday, March 10, 2019 10:34 PM<br />To: <a href="mailto:x3d-public@web3d.org" target="_blank">x3d-public@web3d.org</a><br />Subject: Re: [x3d-public] x3d-public Digest, Vol 120, Issue 34<br /><br /><br /><br />>>>>>>It may be time to come up with some proof of concept implementations of nodes or infrastructure around a scene using web technology before more thought experiments.<br /><br /><br /><br />>>>>>Andreas,<br /><br />I don't mean to interject in your conversation, but my earlier comments (below) were not merely "thought experiments". Most of everything I've talked about is already implemented and working at <a href="http://officetowers.com" target="_blank">officetowers.com</a> (The server is currently suffering from a database malfunction, so login is not currently possible until next week, but I can assure you. Meanwhile, videos are available if you'd like to see them).<br /><br />That world and its associated X3Daemon multiuser server, have been ready for a network sensor for years. But before potentially spending hundreds of hours in implementing one in a new version based on more modern practices and available technologies, I'd like to see what we can come up with as a consensus.<br /><br />What is exactly a network sensor? What are its functions? Within what boundaries and parameters? Do we refer to the earlier draft (when work on it stopped) as a basis? IMO, those are some of the questions that need answers before we can contemplate creating specs for a NS.<br /><br />Cheerz,<br />Gina-Lauren<br /><br /><br /><br />[Christoph]<br /><br />Hi Gina-Lauren, Hi Andreas,<br />It's me, who should not disturb fruitful discussion here, but waiting for Andreas' response I'd like to add my two cents.<br /><br />Just assume the members could agree on a test setup and they could motivate enough manpower to "do it".<br /><br />A) How could such test setup look like?<br /><br />B) Assuming the test setup and the specs would be developed in parallel, what would we need from the specs?<br /><br />As I said, just my 2c.<br /><br />Have good luck :-)<br />Christoph<br /><br />Am 11.03.19, 03:38, GL <<a href="mailto:info@3dnetproductions.com" target="_blank">info@3dnetproductions.com</a>> schrieb:<br /><br /><br />>It may be time to come up with some proof of concept implementations of nodes or infrastructure around a scene using web technology before more thought experiments.<br /><br /><br /><br />Andreas,<br /><br />I don&apos;t mean to interject in your conversation, but my earlier comments (below) were not merely "thought experiments". Most of everything I&apos;ve talked about is already implemented and working at <a href="http://officetowers.com" target="_blank">officetowers.com</a> (The server is currently suffering from a database malfunction, so login is not currently possible until next week, but I can assure you. Meanwhile, videos are available if you&apos;d like to see them).<br /><br />That world and its associated X3Daemon multiuser server, have been ready for a network sensor for years. But before potentially spending hundreds of hours in implementing one in a new version based on more modern practices and available technologies, I&apos;d like to see what we can come up with as a consensus.<br /><br />What is exactly a network sensor? What are its functions? Within what boundaries and parameters? Do we refer to the earlier draft (when work on it stopped) as a basis? IMO, those are some of the questions that need answers before we can contemplate creating specs for a NS.<br /><br />Cheerz,<br />Gina-Lauren<br /><br /><br />________________________________________________________<br />* * * Interactive Multimedia - Internet Management * * *<br />* * Virtual Reality -- Application Programming * *<br />* 3D Net Productions <a href="http://3dnetproductions.com" target="_blank">3dnetproductions.com</a> *<br /><br /><br /><br /><br /><br />Hello Andreas, Christoph and all,<br /><br /><br />>I looked at the network sensor, and BS Collaborate nodes. I think the idea is to explicitly forward all events which need sharing to the server which then distributes those to connected clients.<br /><br /><br />I&apos;d say it&apos;s a fair assessment, though there are also a little more, behind the scene events, such as avatar authentication, login/logout, standby/resume status, and other similar network connections that are not necessarily shared in the scene per say.<br /><br /><br /><br />>This leaves the definition of the shared state to the scene, and therefore requires careful design and code for MU. Perhaps there is a way that the browser can better assist with making a scene MU capable.<br /><br /><br />X3D is very capable of doing this internally, but I&apos;d definitely want it to have its own script node. It may be possible to pass simple events through the browser, but that solution would impose severe limits to the ability to perform multiuser tasks in general. I mean, it can get convoluted enough as it is, without adding the extra complexity of passing events and network connections back and forth through the browser. I understand it isn&apos;t easy, but if it can be done, we probably should do it.<br /><br /><br /><br /><br />>What is the complete state a client needs when it is admitted to a shared scene ?<br /><br /><br />From my experience, that will depend very much on the use case, but generally, the scene is complete within each client, though avatars and/or objects may be hidden and not necessarily seen at any given time. When the client connects to the shared network, that&apos;s pretty much when state is established. There may be exceptions to that, for example when an avatar has a specific identity and/or status in a game or accumulated points, that information will typically first be obtained from the server&apos;s database, before being passed on to the client and in turn to the network.<br /><br /><br /><br />>Since most fields of most nodes accept input, and can therefore potentially change, complete state probably means just the value of all fields of all root nodes which means all nodes. The complete state may only need to be transferred when a client joins.<br /><br /><br />Ditto. Yes exactly. See above.<br /><br /><br /><br />>Plus the offsets of avatars from Viewpoints. And the clock. Perhaps other values.<br /><br /><br />Again yes, so avatars don&apos;t end up on top of each other for example.<br /><br />As far as a clock, I have never shared one or felt I needed to thus far. In my implementation, each client simply polls the server at regular intervals of one, two or more seconds (depending what other subsystems are in place). We sometimes cannot allow a client which is experiencing latency for one reason or another, to hold back all of the other clients. The show must go on, whether a client gets disconnected or happens to get out of sync. It generally seems to have little impact, since, at least in some cases, users are not together in one room. So they are in essence unaware that they are out of sync, as the case may be.<br /><br />But, I can see how specific applications may need and would want to have a clock. And in that case, I believe we should take a good look at what the MIDI standard has to offer. MIDI is a well established and solid standard that has many uses for timing and control, not just music, and is more than likely a very good fit for virtual reality.<br /><br /><br /><br />>I was thinking about avatar initiated event cascades since the state of everything else should be deterministic and only depend on time. These other things should update themselves. There are exceptions such as scripts which generate random values.<br /><br /><br />Avatars with gestures, and also all kind of visible objects, such as doors, cars, elevators (that&apos;s a tough one), a cup of coffee, a guitar, clouds, stars and anything else that moves. But also various more subtle things like say group chat, or items inside pockets or bags, money, ammunition and things of that nature also need shared states, and sometimes to various levels of privacy.<br /><br /><br /><br />>Avatar initiated event cascades generally start with environment sensors. Not sure if there are other ways. The idea would be to just have to transmit this event cascade to other clients which then can replay it to update their scene instances.<br /><br /><br />Sure. General user interactions with the world and its interface, such as buttons and inworld devices, often need to be shared as well.<br /><br /><br />>I also was reading some of the github open-dis documentation. Interesting background, and pretty accurate discussion on coordinate systems. It may be possible to set up somewhere a very simple distributed simulation to join and test clients with.<br /><br /><br />I remember the DIS-Java-VRML work. That was very good. I will take a closer look at Open DIS as you mentioned. It sounds interesting. As I began to touch above, each MU implementation will have their own particularities. Personally, I would very much like to see a general NetworkSensor node that would be flexible enough to accommodate different protocols, but also one that has the ability to be adapted to specific use case and needs.<br /><br /><br /><br />>Single browser MU: I think an additional touchedByUser field would be required but perhaps there is a way to generalize tracking of Users.<br /><br /><br /><br />I don&apos;t know if it&apos;s possible, but I&apos;d like to see the possibility to add any number of fields to the network node. Fields that would be defined by each implementation as needed, as we may not be able to always predict its application.<br /><br /><br />I feel there is much more to discuss, and I&apos;d re-iterate my suggestion to open a NetworkSensor group or similar, so as to allow for more detailed exchanges and begin to have some basis for VR networking.<br /><br />Gina-Lauren<br /><br /><br />P.S. Your work with Python is very interesting and falls in line with some of my own thoughts.<br /><br />________________________________________________________<br />* * * Interactive Multimedia - Internet Management * * *<br />* * Virtual Reality -- Application Programming * *<br />* 3D Net Productions <a href="http://3dnetproductions.com" target="_blank">3dnetproductions.com</a> *<br /><br /><br /><br /><br /><br /><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" target="_blank">http://web3d.org/mailman/listinfo/x3d-public_web3d.org</a><br /><br /><br /><br />_______________________________________________ x3d-public mailing list <a href="mailto:x3d-public@web3d.org" target="_blank">x3d-public@web3d.org</a> <a href="http://web3d.org/mailman/listinfo/x3d-public_web3d.org" target="_blank">http://web3d.org/mailman/listinfo/x3d-public_web3d.org</a><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" target="_blank">http://web3d.org/mailman/listinfo/x3d-public_web3d.org</a><p></p></span></p></blockquote></div><p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;margin-left:19.8pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">_______________________________________________ x3d-public mailing list x3d-public@web3d.org <a href="http://web3d.org/mailman/listinfo/x3d-public_web3d.org" target="_blank">http://web3d.org/mailman/listinfo/x3d-public_web3d.org</a><p></p></span></p></div></div></div></div></div></div></div></div><p class="MsoNormal" style="mso-margin-top-alt:auto;margin-right:3.75pt;margin-bottom:3.75pt;margin-left:12.3pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif">_______________________________________________ x3d-public mailing list x3d-public@web3d.org <a href="http://web3d.org/mailman/listinfo/x3d-public_web3d.org" target="_blank">http://web3d.org/mailman/listinfo/x3d-public_web3d.org</a><p></p></span></p></blockquote></div><p style="margin-left:4.8pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"> <p></p></span></p></div></div></div></div></div><p class="MsoNormal" style="mso-margin-top-alt:auto;margin-right:3.75pt;mso-margin-bottom-alt:auto;margin-left:7.5pt"><span style="font-size:9.0pt;font-family:"Verdana",sans-serif"> <p></p></span></p><p class="MsoNormal"></p><p> </p></div></blockquote></div></body></html></body></html>