Product Code Database
Example Keywords: software -data $2-198
   » » Wiki: Simula
Tag Wiki 'Simula'.
Tag

Simula is the name of two simulation programming languages, Simula I and Simula 67, developed in the 1960s at the Norwegian Computing Center in , by and . Syntactically, it is an approximate of ALGOL 60,

and was also influenced by the design of .

Simula 67 introduced objects, classes, inheritance and subclasses, , , and discrete event simulation, and featured garbage collection. Other forms of (besides inheriting subclasses) were introduced in Simula derivatives.

Simula is considered the first object-oriented programming language. As its name suggests, the first Simula version by 1962 was designed for doing /ref> and provided the framework for many of the features of object-oriented languages today.

Simula has been used in a wide range of applications such as simulating very-large-scale integration (VLSI) designs, , communication protocols, , and other applications such as , computer graphics, and .

Computer scientists such as Bjarne Stroustrup, creator of C++, and , creator of Java, have acknowledged Simula as a major influence. Simula-type objects are reimplemented in C++, , Java, C#, and many other languages.


History
The following account is based on Jan Rune Holmevik's historical essay.

started writing computer simulation programs in 1957. Nygaard saw a need for a better way to describe the heterogeneity and the operation of a system. To further develop his ideas for a computer language to describe a system, Nygaard realized that he needed someone with more computer programming skills than he had. joined him on his work in January 1962. Shortly after, the decision was made to link the language to ALGOL 60. By May 1962, the main concepts for a simulation language were established; SIMULA I, a specialized programming language designed for simulating discrete event systems, was born.

Kristen Nygaard was invited to visit the Eckert–Mauchly Computer Corporation in late May 1962 in connection with the marketing of their new UNIVAC 1107 computer. At that visit, Nygaard presented the ideas of Simula to , the director of systems programming at . Bemer was a great fan and found the Simula project compelling. Bemer was also of a session at the second international conference on information processing hosted by International Federation for Information Processing (IFIP). He invited Nygaard, who presented the paper "SIMULA – An Extension of ALGOL to the Description of Discrete-Event Networks".

The Norwegian Computing Center got a UNIVAC 1107 in August 1963 at a considerable discount, on which Dahl implemented the SIMULA I under contract with UNIVAC. The implementation was based on the UNIVAC ALGOL 60 compiler. SIMULA I was fully operational on the UNIVAC 1107 by January 1965. In the following few years, Dahl and Nygaard spent a lot of time teaching Simula. Simula spread to several countries around the world and SIMULA I was later implemented on other computers including the Burroughs B5500 and the Russian Ural-16.

In 1966 C. A. R. Hoare introduced the concept of record class construct, which Dahl and Nygaard extended with the concept of prefixing and other features to meet their requirements for a generalized process concept. Dahl and Nygaard presented their paper on class and subclass declarations at the IFIP Working Conference on simulation languages in , May 1967. This paper became the first formal definition of Simula 67. In June 1967, a conference was held to standardize the language and initiate a number of implementations. Dahl proposed to unify the and the class concept. This led to serious discussions, and the proposal was rejected by the board. Simula 67 was formally standardized on the first meeting of the Simula Standards Group (SSG) in February 1968.

Simula was influential in the development of and later object-oriented programming languages. It also helped inspire the of concurrent computation although Simula only supports and not true concurrency.

(2026). 9783662444719, Springer.

In the late sixties and the early seventies, there were four main implementations of Simula:

  • 1100 by Norwegian Computing Center (NCC)
  • System/360 and System/370 by NCC
  • CDC 3000 by University of Oslo's Joint Computer Installation at Kjeller
  • TOPS-10 by Swedish National Defence Research Institute (FOA)

These implementations were ported to a wide range of platforms. The TOPS-10 implemented the concept of public, protected, and private member variables and procedures, that later was integrated into Simula Standard in 1986.

Simula Standard 1986 is the latest standard and is ported to a wide range of platforms. There are mainly four implementations:

  • Simula AS
  • Lund Simula
  • GNU Cim
  • Portable Simula Revisited

In November 2001, Dahl and Nygaard were awarded the IEEE John von Neumann Medal by the Institute of Electrical and Electronics Engineers "For the introduction of the concepts underlying object-oriented programming through the design and implementation of SIMULA 67". In April 2002, they received the 2001 A. M. by the Association for Computing Machinery (ACM), with the citation: "For ideas fundamental to the emergence of object oriented programming, through their design of the programming languages Simula I and Simula 67." Dahl and Nygaard died in June and August of that year, respectively, before the ACM Turing Award Lecture that was scheduled to be delivered at the November 2002 conference in Seattle.

Simula Research Laboratory is a research institute named after the Simula language, and Nygaard held a part-time position there from the opening in 2001. The new Computer Science building at the University of Oslo is named Ole Johan Dahl's House, in Dahl's honour, and the main auditorium is named Simula.


Sample code

Minimal program
The empty is the minimal in Simula, measured by the size of the . It consists of one thing only; a dummy statement.

However, the minimal program is more conveniently represented as an empty block:

'''Begin'''
'''End''';
     

It begins executing and immediately terminates. The language lacks any from the program.


Classic Hello world
An example of a Hello world program in Simula:

'''Begin'''
   '''OutText''' ("Hello, World!");
   '''Outimage''';
'''End''';
     

Simula is .


Classes, subclasses and virtual procedures
A more realistic example with use of classes, subclasses and virtual procedures:

