婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁(yè) > 知識(shí)庫(kù) > 如何利用Ruby簡(jiǎn)單模擬Lambda演算詳解

如何利用Ruby簡(jiǎn)單模擬Lambda演算詳解

熱門標(biāo)簽:北京語(yǔ)音電銷機(jī)器人價(jià)格 邯鄲外呼調(diào)研線路 開封百應(yīng)電銷機(jī)器人聯(lián)系方式 真人語(yǔ)音電銷機(jī)器人系統(tǒng) 浦東上海400開頭的電話申請(qǐng) 樂昌電話機(jī)器人 武漢呼叫中心外呼系統(tǒng)線路商 電話機(jī)器人電話卡封號(hào)怎么辦 買了外呼系統(tǒng)不想用了怎么辦

前言

最近看一本叫做《計(jì)算的本質(zhì)》的書,這本書主要說(shuō)了一些底層計(jì)算方面的知識(shí)。可以說(shuō)它刷新了我的三觀,而當(dāng)今天看到可以使用Y組合子來(lái)實(shí)現(xiàn)遞歸的時(shí)候我的世界觀基本崩塌了。故借著七夕來(lái)寫一篇文章總結(jié)一些關(guān)于計(jì)算的一些基本認(rèn)識(shí)。以便后續(xù)可以更好地學(xué)習(xí)。也借著Ruby的語(yǔ)法來(lái)闡述一下關(guān)于Lambda的一些故事。

0. 題外話

為了慶祝一下這個(gè)七夕節(jié)日,我提前關(guān)掉了LOL,打開了Emacs,敲下如下代碼(這里順便推廣一下Ruby的單件方法)

subject = "情侶"
object = "狗"

def subject.do_something(who)
 "#{self} 虐 #{who}"
end

if __FILE__ == $0
 p subject.do_something(object)
 p object.do_something(subject)
end

上面代碼的運(yùn)行結(jié)果是

"情侶 虐 狗"
dog.rb:11:in `main>': undefined method `do_something' for "狗":String (NoMethodError)

很明顯,情侶可以“虐”狗但狗不能“虐”情侶。因此第二句執(zhí)行語(yǔ)句會(huì)報(bào)錯(cuò)。以上也是Ruby優(yōu)雅的地方,我可以直接在指定實(shí)例上定義方法,而不影響其他其他的同類的實(shí)例(以上實(shí)例都是字符串)。

1. 函數(shù)的一些基本認(rèn)識(shí)

“題外話”有個(gè)卵子用?額, 說(shuō)沒用,它還是有一點(diǎn)作用的。我們今天的主題是用Ruby來(lái)模擬Lambda演算。Lambda演算在Wiki上面的解釋是這樣的

Lambda演算可以被稱為最小的通用程序設(shè)計(jì)語(yǔ)言。它包括一條變換規(guī)則(變量替換)和一條函數(shù)定義方式,Lambda演算之通用在于,任何一個(gè)可計(jì)算函數(shù)都能用這種形式來(lái)表達(dá)和求值。


平時(shí)我們使用命令式的編程語(yǔ)言會(huì)更傾向于關(guān)注字符串, 數(shù)字,布爾 這些可以充當(dāng)主語(yǔ)或者賓語(yǔ)的類型。而我們平時(shí)跟他們打交道更多會(huì)以變量的形式,就如同“題外話”中的"狗"和"情侶"。但這篇文章的重點(diǎn)放在"虐"這個(gè)詞上,也就是我們常稱的謂語(yǔ)。在計(jì)算機(jī)里面我們通常稱他做方法 或者 函數(shù)。

既然Wiki上也說(shuō)了Lambda是最小的通用程序設(shè)計(jì)語(yǔ)言,那我們有沒有可能用Lambda來(lái)模擬出數(shù)字, 字符串, 布爾等等的這些常用的數(shù)據(jù)類型呢?這就是接下來(lái)要講的東西。

1) Ruby中的函數(shù)

