Skip to content

Commit

Permalink
Add readme
Browse files Browse the repository at this point in the history
  • Loading branch information
Sten Laane committed Feb 20, 2021
1 parent dccdaf8 commit 8a4783b
Show file tree
Hide file tree
Showing 5 changed files with 55 additions and 1 deletion.
56 changes: 55 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
@@ -1,2 +1,56 @@
# SIMP-abstract-machine
Abstract machine for formal semantics of SIMP (Simple Imperative Language)

In 2020/21 I was a Teaching Assistant for the second year module 5CCS2PLD Programming Language Paradigms at King's
College London. PLD deals with formal semantics and verification of programming languages.

For exploring semantics, the module
textbook ([Programming Languages and Operational Semantics](https://link.springer.com/book/10.1007/978-1-4471-6368-8#about))
defines an educational language SIMP (the Simple Imperative Language), for which an abstract syntax and abstract machine
semantics are given.

This project is a Java implementation of the SIMP abstract machine used to teach students about formal reasoning of SIMP programs.

## Abstract syntax

The following is a concise overview of the abstract syntax of SIMP. This syntax is represented as classes and enums in
the command, integer, and bool packages.
![Abstract syntax of SIMP](img/abstract-syntax.png)

## Abstract machine

An abstract machine interprets an abstract syntax tree of a SIMP program and follows a transition system to evaluate the
programs.

### Configuration

The abstract machine is defined as a tuple (c, r, m), called a configuration, where

* c is a control stack used to store the program and determines which transitions to follow
* r is an auxiliary stack (also called results stack) that stores intermediary results
* m is memory, also called a store, modelled by a partial function mapping each string addresses to memory. Memory is
used to store variables and acts as I/O to the program.

The control stack (c) and result stack (r) can each hold fixed data types:
![Control and result stacks](img/stacks.png)
These types are represented in Java using the ControlStackable and ResultsStackable interfaces. Note that (a • b)
indicates a stack where a is on top of b.

### Transitions

To simulate a SIMP program, a set of transition rules are defined. These determine how the abstract machine changes
configurations based on what is at the top of the control stack.
![Expression transiions](img/expression-transitions.png)
![Commmand transiions](img/command-transitions.png)
These transitions are implemented in the Evaluator class.

## Usage

To run a SIMP program, it must be represented as an abstract syntax tree and passed to the Evaluator class as a
constructor argument.

An example program that calculates x^n can be found in the Main class.

## Further information

Additional information about SIMP can be found in Maribel Fernandez's
textbook [Programming Languages and Operational Semantics](https://link.springer.com/book/10.1007/978-1-4471-6368-8#about)
Binary file added img/abstract-syntax.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added img/command-transitions.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added img/expression-transitions.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added img/stacks.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.

0 comments on commit 8a4783b

Please sign in to comment.