<div><div dir="auto">Michael, have you looked recently at LiveCode script? I believe it has an export to HTML5 now, besides running under practically every platform on the planet. Live code is the descendant of HyperCard/HyperTalk/MetaCard/MetaTalk/xTalk.</div><div dir="auto"><br></div><div dir="auto">John</div></div><div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Tue, Jul 21, 2020 at 2:44 AM Michael Turner <<a href="mailto:michael.eugene.turner@gmail.com">michael.eugene.turner@gmail.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-style:solid;padding-left:1ex;border-left-color:rgb(204,204,204)">I didn't quite follow all that, Joseph, perhaps mostly because I'm<br>
pretty ignorant when it comes to whatever magical powers X3D might<br>
have.<br>
<br>
If it helps, skip all my meandering philosophy in this essay ("Natural<br>
Semantic Programming") by searching on Towers of Hanoi.<br>
<br>
<a href="https://docs.google.com/document/d/1CWpals3OBWgAC8OcWuWBhLoxjgpE-khxxT33NnFnzm8/edit" rel="noreferrer" target="_blank">https://docs.google.com/document/d/1CWpals3OBWgAC8OcWuWBhLoxjgpE-khxxT33NnFnzm8/edit</a><br>
<br>
There, I hypothesize a situation where a blind child prodigy listens<br>
over the phone to the NSP program being read, a version that doesn't<br>
have "Towers of Hanoi" named as such in the code, and realizes what<br>
game it is -- and writes an animation into the code. I suppose that,<br>
with enough NSM definition of what a human is, and how a human body is<br>
constrained, the animation could include a human figure actually<br>
moving the disks from peg to peg.<br>
<br>
To be sure, I have no complete parser for what I wrote there -- it's<br>
an NSM-constrained pseudocode exercise. That said, NSM-DALIA<br>
<br>
<a href="https://github.com/Yakushima/NSM-DALIA" rel="noreferrer" target="_blank">https://github.com/Yakushima/NSM-DALIA</a><br>
<br>
might not be too far from parsing something very close to this<br>
pseudocode and executing a specialized parse tree as Prolog. I got<br>
NSM-DALIA working again (John helped a little at one point) and as far<br>
as I know, it's the only working software that can parse NSM and<br>
translate NSM to other natural-language NSM descriptions.<br>
<br>
My goals are two-fold:<br>
<br>
-- a programming language that uses natural language in a common-sense<br>
way (though allowing for the more-or-less universal syntax of<br>
mathematics where things truly need to be mathematically expressed)<br>
<br>
-- a system that depends on no /particular/ natural language. Programs<br>
are represented as meanings, and are parsed into that semantic<br>
representation and re-generated with appropriate vocabulary and<br>
"natural-language syntactic sugar" as required, depending on the users<br>
preferred or native language.<br>
<br>
I'm not at all sure what this could have to do with X3D. I think the<br>
more natural first area of commercial application of Natural Semantic<br>
Programming would be as a kind of "meta-COBOL" constraint-oriented<br>
programming language, for enterprises that need to operate more<br>
smoothly across language barriers. For 3D animation, I suppose that<br>
internationally distributed machine repair would bring in some need<br>
for graphics with constraint programming. For example, animate "here's<br>
how you swap the old part out and put in a new one", with an animation<br>
that allows the trainee to zoom and pan and even to focus in so far<br>
that the he can see slow-motion/stop-motion finger-level details of a<br>
repair or maintenance procedure.<br>
<br>
Regards,<br>
Michael Turner<br>
Executive Director<br>
Project Persephone<br>
1-25-33 Takadanobaba<br>
Shinjuku-ku Tokyo 169-0075<br>
Mobile: +81 (90) 5203-8682<br>
<a href="mailto:turner@projectpersephone.org" target="_blank">turner@projectpersephone.org</a><br>
<br>
Understand - <a href="http://www.projectpersephone.org/" rel="noreferrer" target="_blank">http://www.projectpersephone.org/</a><br>
Join - <a href="http://www.facebook.com/groups/ProjectPersephone/" rel="noreferrer" target="_blank">http://www.facebook.com/groups/ProjectPersephone/</a><br>
Donate - <a href="http://www.patreon.com/ProjectPersephone" rel="noreferrer" target="_blank">http://www.patreon.com/ProjectPersephone</a><br>
Volunteer - <a href="https://github.com/ProjectPersephone" rel="noreferrer" target="_blank">https://github.com/ProjectPersephone</a><br>
<br>
"Love does not consist in gazing at each other, but in looking outward<br>
together in the same direction." -- Antoine de Saint-Exupéry<br>
<br>
On Mon, Jul 20, 2020 at 10:42 PM Joseph D Williams<br>
<<a href="mailto:joedwil@earthlink.net" target="_blank">joedwil@earthlink.net</a>> wrote:<br>
><br>
><br>
><br>
> it's hard for me to understand how this would<br>
> apply immediately to X3D<br>
><br>
><br>
><br>
> However you can specify actual content by an author producing some combinations of abstract and strictly defined indication of what visualization is desired, then sooner or later we want some human and machine readable user code to examine, validate, and execute. If the author’s intent is to produce an interactive environment then first the author needs to understand available objects and interactions. If we place an interactive humanoid in the environment, then we need to be able to define its features. The application to x3d happens when we form the links between aspects of the environment and the humanoid the author wishes to define using some interaction with some authoring system then the authoring system delivers some realtime simulation of the author’s intent. The x3d is in the parts where something relates intent to some constructed object somewhere and transportable user code. Where else than x3d can we find such a fine linkage between the concrete or abstract object the author wishes to produce and actual user code representation of some device or interaction?<br>
><br>
> For humanoids, he author might need some hints to begin to define the character, then some more to define some standard behaviors. Where else than x3d is there the possibility to, for example, interrogate the use code in order to find usage of certain objects and observed events? When categorizing scene contents by examination of included hierarchies and events, where else than x3d would you find the base user code generator vocabulary with such a direct connection with actual graphics elements, whatever you might be searching for, and whatever author actions might be used to specify content and interactions?<br>
><br>
><br>
><br>
> interpreter -> compiler -> Humanoid Animation<br>
><br>
><br>
><br>
> For hanim, of course we ought be to be able to find ”kicking ball with skin” for example and find something, bring it to the system, and see if it can be used directly or modified. This is the part where there is data out there that must be captured and turned into some usable information, then analyzed and categorized into some knowledge, so we can find examples of usable humanoids that can be studied until they are wise enough for actual application of generating some more data. T every step of this our x3d basic stuff and hanim offers a link between what the author or character might be looking for and what is available. Whatever quack the author might use, there is probably a semantic method for finding it using terms for items and interactions, even though connections may depend upon commentary and metadata in the accessible catalog of connections.<br>
><br>
> Thanks,<br>
><br>
> Joe<br>
><br>
><br>
><br>
><br>
><br>
> From: John Carlson<br>
> Sent: Friday, July 17, 2020 2:19 PM<br>
> To: Michael Turner<br>
> Cc: Joe D Williams; X3D Semantic Web Working Group<br>
> Subject: Re: interpreter -> compiler -> Humanoid Animation<br>
><br>
><br>
><br>
> •step up on stump•<br>
><br>
> I think what I was proposing was NSM for a semantic language of X3D. I don’t think I made that clear. Again, movies, symbols and shapes; what languages or mishmashes can handle all of them without a serious amount of work? No, I don’t want to go backwards like the web did. Now that the web has begun to catch up, what can we do with it? What steps can we take to improve it?<br>
><br>
><br>
><br>
> My goal here is to integrate vector, character and raster, among other things, or at least raise awareness. PostScript/PDF has done it. 3D graphics has not typically supported text as a first class citizen, and the web and NSM have not typically supported 3D graphics as a first class citizen. I don’t want to see further “mistakes” like that. I want to lower barriers, not raise them.<br>
><br>
><br>
><br>
> I believe that one of the things Bruce Garner, Nik Mitschkowitz, Don Vickers and Carolyn Wimple were working on was the integration of STEP and CGM with SGML. I do not know why that was not made widespread. Perhaps there was competition with HP and Adobe? I am sorry I was not more clued into their project. I understand now!<br>
><br>
><br>
><br>
> NSM has more history than OWL/RDF/Turtle and should be considered!<br>
><br>
><br>
><br>
> John<br>
><br>
><br>
><br>
><br>
><br>
> On Fri, Jul 17, 2020 at 1:17 PM Michael Turner <<a href="mailto:michael.eugene.turner@gmail.com" target="_blank">michael.eugene.turner@gmail.com</a>> wrote:<br>
><br>
> So I skipped to the last paragraph, as John suggested. To the rest of<br>
> you: John's understanding of Natural Semantic Metalanguage (NSM) is<br>
> limited. From my more informed stance on NSM (and from some very<br>
> limited acquaintance with X3D) can say categorically: X3D is not "the<br>
> NSM of graphics."<br>
><br>
> While I'm interested in attempting what I call Natural Semantic<br>
> Programming (that is, programming built up in a declarative style, in<br>
> natural language, and executed with constraint solvers, perhaps Prolog<br>
> or ECLiPSe to start), it's hard for me to understand how this would<br>
> apply immediately to X3D. Nor can I understand why any X3D standards<br>
> developer or user would care.<br>
><br>
> Any NSM-based computational framework that's capable of 3D graphical<br>
> animation would probably need start with "what is a bit?" and build up<br>
> from there, through floating point computation and matrix math. That's<br>
> hardly a good starting point for anything like humanoid animation at<br>
> this point. The main advantage of NSM would be to enable interlingual<br>
> programming that's not just highly accessible not only to<br>
> non-programmers, but interlingually so -- programs described in one<br>
> natural language could be readily translatable to another.<br>
><br>
> John tried to interest me in sign language, and fair enough: sign<br>
> languages are natural languages. But to go from (say) English straight<br>
> to some sign language seemed to freight my Natural Semantic<br>
> Programming agenda with an elaborate graphical aspect at a time when<br>
> that agenda was still just a twinkle in my (inner) eye.<br>
><br>
> Long story short: you can safely ignore all this.<br>
><br>
> Regards,<br>
> Michael Turner<br>
> Executive Director<br>
> Project Persephone<br>
> 1-25-33 Takadanobaba<br>
> Shinjuku-ku Tokyo 169-0075<br>
> Mobile: +81 (90) 5203-8682<br>
> <a href="mailto:turner@projectpersephone.org" target="_blank">turner@projectpersephone.org</a><br>
><br>
> Understand - <a href="http://www.projectpersephone.org/" rel="noreferrer" target="_blank">http://www.projectpersephone.org/</a><br>
> Join - <a href="http://www.facebook.com/groups/ProjectPersephone/" rel="noreferrer" target="_blank">http://www.facebook.com/groups/ProjectPersephone/</a><br>
> Donate - <a href="http://www.patreon.com/ProjectPersephone" rel="noreferrer" target="_blank">http://www.patreon.com/ProjectPersephone</a><br>
> Volunteer - <a href="https://github.com/ProjectPersephone" rel="noreferrer" target="_blank">https://github.com/ProjectPersephone</a><br>
><br>
> "Love does not consist in gazing at each other, but in looking outward<br>
> together in the same direction." -- Antoine de Saint-Exupéry<br>
><br>
> On Thu, Jul 16, 2020 at 11:01 PM John Carlson <<a href="mailto:yottzumm@gmail.com" target="_blank">yottzumm@gmail.com</a>> wrote:<br>
> ><br>
> ><br>
> > Don, all, would it be possible to get the X3DUOM as RDF/Turtle (just as an interesting exercise)? Thanks!<br>
> ><br>
> > Michael,<br>
> ><br>
> > TL;DR; Just read last paragraph if you like.<br>
> ><br>
> > The subject basically describes all the technology I've been describing to you. I have never achieved a complete compiler to machine code for a general language. It's possible that I've created a bytecode interpreter using the translator flat file format converted to compileable/interpretable C++ variable declarations. I did at one point, expand branches into the steps a branch would take as a C++ function, but went no further and backed out, primarily because I wanted to decompile the code. I was able to compare the flat file to the decompiled code by re-persisting the programs, to verify the source code generator.<br>
> ><br>
> > This is how I am a languages guy, I guess. I am not a big Natural Semantic Metalanguage (NSM) fan, but if NSM statements can be couched in the terms of persistent objects or class grammar (even list of lists...of primes--the obvious choice), and can fulfill the last paragraph, I would be interested in exploring the NSM concept for whatever purpose you want.<br>
> ><br>
> > As a side note, I state that I've been able to convert documents to lists of lists of words. I merely used something like PDF->HTML, and converted HTML div's to JSON (JavaScript Object Notation) arrays. I wanted to do JSON translation-by-demonstration and I had an existing data source. We can have a very large supply of documents represented as JSON arrays, if we need it. I realize that NSM-DALIA takes English.<br>
> ><br>
> > I guess we're dealing with a *semantic* object model and *semantic* graph with NSM. The Web3D consortium is currently working with RDF/Turtle I believe. There's also OWL/OWL2. I should be able to provide you with around 3000 .ttl (RDF/Turtle) files in a single domain (X3D) translated from XML: <a href="https://www.web3d.org/x3d/content/examples/X3dResources.html#Examples" rel="noreferrer" target="_blank">https://www.web3d.org/x3d/content/examples/X3dResources.html#Examples</a> (try Online link, .ttl is on right for individual scenes). Did you send me an NSM Bible at one point? Can we translate RDF/Turtle to NSM?<br>
> ><br>
> > Ah yes! <a href="https://openresearch-repository.anu.edu.au/bitstream/1885/155252/2/What%20Christians%20Believe%20for%20Open%20Research%2020190204.pdf" rel="noreferrer" target="_blank">https://openresearch-repository.anu.edu.au/bitstream/1885/155252/2/What%20Christians%20Believe%20for%20Open%20Research%2020190204.pdf</a><br>
> ><br>
> > I'm not saying that RDF/Turtle is even desirable. I just have a bunch of XML files (X3D scenes--non-RDF) I'd like to convert to their processable semantics. We may have to improvise some of the semantics, that is, someone converts animations to semantics, such as "walk." (I know this isn't an NSM prime. I want something like "move from point to point upright at normal speed using legs") It's very likely we would have to have thousands of walk examples, and many more with "not walk", and do some kind of supervised learning with current technology that I've seen (I need to think about adversarial networks, here). It may be possible to convert each NSM prime to an animation, IDK. I tried both the dictionary approach (word->video) and the SignWriting approach (word->icons)<br>
> ><br>
> > I know NSM is about breaking down larger structures into simpler ones. Say I'd like to reduce the X3D to VR/AR animations (assume for conversion to a 4D printer/animatronics). If NSM-DALIA would help with that, I'm all ears. If we can even create animations from NSM phrases (skipping the X3D), that would be awesome! Can we create an animation of Towers of Hanoi from the NSM code in your Natural Semantic Programming paper?<br>
> ><br>
> > Yes, I realize you assigned me that very goal with translating a single word to an animation, which I have not achieved yet.<br>
> ><br>
> > In other words, we need to extend NSM to handle virtual worlds, or satellite worlds, not only human worlds, right? How does one describe a virtual world in NSM? We have Towers of Hanoi. We can obviously use any language we like as long as it can be reduced to NSM primes.<br>
> ><br>
> > The HAnim (Humanoid Animation) ISO standard: <a href="https://www.web3d.org/documents/specifications/19774/V2.0/index.html" rel="noreferrer" target="_blank">https://www.web3d.org/documents/specifications/19774/V2.0/index.html</a> has been ratified. We now need examples of HAnimMotion (.bvh) elements. This is my other job.<br>
> ><br>
> > The difficulty in all of this is translating from spatiotemporal semantics (geometry, coordinates, etc.) to/from NSM semantics. The NSM primes for this are:<br>
> ><br>
> > Time: WHEN/TIME, NOW, BEFORE, AFTER, A LONG TIME, A SHORT TIME, FOR SOME TIME, MOMENT<br>
> ><br>
> > Space: WHERE/PLACE, HERE, ABOVE, BELOW, FAR, NEAR, SIDE, INSIDE, TOUCH (CONTACT)<br>
> ><br>
> > Thus, there are three kinds of "output," movies, symbols, and shapes. NSM handles symbols. What handles movies and shapes? X3D! I don't care if it's VRML, XML, JSON, Turtle, Python, JavaScript, Java ... X3D is the NSM of graphics! Now, how can NSM and X3D work together?<br>
> ><br>
> > John<br>
><br>
><br>
</blockquote></div></div>