Church Pair Lambda Calc を実装しようとしています。CLIsp を使用したスタイル。
ウィキペディアによると:
pair ≡ λx.λy.λz.z x y
これまでのところ、これは私のコードです:
(defvar PAIR
#'(lambda(x)
#'(lambda(y)
#'(lambda(z)
(funcall (funcall z x) y)))) )
これらは私のFIRSTとSECOND関数です:
(defvar FIRST
#'(lambda(p)
(funcall(p TRUE)))
)
(defvar SECOND
#'(lambda(p)
(funcall(p FALSE)))
)
この 2 つの関数は Int から ChurchNumber に変換します
(defun church2int(numchurch)
(funcall (funcall numchurch #'(lambda (x) (+ x 1))) 0)
)
(defun int2church(n)
(cond
((= n 0) #'(lambda(f) #'(lambda(x)x)))
(t #'(lambda(f) #'(lambda(x) (funcall f
(funcall(funcall(int2church (- n 1))f)x))))))
)
だから、私がすることは次のとおりです。
(setq six (int2church 6))
(setq four (int2church 4))
その後:
(setq P (funcall (funcall PAIR six) four))
そして、私が持っている:
#<FUNCTION :LAMBDA (Y) (FUNCALL (FUNCALL F X) Y)>
だから私がこれを行うと:
(funcall #'FIRST P)
私はこのエラーを持っています:
*** - FIRST: #<FUNCTION :LAMBDA (Y) (FUNCALL (FUNCALL F X) Y)> is not a list
何が間違っているのかわかりません。どんな助けでも大歓迎です。
ありがとう