TuringMachine
TuringMachine[rule,init,t]
指定されたルールで初期条件 init から t ステップ進んだチューリングマシンの進化を表すリストを生成する.
TuringMachine[rule,init]
init を1ステップ進化させた結果を与える.
TuringMachine[rule]
進化の1ステップに相当するTuringMachineの演算子形である.
詳細
- 一次元のチューリングマシンの場合,TuringMachineで生成された進化の各ステップは{{s,x,dx},{a1,a2,…}}の形で与えられる.ここで,頭部の状態は s であり,テープ上のセルは値 aiを持ち,頭部は aiと相対的な位置 x にあり,初期位置と比べて dx 動いている.
- dx がチューリングマシンの初期条件から省略された場合,dx は0とみなされる.
- d 次元のチューリングマシンでは,テープは d 次元の配列で指定され,位置 x と相対的位置 dx は長さ d のリストになる.
- チューリングマシンのルールは{si,ai}->{spi,api,offi}の形の置換のリストで与えられる.その要素は次のようになる.
-
si 頭部の状態 ai 頭部の下のセルの値 spi 頭部の新しい状態 api 頭部の下のセルの新しい値 offi 頭部が動くオフセット - 状態とセルの値は整数,パターン,任意の式のいずれでもよい.個々のセルの値はリストにはできない.
- 一次元では,各オフセット offiは1個の整数である.次元が高くなると整数のリストになる.
- 状態とセルの値が,それぞれ1から までと0から までの範囲の整数であるとされる場合,rule として次の形を与えることができる.
-
n 数 n の状態が2つで色も2色のマシン {n,s} 数 n の状態が s 個で色が2色のマシン {n,s,k} 数 n の状態が s 個で色が k 色のマシン {n,s,k,r} から の範囲(0を除く)で offiを許容する {n,s,k,{r1,r2,…,rd}} オフセット, , …の 次元マシン {n,s,k,{{off1},{off2},…}} 指定された明示的オフセットを許容するマシン {rule,s,k} 明示的なルールを与えられたマシン rule 明示的なルールを与えられたマシン(s と k は推測される) - 可能なチューリングマシンルールの数は次の通りである.
-
2状態2色のマシン 4096 s 状態 k 色のマシン (2 s k)^(s k) s 状態 k 色で範囲 r のマシン (2 r s k)^(s k) 二次元で s 状態 k 色のマシン (8 s k)^(s k) - マシンがそれ自身が置かれている構造についてのルールを持たない場合,その構造は変化しない.
- TuringMachineは,与えられた構成に対してルールが複数の指定を持っている場合はリストの先頭の物を使う.
- {rule,s,k}の形を使って,指定された構成に対してルールに必ずしも1つの例しかない訳ではない,多方向,非決定性,あるいはその他のチューリングマシンが指定できる.
- 典型的な初期条件 init の形は次の通りである.
-
{s,{{},0}} 頭部の状態 s,0で埋められた一次元テープ上 {s,{{a1,a2,…},0}} 無限テープ上の値 aiで区切られた範囲 {{s,x},{{a1,a2,…},0}} 頭部が最初は位置 xにある有限範囲 {{s,…},{{a1,…},{b1,…}}} 値 biの反復する背景 {{s,…},{a1,a2,…}} 有限テープ,循環を仮定 - TuringMachine[rule,init,t]は,長さ の進化リストを生成する.
- TuringMachine[rule][init]はTuringMachine[rule,init]に等しい.
例題
すべて開くすべて閉じる例 (5)
スコープ (17)
一次元ルール (6)
初期条件 (9)
アプリケーション (12)
特性と関係 (4)
{n,s,k,…}の形式の規則のときは,ヘッドの状態とセルの値は,それぞれ1から s と0から k-1の整数でよい:
{n,s,k,…}の形式の規則のときは,0から k-1までの範囲外の値を持つセルにヘッドが到達するとマシンの進化が停止する:
RulePlotを使って完全な進化の図を生成する:
テキスト
Wolfram Research (2007), TuringMachine, Wolfram言語関数, https://reference.wolfram.com/language/ref/TuringMachine.html (2021年に更新).
CMS
Wolfram Language. 2007. "TuringMachine." Wolfram Language & System Documentation Center. Wolfram Research. Last Modified 2021. https://reference.wolfram.com/language/ref/TuringMachine.html.
APA
Wolfram Language. (2007). TuringMachine. Wolfram Language & System Documentation Center. Retrieved from https://reference.wolfram.com/language/ref/TuringMachine.html