Skip to content
/ Ram Public

Random Access Machine - a simulator for theoretic computer science

Notifications You must be signed in to change notification settings

thesix/Ram

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

33 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Brief description

  A register machine as often used in theoretic computer science.  The
  concept is based on the Random Access Machine introduced in the book
  'Theoretische Informatik' by Alexander Asteroth and Christel Baier
  (ISBN 3-8273-7033-7).

  This little project is dedicated to Bernhard Nessler, who taught me
  theoretical computer science at Graz University of Technology.

Usage

  Import Ram from the module Ram.py and create an instance Ram
  ("filename") where 'filename' is the name of the file containing your
  program text, or run the module Ram.py with your 'filename' as command
  line argument.

  Program text is a plain text file.  Any line starting with a hash mark
  ('#') is ignored.  Empty lines MUST be avoided.  The first non-comment
  line MUST be a series of integer numbers denoting the initial values
  of your registers.  The first register (index 0) is also the
  accumulator and MUST be initialized with 0.  Program text MUST be
  entered as

    NUM COMMAND ARG

  where NUM can be anything (usually the line number for orientation),
  COMMAND is one of the accepted commands (see below) and ARG is the
  argument for COMMAND.  Anything following ARG up to the next newline
  ('\n') is ignored.

COMMANDS (see meaning of arguments below):

  LOAD k  :=  LOAD v(k) into accumulator
  STORE i :=  STORE contents of accumulator at register i
  ADD k   :=  ADD v(k) to accumulator
  SUB k   :=  SUBtract v(k) from accumulator
  MULT k  :=  MULTiply accumulator by v(k)
  DIV k   :=  DIVide accumulator by v(k)
  GOTO l  :=  GOTO line number l
  JZERO l :=  Jump to line number l if accumulator == ZERO (0)
  END ?   :=  set program counter to 0 (termination)

Arguments

  x     v(x)
  ------------
   k    reg[k]
  #k    k
  *k    reg[reg[k]]

Copyright © 2011 Jogi Hofmüller <[email protected]>

  This program is free software: you can redistribute it and/or modify
  it under the terms of the GNU General Public License as published by
  the Free Software Foundation, either version 3 of the License, or (at
  your option) any later version.

  This program is distributed in the hope that it will be useful, but
  WITHOUT ANY WARRANTY; without even the implied warranty of
  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
  General Public License for more details.

  You should have received a copy of the GNU General Public License
  along with this program.  If not, see <http://www.gnu.org/licenses/>.

Sample program

A short sample program for RAM, multiplying two numbers.  Copy/paste it
to a file and run './Ram.py filename' to test it.

# Begining of program
# multiply two numbers in registeres R1 and R2
# initialize registers 0, 1 and 2
REGINIT 0 6 7
1  LOAD #0        # load constant 0 to R0
2  STORE 3        # save value at R3
3  LOAD 1         # load R1 to R0
4  JZERO 11       # got line 11 if R0==0
5  SUB #1         # subtract constant 1 from R0
6  STORE 1        # save value at R1
7  LOAD 2         # load R2 to R0
8  ADD 3          # add R3 to R0
9  STORE 3        # save value at R3
10 GOTO 3         # got line 3
11 LOAD 3         # load R3 to R0
12 END END        # end program
# End of program

About

Random Access Machine - a simulator for theoretic computer science

Resources

Stars

Watchers

Forks

Packages

No packages published