Abstract State Machines

Abstract State Machines

In computer science, an abstract state machine (ASM) is a state machine operating on states which are arbitrary data structures (structure in the sense of mathematical logic, that is a nonempty set together with a number of functions (operations over the set) and relations).

The ASM Method is a practical and scientifically well-founded systems engineering method which bridges the gap between the two ends of system development:

  • the human understanding and formulation of real-world problems (requirements capture by accurate high-level modeling at the level of abstraction determined by the given application domain)
  • the deployment of their algorithmic solutions by code-executing machines on changing platforms (definition of design decisions, system and implementation details).

The method builds upon three basic concepts:

  • ASM: a precise form of pseudo-code, generalizing Finite State Machines to operate over arbitrary data structures
  • ground model: a rigorous form of blueprints, serving as authoritative reference model for the design
  • refinement: a most general scheme for stepwise instantiations of model abstractions to concrete system elements, providing controllable links between the more and more detailed descriptions at the successive stages of system development.

In the original conception of ASMs, a single agent executes a program in a sequence of steps, possibly interacting with its environment. This notion was extended to capture distributed computations, in which multiple agents execute their programs concurrently.

Since ASMs model algorithms at arbitrary levels of abstraction, they can provide high-level, low-level and mid-level views of a hardware or software design. ASM specifications often consist of a series of ASM models, starting with an abstract ground model and proceeding to greater levels of detail in successive refinements or coarsenings.

Due to the algorithmic and mathematical nature of these three concepts, ASM models and their properties of interest can be analyzed using any rigorous form of verification (by reasoning) or validation (by experimentation, testing model executions).

Read more about Abstract State Machines:  History, Tools

Famous quotes containing the words abstract, state and/or machines:

    Somebody once said that I am incapable of drawing a man, but that I draw abstract things like despair, disillusion, despondency, sorrow, lapse of memory, exile, and that these things are sometimes in a shape that might be called Man or Woman.
    James Thurber (1894–1961)

    Me, rule? Me, place the State under my law, when my feeble reason no longer rules even myself!
    Jean Racine (1639–1699)

    If men do not keep on speaking terms with children, they cease to be men, and become merely machines for eating and for earning money.
    John Updike (b. 1932)