Skoči na glavni sadržaj

Izvorni znanstveni članak

https://doi.org/10.31341/jios.40.2.3

Categorical Model of Structural Operational Semantics for Imperative Language

William Steingartner orcid id orcid.org/0000-0002-2852-9403 ; Faculty of Electrical Engineering and Informatics, Technical university of Košice, Letná 9, 042 00 Košice, Slovak Republic
Valerie Novitzká ; Faculty of Electrical Engineering and Informatics, Technical university of Košice, Letná 9, 042 00 Košice, Slovak Republic


Puni tekst: engleski pdf 639 Kb

str. 203-219

preuzimanja: 514

citiraj


Sažetak

Definition of programming languages consists of the formal definition of syntax and semantics. One of the most popular semantic methods used in various stages of software engineering is structural operational semantics. It describes program behavior in the form of state changes after execution of elementary steps of program. This feature makes structural operational semantics useful for implementation of programming languages and also for verification purposes. In our paper we present a new approach to structural operational semantics. We model behavior of programs in category of states, where objects are states, an abstraction of computer memory and morphisms model state changes, execution of a program in elementary steps. The advantage of using categorical model is its exact mathematical structure with many useful proved properties and its graphical illustration of program behavior as a path, i.e. a composition of morphisms. Our approach is able to accentuate dynamics of structural operational semantics. For simplicity, we assume that data are intuitively typed. Visualization and facility of our model is not only a new model of structural operational semantics of imperative programming languages but it can also serve for education purposes.

Ključne riječi

category theory; morphism; semantic function; state; structural operational semantics

Hrčak ID:

170413

URI

https://hrcak.srce.hr/170413

Datum izdavanja:

9.12.2016.

Posjeta: 1.325 *