Научная статья на тему 'Automata programming as a sort of synchronous programming'

Automata programming as a sort of synchronous programming Текст научной статьи по специальности «Компьютерные и информационные науки»

CC BY
251
72
i Надоели баннеры? Вы всегда можете отключить рекламу.

Аннотация научной статьи по компьютерным и информационным наукам, автор научной работы — Shalyto A.A., Naumov L.A.

This paper describes main properties of “automata programming”. It contains such phases of software developing as designing, implementing, debugging and documenting.

i Надоели баннеры? Вы всегда можете отключить рекламу.
iНе можете найти то, что вам нужно? Попробуйте сервис подбора литературы.
i Надоели баннеры? Вы всегда можете отключить рекламу.

Текст научной работы на тему «Automata programming as a sort of synchronous programming»

AUTOMATA PROGRAMMING AS A SORT OF SYNCHRONOUS PROGRAMMING

SHALYTO A.A., NA UMO VL.A.

Saint-Petersburg State Institute of Fine Mechanics and Optics (Technical University)

shalyto@mail.ifmo.ru, { levnaumov@mail.ru

Abstract. This paper describes main properties of “automata programming”. It contains such phases of software developing as designing, implementing, debugging and documenting.

Introduction

Last years great attention is attracted to the developing of the technology of programming for the embedded systems and real-time systems. These systems have special requirements for the quality of software. One of the most well known approaches for this field of tasks is synchronous programming [1].

Simultaneously with the progress of synchronous programming in Europe, in Russia an approach, called “automata programming” is being created [2-4]. This method could be considered as a type of synchronous programming.

At last time the in programming term “event” is used wider and wider. It becomes one of the main terms in software developing. Offered approach is based on the term “state”. After introduction of the term “input action”, which could be an input variable or an event, the term “automaton without outputs” could be brought in. After addition of the term “output action”, the term “automaton” could be brought in. It is the finite, determined automaton.

That is why, the sort of programming, which is based on this term was called “automata programming” in paper [4]. So the process of software creation could be named “automata software design”.

The feature of this approach is that automata, used for developing, are defined with the help oftransition graphs. For distinguishing of the nodes of these graphs the term “state coding” is to be introduced. When using “multiple state coding” with the help of single variable it is possible to distinguish amount of states which is equal to the amount of variables values. This allows to introduce in programming the term “program observability”.

Using the offered approach, programming is to be performed using the concept of “state”, not the concept of “flag variables”. It allows to understand and specify the task and its parts (subtasks) better.

It is necessary to note that it “automata programming” debug is performed with the help of drawing up the protocols (logging) in the terms of automata.

In this approach there is a formal and isomorphic method of transfer from the transition graph to the software source code. So when using programming languages of the high level, the most suitable way is to use construction which is 140

similar to construction “switch” of the programming language C. That is why the technology of “automata programming” in paper [4] was called as “Switch-technology”.

Nowadays this technology is developing in several variants, for different types of task to be solved and for various type of computing devices.

Logical control

In 1996 Russian Fund for Fundamental Investigations (RFFI) in the context of publishing project N° 96-01-14066 supports the publishing ofbook[4]. Offered technology was described in this book, being applied to the systems of logical control, in which there are no events, input and output actions are binary variables and operating system is working in the scanning mode.

Systems of this class as usual are to be implemented on programmable logical controllers, which have relatively few memory and programming is to be performed using specialized languages (for example, the language of functional blocks) [5]. In work [4] formal methods of program developing for such kind of devices were offered. These methods are based on the giving specification for the developing project with the help of set of connected transition graphs. There were shown opportunities which are given by the language of transition graphs comparing with “Graphset” language.

Systems, based on events

Henceforth automata approach was spread to the event-based (reactive) systems [6]. In systems of this kind all limitations, mentioned above are taken away. It is obvious from the name of these systems that events are used among the input actions. Role of output actions could be played by arbitrary functions. Any real-time operating system could be used as an environment.

For programming for event-based systems with the help of automata a procedural approach to software developing was used. So this king of programming was called as “programming with explicit states allotment” [7].

Using this method output actions are assigned to the arcs, loops or nodes of the transition graphs (mixed automata are to be used - Moore-Mealy automata). This allows to present sequences of actions, which are reactions to the corresponding input actions, in the compact form.

On of the features of programming for the reactive systems is that liquidation of logic in the event handlers and forming ofsystem ofinteracting automata, which are called from these handlers, causes logic centralization [8]. Automata in such system can interact by nesting, by calling ability and with the help of state numbers interchange.

Last type of interaction is described in work [9], which declares that “this type ofinteraction may be used as powerful tool for program verification”.

System of interconnected automata forms system independent part of software. At the same time system dependent part is formed by functions of input and output actions, event handlers and so on.

Another important feature of this approach is that automata in it are used triune: for specification, for implementation (they stay in the source code) and for drawing up the

R&I, 2003, Ns 3

protocol, which is performed, as said above, in terms of automata.

Last property allows to verify the propriety of automata system functioning. Logging is performed automatically on the based on the created program. This mechanism could be also used for large scale tasks and for task with difficult, smeared software logic.

Any drawn up protocol could be considered as the action script. Note that for the large tasks it is impossible to use sequence diagrams, cooperation diagrams, which are parts of UML language [10]. That is because usage ofUML language listed diagrams are suggested to be drawn up manually on the projection phase of developing. In automata programming protocols will be build automatically at the run-time.

Protocols allow to keep an eye on program execution and demonstrate that the fact is that automata are not just the “pictures”, but they are actually functioning entities.

Automata approach is offered to be used not only for controlling system developing, but also for objects of control modeling.

This method was approved on the task of developing of controlling system for ship diesel generator [11]. Mentioned system was specified with help of more thanthirteen interacting automata. For describing of model of diesel generator automata were also used. While designing each automaton was provided with four following documents:

- verbal description (“expectancies declaration ”);

- bonds scheme, which explains on the human language all symbols which are involved in automatons interface;

- transition graph with symbolic indication of events, input and output actions;

- source code of program module, which realizes transition graph (also without usage of meaningful identifiers and comments).

These documents replace self documenting programs, which contains meaningful identifiers and comments. These standard facilities cannot ensure the understandability and clearness of the source code for further developing, modifying and enlarging [ 12]. This problem for difficult logic cannot be solved also with the help of self documenting transition graphs [10].

Realized project had proved expediency of protocols usage for verifying propriety of interaction of such great amount of automata and each automaton separately.

This project had been implemented for computing systemwith architecture ix86. Henceforward described approach was evolved by N.I. Tukkel for developing systems for microcontrollers. Advantage of automata technology is that all design may be done on personal computer using Switch-technology and only on last phase of developing software could be ported to microcontroller.

Ob j ect-o riented pro gramming with explicit states allotment

For solving task from a very large spectrum may be rather useful the composite approach, which is based on object-oriented and automata programming paradigms. In work [13] this method was called as “Object-oriented programming with explicit states allotment”.

R&I, 2003, N 3

Feature of this approach is that, like in Turing machines [14], here controlling (automata) states are explicitly singled out.

The amount of these states is noticeably fewer than amount of all other objects states (for example, run-time states).

The term “states space” was introduced in programming. This term means the set of object controlling states.

So this approach provides more understandable behavior in comparison with case when such space is absent.

The minimal set of documents, which are necessary for the npegno^eH MHHHManbHbin Hadop goKyMenroB, no3Bonam-mnn visually and clearly, but strictly describe structural (static) and behavioral (dynamic) sides of the software.

As when using any other approach, this approach needs the set of heuristics, back-steps, accurate definitions and concurrent tasks. But after program had been developed offered approach may be named an ideal technology for storing of decisions which had been made.

After analysis of the knowledge domain the classes could be defined and class diagram may be drawn up.

For each class the verbal description needs to be created at least in the form of list of tasks to be solved.

For each class the structure scheme is to be developed. This scheme describes its interface and structure. Important note is that classes attributes and member functions are to be separated to automaton and others.

If there are several automata in the same class then there is a need in drawing up their interaction scheme.

For each automaton verbal definition is to be developed with the bond scheme and transition graph.

Each class implemented with the separate program module. Its structure is isomorphic to classes structure. Member functions, which have corresponding automata, are realizable according to the template, described in paper [8].

For system debugging and for confirmation of propriety of its work protocols are automatically building during run-time. These protocols describe the functioning of objects, which contains automata, in terms of states, transitions, events, input and output actions.

Project documentation is to be made. Its important part is the program documentation.

From stated above it can concluded that application of automata makes programs behavior clearer as objects using makes programs structure clearer.

Described approach was used for developing tank controlling system for “Robocode” system [15].

In contrast to controlling systems of hundreds of other tanks, there is a detailed project documentation for this tank. Documentation contains transition graphs, bond schemes and others.

Detailed protocols of tanks behavior allow to observe the history of battle. Method of protocols drawing up may form a base of new paradigm of blackbox functioning.

In the described technology automata were implemented inside classes member functions. But there could be another approaches to the object realization of automata, which were described, for example in papers [16-18]. Automata may

141

stand out, in particular, and classes, which are descendants of the class that realizes automata basic functionality. This functionality is declared by the semantics of Switch-technology.

It is also possible to use classes, which realizes concepts of “state” or “group of states”.

For automata programs design pattern “state” [19] or other patterns may be also used.

Peculiarities of automata implementation ofparallel processes, based on messages interchange, are considered in paper [20].

Existence of high quality proj ect documentation makes further program refactoring (changing of programs structure, keeping its functionality the same) much easier. Last thesis was confirmed by refactoring of tank controlling system, which was mentioned above. Refactoring was complete for rising programs “objectness”.

Computational algorithms

Automata approach is used now for computational algorithms implementation [21-23].

It was shown that arbitrary iterative algorithm can be implemented with the help of construction, that is equivalent to loop operator “do ... while”, inside which there is single “switch” operator.

New approach to algorithms visualization programs creation which is based on automata programming was offered. Such visualization programs are widely used on Computer Science Department of Saint-Petersburg State institute of Fine Mechanics and Optics (Technical University) for students teaching of programming and discrete mathematics [24].

Approach allows to represent visualization programs logic as a system of interacting finite automata. Systems consists of pairs of automata, each ofthem contains “forward” and “back forward” automata, which provides step-by-step algorithms execution forwards and back forwards respectively.

One of the aims of this paper if to show that automata can be used not only for language recognition [25] and washing machines control. That they are not only one of mathematical models of discrete mathematics, but can be used for implementation of any programs, which have complicated behavior.

Stream for Open Project Documentation

At the opening of semifinal competitions of world team championship on programming ACM (Association for Computing Machinery) in north-western region 27 of November2002the “Stream for Open Project Documentation” was declared. In the context of this stream on site http:// is. ifmo. ru section “Proj ects” was created. In this section soon will be placed over 40 projects, which are examples of software developing, using automata approach. Lets list some of them:

- automata realization of scripts for educational animation using Macromedia Flash;

- XML-format for video players appearance description (www.crystalplayer.com);

- combined usage of compilers developing theory and Switch-technology;

- tank controlling system for the Robocode game (sponsored by IBM) [15]. Tank “Cynical”, that had been developed, was decided to be one of the best in the world. There also will be placed its refactored version, which, as stated above, was developed for rising programs “objectness”;

- controlling systems for lift (like Knuth’s, but better), cars, percolators, turnstile, semaphores and many others;

- possible, automata-based solutions of classical tasks:

task of synchronization of the chain of the shooters; task of “philosophers dinner”; task of Hanoi-towers [21]; task of knights move [22];

- many well-known classical algorithms (for example, QuickSort, search of substrings and many others);

- illustrations of different approaches to object-oriented programming with explicit states allotment:

automata as classes;

automata as member functions;

formal method of conversion of obj ect-oriented automata programs to programs, written using classical Switch-technology. It allows to develop models of system using personal computer and then formally port it to microcontrollers platform;

“state” pattern;

classes, which realize concepts of “state” and “group of states”;

it was showed that automata have properties of objects, used in object-oriented paradigm;

- automata based graphical users interface toolkit;

- windows manager, with supports all necessary functionality (dragging, groping, resizing, overlapping, minimizing/ maximizing, closing and so on);

- realization of protocol SMTP (Simple Mail Transport Protocol);

- a lot of computer games:

lines;

Automatic Bomber; sea wars;

Zavalinka (bank) and others;

In summary lets note that usage of automata makes formalization of specification of program simpler. It defines programs behavior and plays “key role in matter of inhibition of errors” [26].

The work was carried out with the support of Russian Fund for Fundamental Investigations (RFFI) according to grant N°02-07-90114 “Developing of technology of automata programming”.

iНе можете найти то, что вам нужно? Попробуйте сервис подбора литературы.

142

R&I, 2003, Ns 3

References: 1. Benveniste A., Caspi P., Edwards S. et al. The Synchronous Languages 12 Years Later // Proceedings ofthe IEEE. Vol. 91. 2003. M1. 2. Shalyto A.A. Logic control and “reactive” systems: algorithmization and programming // Automation and Remote Control (Avtomatika i Telemekhanika). 2001. M1. 3. Shalyto A.A. Logical control. Methods of hardware and software algorithms implementation. SPb.:Nauka (Science), 2000. 4.Shalyto A.A. Switch-technology. Algorithmization and programming of tasks oflogical control. SPb.: Nauka (Science), 1998. 5. Shalyto A.A. Realization of algorithms oflogical control with the help of programs written using language of functional blocks // Industrial automatic control system and controllers. 2000. M4. 6. HarelD., PolitiM. Modeling Reactive Systems with Statecharts. NY: McGraw-Hill, 1998. 7. Shalyto A., Tukkel N. Programming with explicit states allotment // World of PC. M8,9. 2001.8. ShalytoA.A., TukkelN.I. SWITCH-technology -automata approach to software developing for “reactive” systems // Programming and Computer Software (Programmirovanie). 2001. M 5. 9. Dijkstra E. Interaction of consequent processes // Programming languages. M.: Mir (World), 1972. 10. Booch G., Rambo D., Jacobson A. UML Language. Users manual. M.: DMK, 2000. 11. Shalyto A.A., Tukkel N.I. Software design for diesel generator controlling system based on automata approach // System for control and information processing. SPb.: NPO “Avrora”. Vol. 5. 2003. 12. Bezrukov N. Repeated look at “council” and “bazaar” //BYTE/Russia. M8. 2000. 13. ShalytoA.A., Tukkel N.I. Object-oriented programming with explicit states allotment // Proceedings of international scientific and technical conferrence “Artificial intelligence - 2002”. Vol. 1. Taganrog -Donetck: TGRU - DIPII, 2002. 14. Shalyto A., Tukkel N. From Turing programming to automata // World of PC. M2. 2002. 15.

Shalyto A.A., Tukkel N.I. Tanks and automata // BYTE/Russia. M2. 2003. 16. Gurov V.S., NarvskyA.S., Shalyto A.A. Automatization of projecting of event-based obj ect-oriented programs with explicit states allotment // Proceedings of X scientific and technical conferrence “Telematica-2003”. Vol. 1. SPb.: SPbIFMO (TU). 2003. http://tm.ifmo.ru. 17. ShopyrinD.G., ShalytoA.A. Usage of class “STATE” in obj ect-oriented programming with explicit states allotment // Proceedings of X scientific and technical conferrence “Telematica-2003”. Vol.1. SPb.: SPbIFMO (TU), 2003. http:// tm.ifmo.ru. 18. Korneev G.A., Shalyto A.A. Realization of finite automata with the help of object-oriented programming // Proceedings ofX scientific and technical conferrence “Telematica-2003”. Vol. 1. SPb.: SPbIFMO (TU). 2003. http://tm.ifmo.ru. 19. Gamma E, Helm R., Johnson R., Vlissides J. Methods of object-oriented programming. Design patterns. SPb.: Piter, 2001.20. Guisov M.I., Kuznetsov A.B., ShalytoA.A. Integration ofmechanism ofmessages interchange into Switch-technology. http://is.ifmo.ru. 21. Shalyto A., Tukkel N., Shamgunov N. Hanoi-towers and automata // Programmer. M8. 2002. 22. Shalyto A., Tukkel N., Shamgunov N. Knights move task // World of PC. M1. 2003. 23. Shalyto A.A., Tukkel N.I. Transformation of iterative algorithms to automata // Programming and Computer Software (Programmirovanie). M5.

2002. 24. Korneev G.A., Kazakov M.A., Shalyto A.A. Construction of functional logic of algorithms visualization programs based on automata approach // Proceedings of X scientific and technical conferrence “Telematica-2003”. Vol.2. SPb.: SPbIFMO (TU),

2003. http://tm.ifmo.ru. 25. Hopcraft D., Motvani R., Ulman D. Introduction to theories of automata, languages and calculations. M.: Williams, 2002. 26.AllenE. Typical design errors. SPb.: Piter, 2003.

R&I, 2003, N 3

143

i Надоели баннеры? Вы всегда можете отключить рекламу.