Periodic Single-Pass Instruction Sequences

Jan A. Bergstra,Alban Ponse
DOI: https://doi.org/10.48550/arXiv.0810.1151
2013-04-16
Abstract:A program is a finite piece of data that produces a (possibly infinite) sequence of primitive instructions. From scratch we develop a linear notation for sequential, imperative programs, using a familiar class of primitive instructions and so-called repeat instructions, a particular type of control instructions. The resulting mathematical structure is a semigroup. We relate this set of programs to program algebra (PGA) and show that a particular subsemigroup is a carrier for PGA by providing axioms for single-pass congruence, structural congruence, and thread extraction. This subsemigroup characterizes periodic single-pass instruction sequences and provides a direct basis for PGA's toolset.
Programming Languages
What problem does this paper attempt to address?