Professional Documents
Culture Documents
The Programming Language Pascal OOP
The Programming Language Pascal OOP
The Programming Language Pascal OOP
9 by Springer-Verlag 1971
1. Introduction
The development of the language Pascal is based on two principal aims. The
first is to m a k e available a language suitable to teach programming as a systematic
discipline based on certain fundamental concepts clearly and naturally reflected
b y the language. The second is to develop implementations of this language which
are both reliable and efficient on presently available computers, dispelling the
commonly accepted notion t h a t useful languages must be either slow to compile
or slow to execute, and the belief t h a t a n y nontrivial system is bound to contain
mistakes forever.
There is of course plenty of reason to be cautious with the introduction of yet
another programming language, and the objection against teaching programming
in a language which is not widely used and accepted has undoubtedly some justi-
fication--at least based on short-term commercial reasoning. However, the choice
of a language for teaching based on its widespread acceptance and availability,
together with the fact t h a t the language most widely taught is thereafter going
to be the one most widely used, forms the safest recipe for stagnation in a subject
of such profound paedagogical influence. I consider it therefore well worth-while
to m a k e an effort to break this vicious circle.
Of course a new language should not be developed just for the sake of novelty;
existing languages should be used as a basis for development wherever t h e y meet
the chosen objectives, such as a systematic structure, flexibility of program and
data structuring, and efficient implementabillty. In that sense ALGOL 60 was used
as a basis for Pascal, since it meets most of these demands to a much higher
degree than a n y other standard language [! ]. Thus the principles of structuring,
and in fact the form of expressions, are copied from ALGOL 60. I t was, however,
not deemed appropriate to adopt ALGOL 60 as a subset of Pascal; certain con-
struction principles, particularly those of declarations, would have been incom-
* Fachgruppe Computer-Wissenschaften, Eidg. Technische Hochschule, Ziirich,
Schweiz.
3*
36 N. Wirth :
patible with those allowing a natural and convenient representation of the ad-
ditional features of Pascal. However, conversion of ALGOL 60 programs to Pascal
can be considered as a negligible effort of transcription, particularly if they obey
the rules of the I F I P ALGOL Subset [2].
The main extensions relative to ALGOL 60 lie in the domain of data structuring
facilities, since their lack in ALGOL 60 was considered as the prime cause for its
relatively narrow range of applicability. The introduction of record and file
structures should make it possible to solve commercial type problems with Pascal,
or at least to employ it successfully to demonstrate such problems in a pro-
gramming course. This should help erase the mystical belief in the segregation
between scientific and commercial programming methods. A first step in extending
the data definition facilities of ALGOL 60 was undertaken in an effort to define
a successor to ALGOL in t965 [31. This language is a direct predecessor of Pascal,
and was the source of m a n y features such as e.g. the while and case statements
and of record structures.
Pascal has been implemented on the CDC 6000 computers. The compiler is
written in Pascal itself as a one-pass system which will be the subject of a sub-
sequent report. The "dialect" processed b y this implementation is described b y
a few amendments to the general description of Pascal. They are included here
as a separate chapter to demonstrate the brevity of a manual necessary to
characterise a particular implementation. Moreover, they show how facilities are
introduced into this high-level, machine independent programming language,
which permit the programmer to take advantage of the characteristics of a
particular machine.
The syntax of Pascal has been kept as simple as possible. Most statements and
declarations begin with a unique key word. This property facilitates both the
understanding of programs b y human readers and the processing b y computers.
In fact, the syntax has been devised so that Pascal texts can be scanned b y the
simplest techniques of syntactic analysis. This textual simplicity is particularly
desirable, if the compiler is required to possess the capability to detect and
diagnose errors and to proceed thereafter in a sensible manner.
in the set. Apart from the definable scalar types, there exist in Pascal four
standard scalar types whose values are not denoted b y identifiers, but instead
b y numbers and quotations respectively, which are syntactically distinct from
identifiers. These types are: integer, real, char, and al/a.
The set of values of type char is the character set available on the printers
of a particular installation. Al]a type values consist of sequences of characters
whose length again is implementation dependent, i.e. is the number of characters
packed per word. Individual characters are not directly accessible, but al]a quan-
tities can be unpacked into a character a r r a y (and vice-versa) b y a standard
procedure.
A scalar type m a y also be defined as a subrange of another scalar type b y
indicating the smallest and the largest value of the subrange.
Structured types are defined b y describing the types of their components and
b y indicating a structuring method. The various structuring methods differ in the
selection mechanism serving to select the components of a variable of the struc-
tured type. In Pascal, there are five structuring methods available: array struc-
ture, record structure, powerset structure, file structure, and class structure.
In an array structure, all components are of the same type. A component is
selected b y an array selector, or computable index, whose type is indicated in
the array t y p e definition and which must be scalar. It is usually a programmer-
defined scalar type, or a subrange of the t y p e integer.
In a record structure, the components (called fields) are not necessarily of the
same type. In order t h a t the type of a selected component be evident from the
program text (without executing the program), a record selector does not contain
a computable value, but instead consists of an identifier uniquely denoting the
component to be selected. These component identifiers are defined in the record
type definition.
A record type m a y be specified as consisting of several variants. This implies
that different variables, although said to be of the same type, m a y assume
structures which differ in a certain manner. The difference m a y consist of a
different number and different types of components. The variant which is assumed
b y the current value of a record variable is indicated b y a component field which
is common to all variants and is called the tag field. Usually, the part common
to all variants will consist of several components, including the tag field.
A powerset structure defines a set of values which is the powerset of its base
type, i.e. the set of all subsets of values of the base type. The base type m u s t
be a scalar type, and will usually be a programmer-defined scalar type or a
subrange of the type integer.
A file structure is a sequence of components of the same type. A natural
ordering of the components is defined through the sequence. At a n y instance,
only one component is directly accessible. The other components are made acces-
sible through execution of standard file positioning procedures. A file is at a n y
time in one of the three modes called input, output, and neutral. According to
the mode, a file can be read sequentially, or it can be written b y appending
components to the existing sequence of components. File positioning procedures
m a y influence the mode. The file type definition does not determine the number
of components, and this number is variable during execution of the program.
38 N. Wirth :
The class structure defines a class of components of the same type whose
number m a y alter during execution of a program. Each declaration of a variable
with class structure introduces a set of variables of the component type. The set
is initially empty. E v e r y activation of the standard procedure alloc (with the class
as implied parameter) will generate (or allocate) a new component variable in the
class and yield a value through which this new component variable m a y be ac-
cessed. This value is called a pointer, and m a y be assigned to variables of type
pointer. E v e r y pointer variable, however, is through its declaration bound to a
fixed class variable, and because of this binding m a y only assume values pointing
to components of that class. There exists a pointer value nil which points to no
component whatsoever, and m a y be assumed b y any pointer variable irrespective
of its binding. Through the use of class structures it is possible to construct data
corresponding to any finite graph with pointers representing edges and com-
ponent variables representing nodes.
The most fundamental statement is the assignment statement. It specifies that
a newly computed value be assigned to a variable (or component of a variable).
The value is obtained b y evaluating an expression. Pascal defines a fixed set of
operators, each of which can be regarded as describing a mapping from the
operand types into the result type. The set of operators is subdivided into
groups of
1. arithmetic operators of addition, subtraction, sign inversion, multiplication,
division, and computing the remainder. The operand and result types are the
types integer and real, or subrange types of integer.
2. Boolean operators of negation, union (or), and conjunction (and). The
operand and result types are Boolean (which is a standard type).
3. set operators of union, intersection, and difference. The operands and
results are of any powerset type.
4. relational operators of equality, inequality, ordering and set membership.
The result of relational operations is of type Boolean. Any two operands m a y
be compared for equality as long as they are of the same type. The ordering
relations apply only to scalar types.
The assignment statement is a so-called simple statement, since it does not
contain a n y other statement within itself. Another kind of simple statement is
the procedure statement, which causes the execution of the designated procedure
(see below). Simple statements are the components or building blocks of structured
statements, which specify sequential, selective, or repeated execution of their
components. Sequential execution of statements is specified b y the compound
statement, conditional or selective execution by the i/ statement and the case
statement, and repeated execution b y the repeat statement, the while statement,
and t h e / o r statement. The if statement serves to make the execution of a statement
dependent on the value of a Boolean expression, and the case statement allows
for the selection among m a n y statements according to the value of a selector.
The for statement is used when the number of iterations is known beforehand,
and the repeat and while statements are used otherwise.
A statement can be given a name (identifier), and be referenced through that
identifier. The statement is then called a procedure, and its declaration a procedure
Tile Programming Language Pascal 39
may be inserted between any two identifiers, numbers (cf. 4), or special symbols.
It is called a comment and may be removed from the program text without
altering its meaning.
40 N. Wirth:
The decimal notation is used for numbers, which are the constants of the data
types integer and real. The symbol i0 preceding the scale factor is pronounced
as " t i m e s t0 to the power of".
Examples:
5. Constant Definitions
A constant definition introduces an identifier as a synonym to a constant.
Examples:
(red, orange, yellow, green, blue)
(club, diamond, heart, spade)
(Monday, Tuesday, Wednesday, Thursday, Friday, Saturday, Sunday)
Functions applying to all scalar types are:
succ the succeeding value (in the enumeration)
pred the preceding value (in the enumeration)
o~ ~ - a 1 . . . a~ ... a n
(subrange t y p e ) :: = ( c o n s t a n t ) . . ( c o n s t a n t )
42 N. Wirth:
Examples:
t..t00
--t0.. +t0
Monday.. Friday
Examples:
a r r a y [ t . . 100] of real
a r r a y [t . .10, 1 . . 20] 0 f 0 . . 9 9
a r r a y [-- t 0 . . + 10] of Boolean
a r r a y [Boolean] o f Color
Examples:
record day: 1.. 31;
month: t . . t 2 ;
year: 0.. 2000
end
r e c o r d x, y : real;
area: real;
c a s e s: Shape o f
triangle: (side: real;
inclination, angle1, angle2: Angle);
rectangle: (side1, side2: real;
skew, angle3: Angle) ;
circle: (diameter: real)
end
(file t y p e ) :: = file of ( t y p e )
actual parameters are expected either to be the standard input and output media
of the computer installation, or to be specifyable in the system command activating
the Pascal system.
Examples:
x, y, z: real
u, v: Complex
i, j: integer
k: 0..9
p, q: Boolean
operator: (plus, times, absval)
a: a r r a y [0.. 63 ] of real
b: array EColor, Boolean] of
record occurrence: integer;
appeal: real
end
c: Color
/: file of Card
hue1, hue2: powerset Color
family: class 100 of Person
pl, p~: ,family
Denotations of variables either denote an entire variable or a component of a
variable.
(variable) :: =- (entire variable) [ (component variable)
The types of the index expressions must correspond with the index types
declared in the definition of the array type.
Examples:
a[12]
a[i + i]
b [red, true]
b [suee (6, P ^ q]
/t[~]
Examples:
u . realpart
v . realpart
b [red, true], appeal
p2 f . size
Examples:
p l f. /ather
p l f . eldersibling t. youngestchitd
The Programming Language Pascal 47
8. Expressions
Expressions are constructs denoting rules of computation for obtaining values
of variables and generating new values by the apphcation of operators. Expressions
consist of operands, i.e. variables and constants, operators, and functions.
The rules of composition specify operator precedences according to four classes
of operators. The operator -1 has the highest precedence, followed by the so-
called multiplying operators, then the so-called adding operators, and finally,
with the lowest precedence, the relational operators. Sequences of operators of
the same precedence are executed from left to right. These rules of precedence
are reflected by the following syntax:
Expressions which are members of a set must all be of the same type, which
is the base type of the set. [ ] denotes the empty set.
Examples:
Factors: X
t5
(x + y +z)
sin (x +y)
[red, c, green]
7p
Terms: x*y
i/(t - - 0
P^q
(x < y) ^ (y < z)
Simple expressions: x + y
--X
hue1 v hue2
i'i+1
48 N. W i r t h :
Expressions: x =1.5
p<=q
(i<i) =(i<k)
c in hue1
8.1. Operators
8.1.1. T h e O p e r a t o r -1
T h e o p e r a t o r -1 a p p l i e d t o a Boolean o p e r a n d d e n o t e s negation.
8.t .2. M u l t i p l y i n g O p e r a t o r s
( m u l t i p l y i n g o p e r a t o r ) :: = * 1/I d i v I r o o d I ^
8.1.3. A d d i n g O p e r a t o r s
( a d d i n g o p e r a t o r ) :: = + I - - I v
real o r
| integer, if both operands
+ addition integer } are of t y p e integer,
real or J real otherwise
-- subtraction integer
-- set difference any powerset t y p e T T
~logical "or" Boolean Boolean
v kset union any powerset t y p e T T
Notice that all scalar types define ordered sets of values. In particular, ]alse < true.
The operators _< and >- m a y also be used for comparing values of powerset
type, and then denote set inclusion ~ and ) respectively.
(function designator) :: =
(function identifier) ((actual parameter {, (actual parameter)}*)
(function identifier) :: = (identifier)
Examples:
Sum (a, 100)
GCD (t47, k)
sin (x + y)
eot(l)
9. Statements
Statements denote algorithmic actions, and are said to be executable.
Examples:
x:=y+2.5
p : - - (~=<i) ^ (i<t00)
i : = sqr (k) - (i * i)
hue : = Eblue, succ (c) ]
Example :
beginz:=x; x:=y; y:=zend
9.2.2.t. If Statements
The if statement specifies that a statement be executed only if a certain
condition (Boolean expression) is true. If it is/alse, then either no statement is
to be executed, or the statement following the symbol else is to be executed.
(if s t a t e m e n t ) :: = if (expression) then ( s t a t e m e n t ) I
if (expression) then (statement) else ( s t a t e m e n t )
The expression between the symbols if and then must be of type Boolean.
4*
52 1~. Wirth:
Examples :
if x < t . 5 t h e n z : = x + y e l s e z : = l.5
i f p 4: nil t h e n p : = p t . / a t h e r
Example:
c a s e operator o f
plus: x:= x + y ;
times: x := x * y ;
absval : i f x < 0 t h e n x : = - - x
end
is equivalent to
if e then
begin S;
while e do S
end
Examples:
w h i l e (a [i] 4= x) ^ (i < n) do i : = i + 1
w h i l e i > 0 do
begin if odd (i) then z : = z * x;
i : = i div 2;
x : = sqr (x)
end
Examples:
repeat k : = i moO j;
i:=i;
i:=k
until i = 0
r e p e a t get (f)
until (/~ = a ) veo/(/)
Examples:
for i : = 2 to t00 d o if a [i] > max t h e n max : = a [i]
for i:= t tondo
for~':=t tondo
begin x : = O;
for k : : 1 to n d o x : = x + a [ i , k]*b[k,{];
c[i, i] : = x
end
for c : = red to blue d o try(c)
Example:
with date do
begin
if month= t2 then
b e g i n month : = t ; y e a r : = y e a r + t
e n d else month : = month + t
end
This statement is equivalent to
begin
if date. m o n t h = 12 then
b e g i n date. month : = 1 ; date . y e a r : = date . y e a r + t
e n d else date. month : = date. month + 1
end
The type definition part contains all type definitions which are local to the
procedure declaration.
( t y p e definition p a r t ) :: = ( e m p t y ) I
type ( t y p e definition) {; ( t y p e definition)}*;
The variable declaration part contains all variable declarations local to the
procedure declaration.
(variable declaration p a r t ) :: = ( e m p t y ) [
var (variable declaration) {; (variable declaration)}*;
The procedure and function declaration part contains all procedure and function
declarations local to the procedure declaration.
(procedure and function declaration p a r t ) :: =
{ (procedure or function declaration) ;}*
(procedure or function declaration) :: =
(procedure declaration) ] (function declaration)
All identifiers introduced in the formal parameter part, the constant definition
part, the type definition part, the variable-, procedure or function declaration
parts are local to the procedure declaration which is called the scope of these
identifiers. They are not known outside their scope. In the case of local variables,
their values are undefined at the beginning of the statement part.
The use of the procedure identifier in a procedure statement within its
declaration implies recursive execution of the procedure.
begin p : = true;
while abs(a --b) > eps do
begin m : = (a + b ) ] 2 ;
if / (m) > 0 t h e n b : = m e l s e a : = m
end;
ze~v0 : ~-- a
end
end
procedure GCD (m, n: integer; v a r , x, y, z: integer); { m > 0 , n > 0 }
v a t al, a2, bl, b2, c, d, q, r: integer;
begln{Greatest Common Divisor x of m and n,
Extended Euclid's Algorithm, cf. [4], p. 14}
e:=m; d:=n;
al:=0; a2:=t; bl:=l; b2:=0;
while d4:0 do
begin{al*m + bl*n = d, a2*m + n2*n = c,
gcd(e, a) =g~d(,~, n)}
q:=cdivd; r:=cmodd;
{e = q*d + r , gcd(d, r) = g c d ( m , n)}
a2 : = a2 -- q'a1; b2 : = b2 -- q'b1;
{a2*m + b2*n = r, a l * m + bl*n = d}
c:=d; d:=r;
r := a l ; a l : = a2 ; a2 : = r ;
r:=bl; bl:=b2; b2:=r;
{ a l * m + bl*n = d, a2*m + b2*n = c,
gcd (c, d) = g c d (m, n)}
end;
(god (c, o) = c = god (m, n)}
x:=c; y:=a2; z:=b2
{x = g c d (m, n), y * m + z*n = g c d (m, n))
end
get(t) advances the file pointer of file ] to the next file component. I t is
only applicable, if the file is either in the input or in the neutral mode.
If there does not exist a next file component, the end-of-file condition
arises, the value of the variable denoted b y tJ' becomes undefined, and
the file is put into the neutral mode.
reset(l) the file pointer of file t is reset to its beginning, and the file is put
into the neutral mode.
(function declaration) :: =
(function heading)
(constant definition p a r t ) ( t y p e definition p a r t )
(variable declaration p a r t )
(procedure and function declaration p a r t ) (statement p a r t )
The function heading specifies the identifier naming the function, the formal
parameters of the function (note that there must be at least one parameter),
and the type of the (result of the) function.
The type of the function must be a scalar or a subrange type or a pointer type.
Within the function declaration there must be at least one assignment statement
assigning a value to the function identifier. This assignment determines the
result of the function. Occurrence of the function identifier in a function designator
within its declaration implies recursive execution of the function. Within the
statement part no assignment must occur to any variable which is not local to
the function. This rule also excludes assignments to parameters.
Examples:
f u n c t i o n Sqrt (x : real): real;
v a r xO, xl: real;
b e g i n xl : = x; { x > 1, Newton's method}
r e p e a t xO : = xl; x l : = (xO + x/xO)*0.5
{xO 2 --2*xl*xO + x = 0}
until abs (xl -- xO) <=eps;
{ (xO -- eps) <=x l ~ (xO + eps),
(x -- 2*eps*xO) < xO2 < (x + 2*eps*xO) }
Sqrt : = xO
end
if odd(i) t h e n z : = z ' w ;
i :=idiv2; {z*w ~ = x y}
w:=sqr(w)
end;
{i--o, z=x'}
Power: ~ z
end
60 N. Wirth:
1 t . t . I . Arithmetic Functions
abs (x) computes the absolute value of x. The type of x must be either real
or integer, and the type of the result is the type of x.
sqr(x) computes x z. The type of x must be either real or integer, and the
type of the result is the type of x.
sin(x) I
cos(x) I
exp (x) [the type of x must be either real or integer, and the type of the result
In (x) |is real
sqrt(x) /
araan (x) J
t t . t . 2 . Predicates
odd (x) the type of x must be integer, and the result is x rood 2 = l
eo/(l) indicates, whether the file ] is in the end-of-file status.
12. Programs
A Pascal program has the form of a procedure declaration without heading
(cf. also 7.4.).
3. Vocabulary
Only capital letters are available in the basic vocabulary of symbols. The
symbol eol is added to the vocabulary. Symbols which consist of a sequence
of underlined letters are called word-delimiters. They are written in Pascal 6000
without underlining and without any surrounding escape characters. Blanks or
end-of-lines may be inserted anywhere except within : = , word-delimiters, iden-
tifiers, and numbers. The symbol lo is written as '.
4. Identifiers
Only the l0 first symbols of an identifier are significant. Identifiers not
differing in the t0 first symbols are considered as equal. Word-delimiters must
not be used as identifiers. At least one blank space must be inserted between
any two word-delimiters or between a word-delimiter and an adjacent identifier.
6. Data Types
6.1.t. Standard Scalar Types
integer is defined as
t y p e integer = - - 2 ~ + t .. 2 ~ -- t
real is defined according to the CDC 6000 floating point format specifications.
Arithmetic operations on real type values imply rounding.
char is defined b y the CDC 6000 display code character set. This set is in-
cremented b y the character denoted b y eol, signifying end-of-line.
The ordered set is:
eol A B C D E F G H I
J K L M N O P Q R S
T U V W X Y Z o 1 2
3 4 5 6 7 8 9 + -- *
I ( ) $ = u , ' [
] : ~: { v ^ t } < >
~ -1 ;
(Note that the characters ' { } are special features on the printers of the
E T H installation, and correspond to the characters ~ ff ~, at standard
CDC systems.)
al/a the number n of characters packed into an alfa value is t0 (cf. 6.1.t.).
62 N. W i r t h :
6.2.3. P o w e r s e t T y p e s
T h e b a s e t y p e of a p o w e r s e t t y p e m u s t be e i t h e r
t. a s c a l a r t y p e w i t h less t h a n 60 values, or
2. a s u b r a n g e of t h e t y p e integer, w i t h a m i n i m u m e l e m e n t min(T) >=0 a n d
a m a x i m u m e l e m e n t max(T) < 59, or
3. a s u b r a n g e of t h e t y p e char w i t h t h e m a x i m u m e l e m e n t max(T)<'>'.
7. V a r i a b l e D e c l a r a t i o n s
File v a r i a b l e s d e c l a r e d in t h e m a i n p r o g r a m m a y be r e s t r i c t e d to e i t h e r i n p u t
or o u t p u t m o d e b y a p p e n d i n g t h e specifiers
[in] or [out3
to t h e file i d e n t i f i e r in its declaration. Files r e s t r i c t e d to i n p u t m o d e (input files)
are e x p e c t e d to be P e r m a n e n t F i l e s a t t a c h e d to t h e j o b b y t h e S C O P E A t t a c h
c o m m a n d , a n d files r e s t r i c t e d to o u t p u t m o d e m a y b e c a t a l o g u e d as P e r m a n e n t
F i l e s b y t h e S C O P E Catalog c o m m a n d . I n b o t h c o m m a n d s , t h e file i d e n t i f i e r is
to be u s e d as t h e Logical F i l e N a m e [51.
t0. a n d 1t. P r o c e d u r e a n d F u n c t i o n D e c l a r a t i o n s
A p r o c e d u r e or a function which c o n t a i n s local file d e c l a r a t i o n s m u s t n o t be
a c t i v a t e d recursively.
14. Glossary
actual p a r a m e t e r 9.t .2. field identifier 7.2.2.
adding operator 8. t. 3. field list 6.2.2.
array type 6.2.t. file t y p e 6.2.4.
a r r a y variable 7.2.1. file variable 7.2.3.
assignment statement 9.1.1. final value 9.2.3.3.
case label 6.2.2. fixed p a r t 6.2.2.
case list element 9.2.2.2. for list 9.2.3.3.
case statement 9.2.2.2. for statement 9.2.3.3.
class t y p e 6.2.5. formal parameter
class variable 6.2.6. section t O.
component statement 9.2.1. function declaration 1 t.
component t y p e 6.2.1. function designator 8.2.
component variable 7.2. function heading 1 t.
compound statement 9.2.t. function identifier 8.2.
conditional statement 9.2.2. goto statement 9.1.3.
constant 5. identifier 4.
constant definition 5. if statement 9.2.2.1.
constant definition p a r t 10. index t y p e 6.2.1.
control variable 9.2.3.3. indexed variable 7.2.1.
current file component 7.2.3. initial value 9.2.3.3.
digit 3. integer 4.
entire variable 7.1. label 9.1.3.
expression 8. label definition 9.2.1.
factor 8. letter 3.
field designator 7.2.2. letter or digit 4.
The Programming Language Pascal 63
References
1. Naur, P. : Report on the algorithmic language ALGOL60. Comm ACM 3, 299-314
(t 960).
2. Report on Subset ALGOL60 (IFIP) : Comm. ACM 7, 626-628 (t964).
3- Wirth, N., Hoare, C. A. R. : A contribution to the development of ALGOL. Comm.
ACM 9, 4t3-432 (t966).
4. Knuth, D. E. : The art of computer programming, Vol. t. Addison-Wesley 1968.
5. Control Data 6000 Computer Systems, SCOPE Reference Manual, Pub. No.
60t 89400.
Prof. Dr. N. Wirth
Eidgen6ssische Technische Hochschule
Fachgruppe Computer-Wissenschaften
ClausiusstraBe 55
CH-8006 Ziirich
Schweiz