General Introduction and the Software Interpreters
CODIL started as the symbolic assembly language of an unconventional computer processor design, proposed in 1967, where the aim was to produce a "white box" system which would work symbiotically with people in the field of non-numerical information processing applications. The hardware was never built but four different software interpreters were written which have shown that the approach was feasible, and would support a wide variety of applications. The four versions of the interpreter were as follows:
- The Pilot program: Written in symbolic assembly code to run on a System 4/70 computer (IBM 360 compatible). This was a batch system which was built to demonstrate the feasibility of the idea for a range of small scale test applications. An introduction to CODIL and information on the design is given in CODIL: Part 2: The CODIL language and its interpreter (1971).
- The ICL 1903A interpreter was written in COBOL (a mistake - but chosen because CODIL had started in the context of very large commercial data processing systems) and while the interpreter could be used via a teletype terminal most of the early work was done in batch mode. It was a complete redesign of the Pilot program, incorporating many of the lessons learnt in the previous version, but in retrospect retained some "conventional computing" features which were later shown to be inappropriate. There were no publications explicitly describing this interpreter, but some information is given in papers describing the applications tested. These included several data bases, Tantalize (a heuristic problem solver), and interactive Teach Yourself CODIL lessons, as well as a variety of small scale test applications. The best account of applications, etc., examined with this version is in A Psychologicl Approach to language design (1978) It was used from 1972 to 1980.
- The Multics interpreter was an interactive upgrade of the ICL version, produced when Brunel university switched from batch working to glass teletypes in 1980. It was used to support a variety of teaching packages and work was done on online interactive educational task. It was used from 1980 to 1988, when I retired and the Multics system was replaced.
- MicroCODIL: The limitation of glass teletype interaction of the Multics system - and the desire to develop a far more flexible and transparent user interface - led to a very significant redesign. It was decided to implement a portable version on a small educational computer, The BBC Micro, and the software was test marketed to schools. The paper CODIL – the architecture of an information language (1990), describes MicroCODIL - and the paper also includes some features of the Multics version. MicroCODIL made it possible to escape from glass teletypes and work on windowed screens including colour. This aspect of the software design is described in detail in The use of colour in language systax analysis (1987). Despite the small size of the BBC computer, which limited the size of the tasks it could process it was logically the most powerful version of CODIL implemented because it used more levels of recursion.
CODIL in Context
Because I had worked on the manual processing of complex research and development information in a subsidiary of the Welcome Foundation and had worked on a very large computerised sales accounting system I had good insight into both manual and computer management information systems, and the limitations of commercial computer systems as they were in the 1960s. Two of the early papers looked specifically on the importance of recognising that not all information was neat and tidy, or could be predicted in advance. The first was presented at Datafair 71, in Nottingham, in March 1971 and reprinted in a slightly modified form as CODIL: Part 1: The Importance of Flexibility (1971). The second was Designing an interactive language for the pragmatic user (1974). This was published when there was a strong movement in the data processing world to more and more formalism - including the introduction of relational data base techniques. This paper points in the opposite direction and argues that you need to start by designing a simple architecture which the human users can understand. Later papers, such as Human Factors in System Design (1987), discussed the design in the context of MicroCODIL.
The much later paper Are we trapped by our training (1991) looks at a different problem that emerged in the research. It appears that people who have been trained to use a conventional programming language found it difficult to unlearn the "need" to predefine an algorithm, and hence found it harder to understand CODIL than people with no computer experience.
CODIL and Artificial Intelligence
At an early stage it was realised that the CODIL approach appeared to model how some people thought about complex information processing tasks. The work was being done in a computer manufacturer with a view to developing a commercially profitable system and at the time little thought was given to what the research might say about human intelligence or computer science theory. Once the work had moved to a university environment the wide implications were considered and initial thoughts are given in An Evolutionary Approach to Artificial Intelligence (1973). It was discovered that CODIL could support a powerful heuristic problem solver, and demonstrate machine learning, and progress on this was outlined as Recent Developments with CODIL (1976). The paper A Psychological Approach to Language Design (1978) includes a summary of what had been achieved, including the incorporation of learning facilities. The powerful problem solver, TANTALIZE, was implemented and was used to solve 15 consecutive Tantalizer Problems (later called Enigma) from the New Scientist. However for various reasons I decided to concentrate on other possible applications of CODIL and as a result the TANTALIZE problem solver was never transferred to the Multics version of the software.
CODIL & Data Bases
CODIL has been tested on a variety of different topics as can be seen in CODIL as an Information Processing Language for University Use (1981). From an early date it was used to process patient diagnostic and treatment information in the Cardiac Department at Hillingdon Hospital – Using CODIL to handle poorly structured clinical information (1978) - but as the information was confidential another data base was set up of family history information. This was chosen not only because it was non-confidential, but also because the information described real life situations and was often incomplete or ambiguous. Four books containing genealogical information were produced to demonstrate the use of CODIL for historical data. The two most relevant papers are CODIL as a knowledge base system for handling historical information (1988) and Knowledge Bases for Historians (1988). A commercial software package for early personal computers, called Superfile, was a pirated version of the file handling routines in CODIL (but lacked the logic processing routines) and was widely used for archaeology and related applications in the UK in the 1980s on the recommendation of English Heritage. It was also decided to demonstrate that CODIL could interfaced with conventionally formatted data base files, and one application was the departmental usage statistics on the university computer. The paper Formalism or Flexibility? (1978) showed how CODIL could be used to support Relational Data Base files.
CODIL - Online Teaching and Publication
In 1980 the university switched to a terminal-based service and CODIL was used by classes of up to 120 students, both to introduce them to the computer and the course, and for computer-aided instruction. At the same time I was involved in the British Library BLEND project to explore the possibility of having online scientific journals. As a result the CODIL system was used to model an online system (accessed directly via dial-up rather through BLEND’s very limited Notepad software)which did not allow such flexible online working). This showed how papers on different applications, including the student activities, could be combined in an online "journal" including the options of including raw test data, operational demonstrations, and hyperlinks between papers. This is summarised in A Software Package for Electronic Journals (1983). It is interesting that this was the only truly interactive paper submitted to the BLEND project at the time, as all the other submitted papers were straight text documents which could be read online.
MicroCODIL
Much of the research in the 1980s concentrated on the development of the MicroCODIL system. The aim was to demonstrate that the basic decision-making unit was so small and fast it would run on a very small home/educational computer and could carry out a wide range of tasks. Papers describing what the system would do include A Microcomputer Package for demonstrating Information Processing Concepts (1985), Human Factors in Systems Design (1987), Introducing Expert Systems to Pupils (1988), A Flexible Approach to Local History Data Bases in the Classroom (1988), A Psychological Approach to the Computer Handling of Historical Information (1990) and Moving Information Technology Research from the Laboratory to the Classroom (1990). The software was well reviewed – see Reviews of MicroCODIL - but did not fit in with the National Curriculum (which assumed more conventional stored program computer systems) and, probably by trying to do too much, the package was not really robust enough for classroom use.
[Note that some of the links point to an earlier blog see Trapped by the Box]
No comments:
Post a Comment