Skip to content

Program that simulates the functionality of a Turing Machine.

License

Notifications You must be signed in to change notification settings

Cano-Jones/Turing-Machine

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

23 Commits
 
 
 
 
 
 
 
 

Repository files navigation

Turing-Machine

Program that simulates the functionality of a Turing Machine.

The Turing Machine consists on an infinite tape divided on 'cells' that where a ASCII character can be written, and a 'Reader' that can move through the tape and change the character on the cell in which it stands and can be on different 'states'. The dynamics of the reader are determined by a set of commands (Code); each command have the next arguments:

-Initial state of the reader. (Is)

-ASCII character readed by the reader. (Vr)

-ASCII character written by the reader. (Vw)

-Movement of the reader. (Mr)

-Final state of the reader. (Fs)

The algorithm goes as follows: If the reader (at some position) is at state 'Is' and read a character 'Vr', then, it changes that character to character 'Vw', then, the reader moves acording to 'Mr' (one position to the right, to the left or it stays put) and changes its state to 'Fs' before repeting the process. If no command is aplicable or if the reader arives to a stopping state, the loop ends, and the result is whatever is left written on the tape.

This program recives a file containing the characters written on a tape and a set of commands. This file mus follow the next format:

%Comment

>INPUT:

TapeCharacters

>CODE:

<@,Vr,Vw,Mr,Fs>

<Is,Vr,Vw,Mr,Fs>

<Is,Vr,Vw,Mr,Fs>

...

<Is,Vr,Vw,Mr,#>

%Comment, >INPUT: and >CODE: headers are mandatory. The first reader state must be '@' and there muct be at least one stopping state '#'.

An example of execution is shown (the file Addition.tm can be found on the CodeExamples folder), using a UNIX terminal:

$ python3 Turing.py<Addition.tm

<< 011001+00111

>> 100000

$

After executing the Turing.py program using the Addition.tm file, the initial tape is printed after '>>' and the final tape is printes after '>>'. This example takes two binary numbers as initial tape and ads them.

If there is any error on the file format, an error message stating the issue will be printed before exiting the program. Possible ERROR messages are:

  • >ERROR: No inital comment header '%'

  • >ERROR: No INPUT header

  • >ERROR: No CODE header

  • >ERROR: Command syntax, '<' or '>' missing

  • >ERROR: Command syntax, incorrect number of arguments

  • >ERROR: No initial command '@'

  • >ERROR: Command syntax, incorrect movement argument

  • >ERROR: No stopping command '#

  • >ERROR: Two commands with equal coditions

  • >ERROR: Infinite loop comand <A,B,B,X,A>

  • >ERROR: Different sets of initial and final states

Needed libraries:

  • sys
  • copy
  • colorama

Creative Commons License
This work is licensed under a Creative Commons Attribution-NonCommercial-NoDerivatives 4.0 International License.

About

Program that simulates the functionality of a Turing Machine.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published