[表示 : 全て 最新50 1-99 101- 201- 301- 401- 501- 601- 701- 801- 901- 1001- 2chのread.cgiへ]
Update time : 05/09 20:08 / Filesize : 254 KB / Number-of Response : 1002
[このスレッドの書き込みを削除する]
[+板 最近立ったスレ&熱いスレ一覧 : +板 最近立ったスレ/記者別一覧] [類似スレッド一覧]


↑キャッシュ検索、類似スレ動作を修正しました、ご迷惑をお掛けしました

Lisp Scheme Part26



1 名前:デフォルトの名無しさん mailto:sage [2009/04/24(金) 19:12:39 ]
※ ここはCommon Lisp、SchemeをはじめとするLisp族全般のスレです ※

■過去スレ
 Part25: ttp://pc12.2ch.net/test/read.cgi/tech/1231856193/
 Part24: ttp://pc11.2ch.net/test/read.cgi/tech/1224939205/
 Part23: ttp://pc11.2ch.net/test/read.cgi/tech/1215875388/
 Part22: ttp://pc11.2ch.net/test/read.cgi/tech/1211381920/
 Part21: ttp://pc11.2ch.net/test/read.cgi/tech/1207300697/
 Part20: ttp://pc11.2ch.net/test/read.cgi/tech/1205021786/
 Part19: ttp://pc11.2ch.net/test/read.cgi/tech/1200237296/
 Part18: ttp://pc11.2ch.net/test/read.cgi/tech/1186922295/
 Part17: ttp://pc11.2ch.net/test/read.cgi/tech/1177065699/
 Part16: ttp://pc11.2ch.net/test/read.cgi/tech/1172404795/
 Part15: ttp://pc11.2ch.net/test/read.cgi/tech/1151025773/
 Part14: ttp://pc11.2ch.net/test/read.cgi/tech/1132275726/
 Part13: ttp://pc11.2ch.net/test/read.cgi/tech/1115901841/
 Part12: ttp://pc11.2ch.net/test/read.cgi/tech/1100229366/
 Part11: ttp://pc11.2ch.net/test/read.cgi/tech/1091456033/
 Part10: ttp://pc11.2ch.net/test/read.cgi/tech/1075630259/
 Part09: ttp://pc11.2ch.net/test/read.cgi/tech/1069594582/
 Part08: ttp://pc5.2ch.net/tech/kako/1058/10582/1058263391.html
 Part07: ttp://pc5.2ch.net/tech/kako/1042/10421/1042167213.html
 Part06: ttp://pc3.2ch.net/tech/kako/1031/10315/1031560687.html
 Part05: ttp://pc3.2ch.net/tech/kako/1023/10230/1023091882.html
 Part04: ttp://pc.2ch.net/tech/kako/1016/10162/1016211619.html
 Part03: ttp://pc.2ch.net/tech/kako/1008/10082/1008220265.html
 Part02: ttp://pc.2ch.net/tech/kako/1002/10025/1002584344.html
 Part01: ttp://piza2.2ch.net/tech/kako/987/987169286.html

■テンプレート置き場
 ttp://wiki.fdiary.net/lisp/ (id:guest pass:cl)

620 名前:デフォルトの名無しさん mailto:sage [2009/06/29(月) 01:16:01 ]
>>618
Cygwin でなくてよかったんかい?
Mingw でビルドした Gauche はいくつかの機能が使えないよ。
重大なのはプロセスとスレッド関連くらいだけど。

621 名前:デフォルトの名無しさん mailto:sage [2009/06/30(火) 14:53:46 ]
問題ない
窓使いでcygwin版を使いたがる人は少ないはず

622 名前:デフォルトの名無しさん mailto:sage [2009/07/01(水) 14:37:48 ]
schemeをさらにシンプルにしようと思って
こんなのを考えてみたんだけどどう思う?
consセルだけのほうが
()について非対称なリストよりもシンプル

;consセル版fold
(define (cfold f a b)
(cond ((not (pair? b)) (f a b))
(else (cfold f (f a (car b)) (cdr b)))))
(define (cfold1 f lst) (cfold f (car lst) (cdr lst)))

