PyoLogo: Difference between revisions

From OLPC
Jump to navigation Jump to search
No edit summary
m (Protected "PyoLogo" [edit=autoconfirmed:move=autoconfirmed] (expires 04:09, 9 May 2009 (UTC)))
 
(23 intermediate revisions by 17 users not shown)
Line 1: Line 1:
{{Translations}}
'''PyoLogo''' [pie-o-logo] or '''PYthon Open Logo''' is an implementation of the Logo programing language created on top of Python. It grew out of [http://www.media.mit.edu/~arnans/ Arnan (Roger) Sipitakiat's] thesis project at the MIT Media Laboratory. PyoLogo consists of a casual Logo interpreter and a simple IDE.
'''PyoLogo''' [pie-o-logo] or '''PYthon Open Logo''' is an implementation of the Logo programing language created on top of Python. It grew out of [http://www.media.mit.edu/~arnans/ Arnan (Roger) Sipitakiat's] thesis project at the MIT Media Laboratory. PyoLogo consists of a casual Logo interpreter and a simple IDE.


Line 50: Line 51:


Although PyoLogo tries to conform with other Logo implementations, it contains some rather unconventional properties.
Although PyoLogo tries to conform with other Logo implementations, it contains some rather unconventional properties.
* Not space delimited. 'Show 1+1' works in PyoLogo whereas most other Logo interpreters do not accept this. Logo normally requires spaces between every token. So, only 'Show 1 + 1' would work. Although the uniformity of the Logo language is broken when space becomes optional, the author believes it is a worthwhile trade off. Kids too often becomes frustrated or annoyed by the strict requirement for space.
* Not space delimited. 'Show 1 1' works in PyoLogo whereas most other Logo interpreters do not accept this. Logo normally requires spaces between every token. So, only 'Show 1 1' would work. Although the uniformity of the Logo language is broken when space becomes optional, the author believes it is a worthwhile trade off. Kids too often becomes frustrated or annoyed by the strict requirement for space.


**This, of course, comes at a cost. There are some cases where the interpreter will not be able to decide what to do. For example, if we have a procedure called sum that takes two integers as an input. So, <tt>sum 2 3</tt> returns 5. A problem occurs when we try to call <tt>sum 2 -3</tt>. The interpreter has no way of knowing if the user wants to do a sum of 2 and -3 or a sum of (2-3) and another value which is missing (and thus should complain to the user.) The user will have to tell the compiler what to do. I.e. in this case the user can call <tt>sum 2 (-3)</tt>.
**This, of course, comes at a cost. There are some cases where the interpreter will not be able to decide what to do. For example, if we have a procedure called sum that takes two integers as an input. So, <tt>sum 2 3</tt> returns 5. A problem occurs when we try to call <tt>sum 2 -3</tt>. The interpreter has no way of knowing if the user wants to do a sum of 2 and -3 or a sum of (2-3) and another value which is missing (and thus should complain to the user.) The user will have to tell the compiler what to do. I.e. in this case the user can call <tt>sum 2 (-3)</tt>.
Line 57: Line 58:


make "counter 0
make "counter 0
make "counter :counter + 1
make "counter :counter 1
show :counter
show :counter


Line 65: Line 66:
setcounter 0
setcounter 0
setcounter counter + 1
setcounter counter 1
show counter
show counter


Line 80: Line 81:
== LOGO words supported ==
== LOGO words supported ==
{| border="1" cellpadding="3" style="border:5px"
{| border="1" cellpadding="3" style="border:5px"
|+ LOGO keyword list
| LOGO keyword list
! Letter
! Letter
! style="background:green" | Implemented
! style="background:green" | Implemented
Line 97: Line 98:
|-
|-
! C
! C
| style="background:#D0FFD0" | cc, cg, char, color, cos, count
| style="background:#D0FFD0" | cc, cg, char, chdir, clean, color, cos, count, currentdir
| style="background:#FFFFAA" |
| style="background:#FFFFAA" |
| style="background:#FF8888" | cancel, carefully, chdir, clean, clearname, clearnames, clickoff, clickon, colorunder, creatprojectvar, currentdir
| style="background:#FF8888" | cancel, carefully, clearname, clearnames, clickoff, clickon, colorunder, creatprojectvar
|-
|-
! D
! D
Line 117: Line 118:
|-
|-
! G
! G
| style="background:#D0FFD0" |
| style="background:#D0FFD0" | getproject
| style="background:#FFFFAA" | get
| style="background:#FFFFAA" | get
| style="background:#FF8888" | getpage, getproject, glide, greater?
| style="background:#FF8888" | getpage, glide, greater?
|-
|-
! H
! H
Line 127: Line 128:
|-
|-
! I
! I
| style="background:#D0FFD0" | if, ifelse, int
| style="background:#D0FFD0" | if, ifelse, int, item
| style="background:#FFFFAA" |
| style="background:#FFFFAA" |
| style="background:#FF8888" | identical?, importtext, infront, item
| style="background:#FF8888" | identical?, importtext, infront
|-
|-
! K
! K
Line 137: Line 138:
|-
|-
! L
! L
| style="background:#D0FFD0" | last, launch, list, ln, log, lt (left)
| style="background:#D0FFD0" | last, launch, list, list?, ln, log, lt (left)
| style="background:#FFFFAA" |
| style="background:#FFFFAA" |
| style="background:#FF8888" | less?, let, list?, listen, loadpict, loadshape, loadtext, local, lput
| style="background:#FF8888" | less?, let, listen, loadpict, loadshape, loadtext, local, lput
|-
|-
! M
! M
Line 147: Line 148:
|-
|-
! N
! N
| style="background:#D0FFD0" | name?, newturtle, not
| style="background:#D0FFD0" | name?, newturtle, not, number?
| style="background:#FFFFAA" |
| style="background:#FFFFAA" |
| style="background:#FF8888" | name, names, newbutton, newpage, newprojectsize, note, np (namepage), number?
| style="background:#FF8888" | name, names, newbutton, newpage, note, np (namepage)
|-
|-
! O
! O
Line 159: Line 160:
| style="background:#D0FFD0" | parse, pd, pensize, pi, pos, pu
| style="background:#D0FFD0" | parse, pd, pensize, pi, pos, pu
| style="background:#FFFFAA" |
| style="background:#FFFFAA" |
| style="background:#FF8888" | pagelist, pick, power, pr (print), presentationmode, product, projectlist, projectsize, projectvars
| style="background:#FF8888" | pagelist, pick, power, pr (print), presentationmode, product, projectlist, projectvars
|-
|-
! Q
! Q
Line 167: Line 168:
|-
|-
! R
! R
| style="background:#D0FFD0" | random, readchar, repeat, resett, round, rt (right), run
| style="background:#D0FFD0" | random, readchar, remove, repeat, resett, round, rt (right), run
| style="background:#FFFFAA" |
| style="background:#FFFFAA" |
| style="background:#FF8888" | remainder, remove, rerandom, rest, restore
| style="background:#FF8888" | remainder, rerandom, rest, restore
|-
|-
! S
! S
| style="background:#D0FFD0" | setc (setcolor), seth (setheading), se (sentence),setpensize, setpos, setx, sety, show, sin, sqrt, st, stamp, stop, stopall
| style="background:#D0FFD0" | setc (setcolor), seth (setheading), se (sentence),setpensize, setpos, setsh (setshape), setsize, setx, sety, shape, show, sin, size, sqrt, st, stamp, stop, stopall
| style="background:#FFFFAA" |
| style="background:#FFFFAA" |
| style="background:#FF8888" | savepict, saveproject, saveshape, savetext, set, setbg, setinstruction, setinstrument, setsh (setshape), setsize, shape, size, startup, stopme, sum
| style="background:#FF8888" | savepict, saveproject, saveshape, savetext, set, setbg, setinstruction, setinstrument, startup, stopme, sum
|-
|-
! T
! T
Line 187: Line 188:
|-
|-
! W
! W
| style="background:#D0FFD0" | wait, waituntil, who, word
| style="background:#D0FFD0" | wait, waituntil, who, word, word?
| style="background:#FFFFAA" |
| style="background:#FFFFAA" |
| style="background:#FF8888" | when, word?
| style="background:#FF8888" | when
|-
|-
! X
! X
Line 206: Line 207:
[[Category:Software development]]
[[Category:Software development]]
[[Category:Programming language]]
[[Category:Programming language]]
[[Category:Python]]
[[Category:LOGO]]

Latest revision as of 05:09, 9 February 2009

  english | 한국어 HowTo [ID# 194781]  +/-  

PyoLogo [pie-o-logo] or PYthon Open Logo is an implementation of the Logo programing language created on top of Python. It grew out of Arnan (Roger) Sipitakiat's thesis project at the MIT Media Laboratory. PyoLogo consists of a casual Logo interpreter and a simple IDE.

Screenshot01.jpg
Screenshot02.jpg
Screenshot03.jpg

Current Status

Since PyoLogo is currently thesis software, it is far from being a complete product. Here is a list of things it can and cannot do.

Available features

  • Logo Primitives. Supports a subset of Logo primitives. See the command list below. More commands will be added as development progresses.
    • Most of the Turtle Geometry (drawing) primitives are available.
    • List and list manipulation commands
    • Common control flow. If, ifelse, repeat, etc
    • Variables. Using the 'make' command and some other alternatives
    • Mathematical operations. sin, cos, tan, sqrt, etc
  • Supports multiple procedures with parameter passing and procedure output
  • Multi-threaded. I.e. the 'launch' and 'forever' commands creates a new background process
  • Support turtle shapes

Thesis Features

There are some non-traditional features built into PyoLogo for the thesis work form which it was created. Here are some that could perhaps be useful.

  • Robotics. PyoLogo can receive sensor input and control actuators via the GoGo Board. Since OLPC will have a sensor input through its microphone jack, this feature can be adapted to make use of this possibility.
  • Line objects. These are slider-like objects that can be used to track a turtle's position or visualize a sensor value.
  • Variable history. Every variable keeps a record of its previous values. It can be used to calculate the rate of a variable (i.e. position -> speed) or for debugging purposes.

Issues and missing items

  • Performance. PyoLogo currently runs very slowly on OLPC machines. This is based on the A test boards
  • Still some UI issues under Linux
  • Bugs are plentiful. It still needs extensive testing.
  • Error reporting. Errors in the Logo programs are not well reported. This makes it difficult for the user to debug their Logo program
  • No multimedia support. No sound, no video, no text box, no drawing tools
  • No UI widgets for the user program. No buttons, checkboxes
  • No multiple page support

Download

The author is currently preparing the source code to be uploaded into OLPC's code repository. Once this is done, a public release of the software will become available.

Technical Info

Please take a look at the technical info page for information about how PyoLogo was built

The Logo Interpreter

Although PyoLogo tries to conform with other Logo implementations, it contains some rather unconventional properties.

  • Not space delimited. 'Show 1 1' works in PyoLogo whereas most other Logo interpreters do not accept this. Logo normally requires spaces between every token. So, only 'Show 1 1' would work. Although the uniformity of the Logo language is broken when space becomes optional, the author believes it is a worthwhile trade off. Kids too often becomes frustrated or annoyed by the strict requirement for space.
    • This, of course, comes at a cost. There are some cases where the interpreter will not be able to decide what to do. For example, if we have a procedure called sum that takes two integers as an input. So, sum 2 3 returns 5. A problem occurs when we try to call sum 2 -3. The interpreter has no way of knowing if the user wants to do a sum of 2 and -3 or a sum of (2-3) and another value which is missing (and thus should complain to the user.) The user will have to tell the compiler what to do. I.e. in this case the user can call sum 2 (-3).
  • Multiple ways to manipulate variables. The author finds Logo's 'make' primitive unnecessarily complicated for children. The 'set' method is perhaps a better way to go. PyoLogo supports both. For example:
make "counter 0
make "counter :counter   1
show :counter

The following alternative is also available

global [counter]

setcounter 0
setcounter counter   1
show counter
  • Object oriented properties as a shortcut for 'ask.' For example, a typical logo command to vertically align one turtle to another would be:
t1, setx ask "t2 "xcor

PyoLogo allows a dot format for accessing a turtle's property.

t1, setx t2.xcor

Both the traditional and shortened approaches are supported in PyoLogo.

LOGO words supported

LOGO keyword list Letter Implemented Partially Missing
A abs, and, announce, answer, arccos, arcsin, arctan, ascii ask
B bf (butfirst), bk (back), bl (butlast) bg, bottom
C cc, cg, char, chdir, clean, color, cos, count, currentdir cancel, carefully, clearname, clearnames, clickoff, clickon, colorunder, creatprojectvar
D distance difference, directories, dolist, done?, dotimes
E empty?, exp equal?, erfile, errormessage, everyone, exporttext
F fd (forward), first, forever files, fill, fontsize, fput, freeze, freezebg
G getproject get getpage, glide, greater?
H heading, ht home
I if, ifelse, int, item identical?, importtext, infront
K key?
L last, launch, list, list?, ln, log, lt (left) less?, let, listen, loadpict, loadshape, loadtext, local, lput
M make, mousepos member?, minus
N name?, newturtle, not, number? name, names, newbutton, newpage, note, np (namepage)
O op (output), or opaque
P parse, pd, pensize, pi, pos, pu pagelist, pick, power, pr (print), presentationmode, product, projectlist, projectvars
Q question quotient
R random, readchar, remove, repeat, resett, round, rt (right), run remainder, rerandom, rest, restore
S setc (setcolor), seth (setheading), se (sentence),setpensize, setpos, setsh (setshape), setsize, setx, sety, shape, show, sin, size, sqrt, st, stamp, stop, stopall savepict, saveproject, saveshape, savetext, set, setbg, setinstruction, setinstrument, startup, stopme, sum
T tan, thing, timer, touching?, towards tto (talkto), turtlesown
U unfreeze, unfreezebg
W wait, waituntil, who, word, word? when
X xcor
Y ycor