Semiotics and Programming Languages
H. Zemanek University of Technology, Vienna, and IBM Laboratory, Vienna
1. A Very Pragmatic Introduction
I t is a very great pleasure for me to have been invited to this conference and to speak in this opening session. When I accepted the invitation, I was sure that some historical background probably prompted the choice of the organizers, as this conference and its title have some specific relations to the town of Vienna and to the country of Austria, where I come from. Let me explain. 1.1 THE TERM "PRAGMATICS". Pragmatics is a word which any Austrian would associate with the history of the 18th century. In 1713 the emperor Charles VI settled the law of succession for the dominions of the house of Habsburg so that his only daughter, Maria Theresa, could follow him on the throne. She governed from 1740 to 1780, the most glorious period of the Austrian history. Those who were in Vienna at the conference last September have seen the many baroque buildings and interiors so characteristic of Vienna; most of them were built in the time of Maria Theresa. The document issued by Charles VI has the name, "Pragmatic Sanction." This term comes from the Roman Right, and stands for a decision of the state dealing with a matter of some importance and given for some community and for a public cause. The word "pragmatic" itself comes from the Greek and means act or affair or business. In the form "pragmatism," this word became a philosophical term when the American logician Charles S. Peirce (1839-1914) [1] introduced this philosophical direction around 1870 as "a method of logic determining the meaning of intellectual concepts, i.e., of those upon which reasoning may hinge." As a philosophical method, pragmatism is something different from pragmatics, but there is enough interconnection and from a pragmatist point of view, one might say with Peirce that pragmatics is "the consideration of practical bearings of a notion," the syntactics and semantics of which are settled. The idea is, of course, considerably older and had already appeared in the ancient Greek philosophy [2], when Theophrastus, the chief disciple of Aristotle, spoke of "the twofold relation of speech: one to the hearers, to whom it signifies something, the other to the things about which it informs the hearers." For Theophrastus, poetics and rhetoric were "pragmatic" aspects. The distinction between syntactics, semantics and pragmatics was first made by the American philosopher Charles Morris (b. 1901) when he developed a science of signs which he called semiotics and which he subdivided into
Presented at an ACM Programming Languages and Pragmatics Conference, San Dimas, California, August 1965.
V o l u m e 9 / N u m b e r 3 / March, 1966
these three fields. The terms-syntactics, semantics and pragmatics--need very careful definition. Morris, and before him Neurath, had given warnings that "they may engender pseudoproblems and produce ambiguities." The warnings soon turned out to be very justified and this is even more true for the field of programming languages. In Foundations of the Theory of Signs [3], Morris defined the three terms as follows: pragmatics--the study of the relation of signs to interpreters; semantics--the study of the relations of signs to the objects to which the signs are applicable; syntactics--the study of the formM relations of signs
to one another.
In his later book, Signs, Language, and Behavior [4], Morris refined his definitions: pragmatics--deals with the origin, uses and effects of signs within the behavior in which they occur; semantics--deals with the signification of signs in all modes of signifying; syntactics--deals with combination of signs without regard for their specific significations or their relation to the behavior in which they occur. 1.2 Ti~E WIENER KREIS. Both Peirce and Morris were essentially oriented towards behavior; they considered the acting human being, and their results cannot, therefore, directly be applied to computers and their languages. The necessary bridge between empiric behaviorism and logic was developed in Vienna in a relatively short period immediately before the barbaric time when an unfortunate political development disturbed and disrupted order, moral and science in Europe and deleted Austria from its map. Almost all the people who worked on this subject during that period left Austria or had to leave it; and when you now come to Vienna, you will hardly find a trace of the glorious time of Austrian philosophy. In 1895, a chair for the philosophy of inductive sciences was instMled at the University of Vienna. The first professor was Ernst Mach (1838-1916), a forerunner of Einstein as a physicist and one of the most important positivists as a philosopher; his name is now attached to the unit of aircraft speed. After Mach, the chair went to Ludwig Boltzmann (1844-1906), who worked in the theory of heat and promoted the notion of entropy; in his readings on gas theory [5] you can find a chapter on the Htheorem, which you will easily recognize as the kernel of C. E. Shannon's famous paper introducing information theory [6]. In 1922, Moritz Schlick was appointed professor to this
Communications o f t h e ACM
139
chair, and during his time--until he was nmrdered by a psychopath in 1936--a short but fruitful activity laid down the ground for a philosophical school which subsequently became one of the most important guide lines for the philosophy of our programming languages. Around Schlick. during this period, a number of his pupils and other people interested in logic and language formed a circle later called the Wiener Kreis [7] promoting a philosophy and philosophical methods which best are designated by the term logical empirism. Some names of this group are Fr. Waismann, Otto Neurath, Hans Feigl, Bela yon Juhos, Rudolf Carnap, Victor Kraft, Karl Menger, K u r t GSdel, and Oskar Morgenstern [9, 10, 11, 12]. For our subject, not all the aspects of the logical empirism are of interest. The essential fact is that language was investigated from a logical point of view so that the abstract world of computing nmchinery was pre-established. The behavioristic view of Peirce and Morris was specified into a formal or, at least into an abstract direction. The spiritus rector of this development was Ludwig Wittgenstein (1889-1951), a pupil of Russell. As a matter of fact, Wittgenstein never belonged to the Wiener Kreis, but his Traclus Logico-Philosophicus [8], finished during his military service in the Austrian army during World War I, influenced the thinking of the group enormously. Wittgenstein did not invent the truth tables, but he contributed essentially to their efficient application; he considered all philosophy to be critique and logical investigation of langnage. And no better motto could have been chosen for the ALGOL documents than the quotation of his principle, to speak clearly or not to speak at all. Wittgenstein is another reference to m y country. He was born in Vienna, he worked in Vienna, and he was a teacher in elementary schools near Vienna. He left, by the way, a fascinating monument for himself, an apartment house he designed himself, where members of the family still live. Of course, the Wiener Kreis was not the only point in the world where the relation between language and logic was studied. There was an exchange of ideas all over the world--which made it easier for its members when they had to go abroad in the late thirties. And the most important exchanges of these ideas were the conferences on the unification of science, to which the Wiener Kreis contributed in an outstanding manner. And with this remark I terminate my historic comments. Let me now turn to the advent of the computer and try to show in what sense the computer justified and actualized the logical investigation of language. Already in precomputer time when mathematicians like Turing, Markov, and G5del defined computability and decidability (or the contrary), they based their arguments on structures which found their implementation later in the computer. And in a more general way one can say that the programming languages implement in a corresponding step the thoughts of the Wiener Kreis: what in their writings may have appeared to many philosophers as a kind of arbitrary for140 Communications o f t h e ACM
malization, looks now quite appropriate and has become the ground for the higher art of programming, which will coronate all kinds of scientific doctrine: because it is only the computer which can describe and realize scientific structures in all generality and without any intuitive jumps. The computer can indeed be made to print clearly whatever it prints and not to print what cannot be printed, just as Wittgenstein desired for philosophy and science.
1.3 SEMIOTICS AND OTHER ASPECTS OF LANGUAGE. I have based my paper on semiotics and its three dimensions. I should insert at this point that language has many aspects and that pragmaties, semantics and syntactics do not necessarily cover all of them. One can, however, project most aspects into the three semiotic dimensions and there seems to be a strong tendency to do so today. Let me say a few words on these other aspects and their projection into semiotics. 1.3.1 Formalization. Many philosophers seem to consider formalism and syntactics to be the same, or at least formalism to be but ideal syntactics. Non it is certainly true that syntax can be treated very informally--and has been treated very informally for centuries. And it is very possible4o formalize semantics as well as pragmatics [17]. Indeed, from a programming languages point of view, we will have to insist tha.t all the three semiotic dimensions of our products can be and should be formalized--pragmatics at least over a certain range. 1.3.2 Object World, Object Language, and Metalanguage. Object world, object language and metalanguage are considered by many philosophers to be semantic levels; the objects of the real (or an invented) world are of level zero, their names are of level one, and the names of the names are of level two. Arbitrarily many levels can be conceived and some authors think that there is no e n d - - b u t that on some points we will ever have to step back to our ultimate metalanguage, i.e., to English. If the investigation is based on these levels as prima~/notions, the semiotic dimensions change character and definition: syntactics becomes relations within one level, whatever the level is; semantics becomes relations between two adjacent levels; and pragmatics presumably becomes the relations leading outside of the level scheme, whatever "outside" is. At this point may I refer a last time to Vienna and remind you of the I F I P Conference on "Formal Language Description Languages" held in Vienna in September, 1964. In the papers of that conference the description relationships of programming languages are reflected in very many ways [13]. 1.3.3 Descriptive and Prescriptive Aspects. Language theory is as well aware as is programming practice that languages have the two aspects of description and prescription: of cognitive v.s instrumental character; of declaration and command; of dealing with states or with actions. Some philosophers consider these two aspects as being of pragmatical character, but it is true that both aspects run through the whole gamut from syntactics to semantics to pragmatics and, especiMly from the programV o l u m e 9 / N u m b e r 3 / M a r c h , 1966
ruing languages point of view, there is no question t h a t these two aspects have to be treated independently of the semiotic triple. On the other hand, I do not believe t h a t the distinction is essential. For any command is the description of the wanted state, and any description can be understood as guidance for construction. The underlying real-time aspect is not i m p o r t a n t for language considerations as such. After this highly pragmatic introduction (containing a lot of relationship between languages and myself) it is time to turn to a more semantic section on the semiotics of programming languages. 2. W h a t is a L a n g u a g e ? As long as somebody speaks only one language, " w h a t is a language?" is not a real question for him. Language is what he speaks. As long as we consider only natural languages, the notion of a language can be designated b y naming some of them, say English, French, and Spanish. B u t as soon as artificial or constructed languages come into the game, it is not at all clear where to put limits. All kinds of doubtful intermediate products m a y occur. Is machine language really a language or is it merely a code? The fact that the carried information may be the same whether described or expressed in English, in FORTRAN, in a flowchart or in the 1401 machine language does not prove anything for our purpose. For translation may happen between languages, but it may happen also from and to languages, to and from other means of communication. Apparently some types of artificial languages are much closer to a natural language than other types. But on the other hand, the general theory of languages insists strongly on including all kinds of language, i.e., even gestures and looks. So we cannot possibly exclude more primitive systems, we can merely classify and subdivide the notion of programming languages. In analogy to the definition of natural language we may say that a programming language is a system of character strings which form words, expressions, sentences and higher aggregates. The purpose is the communication of programs between computers, from man to computers, and also from man to man. And furthermore the elaboration of programs is an important purpose because it is only in exceptional cases that the first writing is the correct and final version. The language is the carrier and the implementation of ideas; since it is very hard to handle ideas in an abstract form, the language is an important instrument for the expression, refinement and precision of ideas. So a programming language is also a means of comnmnication between a human being and himself. In the case of programming languages, the realization of the formulated ideas in the information processing machine is--in a certain sense--guaranteed. This is a fascinating property: writing texts in programming languages can not only be as creative as poetry, the creations, more than in poetIT, belong to the real world as soon as run through the machine. Volume 9 / Number 3 / March, 1966
Programming languages are always constructed languages (Gorn [14, 15] calls t h e m mechanical languages, to which one might object t h a t constructed languages are more than mechanisms insofar as they carry on the nonmeehanieM content the p r o g r a m m e r has put into the text). Programming languages have to be as formal as possible. The reasons for this are obvious. B u t let me remind you t h a t "artificial" and "formal" are not at all identical. There are cases where only one of these aspects applies: there are informal artificial languages, just as there is the formalization of natural languages. Periodically we hear arguments t h a t natural languages should be used in programming; the basic reasons for this m a y be the high generality of natural languages on the one extreme and the easy availability on the other ("the customer does not like to learn the artificial language"). Either reason is a misunderstanding of the purpose. Russell once gave four reasons for formalization which still apply to both theory and practice: (1) security of operation is assured, (2) tacit pre-assumptions are excluded, (3) notions are clarified, and (4) resolving structures can be applied to m a n y other problems. And he has given four other reasons for the application of artificial languages: (1) abstract notions are usually different from the common ones, (2) the syntax of natural languages is not exact, (3) ambiguous words are eliminated, and (4) expressions become shorter. I t m a y be true t h a t our ultimate metalanguage m u s t be E n g l i s h - - I have not seen any convincing proof for this s t a t e m e n t - - b u t even if this is right, it would be no reason for using English as programming language or as first metalanguage. We do not want the full generality of a natural language because we want the written programs to remain in the area our science has already worked through. And we do not w a n t the easy application t h a t a natural language offers because the user w o u l d then not reflect enough on what he instructs the machine to do. 3. O n t h e S e m i o t i c s o f P r o g r a m m i n g L a n g u a g e s Let me start with the remark t h a t the three dimensions of semiotics are ways of consideration or kinds of position rather t h a n absolute properties of a language. The border lines between the three fields are vague and can be m o v e d forward and back by modifying details of investigation principles. There is always pragmatics because there is always an observer and because no language makes sense without interpretation. The first reduction is to remove the pragmatical aspects in order to talk about semantics and syntactics. There is always semantics--unless we play a meaningless game with characters: in this ease alone we would have strictly syntax. We can consider and even formalize semantics independently of notation so t h a t semantics is isolated as such; but then we have to apply a metalanguage which in itself would carry semantics and syntaetics. So we will scarcely have clear and easy situations in the t h e o w of programming languages. Communications of the ACM 141
To distinguish syntactics and semantics we have to separate form and meaning. But this is a particular problem in information processing because of its mathematical nature. Nowhere else have form and meaning been interfaced so intensively. As a matter of fact, formalization is nothing more than packing as much meaning as possible into defined forms. To a certain degree this is done already in natural languages. The plural, for instance, is a syntactical form connected to a clearly established meaning. In our constructed languages we do the same in a much more elaborated fashion. The syntactic elements of constructed languages carry an important portion of meaning. Pragmatically, this is very important because the human being when reading has a kind of meaning-assignment mechanism running which produces many errors if the artificially assigned meaning is different from the usual, the natural one. In numerical analysis, still the first field of application, the meaning of an expression can be considered in two different ways. One possibility is the one we learn in the usual mathematical education. A second version of this meaning, however, is built into the machine during the design of hardware or software, and it is not at all unwise to define the meaning by the implemented form of a mathematical notion. These two kinds of definition of meaning certainly overlap nicely but there is no doubt that there are discrepancies (as well as there are, by the way, between mathematicians of different schools). There is a positive feedback from machinery to philosophy and some of the discrepancies will be overcome simply by the fact that the theory some day will accept the machine-covered notion. If it is philosophically correct that meaning is primarily a matter of verification, then such a development is perfectly sound. There is no better verifier than a computer. But this development intensifies also the tendency to reduce semantics to syntactics and it becomes harder to find or describe the border line between the two. The distinction between semantics and pragmatics is, of course, also touched by this evolution. Since programm i n t languages are a communication link between man and machine, we have two kinds of users: an artificial one and a natural one; a mechanized one and an illogical one. The first is fully algorithmic and carries out what the text means to him, while the second has notions, opinions and feelings. Clearly both kinds can appear in the same m a n - he may react either way depending on his momentary intention. So we have two kinds of pragmaties, the human pragmatics and the mechanical pragmatics, applying a term of S. Gorn [15, 16]. To illustrate the two kinds: to the first kind would belong an investigation to find out why a eertain audience may break out into laughter when the name of a certain programming language is pronounced, and to the second, to find out how much of a certain programming language reflects a certain family of computers. But one could go even further and understand wagmatics as the relation between characters and interpreter
142 Communications of the ACM
in such a way that the interpreter is the compiler in general. E v e r y aspect of the language in relation to the compiler is then of pragmatic nature. S. Gorn, in his paper to the conference in Jerusalem a year ago [16] has extensively treated mechanical pragmatics in what he calls ambiguously stratified language systems and I can only regret that this paper has not yet appeared in print so that it could have served as one of the background papers for this conference.
4. P r a g m a t i e s o f P r o g r a m m i n g Languages
I t is the purpose of this conference to treat the wagmatics of programming languages. I do not have to go into details in this introductory paper. I shall restrict myself to the mention of a few subjects which may outline the general picture of this field. If the general relationship between language and compiler is included, the full problem of how to translate programming languages into machine languages belongs to the subject. And certainly the consideration of efficiency of the involved processes is a part of pragmatics. If we restrict the notion of pragmatics to kinds of individual relationships, then we first have the question: what do different translating principles and what do different compilers do to the language? How do they influence the machine (language) programs and the results? W h a t is the relation between language and operating systems? How much should language and operating system be matched and how far should they influence each other? Then we have the problems of the dependence of programming languages on the machine, as well as the feedback from programming languages to hardware. In the ideal ease the complete system, programming language-machine language--computer hardware, should be conceived at once, which indicates how much pragmatic development we still have before us. Finally, there are the relations between programming languages and their application fields which definitely belong to pragmatics. Here we are very far from any formM treatment. The relation between programming languages and the human being is the last but certainly not the least domain of pragmaties. Reading, learning and teaching of programming languages are psychological problems on which the success of a programming language may depend much more than on M1 its teehnieM properties. A language is a social tool; this is a pragmatic t r u t h which we must also take into account when we wish a programming language to become really a language. For, the best logical system is essentially not a language as long as it is on the desk of its inventor. A real language is characterized by the practical use within a certain group of people. There are programming language minorities with problems similar to the case of natural languages. And there are the big programming nations--and all that makes an important pragmatic problem. Man-machine communication is the next big development which computing can expect. Here we have a wagVolume 9 / Number 3 / March, 1966
matic problem which will strongly influence coming programming languages. Not only will conversational features be essential, there m a y even be a trend back from all
too sophisticated language systems to the simple pointing with a light-pen. Pointing has always been one of the safest ways to convey information. We come back to Wittgenstein and his principle of speaking clearly or not speaking at all. Since we know that it is the computer which we can make speak arbitrarily clearly, we possibly should try to let the computer speak more and more and to restrict the human user in the practical situation to point at YES or NO, or some more equally simple choices, while the computer talks. This may sound like science fiction today, but it could really be true that one day this will become the central application of pragmatics around the computer. REFERENCES PEIRCE, C. S. Collected Papers Harvard Press, Cambridge, Mass. Vol. 1-6, 1931-1935. Philosophical Writings. (J. Buchler, Ed.). Routledge and Kegan Paul, London, 1940; or Dover Publications, New York, 1955; 368 pp. BOCttENSKI, I. M. A History of Formal Logic. U. of Notre Dame Press, Notre Dame, Indiana, 1961; pp. 99-100. MORRIS, C. Foundations of the theory of signs. In International Encyclopedia of Unified Science, Vol. 1, No. 2, University of Chicago Press, Chicago, 1938. --. Signs, Language, and Behavior. G. Braziller, New York, 1955.
1.
2. 3.
4.
5. BOLTZMANN, L. Vorlesungen ueber Gastheorie, 1. Theil, Paragraph 6. Mathematische Bedeutung der Groesse H, J. A. Barth, Leipzig, 1895, pp. 38-42. 6 SHANNON,C.E. A mathematical theory of communication. Bell System Tech. J. 27 (1948), 379-433; 623-656. 7. KRAFT, V. Der Wiener Kreis. Springer Verlag, Vienna, 1950. 8 WITTGENSTEIN, L. Tractatus Logico-Philosophicus. First Print in German, 1921; in English: Routledge and Kegan Paul, London, 1922. 9. SCHLICK,M. Gesammelte Aufsaetze. Gerold and Co., Vienna, 1938. 10. FEIGI~,H. Logical empirism. InTwentieth Century Philosophy (D. D. Runes, Ed.), Philosophical Library, New York, 1943, pp. 373-416. 11. CARNAP,R. The Logical Syntax of Language. First print in German, 1934; in English: Harcourt Brace and Co., New York, 1937. 12. - - . Introduction to Semantics Harvard University Press, Cambridge, Mass., 1942. 13. Formal Language Description Languages (T. B. Steel, Jr., Ed.). Proc. of the IFIP Working Conf., Vienna, 1964; North Holland, Amsterdam 1966. 14. GORN,S. Somebasic terminology connected with mechanical languages and their processors Comm. ACM 4 (1961), 336339. 15. - - . Mechanical pragmatics: a time motion study of a miniature mechanical linguistic system. Comm. ACM 5 (1962), 576-589. 16.--. Semiotic relationships in ambiguously stratified language systems. Presented at the Internat. Colloq. for Algebraic Linguistics and Automata Theory, Jerusalem, 1964. 17. MARTIN,R.M. Towards a Systematic Pragmatics--Studies in Logics. North Holland, Amsterdam, 1959.
Programming Semantics for Multiprogrammed Computations
Jack B. Dennis and Earl C. Van Horn
Massachusetts Institute of Technology, Cambridge, Massachusetts
The semantics are defined for a number of meta-instructions which perform operations essential to the writing of programs in multiprogrammed computer systems. These meta-instructions relate to parallel processing, protection of separate computations, program debugging, and the sharing among users of memory segments and other computing objects, the names of which are hierarchically structured. The language sophistication contemplated is midway between an assembly language and an advanced algebraic language. Presented at an ACM Programming Languages and Pragmatics Conference, San Dimas, California, August 1965. Work reported herein was supported by Project MAC, an MIT research program sponsored by the Advanced Research Projects Agency, Department of Defense, under Office of Naval Research Contract Number Nonr-4102(01). Reproduction in whole or in part is permitted for any purpose of the United States Government
V o l u m e 9 / Number 3 / March, 1966 Introduction
An increasing percentage of computation activity will be carried out by multiprogrammed computer systems. Such systems are characterized by the application of computation resources (processing capacity, main memory, file storage, peripheral equipment) to m a n y separate but concurrently operating computations. We can cite three quite different examples of multiprogrammed computer systems to illustrate their diversity of application. The American Airlines S A B R E passenger record system couples ticketing agents at dispersed offices to a central data file [1]. The computer support systems of NASA provide real time control and monitoring of manned space flights [2]. The Project MAC time-sharing system permits research workers closer interaction with the powers of automatic computation [3]. Although these are all online systems, multiprogramming techniques have also been
Communications of the ACM 143