21 Algol 60 compilers in 1962
The specification of ALGOL 60 was published in May 1960. Unlike today, where the creators of a new language release the source of a corresponding compiler, people were expected to write their own compiler. The June 1962 paper: The Replies to the AB14 Questionnaire lists implementation details on 21’ish compilers (it’s not clear whether some are dialects or languages very similar to Algol 60; 1963: list of 32 Algol compilers/versions).
Compiler writing was a hot leading edge research topic in the 1960s; at the start of this decade all the techniques we take for granted today had not yet been invented (Knuth invented LR parsing in 1965, and algorithms for optimal code generation started appearing in 1970). The 1960s was the period of the Cambrian explosion for programming languages.
Implementors not only had to deal with all the unknowns of writing a compiler, they also had to do the work using systems whose memory was measured in tens of kilobytes, computer interaction probably via punched card or punched tape, or if lucky, the luxury of teletype input/output. It’s no surprise that fourteen of the implementations considered themselves to be a “true subset” (which I take to mean that everything implemented was as per the specification). Compilers for earlier languages probably had the benefit of the language not supporting anything that was hard to implement.
Compiler implementation know-how received a major boost in 1964 with the publication of the book ALGOL 60 Implementation.
The plot below shows the number of compilers having a given reported implementation time (code+data):
The median implementation effort is 2 man-years. Is this the result of a few good people working off the clock to create software, or management supporting the creation of a product that customers are not clamouring for?
The 0.25 man-year implementation looks like a port of an existing compiler to a different version of the same hardware. The 10 man-year implementation time was for what looks like a full implementation, plus extensions. The 80 man-year implementation time was reported by SDC (a large defence contractor) for a range of JOVIAL compilers (derived from Algol 58) targetting five different hardware platforms.
Were the implementors of Algol compilers different from the implementors of other languages? It’s not possible to say, although the language was created by a distinct group of people. The definition of Algol 60 was created by a committee composed of computing academics and like-minded people, while Fortran was dominated by the major computer company of the day, IBM (1963: list of 51 Fortran compilers; 1964: at least 43 Fortran compilers/versions), and COBOL was designed to be used by those strange business people (1963: list of 37 COBOL implementations/versions).
I worked on a COBOL compiler in 1967. It took 10 man years, basically 10 people for a year. We had to develop techniques to write it. Hand coded hash tables etc. I write the Translator pass A, which included the parser. It was 20,000 of assembler, written on coding sheets. All written on an NCR/Elliott 4100 with just tape decks and paper tape. You were lucky to get two compilations a day and maybe 4 tests with patching memory between.
@Greg Hayes
I once had to write a Coral 66 program on an Elliott 920C. The compiler came on five (?) paper tapes, one for each pass. Each tape was read in, transformed the program representation held in memory, with the last tape generating machine code that would then be output on tape. Thankfully, it was a one-off job, and I could return to the luxury of a terminal that support 24 lines and 72 character columns.
@Greg Hayes
I’m working on a COBOL compiler in 2024. Actually, just part of one: the rest is GCC. Our front-end gets compiled probably 100 times a day and is well over 50,000 lines of C++, stored in git. One thing hasn’t changed: time. So far we have about 8 man-years invested.
@James K. Lowden
At the start of the 1990s, I wrote the code generator MicroFocus’s Cobol compiler for Concurrent Computer’s 3200, and designed it for the Sun SPARC and Motorola 88k. It was written in Cobol, with some automatic table generation.