Dansk Datamatik Center

This is a good article. Click here for more information.
Source: Wikipedia, the free encyclopedia.

Dansk Datamatik Center
ServicesComputer science
Managing director
Leif Rystrøm
Scientific leader
Dines Bjørner
Manager, Ada projects
Ole N. Oest
Budget (1984)
DKK 13 million
Staff (1984)
40

Dansk Datamatik Center (DDC) was a Danish software research and development centre that existed from 1979 to 1989. Its main purpose was to demonstrate the value of using modern techniques, especially those involving formal methods, in software design and development.

Three major projects dominated much of the centre's existence. The first concerned the formal specification and compilation of the CHILL programming language for use in telecommunication switches. The second involved the formal specification and compilation of the Ada programming language. Both the Ada and CHILL efforts made use of formal methods.[1] In particular, DDC worked with Meta-IV, an early version of the specification language of the Vienna Development Method (VDM) formal method for the development of computer-based systems. As founded by Dines Bjørner, this represented the "Danish School" of VDM.[2] This use of VDM led in 1984 to the DDC Ada compiler becoming the first European Ada compiler to be validated by the United States Department of Defense.[3] The third major project was dedicated towards creation of a new formal method, RAISE.

The success of the Ada compiler system would lead to creation of the commercial company DDC International A/S (DDC-I, Inc. in the US) in 1985, which would develop, productise, and market it both directly to customers and to other companies which would use it as the basis for their own Ada compiler products.

Origins

DDC's origins were in the Technical University of Denmark.

In spring 1979, Christian Gram, a computer scientist at the Technical University of Denmark (DTU)—located in Kongens Lyngby, north of Copenhagen—suggested to his colleague Dines Bjørner the idea of building an advanced software institute.[4] Looking at the software crisis of the time, they felt that computer science had created foundational and theoretical approaches that if applied could make software development a more professional process and permit the development of large software systems on schedule and with quality.[5]

They approached the Akademiet for de Tekniske Videnskaber (ATV, the Danish Academy for Technical Sciences) with this idea, and in September 1979, Dansk Datamatik Center was formed as an ATV institute for advanced software development.[6] (It was also referred to as the Danish Datamatics Centre in some early documents.[7]) Ten large producers or users of information technology in Denmark became paying members of the new entity: Christian Rovsing [da], Crone & Koch, the Danish Defence Research Establishment, Datacentralen af 1959 [da], Jydsk Telefon [da], Kommunedata, Regnecentralen af 1979, Sparekassernes Datacenter, Teleteknisk Forskningslaboratorium [da] (TFL), and ØK Data, with each member paying DKK 100,000 per year.[6]

Bjørner became the scientific leader of the centre.[8] The managing director of DDC was Leif Rystrøm.

Copenhagen University.[9] In the beginning the centre was housed in a building on the DTU campus,[7] but then it became located in a converted textile mill along the Mølleåen, close to Lyngby centre.[14]

The cube-inspired red logo of DDC was designed by Ole Friis, who in 1984 won the

CHILL projects

During 1978, Bjørner became interested in creating a formal definition, using

Comité Consultatif International Téléphonique et Télégraphique (CCITT) and conducted at DTU,[17] with some eighteen students working on the effort.[18] Once DDC was established, the formal definition was completed there in 1980 and 1981.[17][19] Opinions on the value of the effort differ: Bjørner has stated it discovered a definitional issue that led to the simplification of the language, while Remi Bourgonjon of Philips, the convener of the Implementors' Forum organized by the CCITT, thought the formal definition was too complicated and came too late to benefit CHILL compiler designers.[20]

At the same time, a CHILL compiler was developed, again starting before DDC but completed by it and TFL.

GEC and others during the 1980s.[21]

A joint project that

Ada Programming Support Environment (APSE), to support projects that used both languages .[22] DDC's part of the project used an examination of the denotational semantics of both languages and concluded that such an integration was technically feasible.[23]

DDC continued to be involved in publishing papers at CHILL conferences during the first half of the 1980s, but not after that.[24]

Ada projects

Lyngby.[14]

The advent of the U.S. Defense Department sponsorship of the

Commission of the European Communities (CEC) decided to allocate funding for a European Ada compiler and runtime system.[25] A consortium of Olivetti from Italy and DDC and Christian Rovsing from Denmark submitted a bid that in early 1981 won out over a previously favored bid from a French–German consortium; half of the funding would come from the CEC and half from Danish sources.[25] Ole N. Oest was transferred from the Danish Defence Research Establishment to DDC to manage the Ada work.[9]

