PILOT
Programmed Instruction, Learning, Or Teaching (PILOT) is a simple historic programming language developed in the 1960s.[1] Like its younger sibling LOGO, it was an early foray into the technology of computer assisted instruction (CAI).
History
PILOT was developed by John Amsden Starkweather, a psychology professor at the University of California, San Francisco medical center. In 1962 he developed a simple language for automating learning tests called Computest. Starting in 1968, he developed a follow-on project called PILOT, for various computers of the time such as the SDS 940.[2]
Language syntax
A line of PILOT code contains (from left to right) the following syntax elements:
- an optional label
- a command letter
- an optional Y (for yes) or N (for no)
- an optional conditional expression in parentheses
- a colon (":")
- an operand, or multiple operands delimited by commas.
A label can also be alone in a line, not followed by other code. The syntax for a label is an asterisk followed by an identifier (alphanumeric string with alphabetic initial character).
Command letters
The following commands are used in "core PILOT". Lines beginning with "R:" indicate a remark (or a comment) explaining the code that follows.
- A
- Accept input into "accept buffer". Examples:
R:Next line of input replaces current contents of accept buffer A: R:Next line of input replaces accept buffer, and string variable 'FREE' A:$FREE R:Next 3 lines of input assigned to string variables 'X', 'Y' and 'Z' A:$X,$Y,$Z R:Numeric input assigned to numeric variable "Q" A:#Q
- C
- Compute and assign numeric value. Most PILOT implementations have only integer arithmetic, and no arrays. Example:
R:Assign arithmetic mean of #X and #Y to #AM C:#AM=(#X+#Y)/2
- D
- Dimension an array, on some implementations.
- E
- End (return from) subroutine or (if outside of a subroutine) abort program. Always used without any operand.
- J
- Jump to label. Example:
J:*RESTART
- M
- Match the accept buffer against string variables or string literals. Example:
R:Search accept buffer for "TRUTH", the value of $MEXICO and "YOUTH", in that order M:TRUTH,$MEXICO,YOUTH
The first match string (if any) that is a substring of the accept buffer is assigned to the special variable $MATCH. The buffer characters left of the first match are assigned to $LEFT, and the characters on the right are assigned to $RIGHT.
The match flag is set to 'yes' or 'no', depending on whether a match is made. Any statement that has a Y following the command letter is processed only if the match flag is set. Statements with N are processed only if the flag is not set.
- N
- Equivalent to TN: (type if last match unsuccessful)
- R
- The operand of R: is a comment, and therefore has no effect.
- T
- 'Type' operand as output. Examples:
R:Output a literal string T:Thank you for your support. R:Output a variable expression T:Thank you, $NAME.
- U
- Use (call) a subroutine. A subroutine starts with a label and ends with E: Example:
R:Call subroutine starting at label *INITIALIZE U:*INITIALIZE
- Y
- Equivalent to TY: (type if last match successful)
- Parentheses
- If there is parenthesized expression in a statement, it is a conditional expression, and the statement is processed only if the test has a value of 'true'. Example:
R:Type message if x>y+z T(#X>#Y+#Z):Condition met
Derivatives
Extensions to core PILOT include arrays and floating point numbers in Apple PILOT, and implementation of LOGO-inspired turtle graphics in Atari PILOT.[3]
Between 1979 and 1983 the UK PILOT User Group was run by Alec Wood a teacher at Wirral Grammar School for Boys, Merseyside UK. Several machine code versions of a mini PILOT were produced for the microcomputers of the time and a school in Scotland developed an interactive foreign language tutorial where pupils guided footprints around a town asking and answering questions in German, French etc. An article in Issue 1 December 1979 of Computer Age covered an early implementation called Tiny Pilot and gave a complete machine code listing.
Versions of PILOT overlaid on the BASIC interpreters of early microcomputers were not unknown in the late 1970s and early 1980s, and Byte Magazine at one point published a non-Turing complete derivative of PILOT known as Waduzitdo by Larry Kheriarty as a way of demonstrating what a computer was capable of.[4][5] A 1983 product called Vanilla PILOT for the Commodore 64 combined some features of LOGO,[6] as did Super Turtle PILOT which was published as a type-in listing in the October 1987 issue of COMPUTE! magazine.[7]
In 1991 the Institute of Electrical and Electronics Engineers (IEEE) published a standard for Pilot as IEEE Std 1154-1991. It has since been withdrawn.[8]
In 1990 eSteem PILOT for Atari ST computers was developed and programmed by Tom Nielsen, EdD. Based on the IEEE Standards for PILOT and added GEM features, it included access and control of Laserdisc and CDROM devices. [9]
An open source implementation was called RPilot,[1] and another called Sky Pilot begun in 2005.[10]
References
- ↑ 1.0 1.1 Rob Linwood. "PILOT Resource Center". Sourceforge project. Retrieved October 13, 2011.
- ↑ Xiuzhi Zhou (1998). "Register of the John A. Starkweather Papers, 1965-1985". University of California, San Francisco library. Retrieved October 13, 2011.
- ↑ Atari PILOT for beginners. Reston Publishing. 1983.
|coauthors=
requires|author=
(help) - ↑ Brian Connors (April 6, 2001). "Waduzitdo 2001". Retrieved October 13, 2011.
- ↑ Larry Kheriarty (September 1978). "WADUZITDO: How To Write a Language in 256 Words or Less". Byte.
- ↑ "Vanilla PILOT, PILOT that comes with turtle graphics". Infoworld. September 12, 1983. pp. 67–69. Retrieved October 13, 2011.
- ↑ Atarimagazines.com - COMPUTE! Issue 89, October 1987, p74
- ↑ "IEEE Standard 1154-1991 for Programmed Inquiry, Learning, or Teaching (PILOT)". IEEE Standards Committee. 1991. doi:10.1109/IEEESTD.1991.108548.
- ↑ "Press Release: eSteem PILOT".
- ↑ Rob Linwood (December 25, 2005). "Sky Pilot". Sourceforge project. Retrieved October 13, 2011.
Further reading
- John Starkweather (1985). User's guide to Pilot. Prentice-Hall. ISBN 978-0-13-937755-6.
|