Shop OBEX P1 Docs P2 Docs Learn Events
Starting FORTH -- Running GForth and Tachyon Side-by-Side — Parallax Forums

Starting FORTH -- Running GForth and Tachyon Side-by-Side

JonnyMacJonnyMac Posts: 9,104
edited 2018-02-16 22:51 in Propeller 1
Okay, I'm going spend my lunches for the next month or so wrapping my head around Forth. Despite its age, Starting Forth seems to get the most recommendations. Was motoring right along until the book used this definition...
: STARS  0 DO STAR LOOP ;
I see a note in the Tachyon about FOR NEXT but am having trouble locating syntax rules.

Well, darn, I make the post, play for another minute, and then sort it out:
: STARS  FOR STAR NEXT;


Comments

  • JonnyMac wrote: »
    Okay, I'm going spend my lunches for the next month or so wrapping my head around Forth. Despite its age, Starting Forth seems to get the most recommendations. Was motoring right along until the book used this definition...
    : STARS  0 DO STAR LOOP ;
    
    I see a note in the Tachyon about FOR NEXT but am having trouble locating syntax rules.

    Well, darn, I make the post, play for another minute, and then sort it out:
    : STARS  FOR STAR NEXT;
    

    Try typing into Tachyon without creating a definition
    20 FOR STAR NEXT
    
    The other thing is that you can still treat a FOR NEXT the same way as DO LOOP in that you can reference the index I, LEAVE when you want, step the index BY an amount, and change the starting index FROM the default of 0 etc.
    $20 FROM 95 FOR I EMIT NEXT
    
    The equivalent in GForth would have to be within a definition so it would look like this:
    : ASCII    $7F $20 DO I EMIT LOOP ;
    ASCII
    
    I'm bringing up the Introduction to Tachyon page and I will go through that to make sure it is up to date but any feedback you can give me on what I might have overlooked will be appreciated.

  • JonnyMacJonnyMac Posts: 9,104
    edited 2018-02-17 02:02
    deleted
  • Jon, it's been a couple of years since I played around with Forth, but if you want to run the sample code that's in "Starting Forth" on the Prop you may want to try using pfth. pfth is the only ANSI Forth interpreter that's been done for the Prop. Tachyon is a fine Forth interpreter, but you will need to modify the "Starting Forth" samples to get them to run.

    If you do use pfth, I would suggest using the version that runs under spinix. That provides an OS and tools for editing Forth source files. Or you can use one of the stand-alone versions of pfth if you don't want to mess with spinix.
  • Peter JakackiPeter Jakacki Posts: 10,193
    edited 2018-02-17 16:47
    Don't forget that there really is a big difference between Gforth and Tachyon, just as there is a big difference between a PC and a Propeller.

    Why don't you hook up your favorite peripherals and start playing with them or even a VGA monitor and load VGA.fth where you can even redirect all console output to the screen etc.
    EDIT: I reduced the size of the VGA module down to under 700 bytes so I have incorporated it into EXTEND as standard along with the LCD and KEYPAD modules etc.
    1280 x 856 - 140K
    VGA.jpg 139.7K
  • Don't forget that there really is a big difference between Gforth and Tachyon, just as there is a big difference between a PC and a Propeller.
    Understood and accepted.

    I know I'm making you nuts with this -- and it's not my intention --but I want to learn Forth properly. And, frankly, there's lots of great documentation for standard Forth. Tachyon assumes one already knows Forth. This is not a knock -- it's just what I'm facing. I'm torturing myself with this side-by-side thing a bit so that when I come across something interesting in Forth, I can figure out how to port it to the Propeller.

    I'm not a fan of VGA output. I would rather just work through a terminal. I am running Tachyon on an EFX-TEK HC-8+ which has a couple '165 shift registers and a full-duplex RS-485 port, along with basic IO points. It's the platform I deploy in my "Hollywood" projects using Spin. A big part of this exercise is to figure out if Tachyon would make me more productive as I'm often given very little time to program those big projects.
  • Jon,
    If you want to try/learn basic Forth, I recommend Dave's pfth. It is "standard" Forth with a few Propeller definitions added that let you manipulate the prop. It's pretty easy to find documentation and basic definitions.

    Tachyon has many interfaces/devices built in which make it very useful for productivity. Pfth requires you to build the interfaces in the process learning Forth and getting used to the reverse notation, but it is definitely not as fast as Tachyon.

    When I was first learning the Prop using the PE kit Lab Manual, I had some difficulty understanding the counters. Using pfth, I had to add the definitions for the counter registers, and define words to set or modify the 32 bit counter command. I was able to start, stop, and restart cogs, and by putting trial words for RGB LEDs and servos in 2nd & 3rd cogs while keeping cog 0 for interacting with the program while the other cogs were running (through the terminal) including defining new words. If one of the test words blew up in cogs 1 - 7, I could close that cog while keeping everything else running. It made it very easy to see what was going on and why things worked or not. Later I used it to understand how to interact with BlueTooth apps.

    Tom
  • Cluso99Cluso99 Posts: 18,069
    Jon,
    I am certain once you learn Tachyon it would be a breeze for your work.

    Unfortunately I haven't had the time to wrap myhead around Tachyon, and now it looks like no time on the horizon. I re-entered the work force a month ago. Although its only 3 days a week, I am finding there is so much I no longer know, that I am spending the other 2+ days googling and learning ;)

    OT
    Currently I am learning Python scripting for NotePad++ because we do a lot of copy/paste to html files for newsletters and the website. The biggest hurdle is finding the right editor items/objects and their syntax - they are basically Cintilla objects but wrappered by the Python script. And of course, Python is almost like other languages but just not quite. ie ":" at then end of if line, but otherwise idented like spin, "elif" instead of elseif, etc. :(
  • Peter JakackiPeter Jakacki Posts: 10,193
    edited 2018-02-18 01:19
    Page 33 of Starting Forth tells us that "Forth" can only work with integer numbers in the range of -32768 to +32767 :)
    Now while I love the book, the Forth it is based on is very much a 16-bit 79 standard Forth, and now you are learning Tachyon, and Gforth, and now maybe Pfth, a subset of ANSI Forth. I love your daring Jon, but it is like page 211 of Thinking Forth..... too many variables :)
    toomanyvariables4.png
    But certainly the reason you would like to learn Tachyon is the same reason why I wrote it, for fast turn-around projects. But not only that of course but also fast and compact with inherent debugging built in and the ability to interact and patch easily, even after the product has been "delivered", since there is always something major they haven't told you until it is being installed @#$!*&^!

    Tachyon is non-standard because it is geared for the Propeller architecture which in itself is non-standard. Knowing the Propeller helps you know Tachyon because it knows the Propeller too as well as a lot of the peripherals that we are inclined to use. A standard "language" will never cut it for these real applications that we do. I see that you use DMX protocol and that's something I may add as well. The inbuilt multichannel PWM is good for many control applications and the super fast SPI instructions make interfacing to shift registers a breeze without dedicating cogs.


    Btw, I decided to include VGA into EXTEND simply because it is easier for anyone new to Tachyon to have all these extensions already there, ready to use. I don't use the VGA output as a console in practice but it demonstrates that you can which is what would happen if you attached a PS/2 keyboard although personally I'm not a fan of limited Jupiter Ace type systems. I do use VGA for display purposes and right at the moment I've been inspired by the DIY anemometer to build my own RS485 distributed weather sensors and have these display on VGA monitors or other the Internet with my EASYNET server.

    In fact since I normally run VGA from one of my small Pixie headshell modules over RS485 I then have the Pixie's Prop loaded with a simple bitmap graphics slave terminal software which also includes PS/2. Each module receives power over the RS485 line since I just use cheap 4-core TP phone cable and the SMPS doesn't care if it is 8V or 28V. Great for distributed displays.


  • evanhevanh Posts: 15,916
    Peter's reference to "Thinking Forth" got me a searchable name, which gave me this - http://thinking-forth.sourceforge.net/ On that web page is links to PDFs.

    Okay, getting my head around Forth. A couple of notable issues (Correct me if I'm wrong) as I see it:
    - A serious lack of delimiter/textural formatting in the sources. A parameter looks like a command and vise versa. And when there is more than one command on a single line you can't infer from just reading that line - even when it's explained.

    - No scoping. Everything appears to be globals. That's got to be name clash central! Especially when using multiple libraries/modules/objects.

    It's going to be a while to get comfortable me thinks.
  • evanhevanh Posts: 15,916
    The scoping limit reminds me of Ladder Logic in some ways. There the idea is it's all control logic and therefore the fact that everything is global is of little importance. But even Ladder has functions blocks (FB) now - And those have local scope.

  • Peter JakackiPeter Jakacki Posts: 10,193
    edited 2018-02-18 02:36
    evanh wrote: »
    Peter's reference to "Thinking Forth" got me a searchable name, which gave me this - http://thinking-forth.sourceforge.net/ On that web page is links to PDFs.

    Okay, getting my head around Forth. A couple of notable issues (Correct me if I'm wrong) as I see it:
    - A serious lack of delimiter/textural formatting in the sources. A parameter looks like a command and vise versa. And when there is more than one command on a single line you can't infer from just reading that line - even when it's explained.

    - No scoping. Everything appears to be globals. That's got to be name clash central! Especially when using multiple libraries/modules/objects.

    It's going to be a while to get comfortable me thinks.

    The title of the book "Thinking Forth" does not mean Thinking Forth Should Be More Like Other Languages, but it does involve thinking about a problem with Forth as the tool so that the problem can be readily expressed and simplified by using that tool the way it is meant to be used. As for parameters and commands that look alike, you are right, but what is the difference anyway? I have many parameters that are in fact commands but really in postfix Forth the final word (pun) is the command anyway. If I say 0 64 KB DUMP then KB is a command that is a parameter in that it shifts the 64 left 10 bits and the final word is DUMP which just expects a starting address and a count. Perhaps if it said DUMP(0,KB(64)) it might look more "natural" to many conversant in traditional computer languages but that doesn't make it better, although in this simple example, there is one you can run on the target processor from the serial console, the other you cannot.

    The best way to learn in my opinion is to tackle a real job, not an example. That's the way I started when I decided to use Forth as the basis of the software and development etc for serial networked POS terminals in the 80's. I packed a lot of power into those slow 8-bit micros at the time which included scanning, and what I termed "electronic Journal" etc. Forth made possible what many at the time and even later considered impossible, and in a very short time. A team of C programmers that took over from where I (one person) left off still could not get the same functionality years later with better hardware and more memory.
  • evanhevanh Posts: 15,916
    Can the user define Prop assembly code in Tachyon?

  • Peter JakackiPeter Jakacki Posts: 10,193
    edited 2018-02-18 03:40
    evanh wrote: »
    Can the user define Prop assembly code in Tachyon?
    Probably going OT and more for the general Tachyon threads but I was familiar with the pitfalls of in-line assembly coding since you need the resources to support it properly or else fall back to postfix style mnemonics or even down to cryptic hex/base64 modules.

    From the outset I was determined that I should be able to program an application in fast high-level Forth without resorting to assembler in the app itself. So even timing critical devices such as the WS2812 LEDs and 1-wire etc can be implemented in Tachyon Forth without any need for PASM code, and indeed PASM cannot be executed from hub anyway and usually requires "spare" cog RAM or spare cogs, so it is something to be avoided on the Prop. So this is the case and if the bit-banging and SPI instructions aren't enough then there are the RUNMOD type modules for special uses as well as the ROMs which can be loaded into cogs. Of course, I could load an assembler module that takes up memory to assemble traditional style PASM source, but it makes more sense on the P2 with more resources. Tachyon is not about "PC language", it is a Prop resident environment that lends itself to rapid prototyping and development and also overcoming the speed/memory limitations of other Prop "languages".

  • evanhevanh Posts: 15,916
    edited 2018-02-18 03:50
    That sounds good. I was more after the Spin style objects, where one loads a special timing critical "soft device", than inlining anyway. It sounds like RUNMOD does that job. :)
  • evanhevanh Posts: 15,916
    edited 2018-02-18 04:55
    Ah, so those "modules" will have their own scope. Are they always binary blobs?

    EDIT: Anyway, the important thing here is that the user can create their own modules ... I hope. That way it'll be easy to port them from the Object Exchange.

    PS: Peter, I'm commenting here because of the likelihood of Tachyon becoming a central part of the Prop2. I suspect Jon started the topic for the same reason.
  • Page 33 of Starting Forth tells us that "Forth" can only work with integer numbers in the range of -32768 to +32767 :)
    Now while I love the book, the Forth it is based on is very much a 16-bit 79 standard Forth, and now you are learning Tachyon, and Gforth, and now maybe Pfth, a subset of ANSI Forth.
    The ANSI standard forth doesn't dictate the size of the integers. It allows for 16-bit integers or 32-bit integers, or pretty much any number of bits. Pfth is fully ANSI Forth compliant. It implements 100% of the core words. The ANSI Forth standard defines additional optional words, but they do not have to be implemented to be standards compliant.

  • MJBMJB Posts: 1,235
    ... and right at the moment I've been inspired by the DIY anemometer to build my own RS485 distributed weather sensors and have these display on VGA monitors or other the Internet with my EASYNET server.
    I just got this weather station with serial interface from AliExpress
    https://aliexpress.com/item/weather-station-with-UART-port-with-cable-length-3-2-meter/32807830742.html
    And I intent to use one of Peter's IoT5500+P8 modules to connect it to weather underground at wunderground.com as a personal weather station.
    This gives me local backup of all data to an SD-Card if the internet/router shouldbe down.
    And it will run on battery for power-fail protection.
    Of course the code will be Tachyon using the NW-Module to send the data to the wunderground server.
    This way I can add additional temperature sensors for my mango trees.
    I am here in Spain at an altitude where nobody grows mangos so far -
    but I had two successful harvests already. Just closely monitoring winter cold temperatures to see how hardy the different varieties really are. And when to start the sprinkler in the freezing nights to protect them.

    And @Jon - don't be bothered by Tachyons 'non-standard-ness' just go for it.
    And read lot's of Peter's source code.
    That's how I got into Forth and it's great ...
  • Peter JakackiPeter Jakacki Posts: 10,193
    edited 2018-02-20 06:03
    @MJB - beautiful fresh Bowen mangos are $10 a box here :)
    Cut em in half around the pit, twist off, cross slice the fruit to cube them but leave them on the skin, and then shove it into your face :)
    Any left over can be made into fruit ice-creams!

    Re the weather station - That's a bit over the top plus I'd like to do my own. If however you want some lightning hardened isolated RS485 then say the word. I have two RS485 interfaces on a Puppy module, with solid-state isolators, soft termination, gas tubes, polyfuses, tranzorbs etc.

    Just hooked up a DHT22 and fixed the routines so they don't lock up if one is not connected, and also improved the ping sensors. I was doing some tests on them and for some reason they don't seem to transmit those 8 cycles of 40kHz ping until about 660us after the trigger (like it is just waking up). I also used one as a detector to check the strength and took a whole heap of measurements. I'd like to use them as cheap sensors but certainly as proximity sensors anyway.

    Here's a bit of code I am just leaving to run in a cog to ping distance in millimeters and read the temperature and humidity, with the results in global variables. I will incorporate all my sensors into this routine so the main program can just access the variables.
    word mm		--- current ping distance in mm
    word 'c		--- current DHT22 temperature in Celcius *10
    word rh		--- current DHT22 relative humidity *10
    
    --- Task for PING, TEMPERATURE and HUMIDITY ---
    ---	    run this on 3    T  R  ping mm  save   H&T    save  save  wait
    pri SENSORS	3 RUN:    BEGIN 12 13 DISTANCE mm W!  15 DHT 'c W! rh W! 60 ms AGAIN ;
    
    --- Add SENSORS as an init at boot
    ' SENSORS +INIT
    


  • I love your daring Jon, but it is like page 211 of Thinking Forth..... too many variables
    I love your passion for Tachyon and what you've created with it -- this inspires me to learn.

    I know that "Easy" is a state of mind that I will achieve with Forth. At the moment, however, I am on the steep incline of the learning curve at the moment and, perhaps, grasping at straws.
Sign In or Register to comment.