DDC was responsible for developing a Portable Ada Programming System.

kilobytes code and 110 kilobytes data.[26][27] As a result, the compiler was constructed of many passes, in this case six for the front end alone, with linearized trees stored in files as the representation between passes.[28]

The compiler creation process went through four steps: development of a formal specification of Ada, development of a formal specification of the compiler components; development of more detailed formal specifications of particular compiler passes; implementation of these specifications in Ada itself.[29] Among formal approaches, using the Vienna Development Method (VDM) was advantageous in this project because it was tailored for use with computer languages and compilers and because it allowed stepwise refinement of operations as well as of data representations.[30] The central goal of the process was to prove that the implementation was equivalent to the specification.[31] In cases where the static abstract syntax representation needed to have additional constraints incorporated, well-formedness criteria—another aspect of VDM—were defined.[32] The first step in the process, a formal specification for Ada, had already been started by five students at DTU in 1980 as part of their master's theses.[33]

Ada was a difficult language to implement and early attempts to build a compiler for it often resulted in disappointment or outright failure.

VAX/VMS system in September 1984, being the first European Ada compiler to pass, and proved a success.[35][36] At that point about 44 person-years of development work had gone into it.[37] The defect rate and maintenance costs would prove to be significantly lower for the compiler than for the software industry average.[37]

Attention regarding DDC's use of VDM in compiler design led to interest from other computer manufacturers and sales were made of what became known as the DDC OEM Compiler Kit

The compiler was thus rehosted and retargeted to the Honeywell DPS6 and validated in November 1984.[41]

In addition, cross compilers began to be developed, with DDC doing one from VAX/VMS to the Intel 8086,[41] beginning what would become a successful line of products. In December 1984, DDC signed a contract with Advanced Computer Techniques in New York,[10] based on a license royalty arrangement.[42] They began using the DDC front end to develop a cross-compiler for the MIL-STD-1750A architecture,[41] which would become a reasonably successful product with a number of customers.[43]

Success of the Ada project led to a separate company being formed in 1985, called DDC International A/S, with the purpose of commercializing the Ada compiler system;[6] Oest was named the managing director of the company.[44] A year later a US-based subsidiary of that company, DDC-I, Inc., was formed in the state of Arizona.[45]

Concurrent with the compiler work, there was a push on various fronts to provide a formal definition of Ada, with several different approaches and metalanguages tried.

ISO standard for the language should be published.[46] The CEC sponsored this work and the contract was won by DDC in partnership with two Italian research institutes, the Istituto di Elaborazione dell’Informazione (IEI) in Pisa and the Consorzio per la Ricerca e le Applicazioni di Informatica (CRAI) in Genoa, with work beginning in 1984.[38] Additional consulting on the project was provided by staff at the University of Genoa, the University of Pisa, and at DTU.[47] The work built up the previous formal definitions that had been done at DTU and by DDC at the beginning of its Ada compiler project, but further work was needed the define the entire language and Meta-IV had to be extended in places or alternate approaches taken.[48] This effort culminated in the 1987 publication of the full formal definition of Ada, encompassing three separate publications and eight volumes in total.[49] While this effort did lead to a better understanding of the language and a number of clarifications to it being made, in the end the ultimate definition of the language remained the natural language one in the Ada Language Reference Manual.[46]

RAISE projects

The use of VDM in the CHILL and Ada projects revealed the need for improvements in formal specification techniques, and in 1983 DDC conducted a Formal Methods Appraisal study, producing a number of requirements that a formal specification language should embody.[50]

Following that DDC was awarded a CEC contract to develop a successor to VDM, which was called RAISE (Rigorous Approach to Industrial Software Engineering).[50] This was done in consortium with STC Technology of Great Britain, which helped in the creation of the new technology, and with Nordisk Brown Boveri of Denmark and International Computers Limited of Britain, which exercised it in industrial settings.[51][52] The project involved some 120 person-years of effort and sought to create a wide-spectrum language intended to handle every level from the initial, high-level abstract one down to one level above programming.[52] It sought to remedy VDM's weaknesses with respect to modularity, concurrency, and lack of tools,[53] and it also sought to unify approaches taken in the likes of Z notation, CSP, Larch, and OBJ.[50]

