回答:
承知しました!例を使用してFORをエンコードする方法を示します。
単純な階乗FORプログラムを翻訳したいとします
x := 1
for i := 1 to N do
x := x * i
次のように書き直します
x := 1
i := 1
repeat N times
x := x*i
i := i+1
次に、使用するすべての変数をタプルに入れます(ここではペアで十分です)。
(x,i) := (1,1)
repeat N times
(x,i) := (x*i, i+1)
これは効果的に機能を適用します 最初のペアに ために 回。
以来 教会の数字で表すことができます。
上記の構文は、単純なラムダ計算を超えていくつかのことを使用しています。数字と算術は、教会の数字を使用して正確にすることができます。ペアにも独自の教会エンコーディングがあります:
3つ以上の変数がある場合は、上記のエンコーディングをタプルに一般化するか、単にタプルをネストされたペアとして表すことができます。
WHILEは再帰を使用することで最もよく処理されます:の代わりに
while p(x,i) do
(x,i) := f(x,i)
どこp
述語で、f
いくつかの(部分)関数であり、我々のようなものを使用することができます
def recFun(x,i):
if p(x,i):
return recFun(f(x,i))
else:
return (x,i)
ラムダ計算では、再帰は、固定小数点コンビネータ、たとえばChurch's またはチューリングの 。私たちは次のようなものを得ます
どこ ブール値が教会でエンコードされていると仮定します。
また、WHILEは(厳密に)FORより強力です。すべてのFORはWHILEとしてエンコードできるため、このエンコード手法はFORにも使用できます。
ループのエンコーディングはありますが、ラムダ計算は命令型言語ではないため、慣れ親しんだループとまったく同じようには機能しません。ラムダ計算には副作用がないので(純粋に関数型の言語です)、ループとまったく同じものは役に立たないでしょう。
命令型プログラムは、すべての状態をプログラム内の変数として明示的に渡すことにより、純粋に関数型の言語に変換できます。命令型疑似コードにはPython構文を使用します。それという指示と、ほとんど透明でなければならない(a, b) = f(…)
関数の呼び出しがあることを意味f
ペアを返し、a
そしてb
それぞれの対の第一及び第二成分が割り当てられています。ループを考える
while test_condition():
do_stuff()
状態を明示的にしましょう。
state = initial_state
(state, cond) = test_condition(state)
while cond:
(state, cond) = test_condition(do_stuff(state))
これを再帰呼び出しに変換できます。def loop(state):
と呼ばれる関数を定義しますloop
。
def loop(state):
(state, cond) = test_condition(state)
if cond: return loop(do_stuff(state))
else: return state
state = loop(initial_state)
これは、次の概念のみを使用します。これらの概念はすべて、ラムダ計算で簡単に表現できます。
したがってwhile
、条件の関数を定義できます(test_condition
)とボディ(do_stuff
):
forループはプログラミング言語によって異なりますが、常にwhileループの特殊なケースであるため、同じ方法でエンコードできます。ソース言語がforループの表現力を制限している場合は、より単純なエンコーディングが考えられます。たとえば、「繰り返し 回」は単に関数構成です 回、関数はループの本体を構成する状態変換であり、 教会の数字なので、それは単に適用されます ループ本体関数にそれ自体。
状態に対する別のアプローチは、状態操作プリミティブを使用してラムダ計算を拡張することです。その場合、評価の順番が重要になります。その場合、whileループは再帰で直接表現できます。