PLT 板


LINE

看板 PLT  RSS
※ 引述《SansWord (是妳)》之銘言: : 來這裡問問有沒有更general 的 "letrec 如何可能" 的學理原則 Hmm... 我是覺得可以找 ccshan 建議的課本來看看。 我不知道 letrec 實際上是怎麼做的,不過如果是談原則, 我會用 fixed-point combinator 來解釋 letrec. 這樣不用 用到 set-cdr 或其他副作用。只要語言本身有提供 lambda abstraction 就可以做出 letrec 的效果。 以你寫到的 fact 為例子。在一個已經允許你用遞迴定義的 語言中你可以這樣定 fact: (define (fact n) (if (= n 1) 1 (* n (fact (- n 1))))) e.g. (fact 6) = 720. (這邊的 define 就是 letrec)但如果不准遞迴定義呢? 我們先定一個函數叫做 factF, 把遞迴的地方抽出來: (define (factF g) (lambda (n) (if (= n 1) 1 (* n (g (- n 1)))))) factF 是一個產生函數的函數。給一個函數 g, (fact g) 又是一個整數到整數的函數。它只做了 fact 的「 第一層」。本來應該遞迴的地方則呼叫 f. 我們希望 g 的位置又是 (factF g). 也就是說我們得把 factF 餵給自己: (factF (factF (factF ..... ))) 6 = 720. 這個「餵給自己」的動作可以用 Y combinator 來作。 Lambda calculus 中 Y combinator 是定義成: Y F = (\x . F (x x)) (\x . F (x x)) 這樣一看實在是不知道在做什麼。但如果我們把它展開: Y F = (\x . F (x x)) (\x . F (x x)) = F ((\x . F (x x)) (\x . F (x x))) = F (F ((\x . F (x x)) (\x . F (x x)))) = F (F (F ((\x . F (x x)) (\x . F (x x)))) = ... 就看到 F 一個個跑出來了。 :) 在 Scheme 中原則上也是可以這麼做,但 Scheme 是 strict 的語言,如果 Y 那樣寫會停不下來。所以得 多加一些 lambda 把那些 (x x) 的計算延遲掉: (define (Y F) ((lambda (x) (F (lambda (a) ((x x) a)))) (lambda (x) (F (lambda (a) ((x x) a)))))) 然後我們就可以定義 (define factY (Y factF)) 某個意義上 Y 就是實作出了 letrec. 剩下來的就是 怎麼用一些 macro 把它包起來... 這就要問真正會 Scheme 的人了.. Google 一下 Y combinator 會找到很多解說。例如 http://www.ece.uc.edu/~franco/C511/html/Scheme/ycomb.html : 更麻煩的問題~那mutual recursion呢?又要怎實作? : 會不會有晦暗的角落出錯我卻沒注意到? Mutual recursion 其實也是一樣的. 單獨的遞迴定義是定義 一個東西,mutual recursion 是一次定義一組。 (下次有空試試看... ) --



※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 140.109.20.217
1F:推 SansWord:謝謝! 我來試試看~ 06/02 13:59
2F:→ SansWord:這個方法是不是很像 Functional Programming with 06/02 14:01
3F:→ SansWord:Overloading and Higher-Order Polymorphism 06/02 14:01
4F:→ SansWord:ch 5.1 提到的functor? (上面那篇by Mark P. Jones) 06/02 14:02
5F:→ SansWord:裡面提到了如何抽象化 fold 之類的函數 06/02 14:03
6F:→ SansWord:使用到了一個cata phi 機制~ 06/02 14:03
7F:推 godfat:對不起,推文請勿超過三行,超過麻煩用回文的方式,謝謝 06/03 02:20
8F:推 SansWord:抱歉我不知道這個規則~所以我直接回這篇嗎? 06/03 02:38
9F:→ godfat:板規有寫,沒關係以後記得就好 06/03 02:50
10F:推 SansWord:好的~謝謝板主 06/03 08:52







like.gif 您可能會有興趣的文章
icon.png[問題/行為] 貓晚上進房間會不會有憋尿問題
icon.pngRe: [閒聊] 選了錯誤的女孩成為魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一張
icon.png[心得] EMS高領長版毛衣.墨小樓MC1002
icon.png[分享] 丹龍隔熱紙GE55+33+22
icon.png[問題] 清洗洗衣機
icon.png[尋物] 窗台下的空間
icon.png[閒聊] 双極の女神1 木魔爵
icon.png[售車] 新竹 1997 march 1297cc 白色 四門
icon.png[討論] 能從照片感受到攝影者心情嗎
icon.png[狂賀] 賀賀賀賀 賀!島村卯月!總選舉NO.1
icon.png[難過] 羨慕白皮膚的女生
icon.png閱讀文章
icon.png[黑特]
icon.png[問題] SBK S1安裝於安全帽位置
icon.png[分享] 舊woo100絕版開箱!!
icon.pngRe: [無言] 關於小包衛生紙
icon.png[開箱] E5-2683V3 RX480Strix 快睿C1 簡單測試
icon.png[心得] 蒼の海賊龍 地獄 執行者16PT
icon.png[售車] 1999年Virage iO 1.8EXi
icon.png[心得] 挑戰33 LV10 獅子座pt solo
icon.png[閒聊] 手把手教你不被桶之新手主購教學
icon.png[分享] Civic Type R 量產版官方照無預警流出
icon.png[售車] Golf 4 2.0 銀色 自排
icon.png[出售] Graco提籃汽座(有底座)2000元誠可議
icon.png[問題] 請問補牙材質掉了還能再補嗎?(台中半年內
icon.png[問題] 44th 單曲 生寫竟然都給重複的啊啊!
icon.png[心得] 華南紅卡/icash 核卡
icon.png[問題] 拔牙矯正這樣正常嗎
icon.png[贈送] 老莫高業 初業 102年版
icon.png[情報] 三大行動支付 本季掀戰火
icon.png[寶寶] 博客來Amos水蠟筆5/1特價五折
icon.pngRe: [心得] 新鮮人一些面試分享
icon.png[心得] 蒼の海賊龍 地獄 麒麟25PT
icon.pngRe: [閒聊] (君の名は。雷慎入) 君名二創漫畫翻譯
icon.pngRe: [閒聊] OGN中場影片:失蹤人口局 (英文字幕)
icon.png[問題] 台灣大哥大4G訊號差
icon.png[出售] [全國]全新千尋侘草LED燈, 水草

請輸入看板名稱,例如:WOW站內搜尋

TOP