CTSS: MAD language
MAD - the Michigan Algorithm Decoder - was a ALGOL inspired language
commonly used for scientific programming on the IBM 7x series of
computers. It was conceived by Bernard Galler and colleagues at the
University of Michigan in 1959. A version from around 1963 was ported
to CTSS, where it was used to write many of the system utilities such
as LISTF
.
To demonstrate MAD and how to write programs in it on CTSS, I will show an implementation of the TPK algorithm.
What is the TPK algorithm?
See the repo project-tpk for more details, but basically this was developed by Donald Knuth and Luis Trabb Pardo for a paper about early (pre-1957) languages. It does the following
read 11 numbers to an array for each x in in reverse order of the array calculate √|x| + 5x³ print that number if ≤ 400, else print TOO BIG
which is not supposed to be a useful task, but demonstrates many typical language features like I/O, loops, arrays, functions and conditionals.
TPK in MAD
Here is the complete program.
R TPK ALGORITHM IN MAD ① R FUNCTION F INTERNAL FUNCTION(X) ③ ENTRY TO F. FUNCTION RETURN SQRT.(.ABS.X) + 5 * X.P.3 END OF FUNCTION ⑥ R MAIN PROGRAM INTEGER N,J ⑧ N = 11 DIMENSION NUM(11) ⑩ VECTOR VALUES FMT = $F9.4 *$ ⑪ PRINT COMMENT $PLEASE ENTER 11 NUMBERS$ ⑫ THROUGH INPUT,FOR J=0,1,J.GE.N ⑬ INPUT READ FORMAT FMT,NUM(J) ⑭ PRINT COMMENT $RESULTS ARE$ THROUGH CALC,FOR J=N-1,-1,J.L.0 ⑯ RESULT = F.(NUM(J)) WHENEVER RESULT.G.400 ⑱ PRINT COMMENT $TOO LARGE$ OTHERWISE PRINT FORMAT FMT,RESULT CALC END OF CONDITIONAL ㉒ END OF PROGRAM
Numbers in circles (like ①) are for reference below, not part of the program. You can download the machine readable file from github.
The layout is fixed, with
- columns 1-10 containing an optional line label
- column 11 contains
R
if the line should be treated as a comment (such as line ①), or a digit if it is a continuation line, blank otherwise - code is in columns 12-72
- columns 73-80 are optional sequence numbers, useful for punched cards
Lines ③-⑥ contain the function F.
to do the calculation. Functions
can share code have multiple entry points indicated by ENTRY TO
.
Functions are denoted by a dot on the end, eg F.
, SQRT.
, whereas
language operators have dots before and after, like .ABS.
and .P.
(power).
The main program starts at ⑧ with some variable definitions. Default
type for undefined variables is floating point (can be overridden per
program file with eg NORMAL MODE IS INTEGER
). ⑩ introduces an array
of floats called NUM
.
⑪ defines and initialises an array of six-bit BCD characters; the $
indicates the character type. The contents of ⑪ is a
format specification, similar to a C scanf
string, requesting
floating point.
⑬-⑭ is a loop, delimited by the label INPUT
, to read in 11 floating
point numbers from the user.
⑯-㉒ is another loop to execute the function on each array item in
reverse order, with a conditional in ⑱-㉒ to display TOO LARGE
or
the result of the function.
One other language feature not used here is the ability to abbreviate
keywords: instead of typing WHENEVER
you can use W'R
, or E'M
instead of END OF PROGRAM
.
Compiling and running
See the guides on how to upload or edit files to enter the program into the system.
MAD TPK
will compile this file and create an object file TPK BSS
.
The compiler has two optional arguments
(LIST)
to produce a full listing file inTPK BCD
(SYMB)
to include symbols in the object file for debugging.
mad tpk (list) W 1831.4 LENGTH 00211. TV SIZE 00007. ENTRY 00040 R .016+.016
Run the program directly with LOADGO TPK
, or save it to an
executable file that can be used later, and run it via
LOAD TPK SAVE TPK R TPK
(see this previous post on how loading works on CTSS.)
When running the program, you need to include a decimal point in each
item to indicate its type, so you'd enter 1 as 1.
. An example run:
loadgo tpk W 1831.7 EXECUTION. PLEASE ENTER 11 NUMBERS 10. -1. 1. 2. 3. 4. 4.3 4.305 4.303 4.302 4.301 RESULTS ARE 399.8863 TOO LARGE TOO LARGE TOO LARGE 399.6086 322.0000 136.7320 41.4142 6.0000 -4.0000 TOO LARGE EXIT CALLED. PM MAY BE TAKEN. R .150+.016
See github for the compile/run transcript, and the full listing.
Further reading
I have not been able to find the language reference for this particular version of MAD, but this manual from the University of Illinois on bitsavers is close. Also there is Bernard Galler's introduction to programming using MAD, The Language of Computers.
CTSS project director Fernando Corbato wrote an abbreviated guide to MAD in MIT Computer Center Memo 213, but the print quality is not great so this is hard to read.
ELIZA is a good example of a larger program written in a mix of MAD and assembly language.
I have written about GOM (Good Old MAD), a later version of MAD for MTS on the System/370 over at try-mts.com.
Questions, corrections, comments
I welcome any questions or comments, and also especially any corrections if I have got something wrong. Please email me at rupert@timereshared.com