Besides the RAISE Specification language, the project also produced a description of best practices for the RAISE Method,[54] and a RAISE toolset.[54]

Other projects

In 1981 DDC, in conjunction with some of its members, conducted a study of the many office automation initiatives and products then available and published a taxonomy and terminology guide that analysed the domain. They then specified a generic office automation system using both VDM and informal language.[55]

Later during 1983–1987, DDC worked as a subcontractor to member ØK Data on the Functional Analysis of Office Requirements (FAOR) project under

ESPRIT.[55]

DDC also gave courses and seminars in various software development topics, and starting in 1987, initiated a Danish-language quarterly publication Cubus which discussed various technical and scientific topics in an effort to engage in technology transfer.[56]

Conclusion and legacy

During the centre's existence, some of the constituent members lost interest in its work, with no need for the CHILL or Ada compilers and the RAISE work too ambitious for their use.[13] General acceptance of Ada as a language underperformed expectations and Ada product sales by DDC-I did not provide sufficient profits to allow money to flow to DDC.[13] With sustained funding becoming a problem, in 1989 Dansk Datamatik Center was closed down.[6]

Work on the Ada products was carried on by DDC-I, where it was used in many high-visibility aerospace and similar projects.[38] The best-known of these was the Airplane Information Management System flight software for the Boeing 777 airliner.[57] Subsequent developers of the DDC-I Ada compiler were often not as well versed in formal methods as the original developers.[37] The Ada products would still be generating revenue for DDC-I into the 2010s.[38]

DDC's work and staff on RAISE were transferred to

ESPRIT II LaCoS project in the 1990s.[6] The RAISE effort was subsequently sold to Terma A/S, who use it as part of work for the European Space Agency and various defense industry projects.[13]

DDC had relatively little involvement with the Nordic software world, because it relied on European Union-based partners and funding and Denmark was the only Nordic country in the EU at the time.[6] Nor did the Danish financial sector ever show an interest in DDC's work.[6] In looking back, the founders of the centre have stated that, "Where DDC failed was to [convince] major Danish companies of the benefits of using reliable software development based on formal methods. (But, DDC did not try very much.)"[13] DDC researchers believed that their work was still beneficial in making Danish technology firms aware of modern software development approaches and in populating those firms with as many as a hundred software designers and developers who had worked at DDC, and that in any case, "DDC completed a large number of projects with better performance and higher product quality than was common in the 1980s."[13] In a 2014 survey of forty years of formal methods efforts, Bjørner and Klaus Havelund lamented that adoption of formal methods has not become widespread in the software industry and referred to the DDC Ada compiler as an unsung success story of the value of such use.[37]

Bibliography

