SUPPORT THE WORK

GetWiki

Information Processing Language

ARTICLE SUBJECTS
aesthetics  →
being  →
complexity  →
database  →
enterprise  →
ethics  →
fiction  →
history  →
internet  →
knowledge  →
language  →
licensing  →
linux  →
logic  →
method  →
news  →
perception  →
philosophy  →
policy  →
purpose  →
religion  →
science  →
sociology  →
software  →
truth  →
unix  →
wiki  →
ARTICLE TYPES
essay  →
feed  →
help  →
system  →
wiki  →
ARTICLE ORIGINS
critical  →
discussion  →
forked  →
imported  →
original  →
Information Processing Language
[ temporary import ]
please note:
- the content below is remote from Wikipedia
- it has been imported raw for GetWiki
{{Short description|Early programming language for lists}}{{More citations needed|date=January 2022}}







factoids
Information Processing Language (IPL) is a programming language created by Allen Newell, Cliff Shaw, and Herbert A. Simon at RAND Corporation and the Carnegie Institute of Technology about 1956. Newell had the job of language specifier-application programmer, Shaw was the system programmer, and Simon had the job of application programmer-user.The code includes features intended to help with programs that perform simple problem solving actions such as lists, dynamic memory allocation, data types, recursion, functions as arguments, generators, and cooperative multitasking. IPL invented the concept of list processing, albeit in an assembly-language style.

Basics of IPL

An IPL computer has:
  1. A set of symbols. All symbols are addresses, and name cells. Unlike symbols in later languages, symbols consist of a character followed by a number, and are written H1, A29, 9–7, 9–100.
    • Cell names beginning with a letter are regional, and are absolute addresses.
    • Cell names beginning with "9-" are local, and are meaningful within the context of a single list. One list's 9-1 is independent of another list's 9–1.
    • Other symbols (e.g., pure numbers) are internal.
  2. A set of cells. Lists are made from several cells including mutual references. Cells have several fields:
    • P, a 3-bit field used for an operation code when the cell is used as an instruction, and unused when the cell is data.
    • Q, a 3-valued field used for indirect reference when the cell is used as an instruction, and unused when the cell is data.
    • SYMB, a symbol used as the value in the cell.
  3. A set of primitive processes, which would be termed primitive functions in modern languages.
