Skip to content

Latest commit

 

History

History
248 lines (230 loc) · 9.11 KB

Universal_Turing_machine.md

File metadata and controls

248 lines (230 loc) · 9.11 KB
sub run_utm(:$state! is copy, :$blank!, :@rules!, :@tape = [$blank], :$halt, :$pos is copy = 0) {
    $pos += @tape if $pos < 0;
    die "Bad initial position" unless $pos ~~ ^@tape;

STEP: loop {
        print "$state\t";
        for ^@tape {
            my $v = @tape[$_];
            print $_ == $pos ?? "[$v]" !! " $v ";
        }
        print "\n";

        last if $state eq $halt;

        for @rules -> @rule {
            my ($s0, $v0, $v1, $dir, $s1) = @rule;
            next unless $s0 eq $state and @tape[$pos] eq $v0;

            @tape[$pos] = $v1;

            given $dir {
                when 'left' {
                    if $pos == 0 { unshift @tape, $blank }
                    else { $pos-- }
                }
                when 'right' {
                    push @tape, $blank if ++$pos >= @tape;
                }
            }

            $state = $s1;
            next STEP;

        }
        die 'No matching rules';
    }

}

say "incr machine";
run_utm	:halt<qf>,
    :state<q0>,
    :tape[1,1,1],
    :blank<B>,
    :rules[
        [< q0 1 1 right q0 >],
        [< q0 B 1 stay  qf >]
    ];

say "\nbusy beaver";
run_utm :halt<halt>,
    :state<a>,
    :blank<0>,
    :rules[
        [< a 0 1 right b >],
        [< a 1 1 left  c >],
        [< b 0 1 left  a >],
        [< b 1 1 right b >],
        [< c 0 1 left  b >],
        [< c 1 1 stay  halt >]
    ];

say "\nsorting test";
run_utm :halt<STOP>,
    :state<A>,
    :blank<0>,
    :tape[< 2 2 2 1 2 2 1 2 1 2 1 2 1 2 >],
    :rules[
        [< A 1 1 right A >],
        [< A 2 3 right B >],
        [< A 0 0 left  E >],
        [< B 1 1 right B >],
        [< B 2 2 right B >],
        [< B 0 0 left  C >],
        [< C 1 2 left  D >],
        [< C 2 2 left  C >],
        [< C 3 2 left  E >],
        [< D 1 1 left  D >],
        [< D 2 2 left  D >],
        [< D 3 1 right A >],
        [< E 1 1 left  E >],
        [< E 0 0 right STOP >]
    ];

Output:

incr machine
q0      [1] 1  1
q0       1 [1] 1
q0       1  1 [1]
q0       1  1  1 [B]
qf       1  1  1 [1]

busy beaver
a       [0]
b        1 [0]
a       [1] 1
c       [0] 1  1
b       [0] 1  1  1
a       [0] 1  1  1  1
b        1 [1] 1  1  1
b        1  1 [1] 1  1
b        1  1  1 [1] 1
b        1  1  1  1 [1]
b        1  1  1  1  1 [0]
a        1  1  1  1 [1] 1
c        1  1  1 [1] 1  1
halt     1  1  1 [1] 1  1