'''Begin'''
   '''Class''' Glyph;
      '''Virtual''': '''Procedure''' print '''Is''' '''Procedure''' print;;
   '''Begin'''
   '''End''';
     

   Glyph '''Class''' Char (c);
      '''Character''' c;
   '''Begin'''
      '''Procedure''' print;
        OutChar(c);
   '''End''';
     

   Glyph '''Class''' Line (elements);
      '''Ref''' (Glyph) '''Array''' elements;
   '''Begin'''
      '''Procedure''' print;
      '''Begin'''
         '''Integer''' i;
         '''For''' i:= 1 '''Step''' 1 '''Until''' UpperBound (elements, 1) '''Do'''
            elements (i).print;
         OutImage;
      '''End''';
   '''End''';
     

   '''Ref''' (Glyph) rg;
   '''Ref''' (Glyph) '''Array''' rgs (1 : 4);
     

   ''! Main program;''
   rgs (1):- '''New''' Char ('A');
   rgs (2):- '''New''' Char ('b');
   rgs (3):- '''New''' Char ('b');
   rgs (4):- '''New''' Char ('a');
   rg:- '''New''' Line (rgs);
   rg.print;
'''End''';
     

The above example has one super class (Glyph) with two subclasses (Char and Line). There is one with two . The execution starts by executing the main program. Simula lacks the concept of , since classes with pure can be instantiated. This means that in the above example, all classes can be instantiated. Calling a pure virtual procedure will however produce a run-time .


Call by name
Simula supports call by name so the Jensen's Device can easily be implemented. However, the default transmission mode for simple parameter is call by value, contrary to which used call by name. The source code for the Jensen's Device must therefore specify call by name for the parameters when compiled by a Simula compiler.

Another much simpler example is the summation function \sum which can be implemented as follows:

'''Real''' '''Procedure''' Sigma (k, m, n, u);
   '''Name''' k, u;
   '''Integer''' k, m, n; '''Real''' u;
'''Begin'''
   '''Real''' s;
   k:= m;
   '''While''' k <= n '''Do''' '''Begin''' s:= s + u; k:= k + 1; '''End''';
   Sigma:= s;
'''End''';
     

The above code uses call by name for the controlling variable (k) and the expression (u). This allows the controlling variable to be used in the expression.

Note that the Simula standard allows for certain restrictions on the controlling variable in a . The above code therefore uses a while loop for maximum portability.

The following:

Z = \sum_{i=1}^{100}{1 \over (i + a)^2}

can then be implemented as follows:

Z:= Sigma (i, 1, 100, 1 / (i + a) ** 2);
     


Simulation
Simula includes a package for doing discrete event simulations. This simulation package is based on Simula's object-oriented features and its concept. Simula provided functions to do random number generation of pseudo-random numbers.

Sam, Sally, and Andy are shopping for clothes. They must share one fitting room. Each one of them is browsing the store for about 12 minutes and then uses the fitting room exclusively for about three minutes, each following a normal distribution. A simulation of their fitting room experience is as follows:

Simulation '''Begin'''
   '''Class''' FittingRoom; '''Begin'''
      '''Ref''' (Head) door;
      '''Boolean''' inUse;
      '''Procedure''' request; '''Begin'''
         '''If''' inUse '''Then''' '''Begin'''
             Wait (door);
             door.First.Out;
         '''End''';
         inUse:= '''True''';
      '''End''';
      '''Procedure''' leave; '''Begin'''
         inUse:= '''False''';
         '''Activate''' door.First;
      '''End''';
      door:- '''New''' Head;
   '''End''';
     

   '''Procedure''' report (message); '''Text''' message; '''Begin'''
      OutFix (Time, 2, 0); OutText (": " & message); OutImage;
   '''End''';
     

   Process '''Class''' Person (pname); '''Text''' pname; '''Begin'''
      '''While''' '''True''' '''Do''' '''Begin'''
         Hold (Normal (12, 4, u));
         report  (pname & " is requesting the fitting room");
         fittingroom1.request;
         report (pname & " has entered the fitting room");
         Hold (Normal (3, 1, u));
         fittingroom1.leave;
         report (pname & " has left the fitting room");
      '''End''';
   '''End''';
     

   '''Integer''' u;
   '''Ref''' (FittingRoom) fittingRoom1;
     

   fittingRoom1:- '''New''' FittingRoom;
   '''Activate''' '''New''' Person ("Sam");
   '''Activate''' '''New''' Person ("Sally");
   '''Activate''' '''New''' Person ("Andy");
   Hold (100);
'''End''';
     

The main block is prefixed with Simulation for enabling simulation. The simulation package can be used on any block and simulations can even be nested when simulating someone doing simulations.

The fitting room object uses a queue (door) for getting access to the fitting room. When someone requests the fitting room and it's in use they must wait in this queue (Wait (door)). When someone leaves the fitting room the first one (if any) is released from the queue ('''Activate''' door.first) and accordingly removed from the door queue (door.First.Out).

Person is a subclass of Process and its activity is described using hold (time for browsing the store and time spent in the fitting room) and calls procedures in the fitting room object for requesting and leaving the fitting room.

The main program creates all the objects and activates all the person objects to put them into the event queue. The main program holds for 100 minutes of simulated time before the program terminates.


Notes

Sources

Further reading

External links

Page 1 of 1
1
Page 1 of 1
1

Account

Social:
Pages:  ..   .. 
Items:  .. 

Navigation

General: Atom Feed Atom Feed  .. 
Help:  ..   .. 
Category:  ..   .. 
Media:  ..   .. 
Posts:  ..   ..   .. 

Statistics

Page:  .. 
Summary:  .. 
1 Tags
10/10 Page Rank
5 Page Refs