References

  1. ^ Bjørner, Gram, Oest, and Rystrøm, "Dansk Datamatik Center", pp. 351–352.
  2. ^ O'Regan, Mathematical Approaches to Software Quality, pp. 92–93.
  3. ^ Fitzgerald, Larsen, and Verhoef, "Vienna Development Method".
  4. ^ Bjørner, Gram, Oest, and Rystrøm, "Dansk Datamatik Center", p. 350.
  5. ^ Bjørner, Gram, Oest, and Rystrøm, "Dansk Datamatik Center", pp. 350–351.
  6. ^ a b c d e f g Bjørner, Gram, Oest, and Rystrøm, "Dansk Datamatik Center", p. 351.
  7. ^ a b Bjørner and Oest, Towards a Formal Description of Ada, p. xiii–xiv.
  8. ^ Bjørner, Gram, Oest, and Rystrøm, "Dansk Datamatik Center", expanded version, p. 2.
  9. ^ a b c Bjørner et al., "Dansk Datamatik Center", further expanded version.
  10. ^ a b Ada TM Marketing and Distribution Agreement. Dansk Datamatik Center, Advanced Computer Techniques. 20 December 1984.
  11. ^ a b Gram et al., "Why Dansk Datamatik Center?", presentation version, slide 3.
  12. ^ Bjørner, Gram, Oest, and Rystrøm, "Dansk Datamatik Center", expanded version, p. 3.
  13. ^ a b c d e f Bjørner, Gram, Oest, and Rystrøm, "Dansk Datamatik Center", pp. 357–358.
  14. ^ a b Clemmensen, "Retargeting and rehosting the DDC Ada compiler system", author affiliation gives address of Dansk Datamatik Center as Lundtoftevej 1C, DK-2800 Lyngby; for history and location of that structure, see "Julekort 2017" (in Danish). Emcon. Retrieved January 19, 2021.
  15. ^ "Æresbevisninger" (in Danish). friisgrafik.dk. Archived from the original on 29 October 2015. Retrieved 5 June 2015.
  16. ^ Paulsen, Betwixt and between, pp. 137–138.
  17. ^ a b c d Bjørner, Gram, Oest, and Rystrøm, "Dansk Datamatik Center", p. 352.
  18. ^ Bjørner and Oest, Towards a Formal Description of Ada, p. vii.
  19. ^ Paulsen, Betwixt and between, p. 139.
  20. ^ Paulsen, Betwixt and between, pp. 139–140.
  21. ^ Paulsen, Betwixt and between, pp. 216–217.
  22. ^ Paulsen, Betwixt and between, pp. 180, 216.
  23. ^ Meiling and Palm, "A comparative study of CHILL and Ada on the basis of denotational descriptions", pp. 78, 88.
  24. ^ Paulsen, Betwixt and between, p. 199.
  25. ^ a b Bjørner, Gram, Oest, and Rystrøm, "Dansk Datamatik Center", p. 353.
  26. ^ a b Clemmensen and Oest, "Formal specification and development of an Ada compiler", p. 431.
  27. ^ Bundgaard, "The development of an Ada front end for small computers", p. 321.
  28. ^ Bundgaard, "The development of an Ada front end for small computers", pp. 322, 325.
  29. ^ Clemmensen and Oest, "Formal specification and development of an Ada compiler", p. 432.
  30. ^ Clemmensen and Oest, "Formal specification and development of an Ada compiler", p. 430.
  31. ^ Clemmensen and Oest, "Formal specification and development of an Ada compiler", pp. 430–431.
  32. ^ Clemmensen and Oest, "Formal specification and development of an Ada compiler", pp. 432, 440n.
  33. ^ Bjørner and Oest, Towards a Formal Description of Ada, p. vi.
  34. ^ Whitaker, "Ada—The Project", pp. 217–218.
  35. ^ Bundgaard, "The development of an Ada front end for small computers", p. 322.
  36. ^ a b Clemmensen, "Retargeting and rehosting the DDC Ada compiler system", p. 22.
  37. ^ a b c d Bjørner and Havelund, "40 Years of Formal Methods", pp. 48–49.
  38. ^ a b c d e f Bjørner, Gram, Oest, and Rystrøm, "Dansk Datamatik Center", p. 354.
  39. ^ Clemmensen, "Retargeting and rehosting the DDC Ada compiler system", pp. 24–25.
  40. ^ Ibsen, "A portable virtual machine for Ada", pp. 17, 27.
  41. ^ a b c d Bundgaard, "The development of an Ada front end for small computers", p. 328.
  42. ^ Haigh, An Interview with Oscar Schachter, p. 22.
  43. ^ Haigh, An Interview with Oscar Schachter, pp. 17, 22.
  44. ^ Bjørner, Gram, Oest, and Rystrøm, "Dansk Datamatik Center", expanded version, p. 11.
  45. ^ "DDC-I, Inc". OpenCorporates. Retrieved 20 September 2015.
  46. ^ a b c Whitaker, "Ada—The Project", pp. 215–216.
  47. ^ Pedersen, "VDM in Three Generations of Ada Formal Descriptions", p. 34.
  48. ^ Pedersen, "VDM in Three Generations of Ada Formal Descriptions", pp. 44–46.
  49. ^ Whitaker, "Ada—The Project", pp. 226–228.
  50. ^ a b c Bjørner, Gram, Oest, and Rystrøm, "Dansk Datamatik Center", pp. 355.
  51. ^ Prehn, "From VDM to RAISE", pp. 144–145.
  52. ^ a b c George, "The RAISE Specification Language", p. 238.
  53. ^ Prehn, "From VDM to RAISE", p. 141.
  54. ^ a b George, "The RAISE Specification Language", p. 239.
  55. ^ a b Bjørner, Gram, Oest, and Rystrøm, "Dansk Datamatik Center", pp. 355–356.
  56. ^ Bjørner, Gram, Oest, and Rystrøm, "Dansk Datamatik Center", pp. 356–357.
  57. ^ Wolfe, Alexander (October 2004). "There's Still Some Life Left in Ada". ACM Queue. Also at http://delivery.acm.org/10.1145/1040000/1035608/p28-wolfe.pdf[permanent dead link]