sorting test
A       [2] 2  2  1  2  2  1  2  1  2  1  2  1  2
B        3 [2] 2  1  2  2  1  2  1  2  1  2  1  2
B        3  2 [2] 1  2  2  1  2  1  2  1  2  1  2
B        3  2  2 [1] 2  2  1  2  1  2  1  2  1  2
B        3  2  2  1 [2] 2  1  2  1  2  1  2  1  2
B        3  2  2  1  2 [2] 1  2  1  2  1  2  1  2
B        3  2  2  1  2  2 [1] 2  1  2  1  2  1  2
B        3  2  2  1  2  2  1 [2] 1  2  1  2  1  2
B        3  2  2  1  2  2  1  2 [1] 2  1  2  1  2
B        3  2  2  1  2  2  1  2  1 [2] 1  2  1  2
B        3  2  2  1  2  2  1  2  1  2 [1] 2  1  2
B        3  2  2  1  2  2  1  2  1  2  1 [2] 1  2
B        3  2  2  1  2  2  1  2  1  2  1  2 [1] 2
B        3  2  2  1  2  2  1  2  1  2  1  2  1 [2]
B        3  2  2  1  2  2  1  2  1  2  1  2  1  2 [0]
C        3  2  2  1  2  2  1  2  1  2  1  2  1 [2] 0
C        3  2  2  1  2  2  1  2  1  2  1  2 [1] 2  0
D        3  2  2  1  2  2  1  2  1  2  1 [2] 2  2  0
D        3  2  2  1  2  2  1  2  1  2 [1] 2  2  2  0
D        3  2  2  1  2  2  1  2  1 [2] 1  2  2  2  0
D        3  2  2  1  2  2  1  2 [1] 2  1  2  2  2  0
D        3  2  2  1  2  2  1 [2] 1  2  1  2  2  2  0
D        3  2  2  1  2  2 [1] 2  1  2  1  2  2  2  0
D        3  2  2  1  2 [2] 1  2  1  2  1  2  2  2  0
D        3  2  2  1 [2] 2  1  2  1  2  1  2  2  2  0
D        3  2  2 [1] 2  2  1  2  1  2  1  2  2  2  0
D        3  2 [2] 1  2  2  1  2  1  2  1  2  2  2  0
D        3 [2] 2  1  2  2  1  2  1  2  1  2  2  2  0
D       [3] 2  2  1  2  2  1  2  1  2  1  2  2  2  0
A        1 [2] 2  1  2  2  1  2  1  2  1  2  2  2  0
B        1  3 [2] 1  2  2  1  2  1  2  1  2  2  2  0
B        1  3  2 [1] 2  2  1  2  1  2  1  2  2  2  0
B        1  3  2  1 [2] 2  1  2  1  2  1  2  2  2  0
B        1  3  2  1  2 [2] 1  2  1  2  1  2  2  2  0
B        1  3  2  1  2  2 [1] 2  1  2  1  2  2  2  0
B        1  3  2  1  2  2  1 [2] 1  2  1  2  2  2  0
B        1  3  2  1  2  2  1  2 [1] 2  1  2  2  2  0
B        1  3  2  1  2  2  1  2  1 [2] 1  2  2  2  0
B        1  3  2  1  2  2  1  2  1  2 [1] 2  2  2  0
B        1  3  2  1  2  2  1  2  1  2  1 [2] 2  2  0
B        1  3  2  1  2  2  1  2  1  2  1  2 [2] 2  0
B        1  3  2  1  2  2  1  2  1  2  1  2  2 [2] 0
B        1  3  2  1  2  2  1  2  1  2  1  2  2  2 [0]
C        1  3  2  1  2  2  1  2  1  2  1  2  2 [2] 0
C        1  3  2  1  2  2  1  2  1  2  1  2 [2] 2  0
C        1  3  2  1  2  2  1  2  1  2  1 [2] 2  2  0
C        1  3  2  1  2  2  1  2  1  2 [1] 2  2  2  0
D        1  3  2  1  2  2  1  2  1 [2] 2  2  2  2  0
D        1  3  2  1  2  2  1  2 [1] 2  2  2  2  2  0
D        1  3  2  1  2  2  1 [2] 1  2  2  2  2  2  0
D        1  3  2  1  2  2 [1] 2  1  2  2  2  2  2  0
D        1  3  2  1  2 [2] 1  2  1  2  2  2  2  2  0
D        1  3  2  1 [2] 2  1  2  1  2  2  2  2  2  0
D        1  3  2 [1] 2  2  1  2  1  2  2  2  2  2  0
D        1  3 [2] 1  2  2  1  2  1  2  2  2  2  2  0
D        1 [3] 2  1  2  2  1  2  1  2  2  2  2  2  0
A        1  1 [2] 1  2  2  1  2  1  2  2  2  2  2  0
B        1  1  3 [1] 2  2  1  2  1  2  2  2  2  2  0
B        1  1  3  1 [2] 2  1  2  1  2  2  2  2  2  0
B        1  1  3  1  2 [2] 1  2  1  2  2  2  2  2  0
B        1  1  3  1  2  2 [1] 2  1  2  2  2  2  2  0
B        1  1  3  1  2  2  1 [2] 1  2  2  2  2  2  0
B        1  1  3  1  2  2  1  2 [1] 2  2  2  2  2  0
B        1  1  3  1  2  2  1  2  1 [2] 2  2  2  2  0
B        1  1  3  1  2  2  1  2  1  2 [2] 2  2  2  0
B        1  1  3  1  2  2  1  2  1  2  2 [2] 2  2  0
B        1  1  3  1  2  2  1  2  1  2  2  2 [2] 2  0
B        1  1  3  1  2  2  1  2  1  2  2  2  2 [2] 0
B        1  1  3  1  2  2  1  2  1  2  2  2  2  2 [0]
C        1  1  3  1  2  2  1  2  1  2  2  2  2 [2] 0
C        1  1  3  1  2  2  1  2  1  2  2  2 [2] 2  0
C        1  1  3  1  2  2  1  2  1  2  2 [2] 2  2  0
C        1  1  3  1  2  2  1  2  1  2 [2] 2  2  2  0
C        1  1  3  1  2  2  1  2  1 [2] 2  2  2  2  0
C        1  1  3  1  2  2  1  2 [1] 2  2  2  2  2  0
D        1  1  3  1  2  2  1 [2] 2  2  2  2  2  2  0
D        1  1  3  1  2  2 [1] 2  2  2  2  2  2  2  0
D        1  1  3  1  2 [2] 1  2  2  2  2  2  2  2  0
D        1  1  3  1 [2] 2  1  2  2  2  2  2  2  2  0
D        1  1  3 [1] 2  2  1  2  2  2  2  2  2  2  0
D        1  1 [3] 1  2  2  1  2  2  2  2  2  2  2  0
A        1  1  1 [1] 2  2  1  2  2  2  2  2  2  2  0
A        1  1  1  1 [2] 2  1  2  2  2  2  2  2  2  0
B        1  1  1  1  3 [2] 1  2  2  2  2  2  2  2  0
B        1  1  1  1  3  2 [1] 2  2  2  2  2  2  2  0
B        1  1  1  1  3  2  1 [2] 2  2  2  2  2  2  0
B        1  1  1  1  3  2  1  2 [2] 2  2  2  2  2  0
B        1  1  1  1  3  2  1  2  2 [2] 2  2  2  2  0
B        1  1  1  1  3  2  1  2  2  2 [2] 2  2  2  0
B        1  1  1  1  3  2  1  2  2  2  2 [2] 2  2  0
B        1  1  1  1  3  2  1  2  2  2  2  2 [2] 2  0
B        1  1  1  1  3  2  1  2  2  2  2  2  2 [2] 0
B        1  1  1  1  3  2  1  2  2  2  2  2  2  2 [0]
C        1  1  1  1  3  2  1  2  2  2  2  2  2 [2] 0
C        1  1  1  1  3  2  1  2  2  2  2  2 [2] 2  0
C        1  1  1  1  3  2  1  2  2  2  2 [2] 2  2  0
C        1  1  1  1  3  2  1  2  2  2 [2] 2  2  2  0
C        1  1  1  1  3  2  1  2  2 [2] 2  2  2  2  0
C        1  1  1  1  3  2  1  2 [2] 2  2  2  2  2  0
C        1  1  1  1  3  2  1 [2] 2  2  2  2  2  2  0
C        1  1  1  1  3  2 [1] 2  2  2  2  2  2  2  0
D        1  1  1  1  3 [2] 2  2  2  2  2  2  2  2  0
D        1  1  1  1 [3] 2  2  2  2  2  2  2  2  2  0
A        1  1  1  1  1 [2] 2  2  2  2  2  2  2  2  0
B        1  1  1  1  1  3 [2] 2  2  2  2  2  2  2  0
B        1  1  1  1  1  3  2 [2] 2  2  2  2  2  2  0
B        1  1  1  1  1  3  2  2 [2] 2  2  2  2  2  0
B        1  1  1  1  1  3  2  2  2 [2] 2  2  2  2  0
B        1  1  1  1  1  3  2  2  2  2 [2] 2  2  2  0
B        1  1  1  1  1  3  2  2  2  2  2 [2] 2  2  0
B        1  1  1  1  1  3  2  2  2  2  2  2 [2] 2  0
B        1  1  1  1  1  3  2  2  2  2  2  2  2 [2] 0
B        1  1  1  1  1  3  2  2  2  2  2  2  2  2 [0]
C        1  1  1  1  1  3  2  2  2  2  2  2  2 [2] 0
C        1  1  1  1  1  3  2  2  2  2  2  2 [2] 2  0
C        1  1  1  1  1  3  2  2  2  2  2 [2] 2  2  0
C        1  1  1  1  1  3  2  2  2  2 [2] 2  2  2  0
C        1  1  1  1  1  3  2  2  2 [2] 2  2  2  2  0
C        1  1  1  1  1  3  2  2 [2] 2  2  2  2  2  0
C        1  1  1  1  1  3  2 [2] 2  2  2  2  2  2  0
C        1  1  1  1  1  3 [2] 2  2  2  2  2  2  2  0
C        1  1  1  1  1 [3] 2  2  2  2  2  2  2  2  0
E        1  1  1  1 [1] 2  2  2  2  2  2  2  2  2  0
E        1  1  1 [1] 1  2  2  2  2  2  2  2  2  2  0
E        1  1 [1] 1  1  2  2  2  2  2  2  2  2  2  0
E        1 [1] 1  1  1  2  2  2  2  2  2  2  2  2  0
E       [1] 1  1  1  1  2  2  2  2  2  2  2  2  2  0
E       [0] 1  1  1  1  1  2  2  2  2  2  2  2  2  2  0
STOP     0 [1] 1  1  1  1  2  2  2  2  2  2  2  2  2  0