The data structure of IPL is the list, but lists are more intricate structures than in many languages. A list consists of a singly linked sequence of symbols, as might be expected—plus some description lists, which are subsidiary singly linked lists interpreted as alternating attribute names and values. IPL provides primitives to access and mutate attribute value by name. The description lists are given local names (of the form 9–1). So, a list named L1 containing the symbols S4 and S5, and described by associating value V1 to attribute A1 and V2 to A2, would be stored as follows. 0 indicates the end of a list; the cell names 100, 101, etc. are automatically generated internal symbols whose values are irrelevant. These cells can be scattered throughout memory; only L1, which uses a regional name that must be globally known, needs to reside in a specific place.{|style="font-family:monospace; margin: 1em auto"|+ IPL-V List Structure Example!Name !! SYMB !! LINK
|- | 100
|-
| 101
|-
| 0
|-
| 200
|-
| 201
|-
| 202
|-
| 203
|-
| 0IPL is an assembly language for manipulating lists. It has a few cells which are used as special-purpose registers. H1, for example, is the program counter. The SYMB field of H1 is the name of the current instruction. However, H1 is interpreted as a list; the LINK of H1 is, in modern terms, a pointer to the beginning of the call stack. For example, subroutine calls push the SYMB of H1 onto this stack.H2 is the free-list. Procedures which need to allocate memory grab cells off of H2; procedures which are finished with memory put it on H2. On entry to a function, the list of parameters is given in H0; on exit, the results should be returned in H0. Many procedures return a boolean result indicating success or failure, which is put in H5. Ten cells, W0-W9, are reserved for public working storage. Procedures are "morally bound" (to quote the CACM article) to save and restore the values of these cells.There are eight instructions, based on the values of P: subroutine call, push/pop S to H0; push/pop the symbol in S to the list attached to S; copy value to S; conditional branch. In these instructions, S is the target. S is either the value of the SYMB field if Q=0, the symbol in the cell named by SYMB if Q=1, or the symbol in the cell named by the symbol in the cell named by SYMB if Q=2. In all cases but conditional branch, the LINK field of the cell tells which instruction to execute next.IPL has a library of some 150 basic operations. These include such operations as:
  • Test symbols for equality
  • Find, set, or erase an attribute of a list
  • Locate the next symbol in a list; insert a symbol in a list; erase or copy an entire list
  • Arithmetic operations (on symbol names)
  • Manipulation of symbols; e.g., test if a symbol denotes an integer, or make a symbol local
  • I/O operations
  • "Generators", which correspond to iterators and filters in functional programming. For example, a generator may accept a list of numbers and produce the list of their squares. Generators could accept suitably designed functions—strictly, the addresses of code of suitably designed functions—as arguments.

History

IPL was first utilized to demonstrate that the theorems in Principia Mathematica which were proven laboriously by hand, by Bertrand Russell and Alfred North Whitehead, could in fact be proven by computation. According to Simon's autobiography Models of My Life, this application was originally developed first by hand simulation, using his children as the computing elements, while writing on and holding up note cards as the registers which contained the state variables of the program.IPL was used to implement several early artificial intelligence programs, also by the same authors: the Logic Theorist (1956), the General Problem Solver (1957), and their computer chess program NSS (1958).Several versions of IPL were created: IPL-I (never implemented), IPL-II (1957 for JOHNNIAC), IPL-III (existed briefly), IPL-IV, IPL-V (1958, for IBM 650, IBM 704, IBM 7090, Philco model 212, many others. Widely used). IPL-VI was a proposal for an IPL hardware.{{sfn|Shaw|Newell|Simon|Ellis|1958}}{{sfn|Sammet|1969|p=389}}A co-processor “IPL-VC” for the CDC 3600 at Argonne National Libraries was developed which could run IPL-V commands.{{sfn|Hodges|1964}}{{sfn|Sammet|1969|p=393–394}} It was used to implement another checker-playing program.{{sfn|Cowell|Reed|1965}} This hardware implementation did not improve running times sufficiently to “compete favorably with a language more directly oriented to the structure of present-day machines”.{{sfn|Carson|Robinson|1966|p=5}}IPL was soon displaced by Lisp, which had much more powerful features, a simpler syntax, and the benefit of automatic garbage collection.

Legacy to computer programming

IPL arguably introduced several programming language features:
  • List manipulation—but only lists of atoms, not general lists
  • Property lists—but only when attached to other lists
  • Higher-order functions—while assembly programming had always allowed computing with the addresses of functions, IPL was an early attempt to generalize this property of assembly language in a principled way
  • Computation with symbols—though symbols have a restricted form in IPL (letter followed by number)
  • Virtual machine
Many of these features were generalized, rationalized, and incorporated into LispJohn McCarthy (1979) History of Lisp "LISP prehistory - Summer 1956 through Summer 1958." and from there into many other programming languages during the next several decades.

References

{{Reflist}}

Sources

  • REPORT, Daniel F., Carson, George A., Robinson, May 1966, Gyro II, A Macro-Defined System for List Processing, ANL-7149, Applied Mathematics Division, Argonne National Laboratories,
  • REPORT, W. R., Cowell, M. C., Reed, October 1965, A Checker-Playing Program for the IPL-VC Computer, ANL-7109, Applied Mathematics Division, Argonne National Laboratories,
  • REPORT, Donald, Hodges, May 1964, IPL-VC: A Computer System having the IPL-V Instruction Set, ANL-6888, Applied Mathematics Division, Argonne National Laboratories,
  • BOOK, Sammet, Jean E., Programming languages: history and fundamentals, Prentice Hall, Englewood Cliffs, N.J., 1969, 388{{en dash, 400}}
  • CONFERENCE, Shaw, J. C., Newell, A., Simon, H. A., Ellis, T. O., A Command Structure for Complex Information Processing, 1958, Association for Computing Machinery, 9781450378642, 10.1145/1457769.1457803, Proceedings of the May 6–8, 1958, Western Joint Computer Conference: Contrasts in Computers, IRE-ACM-AIEE '58 (Western), 119128,

Further reading

  • CONFERENCE, Newell, Allen, Shaw, J. C., Programming the Logic Theory Machine, 1957, Association for Computing Machinery, 9781450378611, Papers Presented at the February 26–28, 1957, Western Joint Computer Conference: Techniques for Reliability, 230–240, IRE-AIEE-ACM '57 (Western)doi-access=free
,
  • JOURNAL, Newell, Allen, Tonge, Fred M., An Introduction to Information Processing Language V, 1960, Association for Computing Machinery, New York, NY, USA, 3, 4, 0001-0782, 10.1145/367177.367205, Communications of the ACM
s2cid=16609075, free,
  • BOOK, Newell, Allen, Tonge, Fred M., Feigenbaum, Edward A., Green Jr., Bert F., Mealy, George H., 2, Information Processing Language-V Manual, Prentice Hall, Englewood Cliffs, N.J., 1964,
  • BOOK, Samuel, Arthur L., Advances in Computers Volume 1, Programming Computers to Play Games, Advances in Computers, 1, Alt, Franz L., Elsevier, 165–192, 1960, 0065-2458
isbn=9780120121014,

External links

{{Authority control}}

- content above as imported from Wikipedia
- "Information Processing Language" does not exist on GetWiki (yet)
- time: 6:04pm EDT - Wed, May 01 2024
[ this remote article is provided by Wikipedia ]
LATEST EDITS [ see all ]
GETWIKI 23 MAY 2022
GETWIKI 09 JUL 2019
Eastern Philosophy
History of Philosophy
GETWIKI 09 MAY 2016
GETWIKI 18 OCT 2015
M.R.M. Parrott
Biographies
GETWIKI 20 AUG 2014
CONNECT