;reverseがリストよりもシンプルで効率的に(appendなしで)書ける
(cfold1 (lambda (x y) (cons y x)) '(1 2 . 3))

;このままだと、「空」が表現できないので
;consを仮にこんな風に定義してみる

;()なら無視するcons
(define (conss x y)
(cond ((null? x) y)
((null? y) x) ;片側だけのほうがよいか?
(else (cons x y))))

;末尾に()がないと思っても良い
(cfold (lambda (x y) (conss y x)) () '(1 2 . 3)) ;←これを言語レベルで'(1 2 3)と表記
(cfold (lambda (x y) (conss y x)) () '(1 2 3))

623 名前:デフォルトの名無しさん mailto:sage [2009/07/01(水) 14:41:18 ]
「リストを末尾の要素に持つリスト」はどう表現するの、それ。

624 名前:デフォルトの名無しさん mailto:sage [2009/07/01(水) 14:49:58 ]
普通に'(1 2 (1 2))という感じです
(cfold (lambda (x y) (conss y x)) () '(1 2 (1 . 2)))
(cfold (lambda (x y) (conss y x)) () '(1 2 (1 2)))

ただ、空リストからなるリストは表現できないので
これは不備だなぁ
conssを片側だけにしてもreverseは動かないし

625 名前:デフォルトの名無しさん mailto:sage [2009/07/01(水) 15:01:49 ]
ああ、言ってる意味がわかった
(cdr '((1 2)))が()だから今動いてるけど
そうじゃなかったら動かないですね
そういう意味ではリストの末尾は必ずatomじゃないとダメになるから
これじゃダメだ

626 名前:デフォルトの名無しさん mailto:sage [2009/07/01(水) 21:12:08 ]
ボクの考えた最強のLISP(Scheme)!
ってネタは尽きないよな
気持ちは判るが、妄想垂れ流す前に一度それで組んでみろよ
>>622みたいなのはすぐ作って確認できるだろ
どう思う?って、俺はまたキチガイかと思ったよ

627 名前:デフォルトの名無しさん mailto:sage [2009/07/01(水) 21:46:01 ]
>>626
作らない奴はクソだ,と思っているんだろうけど,
設計は設計で,そっちも大事だと思うぞ。
全部作ってみろで返すのはひどい。

628 名前:デフォルトの名無しさん mailto:sage [2009/07/01(水) 21:57:45 ]
そういうネタだらけでスレが埋まってしまうのは困るけど
閑散としている時のネタとしてはアリじゃないかな



629 名前:デフォルトの名無しさん mailto:sage [2009/07/02(木) 00:05:48 ]
S式を2分木として見ればどうやっても歪に見える

ドットペアを含むリスト(1 2 . 3)は
 /\
1  /\
  2   3

リスト(1 2 3)は
 /\
1  /\
  2  /\
    3   nil

主観ではcdrがconsかnilに統一されてる後者の方がシンプルだと思う
前者はcdrがatomという可能性をいつも意識するからハゲそう


630 名前:デフォルトの名無しさん mailto:sage [2009/07/02(木) 02:24:46 ]
竹内先生の入門本が増補改訂版で出るらしいんだが、
Schemeなのかな。CLなのかな。

631 名前:デフォルトの名無しさん mailto:sage [2009/07/02(木) 09:28:58 ]
ICFPのプログラミングコンテスト、Steele兄貴の招待講演が
Organizing Functional Code for Parallel Execution: or, foldl and foldr Considered Slightly Harmful
ってなってるが、foldは悪なのだろうか
内容が気になるな

632 名前:デフォルトの名無しさん mailto:sage [2009/07/02(木) 09:51:32 ]
foldじゃなくてl or rだよ。
シーケンシャルなのを問題にしてるんでしょ。

>>630
これかな?
www.amazon.co.jp/初めての人のためのLISP-ソフトウェアライブラリ-3-竹内-郁雄/dp/4781904548
特定の言語を対象としている本じゃないよ。このスレのように。
トピックスが増えるんじゃないのかな。

633 名前:デフォルトの名無しさん mailto:sage [2009/07/02(木) 10:04:34 ]
演算がmonoidalならfoldも並列化できる

(x + y) + z = x + (y + z) { associative }
x + e = e + x { unit }

x + (y + (z + e)) = (x + y) + (z + e)
(((e + x) + y ) + w) = (e + x) + (y + w)
ちなみにこれはfoldlからfoldrへの相互書き換えが可能になる条件でもある

多分この辺がslightlyに留まる理由で、
結論としてmonad最高!!ってな流れになったりならなかったりという予想

634 名前:デフォルトの名無しさん mailto:sage [2009/07/02(木) 10:26:36 ]
>>632
HMVはお取り寄せ可能になってる。
www.hmv.co.jp/product/detail/3608319
発行年月 : 2009年06月
出版社 : 翔泳社

seshop.com/には載ってないが


635 名前:デフォルトの名無しさん mailto:sage [2009/07/02(木) 12:14:49 ]
予約受付中?
www.bk1.jp/product/03125439

636 名前:デフォルトの名無しさん mailto:sage [2009/07/02(木) 16:08:20 ]
>>633
wじゃなくてz使ってよ、気色悪いw

637 名前:デフォルトの名無しさん mailto:sage [2009/07/02(木) 18:41:29 ]
うはxxxxxxxxxおkxxxxxxxxxxxxxxxx

638 名前:デフォルトの名無しさん mailto:sage [2009/07/02(木) 18:59:01 ]
>>634
書店の人が出版社に確認してくれた。当初予定より遅れて
平成21年12月2日だそうだ。楽しみだね。



639 名前:デフォルトの名無しさん mailto:sage [2009/07/02(木) 23:15:22 ]
>>638
\(^o^)/

640 名前:デフォルトの名無しさん mailto:sage [2009/07/03(金) 00:05:29 ]
入門Gaucheで勉強してるけどp64から急に難しくなってきたぜでもがんばるぜ

641 名前:デフォルトの名無しさん mailto:sage [2009/07/03(金) 00:07:24 ]
LittleSchemer読もうぜ

642 名前:デフォルトの名無しさん mailto:sage [2009/07/03(金) 00:21:15 ]
>>641
ありがとうだぜさっそくポチるぜ。

643 名前:デフォルトの名無しさん mailto:sage [2009/07/03(金) 02:43:14 ]
竹内センセの本が出るのか。それは全力で買いだ。

644 名前:デフォルトの名無しさん mailto:sage [2009/07/03(金) 04:18:45 ]
一冊あれば十分だけどなw

645 名前:デフォルトの名無しさん mailto:sage [2009/07/03(金) 04:55:07 ]
増補で付録とか付くんかな?
竹内先生の本は持ってるけど、記念で買おう。

646 名前:デフォルトの名無しさん mailto:sage [2009/07/03(金) 05:50:44 ]
lisp本、wktkしてきたぜ。

647 名前:デフォルトの名無しさん mailto:sage [2009/07/03(金) 06:20:20 ]
初めての人向けじゃなくって
もっと突っ込んだの書いて欲しいな


648 名前:デフォルトの名無しさん mailto:sage [2009/07/03(金) 06:34:49 ]
竹内先生監修シリーズって感じで、5人ぐらいに書かせればいいんじゃねえ?



649 名前:デフォルトの名無しさん mailto:sage [2009/07/03(金) 09:42:11 ]
Lispじゃないけどそういう感じの本あったよね。
意外と面白くなかったw
それより雑誌bitのTAOの連載を合本したら面白いのに。


650 名前:デフォルトの名無しさん mailto:sage [2009/07/03(金) 10:45:35 ]
今思えば、ビューティフルコードは初心者に媚びない所だけはよかった
日本であれぐらい書ければ、もっちーがファビョることもなかっただろうに

651 名前:デフォルトの名無しさん mailto:sage [2009/07/03(金) 18:26:23 ]
>>647
あの本は初心者向けの本じゃないよ。
Lispマニア向けの本だ。初心者が読んでもそれなりに楽しめるけど。

652 名前:デフォルトの名無しさん mailto:sage [2009/07/03(金) 18:29:18 ]
LISPの本と思わずに、T先生と生徒のかけあいを楽しめばいいんだ。

653 名前:デフォルトの名無しさん mailto:sage [2009/07/03(金) 20:12:01 ]
初心者向けと書かれるとおれそんなんじゃないし読むことないや
と結局買っても積んだままにしてしまう
お決まりの言語のおさらいを数章割かれてるのを見ると頭に来るからだ
いっそのこと超上級者向けのが興味をそそられる

654 名前:デフォルトの名無しさん mailto:sage [2009/07/03(金) 20:24:17 ]
>>653
SICP も初心者向だよwW


655 名前:デフォルトの名無しさん mailto:sage [2009/07/03(金) 21:51:02 ]
だから1章で飽きて放り投げちゃったんだよ。

656 名前:デフォルトの名無しさん mailto:sage [2009/07/03(金) 22:05:20 ]
目次みて1章はつまんなそうだと思ったら3章あたりから読み始めればよかったのに。

657 名前:デフォルトの名無しさん mailto:sage [2009/07/04(土) 00:37:31 ]
良い本は、
例え初心者向けと銘打たれていても、
光る記述で満ち溢れており、
熟練者でも楽しめるものなのだ。
だからグルの書いた本は面白いのだ。

658 名前:デフォルトの名無しさん mailto:sage [2009/07/04(土) 01:45:12 ]
苫米地先生の事ですね。わかります。



659 名前:デフォルトの名無しさん mailto:sage [2009/07/04(土) 01:54:17 ]
>>658
ビビッタ。
実は、最近なぜか洗脳について勉強していたりする。関係あるの?

660 名前:デフォルトの名無しさん mailto:sage [2009/07/04(土) 02:01:58 ]
Lisperじゃん。

661 名前:デフォルトの名無しさん [2009/07/04(土) 02:02:46 ]
とまちゃんだけはガチ

662 名前:デフォルトの名無しさん mailto:sage [2009/07/04(土) 02:04:31 ]
sage忘れたすまぬ

663 名前:デフォルトの名無しさん mailto:sage [2009/07/04(土) 03:21:58 ]
竹内本は目次の時点で駄目だな

664 名前:デフォルトの名無しさん mailto:sage [2009/07/04(土) 03:34:00 ]
無縁の衆生ですな。

665 名前:デフォルトの名無しさん mailto:sage [2009/07/04(土) 05:49:37 ]
>>655
もったいないお化けが出るぞ

666 名前:デフォルトの名無しさん mailto:sage [2009/07/04(土) 19:46:29 ]
The Little Schemer買ったお。たくさん勉強するお。

667 名前:デフォルトの名無しさん mailto:sage [2009/07/05(日) 10:42:05 ]
shibuya.lispどうだった、行った人?

668 名前:デフォルトの名無しさん mailto:sage [2009/07/05(日) 12:41:05 ]
>>667
面白かったよ。#4あるならLTしようと思ったくらいには(TTはなんいどたかい)。



669 名前:デフォルトの名無しさん mailto:sage [2009/07/05(日) 12:47:18 ]
すみません、以下のプログラム想定外なことだらけなのですが
以下のs1で、値が変更出来るようなプログラムは書けますか?
schemeは値渡しなので無理なような気もしますが
また、test関数では内部でtをset!しているにもかかわらず
その変更は影響がないように見えますが何故なのでしょうか

(define (s1 t v) (set! t v))
(define (sa t v) (set-car! t v))
(define (sd t v) (set-cdr! t v))
(define (sa2 t v) (let ((r (cdr t))) (set-car! r v)))

(define (test f)
(define t '(()()))
(let ((r (f t 1)))
(print t)
(set! t '(()()))
r))

(test s1)
(test sa)
(test s1) ;why?
(test sd)
(test sa2)
;(map test (list s1 sa sd sa2))

670 名前:デフォルトの名無しさん mailto:sage [2009/07/05(日) 13:11:03 ]
引数のバインディング変えても外からは見えないだろ。

int f(int x) {
x = 10;
}
やってるのはこれと同じ

671 名前:デフォルトの名無しさん mailto:sage [2009/07/05(日) 13:17:32 ]
>>669
set! は変数とオブジェクトの結び付き (束縛) を付け替えるオペレータ。
set-car! や set-cdr! はオブジェクト (consセル) の中身を変更するオペレータ。
ってことを念頭に置いて考えるとわかりやすいかも。
あまりに根本的すぎることなのでそこを理解できてないようだとちょっと説明しづらい。

672 名前:デフォルトの名無しさん mailto:sage [2009/07/05(日) 13:26:06 ]
> また、test関数では内部でtをset!しているにもかかわらず
> その変更は影響がないように見えますが何故なのでしょうか

処理系がわからんから何とも言えんが、
おそらくその処理系は、クォートされたリストをすべての関数呼び出しで共有するように作られているんだと思う。

test 内の (define t '(()())) のところでは、
すべての関数呼び出しで共有される '(()()) というリストを t に束縛する、みたいな処理が行われる。
そこで、(test sa) を実行してしまうと、そのリストが '(1 ()) に書き換えられてしまう。
そのため、次回以降の test の呼び出しでは、'(1 ()) というリストが t に束縛されてしまう。

そもそも scheme では、クォートされたリストに set-car!、set-cdr! しちゃいけないことになってるので、
こんな処理をすること自体が間違い。
やるんだったら、毎回リストを生成するようにする。

(define t (list '() '())

673 名前:デフォルトの名無しさん mailto:sage [2009/07/05(日) 13:55:51 ]
問題をきちんと理解してから解答を考えよう
って約束したじゃないですかー

674 名前:デフォルトの名無しさん mailto:sage [2009/07/05(日) 14:02:00 ]
>>672
> 処理系がわからんから何とも言えんが、

むしろ何も言うな

675 名前:デフォルトの名無しさん mailto:sage [2009/07/05(日) 14:29:33 ]
おまえがな。

676 名前:デフォルトの名無しさん mailto:sage [2009/07/05(日) 15:05:14 ]
shibuya.lispの参加者、もっと感想・ネタを書いてくれ。
悪口・不満的な話は、直接、主催者にメールでもしてくれ。

677 名前:デフォルトの名無しさん mailto:sage [2009/07/05(日) 15:24:01 ]
いずれ上がるだろう動画を楽しみに待つ

678 名前:デフォルトの名無しさん [2009/07/05(日) 15:48:43 ]
www.nicovideo.jp/mylist/13373941



679 名前:デフォルトの名無しさん mailto:sage [2009/07/05(日) 15:53:09 ]
ニコに挙げたのか
つべで探してたわ

680 名前:デフォルトの名無しさん mailto:sage [2009/07/05(日) 15:53:51 ]
感謝。既に上がってるのは想定外だった

681 名前:デフォルトの名無しさん [2009/07/05(日) 15:54:39 ]
つべはこっち。
www.youtube.com/view_play_list?p=C7D5490AD455E464


682 名前:デフォルトの名無しさん mailto:sage [2009/07/05(日) 17:24:59 ]
>>670-672
ありがとうございます

>>671
関数の引数はjavaのように、
実体を指すポインタのコピーが渡ると考えれば良いですよね
set!だとコピーしたポインタ自体を変更しても元データには全く影響がないが
set-car!だと、コピーしたポインタの指す先を変更するので
引数にset-car!しても破壊的変更が可能

だとすれば、参照渡しで実現出来る
関数の実引数の実体を直接書き換えるような
関数の作成は不可能ですね

>>672
>そもそも scheme では、クォートされたリストに set-car!、set-cdr! しちゃいけない
これは初めて知りました。これが原因ですね
コードはGaucheとGuileで試したのですが
どちらもクォートされたリストは共有されるような実装ってことですね

683 名前:デフォルトの名無しさん mailto:sage [2009/07/05(日) 18:31:28 ]
>>682
> クォートされたリストは共有されるような実装ってことですね

確か Gauche の場合は REPL が起動してるときは共有されないはず。
だからといってそれを期待しちゃだめなんだけど。

Gauche のマニュアルから引用 ↓

注: R5RSは、リテラル式の値を変更するのはエラーであるとしています。
しかしGaucheはペアとベクタについてはそれが定数であるかどうかをチェックしておらず、
set-car!やvector-set!等の破壊的手続きによってそれらの値を変更してもエラーは報告されません。
そうした場合の動作は不定です。

684 名前:デフォルトの名無しさん mailto:sage [2009/07/05(日) 18:45:19 ]
参照渡しって何か
ダイナミックスコープっぽいような気がするけど
この二つは何か関係あるのかな?

685 名前:デフォルトの名無しさん mailto:sage [2009/07/05(日) 18:48:13 ]
>>684
関係ない。

686 名前:デフォルトの名無しさん mailto:sage [2009/07/05(日) 18:49:34 ]
全く関係ない。
参照渡しは仮引数/実引数バインディングスタイルの一つ
ダイナミックスコープは自由変数のルックアップスタイルの一つ

687 名前:デフォルトの名無しさん mailto:sage [2009/07/05(日) 18:52:02 ]
そんなめんどうな話なのか?
局所変数と大域変数の話なのでは。
湯浅先生の「Scheme入門」だとP32〜。

688 名前:デフォルトの名無しさん mailto:sage [2009/07/05(日) 18:58:16 ]
koguro さんのトークは資料が見やすくていいなー



689 名前:デフォルトの名無しさん mailto:sage [2009/07/05(日) 19:13:16 ]
いちいちそんな糞本挙げなくていいよ

690 名前:デフォルトの名無しさん mailto:sage [2009/07/05(日) 19:19:18 ]
湯浅先生を糞呼ばわりできるお前って何様?

691 名前:デフォルトの名無しさん mailto:sage [2009/07/05(日) 19:23:28 ]
俺は>>689じゃないけど、その先生が立派な人で、その本が立派なものだったとしても時代にそぐわなくなることってあると思うんだよなー。
湯浅先生の名前があればもう否定しどころがないみたいな言い方じゃなくて、もっと良い点と悪い点を検討する必要はあるんじゃないの?
もちろん、糞本って言う方もどのへんが糞なのか示さないと議論にならんけど。

692 名前:デフォルトの名無しさん mailto:sage [2009/07/05(日) 19:49:36 ]
とりあえず糞って言っとこう的な煽りは2chの華だねw

693 名前:デフォルトの名無しさん mailto:sage [2009/07/05(日) 19:51:06 ]
たいした人でもないのに
いちいち先生つけるなよ

694 名前:デフォルトの名無しさん mailto:sage [2009/07/05(日) 19:52:53 ]
何の脈絡もなく
湯浅の糞本持ち出す687ってなんなんだろう?

695 名前:デフォルトの名無しさん mailto:sage [2009/07/05(日) 20:03:58 ]
名著はちゃんと読んだ方がいいと思うぞ。
おっと、ここは2chだったな。玉石混交ですな。

696 名前:デフォルトの名無しさん mailto:sage [2009/07/05(日) 20:13:11 ]
読む本は選べ
時間の無駄

697 名前:デフォルトの名無しさん mailto:sage [2009/07/05(日) 21:01:42 ]
嫉妬ってみっともないなとオモタ

698 名前:デフォルトの名無しさん mailto:sage [2009/07/05(日) 21:05:35 ]
糞本の宣伝に嫉妬とか



699 名前:デフォルトの名無しさん mailto:sage [2009/07/05(日) 21:06:09 ]
釣れますか

700 名前:デフォルトの名無しさん mailto:sage [2009/07/05(日) 21:18:47 ]
>>690
生暖かく見守っといてやれって。

701 名前:デフォルトの名無しさん mailto:sage [2009/07/05(日) 21:24:08 ]
湯浅の本なんて有り難がってよんでんのか

702 名前:デフォルトの名無しさん mailto:sage [2009/07/05(日) 22:23:54 ]
ところでここLispスレ

703 名前:デフォルトの名無しさん mailto:sage [2009/07/05(日) 23:57:54 ]
うっかりSICP

704 名前:デフォルトの名無しさん mailto:sage [2009/07/06(月) 05:04:12 ]
>>677
そういうことじゃないだろ。
実際に参加したの感想が聞きたいんだが。

いいアイデアが浮かんだとか、もっと○○の分野を勉強しようと思ったとか、その他いろいろ。

705 名前:デフォルトの名無しさん mailto:sage [2009/07/06(月) 08:04:38 ]
マ板行けよ

706 名前:デフォルトの名無しさん mailto:sage [2009/07/06(月) 09:12:44 ]
Scheme入門はちょっと古すぎる気がしないでもないな
内容もCommonLisp入門とほぼ同じだし。
でも絶版とはいえ某所でpdfでくばってたから結構読んでる人は居るんじゃないかな

707 名前:デフォルトの名無しさん mailto:sage [2009/07/06(月) 12:32:27 ]
>>701
ありがたがってるかどうか別として、先人への敬意が無い連中って
人として問題ありってことだと思うよ。

708 名前:デフォルトの名無しさん mailto:sage [2009/07/06(月) 12:47:26 ]
世界初のCL実装



709 名前:デフォルトの名無しさん mailto:sage [2009/07/06(月) 12:48:13 ]
世界初のCL実装でしょ。
MITあたりの人達もびっくりしたという。

710 名前:デフォルトの名無しさん mailto:sage [2009/07/06(月) 12:52:02 ]
Little Schemerに出てくるYコンビネーターってどういう利点があるの?
難しくてめげそう。だれか教えれ。プリーズ

711 名前:デフォルトの名無しさん mailto:sage [2009/07/06(月) 12:56:15 ]
実用上たいして意味は無い
(define (fact n) (if (= n 1) 1 (* n (fact (- n 1))))
みたいなのを、factっていう名前を使わずに
無名関数のみで定義できるという意義がある

712 名前:デフォルトの名無しさん mailto:sage [2009/07/06(月) 12:57:21 ]
そうそう。KCLをわずか2人で開発した日本が世界に誇るLisperだぜ。
本の内容は今となっては古い部分もあるが基本的な考え方は変わらないだろ。

713 名前:デフォルトの名無しさん mailto:sage [2009/07/06(月) 13:01:27 ]
util.sparse が組込みになってないのは、
やっぱ普通のスクリプト言語的用途だと従来のハッシュテーブルの方が効率はいいってことでいいんだよね?

714 名前:デフォルトの名無しさん mailto:sage [2009/07/06(月) 13:08:15 ]
>>710
無名関数のみで定義できるという意義ってナーヌ?

715 名前:デフォルトの名無しさん mailto:sage [2009/07/06(月) 13:13:46 ]
λ計算には関数定義なんてない
無名関数だけで再帰の計算が出来ることがわかれば
λ計算だけで、色々な計算が出来ることが示せるわけ

716 名前:デフォルトの名無しさん mailto:sage [2009/07/06(月) 13:16:46 ]
スマヌ。
λ計算だけで、色々な計算が出来ることが示せると何が証明できるの?

717 名前:デフォルトの名無しさん mailto:sage [2009/07/06(月) 13:19:42 ]
ちょっとは自分で調べれ
チャーチ・チューリングとかでググってみそ

718 名前:デフォルトの名無しさん mailto:sage [2009/07/06(月) 13:26:54 ]
>>717
ググッた。
「チャーチ=チューリングのテーゼとは、「計算できる関数」という直観的な概念を、帰納的関数と呼ばれる数論的関数のクラスと同一視しようという主張である。
このクラスはチューリング・マシンで実行できるプログラムのクラス、ラムダ記法で定義できる関数のクラスとも一致する。
よって簡単にはテーゼは、計算が可能な関数とは、その計算を実行できるような有限のアルゴリズムが存在するような関数、
よっておおよそコンピュータで実行できる関数と同じだと主張する。」

つまり、「SchemeはYコンビネータがあれば計算可能な再帰関数を有限のステップで計算可能ですYO!」ってことでおk?



719 名前:デフォルトの名無しさん mailto:sage [2009/07/06(月) 13:31:18 ]
「あれば」じゃなくて「あるので」の方が正しいニホンゴかなw

720 名前:デフォルトの名無しさん mailto:sage [2009/07/06(月) 13:38:34 ]
schemeはYコンビネータを使わなくても計算可能な関数は計算出来る
普通の名前つきの再帰関数やletrecなどが実質Yコンビネータに相当






[ 続きを読む ] / [ 携帯版 ]

前100 次100 最新50 [ このスレをブックマーク! 携帯に送る ] 2chのread.cgiへ
[+板 最近立ったスレ&熱いスレ一覧 : +板 最近立ったスレ/記者別一覧]( ´∀`)<254KB

read.cgi ver5.27 [feat.BBS2 +1.6] / e.0.2 (02/09/03) / eucaly.net products.
担当:undef