在Ruby中,函數(shù)其實(shí)可以算是一等公民,只是它的鋒芒往往被Ruby強(qiáng)大的面向?qū)ο筇卣鹘o掩蓋掉了(它使得我們更多地關(guān)注類還有模塊)。Ruby里面有個(gè)十分簡(jiǎn)單的創(chuàng)建函數(shù)的方式

[1] pry(main)> -> x { x + 2 }
=> #Proc:0x007fc171dc6010@(pry):1 (lambda)>

它返回了一個(gè)Proc對(duì)象。其實(shí)這個(gè)對(duì)象,就類似于我們平時(shí)操作的函數(shù)對(duì)象。但是這里我們并沒有給函數(shù)賦予名字,可以理解為它是一個(gè)匿名函數(shù)。那么這種函數(shù)如何調(diào)用呢?有一種很語(yǔ)義化的調(diào)用方式,我們甚至不需要用變量來(lái)接受這個(gè)函數(shù)就可以調(diào)用它。

[2] pry(main)> -> x { x + 2 }.call(1000)
=> 1002
[3] pry(main)> -> x { x + 2 }.call(1000, 100000)
ArgumentError: wrong number of arguments (given 2, expected 1)
from (pry):3:in `block in __pry__'

Ruby還提供了參數(shù)檢測(cè),如果傳入的參數(shù)與定義該函數(shù)的時(shí)候不匹配的話,則會(huì)拋出ArgumentError異常。此外,Ruby還提供了一種語(yǔ)法糖,我們可以用Proc#[]包裹參數(shù)來(lái)調(diào)用Proc實(shí)例。

使用方式如下:

[4] pry(main)> ADD_THREE = -> x { x + 3 }
=> #Proc:0x007fd8341ffc48@(pry):4 (lambda)>
[5] pry(main)> ADD_THREE[1000]
=> 1003

2) 柯里化

Wiki 上的解釋如下

在計(jì)算機(jī)科學(xué)中,柯里化(英語(yǔ):Currying),又譯為卡瑞化或加里化,是把接受多個(gè)參數(shù)的函數(shù)變換成接受一個(gè)單一參數(shù)(最初函數(shù)的第一個(gè)參數(shù))的函數(shù),并且返回接受余下的參數(shù)而且返回結(jié)果的新函數(shù)的技術(shù)。
既然上面已經(jīng)講了Ruby創(chuàng)建匿名函數(shù)的基本方式,那下面來(lái)看看如何用Ruby來(lái)模擬一個(gè)柯里化的過(guò)程, 假設(shè)我有一個(gè)函數(shù)接收三個(gè)參數(shù), 我定義如下

[10] pry(main)> ADD_THREE_NUMBER = -> (x, y, z) { x + y + z}
=> #Proc:0x007fd834aa4150@(pry):10 (lambda)>
[11] pry(main)> ADD_THREE_NUMBER.call(1,2,3)
=> 6

PS: 定義函數(shù)時(shí)參數(shù)用括號(hào)包裹是為了提高識(shí)別度,其實(shí)括號(hào)可加可不加,定義函數(shù)也可以寫成 -> x, y, z { x + y + z }
上述函數(shù)如何柯里化?按照柯里化的定義,我們可以把多參數(shù)的函數(shù)寫成嵌套返回多個(gè)單一參數(shù)函數(shù)的形式,為了方便閱讀我把代碼寫在Ruby腳本文件里面

# currying.rb
ADD_THREE_NUMBER_NEW = -> (a) {
 -> (b) {
 -> (c) {
 a + b + c
 }
 }
}

if __FILE__ == $0
 p ADD_THREE_NUMBER_NEW.call(1).call(2).call(3)
end

運(yùn)行結(jié)果

6

其實(shí)這個(gè)函數(shù)每次調(diào)用都返回了一個(gè)只帶一個(gè)參數(shù)的函數(shù),而且返回的函數(shù)會(huì)保存著調(diào)用當(dāng)前函數(shù)時(shí)傳入的參數(shù),就是我們通常講的閉包。直到最后一個(gè)函數(shù)被調(diào)用并返回的時(shí)候,才會(huì)真正得到期望的計(jì)算結(jié)果。

當(dāng)然我們可以更簡(jiǎn)單的用Proc#[]來(lái)調(diào)用(在文章的后半部分我會(huì)統(tǒng)一用這種方式,比較節(jié)省代碼)

[1] pry(main)> require('./currying')
=> true
[2] pry(main)> ADD_THREE_NUMBER_NEW[1][2][3]
=> 6

2. 模擬Lambda演算

Lambda既然是最小的通用編程語(yǔ)言,那么我們現(xiàn)在嘗試一下用Ruby的Proc這個(gè)現(xiàn)成的Lambda來(lái)演算一些東西。難的東西我自己都還接受不了,這里只能先來(lái)模擬一些最為簡(jiǎn)單的東西了。


1) 數(shù)字

首先嘗試模擬一下數(shù)字。《計(jì)算的本質(zhì)》一書中提供了一個(gè)比較直觀的段子,以下是我概括的大意

我們?nèi)绻麤]辦法直接使用數(shù)字,而只能使用謂語(yǔ)(動(dòng)作),那么我們只能重復(fù)數(shù)這個(gè)動(dòng)作來(lái)描述數(shù)字這個(gè)特征,而數(shù)這個(gè)動(dòng)作其實(shí)就是我們需要寫的Lambda表達(dá)式

直觀點(diǎn)講當(dāng)我們要表示0的時(shí)候就數(shù)0次,調(diào)用方法0次,表示1的時(shí)候就調(diào)用方法一次。

那我們簡(jiǎn)單地表示0~2就可以是

ZERO = -> (p) { -> (x) { x } }
ONE = -> (p) { -> (x) { p[x] } }
TWO = -> (p) { -> (x) { p[p[x]] } }

這樣或許看起來(lái)有點(diǎn)迷糊,其實(shí)他們都用Lambda演算出來(lái)的,他們都接受一個(gè)函數(shù)p(數(shù)數(shù)這個(gè)動(dòng)作)以及一個(gè)基礎(chǔ)值x作為參數(shù),如果是ZERO就直接返回基礎(chǔ)值x, 如果是ONE就以x這個(gè)基礎(chǔ)值作為參數(shù)調(diào)用函數(shù)p表示數(shù)了一次。

這里我們并沒有辦法很好的表示這個(gè)基礎(chǔ)值x,為了直觀,我需要借用一下Ruby內(nèi)置的數(shù)字0 作為一個(gè)基礎(chǔ)值,并且要另外定義數(shù)數(shù)這個(gè)動(dòng)作。

CALCULATE = -> (n) { n + 1 }

其實(shí)數(shù)數(shù)的動(dòng)作就是在原來(lái)的基礎(chǔ)值上加1,最后我統(tǒng)一寫腳本

# coding: utf-8

# number.rb
ZERO = -> (p) { -> (x) { x } }
ONE = -> (p) { -> (x) { p[x] } }
TWO = -> (p) { -> (x) { p[p[x]] } }

def to_integer(proc)
 calculate = -> (n) { n + 1 }
 # 其中0是基礎(chǔ)值
 proc[calculate][0]
end

在解析環(huán)境里面引入腳本并執(zhí)行一些相關(guān)的語(yǔ)句,就能得到我們想要的結(jié)果了

[1] pry(main)> require('./number')
=> true
[2] pry(main)> to_integer(ZERO)
=> 0
[3] pry(main)> to_integer(ONE)
=> 1
[4] pry(main)> to_integer(TWO)
=> 2

雖然對(duì)于已經(jīng)含有內(nèi)置數(shù)字類型的Ruby來(lái)說(shuō)這種模擬完全沒有任何實(shí)用價(jià)值,不過(guò)對(duì)于了解Lambda演算這可以是一個(gè)不錯(cuò)的開始。

2) 布爾型

說(shuō)完數(shù)字,再來(lái)簡(jiǎn)單說(shuō)一下布爾類型吧,他們也算是比較基礎(chǔ)的數(shù)據(jù)類型了。而且布爾型模擬起來(lái)還更簡(jiǎn)單些。畢竟布爾型,不是true就是false。我們可以分別寫兩個(gè)都接受兩個(gè)參數(shù)的函數(shù),一個(gè)代表true一個(gè)代表false。true函數(shù)就返回其中的第一個(gè)參數(shù),false函數(shù)直接返回第二個(gè)參數(shù)。

TRUE = -> (x) { -> (y) { x }}
FALSE = -> (x) { -> (y) { y }}

我們?cè)賹懸粋€(gè)解析腳本,作為驗(yàn)證。我記得在C這種沒有布爾類型的語(yǔ)言中我們是用0代表false 用大于1代表true。這里我就簡(jiǎn)單用0和1作為基礎(chǔ)值來(lái)驗(yàn)證我們的Lambda演算是否正確

# boolean.rb
TRUE = -> (x) { -> (y) { x }}
FALSE = -> (x) { -> (y) { y }}

def to_boolean(proc)
 proc[1][0]
end

引入運(yùn)行腳本試試

[1] pry(main)> require('./boolean')
/Users/lan/Personal/Ruby/boolean.rb:1: warning: already initialized constant TRUE
/Users/lan/Personal/Ruby/boolean.rb:2: warning: already initialized constant FALSE
=> true
[2] pry(main)> to_boolean(FALSE)
=> 0
[3] pry(main)> to_boolean(TRUE)
=> 1

跟預(yù)期的一樣,我們的模擬是正確的,F(xiàn)ALSE函數(shù)最后被解析成0, 而TRUE函數(shù)最后被解析成1。

以上的警告是重復(fù)定義常量所致,這里可以暫時(shí)忽略。

3) 簡(jiǎn)單判斷一個(gè)數(shù)是否為0

最后我們?cè)僮鰝€(gè)簡(jiǎn)單的模擬,用到我們前面模擬的數(shù)字以及布爾兩種類型來(lái)定義一個(gè)方法,判斷傳入的參數(shù)是否為0(是否我們定義的ZERO), 并返回一個(gè)布爾類型(TRUE或者FALSE)的模擬結(jié)果。算法很簡(jiǎn)單

def zero?(n)
 if n == 0
 true
 else
 false
 end
end

那如何用Lambda表示?我們前面都講過(guò)了,ZERO這個(gè)函數(shù)會(huì)接收兩個(gè)參數(shù): 第一個(gè)參數(shù)是函數(shù),第二個(gè)為基礎(chǔ)值,如果傳入的是ZERO函數(shù)的話,我們調(diào)用ZERO的時(shí)候,不管傳入第一個(gè)參數(shù)是什么,調(diào)用結(jié)果都會(huì)直接返回第二個(gè)參數(shù)(也就是基礎(chǔ)值)。

那我們回過(guò)頭來(lái)想如果把TRUE作為它第二個(gè)參數(shù),把一個(gè)返回FALSE的函數(shù)作為第一個(gè)參數(shù),那當(dāng)我們新函數(shù)接收的是ZERO函數(shù)并且調(diào)用它的時(shí)候不就會(huì)直接返回TRUE了嗎?而其他的方法,如ONE, TWO就會(huì)執(zhí)行-> (x) { FALSE }這個(gè)過(guò)程。

可以把代碼寫成

require "./number"
require "./boolean"

IS_ZERO = -> (proc) {
 proc[-> (x) {FALSE}][TRUE]
}

if __FILE__ == $0
 p to_boolean(IS_ZERO[ZERO])
 p to_boolean(IS_ZERO[ONE])
 p to_boolean(IS_ZERO[TWO])
end

運(yùn)行結(jié)果是

1
0
0

只有第一個(gè)ZERO是我們期望的值,最后返回了1(就是true)。其他的都不是我們需要的代表數(shù)值0的Lambda表達(dá)式。

3. 尾聲

這篇文章有點(diǎn)長(zhǎng),主要介紹了Ruby里面的Proc類,以及對(duì)函數(shù)柯里化和Lambda表達(dá)式做了最基本的講解。最后舉了一些例子,用Lambda表達(dá)式來(lái)模擬數(shù)字和布爾類型,另外使用我們模擬出來(lái)的類型作為基礎(chǔ)來(lái)定義一個(gè)實(shí)用的方法IS_ZERO。

本文沒有涉及太多高深的東西,因?yàn)橛泻芏喔呱畹臇|西我還吸收不了,當(dāng)吸收了之后會(huì)繼續(xù)發(fā)文講述。很感謝您的閱讀。以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,如果有疑問大家可以留言交流,謝謝大家對(duì)腳本之家的支持。

您可能感興趣的文章:
  • Ruby中使用Block、Proc、lambda實(shí)現(xiàn)閉包

標(biāo)簽:六安 石嘴山 宜春 鄂州 松原 自貢 河北 淄博

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《如何利用Ruby簡(jiǎn)單模擬Lambda演算詳解》,本文關(guān)鍵詞  如何,利用,Ruby,簡(jiǎn)單,模擬,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《如何利用Ruby簡(jiǎn)單模擬Lambda演算詳解》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于如何利用Ruby簡(jiǎn)單模擬Lambda演算詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    欧美午夜精品免费| 亚洲欧洲国产日韩| 黄一区二区三区| 亚洲无线码一区二区三区| 精品国精品自拍自在线| 精品国产污污免费网站入口 | 国产欧美一区二区精品秋霞影院| 色美美综合视频| 91高清视频在线| 88在线观看91蜜桃国自产| 欧美丰满一区二区免费视频| 91麻豆精品国产自产在线观看一区| 欧美日韩国产高清一区二区三区| 欧美一卡2卡3卡4卡| 日韩精品在线一区| 中文字幕在线一区免费| 亚洲在线视频网站| 极品少妇xxxx精品少妇| 国产suv一区二区三区88区| 99国产精品久| 久久久午夜精品理论片中文字幕| 国产精品婷婷午夜在线观看| 亚洲综合男人的天堂| 日本视频在线一区| 成人免费高清在线观看| 日韩免费观看2025年上映的电影| 中文字幕精品在线不卡| 视频一区在线播放| 欧美亚洲日本国产| 国产精品视频在线看| 免费在线观看日韩欧美| 91久久精品一区二区| 日本一二三四高清不卡| 国产一区欧美二区| 久久影院午夜片一区| 蜜桃久久久久久| 欧美日韩国产精品成人| 欧美一三区三区四区免费在线看| 五月天激情综合网| 欧美日韩中文精品| 日本在线不卡一区| 欧美xxxxxxxx| 粉嫩aⅴ一区二区三区四区五区 | 色老综合老女人久久久| 欧美一区二区三区四区久久| 亚洲一区二区四区蜜桃| 欧美日韩国产天堂| 午夜欧美视频在线观看| 欧洲另类一二三四区| 亚洲777理论| 久久久一区二区三区捆绑**| 国产精品一区三区| 国产精品午夜电影| 欧美唯美清纯偷拍| 蜜桃av噜噜一区二区三区小说| 欧美大白屁股肥臀xxxxxx| 国产91露脸合集magnet| 亚洲品质自拍视频| 欧美一级一区二区| 国产精品亚洲综合一区在线观看| 欧美韩日一区二区三区| 欧美人成免费网站| 成人教育av在线| 午夜欧美大尺度福利影院在线看| 26uuu色噜噜精品一区| 成人黄色大片在线观看| 日本成人在线看| 亚洲一区二区视频| 国产精品视频你懂的| 久久亚洲一级片| 91精品欧美一区二区三区综合在 | 日韩欧美一区中文| 日本大胆欧美人术艺术动态| 亚洲日本在线视频观看| 26uuu精品一区二区| 欧美电影一区二区| 欧美在线观看你懂的| 99久免费精品视频在线观看 | 在线播放一区二区三区| 国产麻豆9l精品三级站| 亚洲一区二区在线观看视频| 国产亚洲1区2区3区| 欧美群妇大交群的观看方式| 国产在线国偷精品免费看| 一区二区三区产品免费精品久久75| 久久久久国色av免费看影院| 久久一留热品黄| 国产精品第五页| 亚洲人成网站在线| 偷拍日韩校园综合在线| 男女视频一区二区| 韩国女主播成人在线| 国产高清成人在线| 色综合久久中文综合久久97| 欧美日韩一区二区三区在线看 | 欧美一级高清大全免费观看| 91超碰这里只有精品国产| 精品少妇一区二区三区日产乱码| 久久精品亚洲麻豆av一区二区 | 另类成人小视频在线| 国产suv精品一区二区6| 欧美综合一区二区| 日韩午夜三级在线| 国产精品久久久久7777按摩 | 色综合亚洲欧洲| 国产成人av电影在线播放| 欧美国产97人人爽人人喊| 污片在线观看一区二区| 99vv1com这只有精品| 久久蜜桃av一区精品变态类天堂 | 国产精品灌醉下药二区| 婷婷久久综合九色综合伊人色| 成人在线视频一区| 欧美一区二区国产| 午夜久久电影网| 欧美亚洲一区三区| 亚洲一区免费在线观看| 91玉足脚交白嫩脚丫在线播放| 精品少妇一区二区三区视频免付费 | 精品精品国产高清一毛片一天堂| 亚洲色图自拍偷拍美腿丝袜制服诱惑麻豆| 天天影视网天天综合色在线播放| 91在线播放网址| 椎名由奈av一区二区三区| 国产精品一线二线三线| 国产精品免费人成网站| 亚洲最新在线观看| 欧美午夜电影在线播放| 亚洲成人免费视频| 5858s免费视频成人| 日本一区中文字幕| 26uuu国产在线精品一区二区| 免费观看久久久4p| 国产亚洲欧美日韩俺去了| 国产精品1024| 亚洲一区二区三区四区不卡| 欧美一区二区三区系列电影| 国内一区二区在线| 最新热久久免费视频| 欧美午夜精品久久久| 日韩专区一卡二卡| 日韩和欧美的一区| 日韩一区二区三区高清免费看看| 美国十次综合导航| 亚洲欧洲日韩一区二区三区| 欧洲一区二区三区在线| 国产精品资源网| 亚洲成av人片| 国产精品每日更新| 精品国产乱码久久久久久影片| av一区二区久久| 韩日av一区二区| 亚洲第一二三四区| 国产三级精品在线| 精品国产青草久久久久福利| 欧美怡红院视频| 在线观看欧美精品| 处破女av一区二区| 国产乱对白刺激视频不卡| 日本在线播放一区二区三区| 亚洲一区在线观看免费| 中文字幕亚洲一区二区av在线| 日韩精品一区二区三区在线播放 | 欧美一区欧美二区| 欧美人与性动xxxx| 欧美日韩一级二级| 欧美日韩精品一区二区三区四区 | 国产福利一区二区三区视频在线| 蜜桃一区二区三区在线| 久久成人麻豆午夜电影| 久久99精品国产麻豆不卡| 国产精品亚洲一区二区三区妖精 | 一区二区三区成人| 偷偷要91色婷婷| 国产精品一区二区你懂的| 一本大道综合伊人精品热热| 色哟哟日韩精品| 日韩一区二区三区四区| 久久久综合激的五月天| 亚洲精品你懂的| 另类小说图片综合网| 91热门视频在线观看| 国内精品久久久久影院色| 国产精品美女久久久久aⅴ| 亚洲精品国产第一综合99久久| 婷婷一区二区三区| 成人精品视频一区二区三区| 欧美在线你懂得| 欧美激情自拍偷拍| 亚洲综合免费观看高清完整版在线| 美腿丝袜亚洲一区| 欧美性极品少妇| 国产日韩欧美亚洲| 久久成人久久爱| 3d成人h动漫网站入口| 中文字幕在线观看不卡视频| 国产一区二区福利| 亚洲chinese男男1069| 91香蕉视频污| 一区免费观看视频|