Skip to content

354ika/SunflowerTuringMachineSimulator

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

27 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

SunflowerTuringMachineSimulator is a Turing Machine simulator supporting up to 3 symbols and a blank.
It is entirely-commandline based, so it might seem like black box magic (And it kind of is). Some binaries are included in the /bin/<platform> folder if you don't want to compile anything, but the source code should be available in src.

More information can be found in the documentation.txt file.

To run the program, make sure your current directory contains a copy of
<Intape.txt>, <Machine.txt> and <Outtape.txt>.

Change the permissions of the executables with
chmod +x Output+.exe (If per chance you're on linux. Windows could allow you to just double click it.)

Then just use ./<Path to program>/Output+.exe to run it!

If you want to compile the binaries yourself, go to /src.


TMsim+.c ---| Compile |--> output+.exe: The main Turing Machine simulator. Edit to configure which program the TM runs.

Use with 1, 2 or 3 arguments.

./output+.exe <Number of iterations before timeout, %llu> <Maximum number of states allowed, %i>
Default maximum runtime is 4294967296 iterations, and state maximum is 1024 states.

Dependency: Reads the machine from Machine.txt.
Dependency: Reads from the input tape Intape.txt.

Outputs the result to Outtape.txt.

The machine's speed cannot be configured. It will always run at full speed.
2 billion iterations takes approximately 10 ~ 20 seconds, so runtime shouldn't be a concern.



Intape.txt: The input tape for the Turing Machine. Edit to configure what the input to the TM will be.
The input alphabet should be {'0', '1', '2'}.
The tape alphabet is {'0', '1', '2', '\0'}. with '\0' denoting the blank.



Outtape.txt: The output tape for the Turing Machine. This is the output.
The output should contain only {'0', '1', '2'}. '\0' will cut off the output.




When writing your Turing Machine...

Use the symbol '3' to indicate a 'blank' symbol. This is because a 'NULL' character is hard to type.
'L' and 'R' will be used to move the head.

The syntax for each line is:

<State to go when read 0>,<Char to write when read 0>,<State to go when read 1>,<Char to write when read 1>...
The CSV must be exactly 8 columns. A comment can be written afterwards (It'll be ignored)

The program assumes the state number is the linenumber. So state '0' will be present on the first line.
state '0' is always assumed to be the start state, and
the last line is always assumed to be the final state.

If you don't want the transition, write '-1' for the destination state number.
An example of a state:

43,1,43,2,43,3,44,0 # This is state 43. It will go to state 44 and write a 0 of it reads a blank.

-1,3,-1,3,-1,3,-1,3 # This is state 44 and it looks like the halt state.



Stateshifter.c ---| Compile |--> Stateshifter.exe: Shifts every state number in the Machine file.

Use with 2 arguments.

./Stateshifter.exe <Number to shift by>

Dependency: Reads the machine from Machine.txt

Writes a modified copy of the machine to Modify.txt. Useful if you want to add some states because line 0 is assumed to be the start.



IntapeWriter.c ---| Compile |--> IntapeWriter.exe: Writes some pattern to the input tape.

Change the code yourself. If you're tired of typing into the file, use this program to write it for you
Make sure to compile it every time!




Code first constructed by 354ika (Hong Fulin).

The author(s) are not liable for any kind of physical (burning computer) or emotional damage (as a result of frustration) caused to anyone who chooses to use this program or derivative works of this program, or the inability to recognize that, indeed, there are no sunflowers contained in this program.

Have fun using / modding!