2008-10-16
配列の型推論ができた
|YARV2LLVM::compile(<<-EOS def arr1() a = [] a[0] + 1 a end def arr2() a = [] a[0] + 1.0 a end EOS )
arr1 :() -> Array of Int32Ty arr2 :() -> Array of FloatTy
a[0] + 1でnilと1を足しているじゃないかと突っ込まれると思いますが、こればっかりは動的に型チェックしないといかんかなと思います。今はまだ型チェックが組み込んでないのでこんなコードがコンパイラを通ってしまいます。さらに、まだ配列の書き込み([]=メソッド)ができてないです。
配列ライブラリはRubyのものを使うので、結果はVALUE型で返って来ます。その後、ここの変数の型に変換するのでここで型チェックができるかなと思います。配列を参照するたびに型変換が入るので効率が悪いです。でも、型変換をなくすようにするとRubyの配列ライブラリ相当のものを作り直さないといけないので(GCも含めて)めちゃめちゃつらいです。
あと、静的に配列の大きさが決められるならエスケープ解析して、配列をメソッドの外に持ち出してないならallocaでスタック上に取ることができて、簡単・速度すごく向上 なんですが、静的に配列の大きさを決めるにはどうしようって悩んでいます。ここまで来たら配列のサイズの宣言を入れるってのも嫌だなーと思うし。
コメントを書く
トラックバック - http://d.hatena.ne.jp/miura1729/20081016/1224162065
リンク元
- 5 http://llvmruby.org/wordpress-llvmruby/
- 1 http://209.85.175.104/search?q=cache:i9N9MBgY7HoJ:k.hatena.ne.jp/keywordblog/アクセス?date=20080923+wp-dokuwiki+アタック&hl=ja&ct=clnk&cd=2&gl=jp&lr=lang_ja&client=firefox-a
- 1 http://counter.hatena.ne.jp/takihiro/log?cid=1&date=&type=
- 1 http://d.hatena.ne.jp/ha-tan/20080108/1199725414
- 1 http://d.hatena.ne.jp/hzkr/20070323
- 1 http://github.com/miura1729/yarv2llvm/tree/master
- 1 http://www.google.co.jp/search?as_q=ruby+1.9+バイトコード&hl=ja&num=100&btnG=Google 検索&as_epq=&as_oq=&as_eq=&lr=&cr=&as_ft=i&as_filetype=&as_qdr=all&as_occt=any&as_dt=i&as_sitesearch=&as_rights=
- 1 http://www.google.co.jp/search?num=50&hl=ja&q=ypsilon scheme&ie=UTF-8&oe=UTF-8
- 1 http://www.google.co.jp/search?q=+Fixnum+30bit ruby&lr=lang_ja&ie=utf-8&oe=utf-8&aq=t&rls=org.mozilla:ja:official&client=firefox-a
- 1 http://www.google.co.jp/search?q=RFC+1213&lr=lang_ja&ie=utf-8&oe=utf-8&aq=t&rls=org.mozilla:ja:official&client=firefox-a