1 名前:デフォルトの名無しさん mailto:sage [2009/06/15(月) 07:15:21 .net] 関数型言語MLについて語るスレッドです。 MLは、確固とした理論的背景を持つ言語でありながら、 現実的なソフトの開発にも使用できる実用性を備えた言語です。 また、プログラミングの初心者が最初に学習する言語としても優れています。 総本山 Standard ML www.smlnj.org/ Objective Caml caml.inria.fr/ocaml/ 前スレ 関数型言語ML(SML, OCaml, etc.), Part 5 pc12.2ch.net/test/read.cgi/tech/1186292994/
731 名前:されてんのかね? [] [ここ壊れてます]
732 名前:デフォルトの名無しさん [2013/10/05(土) 09:27:34.70 .net] 副作用にも色々表現方法があって迷うなぁ まぁOCamlはそれがいいんだろうけど
733 名前:デフォルトの名無しさん mailto:sage [2013/10/05(土) 14:18:01.03 .net] 文字列だけなら print_string とか print_endline とかでいいだろうけど、 数値とか含むのを出力するときはどうするのがスマートなんだろう? 俺はだいたい Printf.printf を使ってしまうのだけど。
734 名前:デフォルトの名無しさん mailto:sage [2013/10/05(土) 14:42:49.03 .net] >>721 間違ってる Windows は CR+LF すなわち現在行を消して先頭に戻してから改行するのだッ
735 名前:デフォルトの名無しさん mailto:sage [2013/10/05(土) 14:51:34.09 .net] > Linuxだと\nで改行、\rで現在の行を消して先頭からやり直し、 OSのアプリが, 慣習的に "\n" を論理改行文字として扱ってる(tty ドライバーも このように扱いやすく作ってある)だけで, 端末制御として使う CR だとか LF とは 分けて考えるべきだと思うよ. 実際に tty を raw モードに設定すると, CR - LF("\r\n") を "\n" にマップする 作業はアプリの仕事になる. 端末から見た, 各制御文字の役割は以下であってそれ以外の何者でもない CR: カーソルを行の先頭に戻す, LF: カーソルを次の行に移動する(カラムは移動しない)
736 名前:デフォルトの名無しさん [2013/10/05(土) 17:25:39.93 .net] ocamlのcryptokit使おうとしたら、エラーになるんだがなんでなんだぜ。 Fatal error: cannot load shared library dllcryptokit_stubs Reason: dllcryptokit_stubs.so: cannot open shared object file: No such file or directory
737 名前:デフォルトの名無しさん [2013/10/06(日) 08:19:42.15 .net] #ocaml #opam 自己解決したっす dllcryptokit_stubs.so はopamゆーざーなら以下の環境変数の設定が必要っぽい export CAML_LD_LIBRARY_PATH=~/.opam/system/lib/stublibs/
738 名前:デフォルトの名無しさん [2013/10/09(水) 00:18:05.42 .net] なんかopamも便利なんだか不便なんだかわからんな
739 名前:デフォルトの名無しさん [2013/10/10(木) 12:26:47.83 .net] フィボナッチ計算させるときに メモ化するのもアキュムレータ使うのも 同じ振る舞いな気がするんだが 何か違うのかな?
740 名前:デフォルトの名無しさん mailto:sage [2013/10/10(木) 13:44:52.77 .net] 複数回呼び出したら違うんじゃないの
741 名前:デフォルトの名無しさん [2013/10/10(木) 14:11:03.39 .net] それぞれの f(n)までの値をそれぞれ1回ずつ計算して テーブルに入れるかレコードに入れるかの違いだから 計算回数は同じじゃね?
742 名前:デフォルトの名無しさん mailto:sage [2013/10/10(木) 18:11:17.89 .net] fibを何回か呼ぶことを言ってるんじゃねぇの
743 名前:デフォルトの名無しさん [2013/10/10(木) 18:49:43.04 .net] 呼ぶ回数=計算回数じゃないの? どっちもO(n)っぽいんだけど
744 名前:デフォルトの名無しさん mailto:sage [2013/10/10(木) 19:24:41.41 .net] fib(n) = fib(n-1) + fib(n-2) fib(n-2)は呼ばれるが、計算済みだから新に計算はしないってことでしょ。
745 名前:デフォルトの名無しさん [2013/10/10(木) 21:27:14.82 .net] そういう二重再帰じゃない方のフィボナッチだよ
746 名前:デフォルトの名無しさん [2013/10/10(木) 21:50:36.16 .net] let fib x = let rec fib_sub (x, accumulator1, accumulator2) = if x = 0 then accumulator1 else fib_sub (x - 1, accumulator1 + accumulator2, accumulator1) in fib_sub (x, 1, 0) こういう感じでアキュムレータ使うようなフィボナッチ
747 名前:デフォルトの名無しさん mailto:sage [2013/10/10(木) 23:36:42.55 .net] 何が言いたいのかわからん 末尾再帰のアキュムレータだろうが、 fib nをm回呼び出す場合メモ化ならO(m+n)だろ
748 名前:デフォルトの名無しさん [2013/10/11(金) 01:37:05.82 .net] >>734 この 二重再帰の計算オーダーはそうじゃないだろ??
749 名前:デフォルトの名無しさん mailto:sage [2013/10/11(金) 02:57:20.14 .net] >>735 >>738 メモ化のコード書いてくれないとわからない。 あと計算オーダーはそうじゃないのそうって何?
750 名前:デフォルトの名無しさん mailto:sage [2013/10/11(金) 03:24:27.66 .net] >>738 >>734 の場合でも、f(n)はf(n-1), f(n-2)がメモ化されている場合常にO(1) メモ化していない場合(最初の一回目)は再帰計算だからO(n) これはわかるな? その後 再帰メモ化版のfib(n)は、 それまでn以上の値が呼び出されていたならO(1)であり、 fib nをm回呼び出すならO(m)、2つ合わせて O(m+n) アキュムレータだけの場合、fib(n)は "常に" O(n) つまりfib nをm回呼び出すならO(nm) わかったか?
751 名前:デフォルトの名無しさん mailto:sage [2013/10/11(金) 04:17:04.97 .net] HaMLet がまさかのニューバージョン。 www.mpi-sws.org/~rossberg/hamlet/
752 名前:デフォルトの名無しさん [2013/10/11(金) 10:20:41.62 .net] >>740 あー >>734 はメモ化の再帰バージョンの話ね 理解した とすると >>729 この違いは 使い捨てならアキュムバージョンは 簡潔に書けて早く 使いまわすならメモ化した方が 再呼び出しは早くていいって感じか
753 名前:デフォルトの名無しさん [2013/10/11(金) 19:30:47.32 .net] SMLも開発すすんでるんだな
754 名前:デフォルトの名無しさん mailto:sage [2013/10/14(月) 18:44:12.10 .net] www.pllab.riec.tohoku.ac.jp/smlsharp/docs/1.0/ja/Ch1.S1.xhtml SMLの開発って、もしかしてSML#のこと?
755 名前:デフォルトの名無しさん mailto:sage [2013/10/14(月) 18:45:23.58 .net] あ、上のhamletのことか。
756 名前:デフォルトの名無しさん [2013/10/14(月) 18:54:06.65 .net] SML#は64ビット対応せんのかな。結構期待してるんだけど。
757 名前:デフォルトの名無しさん [2013/10/15(火) 01:40:51.77 .net] SML/NJとかも
758 名前:デフォルトの名無しさん [2013/10/15(火) 01:52:43.43 .net] Standard SMLってなんだろ?
759 名前:デフォルトの名無しさん [2013/10/15(火) 15:17:19.69 .net] int型のmaxって1073741823ですよね これを超えたらBig_intに切り替えたいんですが int型の計算でmax_intを超えたかどうかの判定って どうやったらいいですか?
760 名前:デフォルトの名無しさん mailto:sage [2013/10/15(火) 17:14:51.41 .net] 無理じゃね 最初からBig_int使えばいいんじゃね
761 名前:デフォルトの名無しさん mailto:sage [2013/10/15(火) 18:42:26.56 .net] 大学の研究室のプロジェクトだと、パワーのある院生がいる時にどかっと 進んだりするんだよなぁ。
762 名前:デフォルトの名無しさん [2013/10/15(火) 22:18:09.71 .net] キャリーフラグを無視しない高級言語ってごくわずかしかないよね。
763 名前:デフォルトの名無しさん mailto:sage [2013/10/15(火) 23:25:06.01 .net] そもそも1bit分フラグに使ってるからキャリーフラグなんて役に立たんでしょ SML#はどうか知らんけど
764 名前:デフォルトの名無しさん mailto:sage [2013/10/16(水) 22:57:21.15 .net] C++ blog.regehr.org/archives/593 ocaml batteriesには、SafeIntというのがあるらしい。参考になるかもよ。 dutherenverseauborddelatable.wordpress.com/2008/08/27/whats-up-with-batteries/
765 名前:デフォルトの名無しさん [2013/10/18(金) 10:52:33.25 .net] オブジェクトがさっぱりわからん レコードと何が違うんだ・・・
766 名前:デフォルトの名無しさん [2013/10/18(金) 12:04:36.71 .net] Obj.magic使えば 型なんて関係無くなる?
767 名前:デフォルトの名無しさん [2013/10/18(金) 12:12:18.87 .net] [Obj.magic 'a'; Obj.magic "abc"; Obj.magic 123];; すげー リストに型が違っても入るぞ 何に使えるんだろ?
768 名前:デフォルトの名無しさん [2013/10/18(金) 12:52:31.16 .net] Obj.magic 'a' + 1 ;; すげー こんなのもできるんだwwww 関数型言語界のgotoやで
769 名前:デフォルトの名無しさん mailto:sage [2013/10/18(金) 14:08:58.82 .net] 奇跡も魔法もあるんだよ。
770 名前:デフォルトの名無しさん mailto:sage [2013/10/18(金) 18:35:29.49 .net] ただしよくわからんで使うと死ぬ
771 名前:デフォルトの名無しさん [2013/10/18(金) 18:46:15.03 .net] OCamlって最強の言語じゃね? なんでみんなやらないんだろ
772 名前:デフォルトの名無しさん mailto:sage [2013/10/18(金) 18:49:32.53 .net] 変なライセンスだから
773 名前:デフォルトの名無しさん mailto:sage [2013/10/18(金) 18:53:24.02 .net] intが1ビット少ないとか、モジュールの仕様上スマートリンクができないとか ファーストクラスモジュールでOCamlのOたるオブジェクトがゴミになりましたとか そのファーストクラスモジュールは後付けで構文がカオスですとか、あと+.(笑)とかGC遅いとか ケチを付けようと思ったらいくらでも付けられるからなあ
774 名前:デフォルトの名無しさん mailto:sage [2013/10/18(金) 19:13:13.78 .net] Windows版の更新サボってるのが一番の原因だな
775 名前:デフォルトの名無しさん mailto:sage [2013/10/18(金) 19:31:42.10 .net] みんなって誰だよ
776 名前:デフォルトの名無しさん mailto:sage [2013/10/18(金) 19:33:25.20 .net] 研究室ではよく使ってる
777 名前:デフォルトの名無しさん [2013/10/18(金) 20:02:22.74 .net] >>765 健常者の集合
778 名前:デフォルトの名無しさん mailto:sage [2013/10/18(金) 22:46:49.64 .net] 言語の素性はともかくマンパワーは全然足りてないしな
779 名前:デフォルトの名無しさん [2013/10/18(金) 23:43:15.36 .net] スマートリンクってなんぞ?
780 名前:デフォルトの名無しさん mailto:sage [2013/10/18(金) 23:50:11.98 .net] sageたら教えてやる
781 名前:sage [2013/10/18(金) 23:56:08.97 .net] 教えてください
782 名前:sega [2013/10/19(土) 19:03:49.62 .net] 俺にも教えて
783 名前:デフォルトの名無しさん mailto:sage [2013/10/19(土) 22:25:27.91 .net] じゃあおれも
784 名前:デフォルトの名無しさん [2013/10/28(月) 11:48:04.04 .net] 汎関数と高階関数って同じ意味ですか?
785 名前:デフォルトの名無しさん [2013/10/28(月) 13:22:54.90 .net] ちがいます
786 名前:デフォルトの名無しさん mailto:sage [2013/10/28(月) 13:38:38.58 .net] おなじです
787 名前:デフォルトの名無しさん [2013/10/28(月) 13:43:33.45 .net] どっちだよ・・・
788 名前:デフォルトの名無しさん mailto:sage [2013/10/28(月) 13:58:52.58 .net] >>774 関数を計算の対象とすること、いいかえると、関数を引数として受け付けたり 関数を返す関数のことを「高階の関数」または「高階関数」という さらに、高階関数の中で計算の対象が関数だけなものを「汎関数」という つまり高階関数は広い概念で、汎関数は狭い概念 たとえば関数 map や filter は高階関数であるけれど、リストも計算対象だから汎関数ではない それに対して、合成関数 o は高階関数であるし汎関数でもある
789 名前:デフォルトの名無しさん [2013/10/28(月) 14:26:11.39 .net] let foo f g x = g (f x) ;; val foo : ('a -> 'b) -> ('b -> 'c) -> 'a -> 'c = <fun> って合成関数があったとして 'aの引数は計算対象外になるの?
790 名前:デフォルトの名無しさん mailto:sage [2013/10/28(月) 15:17:35.72 .net] >>779 記法のせいでわかりにくいけど ('a -> 'b) -> ('b -> 'c) -> ('a -> 'c) って考えればいい
791 名前:デフォルトの名無しさん mailto:sage [2013/10/28(月) 15:25:02.71 .net] あと汎関数は量を返す物をいうはず。 だから合成関数は汎関数でなく、高階関数。
792 名前:デフォルトの名無しさん mailto:sage [2013/10/28(月) 15:27:39.31 .net] 間違えた 合成関数を"返す" 関数は汎関数でなく、高階関数。
793 名前:デフォルトの名無しさん mailto:sage [2013/10/28(月) 15:32:51.19 .net] >>779 まず 'a は型変数だから、「'a の引数は...」という用法は日本語として不適切 で、もし質問の意図が「関数 foo の定義における第三引数 x は、関数 foo の計算対象外か?」 であるならば、答えは Yes 引数 x は関数 f の計算対象であるけれど、汎関数 foo の計算対象ではない 汎関数を定義する場合、>>779 も決して間違いではないが、以下のように書いたほうが、 「x は(fooの引数ではなく)無名関数の引数である」という意図が理解しやすいだろう(言語はSML) - fun foo f g = fn x => g (f x); > val ('a, 'b, 'c) foo = fn : ('a -> 'b) -> ('b -> 'c) -> 'a -> 'c >>781 では、その量を返すという汎関数の具体例を挙げてみてくれないか?
794 名前:デフォルトの名無しさん [2013/10/28(月) 16:06:23.87 .net] 例えばmapをばらしたときに let rec map f ls = match ls with [] -> [] | x::xs -> f x :: map f xs ;; val : ('a -> 'b) -> 'a list -> 'b list = <fun> たぶんこんな感じで再帰になってるけど 無名関数は再帰で書けないから 無名関数で書けたら汎関数でよい?
795 名前:デフォルトの名無しさん mailto:sage [2013/10/28(月) 16:10:19.68 .net] >>783 >では、その量を返すという汎関数の具体例を挙げてみてくれないか? なんで? とりあえず、定義っぽいのは見つけたよ。 www.encyclopediaofmath.org/index.php/Functional
796 名前:デフォルトの名無しさん [2013/10/28(月) 16:41:42.96 .net] ん?schemeはYコンビネータを使って Y = (λf . (λx . f (x x)) (λx . f (x x))) 無名再帰ができると書いてあるな 何が違うんだろ?動的言語だと出来るとか?
797 名前:デフォルトの名無しさん mailto:sage [2013/10/28(月) 17:26:32.96 .net] >>784 汎関数の定義に無名関数を使うことは多いけど、 だからといって、すべての無名関数を用いた定義が汎関数となる訳ではない だから「無名関数で書けたら汎関数でよい?」という質問については No だ ただし「引数としてある関数を渡すとmapと同等な無名関数を返す」汎用的な関数が 定義できるのであれば、その関数は汎関数であるといえるだろう なお、再帰と汎関数は直交するから再帰を伴わない汎関数も存在する(たとえば合成関数 o) したがって「再帰で書けたら汎関数でよい?」という質問についても No となる >>785 数学における用語「汎関数」と計算機科学における「汎関数」をごっちゃにしているのでは? で、ここは(数学板ではなく)プログラム板だ
798 名前:デフォルトの名無しさん mailto:sage [2013/10/28(月) 17:37:07.70 .net] >>787 >数学における用語「汎関数」と計算機科学における「汎関数」をごっちゃにしているのでは? えええー!初耳だよそんなの。 計算機科学の汎関数の定義は?
799 名前:デフォルトの名無しさん [2013/10/28(月) 19:17:55.24 .net] 同値再帰型なんてのもあるんだね OCamlって最強言語じゃね?
800 名前:デフォルトの名無しさん [2013/10/30(水) 09:26:41.50 .net] 高階関数のままと 簡約した形と 評価までの速度に違いがあるのかな? 見やすさで選ばれてるだけ?
801 名前:デフォルトの名無しさん mailto:sage [2013/10/30(水) 13:20:56.16 .net] cygwin64bitにもOCaml登場
802 名前:デフォルトの名無しさん mailto:sage [2013/10/30(水) 19:40:53.15 .net] 簡約した形とは
803 名前:デフォルトの名無しさん mailto:sage [2013/10/31(木) 18:52:31.73 .net] ゴルフに出てくる;;の後の 1@0 って何ですか??
804 名前:デフォルトの名無しさん mailto:sage [2013/11/01(金) 12:27:52.67 .net] kwsk >>793 #ゴルフ
805 名前:デフォルトの名無しさん mailto:sage [2013/11/01(金) 21:39:55.79 .net] コードゴルフか? 'a list -> 'a list -> 'a list じゃなさそうだし自分で定義してるんじゃね?
806 名前:デフォルトの名無しさん [2013/11/02(土) 18:53:12.88 .net] S式みたいに (< 1 2 3 4 5 6 7 8 9) でtrue みたいに一発で計算ってできますか?
807 名前:デフォルトの名無しさん [2013/11/02(土) 19:14:43.17 .net] そういうの書けばできるでしょ
808 名前:デフォルトの名無しさん [2013/11/03(日) 00:39:10.77 .net] let rec less_than lst = match lst with [] -> None | x :: [] -> Some true | x :: y :: xs -> if x < y then less_than (y :: xs) else Some false ;; なんか一行ですっきり書きたい
809 名前:デフォルトの名無しさん mailto:sage [2013/11/03(日) 09:57:51.24 .net] f op xs = and $ zipWith op xs (tail xs)
810 名前:デフォルトの名無しさん [2013/11/03(日) 11:18:30.19 .net] ん?それHaskellじゃね?
811 名前:デフォルトの名無しさん [2013/11/03(日) 11:27:32.82 .net] こうかな。 fun lessThanForAll l = ListPair.all (op <) (l, tl l);
812 名前:デフォルトの名無しさん mailto:sage [2013/11/03(日) 21:33:04.10 .net] ocamlだとむずい
813 名前:デフォルトの名無しさん [2013/11/21(木) 06:02:11.85 .net] 盛り上がってるね。
814 名前:デフォルトの名無しさん mailto:sage [2013/11/25(月) 19:28:29.05 .net] camlp4の入手先を教えて下さい
815 名前:デフォルトの名無しさん mailto:sage [2013/11/25(月) 20:49:45.57 .net] ttps://github.com/ocaml/camlp4
816 名前:デフォルトの名無しさん [2013/11/25(月) 23:43:19.04 .net] camlp4ってなんか開発側のよくわからない方針により大幅に変更されてもともと乏しかったドキュメントが一層整備されてない状態になってから使う気なくした。
817 名前:デフォルトの名無しさん mailto:sage [2013/12/13(金) 08:01:15.59 .net] ああ、ハームが強いとか言ってたキルハイエナさんか
818 名前:デフォルトの名無しさん mailto:sage [2013/12/13(金) 08:02:13.53 .net] 誤爆
819 名前:デフォルトの名無しさん mailto:sage [2013/12/14(土) 16:52:12.01 .net] fezにお帰りください
820 名前:デフォルトの名無しさん [2013/12/19(木) 13:30:02.87 .net] ABC予想をOCamlで書いて
821 名前:デフォルトの名無しさん mailto:sage [2014/01/16(木) 19:03:28.13 .net] row polymorphism(< method_foo : foo -> bar ; .. >の"..")が何か泥臭い感じがしてOCamlのOが好きじゃないのですが、 row polymorphismとexact typeを区別するべき理由ってあるのでしょうか。
822 名前:デフォルトの名無しさん mailto:sage [2014/01/20(月) 01:16:23.89 .net] こんな本でた JavaScriptで学ぶ関数型プログラミング www.amazon.co.jp/dp/4873116600/ なんか面白そう
823 名前:デフォルトの名無しさん [2014/01/25(土) 20:39:37.59 .net] みんなどこいったんや
824 名前:デフォルトの名無しさん mailto:sage [2014/01/27(月) 00:37:41.63 .net] VBAを捨てて関数型言語がデフォルトでサポートされるのは、いつだろうか
825 名前:デフォルトの名無しさん mailto:sage [2014/01/27(月) 01:45:51.79 .net] そんな日は来なくていい
826 名前:デフォルトの名無しさん mailto:sage [2014/01/28(火) 03:59:19.18 .net] ExcelマクロにVBAとF#の選択肢が標準だったなら、関数型は主流になれる
827 名前:デフォルトの名無しさん mailto:sage [2014/01/28(火) 04:04:55.48 .net] >>813 クオンツやアクチュアリーもどきの個体数が増えすぎて、 市場価値が下がらないように口を紡ぎだしたとみた
828 名前:デフォルトの名無しさん mailto:sage [2014/01/29(水) 01:01:52.05 .net] 口を・・・つむぐ?
829 名前:デフォルトの名無しさん mailto:sage [2014/01/29(水) 01:04:27.44 .net] 口をつぐんだ人ならいるかもね
830 名前:デフォルトの名無しさん [2014/01/29(水) 21:56:44.82 .net] あれでしょ、世の中に不満があるなら自分を変えろ、それが嫌なら耳と目を閉じ、口を紡いで…あれ?
831 名前:デフォルトの名無しさん mailto:sage [2014/01/29(水) 21:58:26.24 .net] お口にチャックノリス
832 名前:デフォルトの名無しさん mailto:sage [2014/02/12(水) 23:38:39.41 .net] Batteriesを使用しているコードをjs_of_ocamlで変換するとMissing primitivesという警告?が出て JavaScriptの実行時エラーが出てしまいます これはどうしたら解消できるのでしょうか コマンド ocamlfind ocamlc -syntax camlp4o -package lwt,js_of_ocaml.syntax,batteries -g -c foo.ml ocamlfind ocamlc -package lwt,js_of_ocaml,batteries -linkpkg -o foo.byte foo.cmo js_of_ocaml foo.byte 出ているメッセージ Missing primitives: caml_ba_init caml_sys_const_big_endian caml_sys_const_ostype_cygwin caml_sys_const_ostype_unix caml_sys_const_ostype_win32 caml_sys_const_word_size create_nat incr_nat initialize_nat mult_digit_nat set_digit_nat set_to_zero_nat unix_inet_addr_of_string
833 名前:デフォルトの名無しさん mailto:sage [2014/02/13(木) 19:52:50.09 .net] いくつかはjs_of_ocamlを更新すれば定義されてる nat関係のは提供されてないのでダミーの関数を funciton create_nat(){}のように自分で追加するか batteriesのサブセットを切り出して使うか core_kernel使ってる人もいるらしい
834 名前:デフォルトの名無しさん mailto:sage [2014/02/13(木) 23:42:09.86 .net] js_of_ocaml 1.4.0を使っていますがこれではダメなのでしょうか? nat関係は適当にスクリプトを書いて対応しようと思います unix_inet_addr_of_stringはbatteries関係なく出てしまうようですね
835 名前:デフォルトの名無しさん mailto:sage [2014/02/13(木) 23:59:27.54 .net] bigarrayサポートがまだgit版にしかない unix_inet_addr_of_stringはruntime/unix.jsをリンクすれば大丈夫だけど opamで入れたなら多分入ってない
836 名前:デフォルトの名無しさん mailto:sage [2014/02/14(金) 00:28:20.76 .net] bigarrayサポートはnat関係のことですよね? もしそうだとするとcaml_XXXは一体何が原因なのでしょう それとunix_inet_addr_of_stringはopamで入れている以上直る?ことはないということなのでしょうか
837 名前:デフォルトの名無しさん mailto:sage [2014/02/14(金) 00:35:30.75 .net] 調べてから書くべきでした caml_XXXがbitarrayの関数ですね
838 名前:デフォルトの名無しさん mailto:sage [2014/02/14(金) 00:36:59.24 .net] big・・・
839 名前:デフォルトの名無しさん mailto:sage [2014/02/14(金) 00:45:48.03 .net] > それとunix_inet_addr_of_stringはopamで入れている以上直る?ことはないということなのでしょうか 公式のも唯の空の関数なんで自分で定義しても一緒だし 開発版では修正済みだから1.99だか2.0が出てopamパッケージになれば大丈夫
840 名前:デフォルトの名無しさん mailto:sage [2014/02/14(金) 01:06:19.10 .net] なるほど いずれ修正されることと今でも少し手を入れれば動くことがわかったので良かったです 親切にありがとうございました
841 名前:デフォルトの名無しさん mailto:sage [2014/02/16(日) 20:02:36.51 .net] www.reddit.com/r/programming/comments/1xtohg/ocaml_replacing_python_what_you_gain/
842 名前:デフォルトの名無しさん mailto:sage [2014/02/24(月) 14:22:45.10 .net] toplevelで、コンパイルした自作のライブラリを使いたいとき、 #load "/foo/bar/my.cmo";; とやったのですが、モジュールMyが無いと怒られたため、試行錯誤した結果、toplevelで #directory "/foo/bar";; #load "my.cmo";; と2段階に分けるか、コマンドラインで -I /foo/bar としなければならなかったのですが、こんな不便な仕様が存在しているはずがないと感じました。 別ディレクトリにあるファイルを読み込む正しいやり方ではどうすればいいのでしょうか。誰か教えていただけたらと思います。 my.cmoは/foo/bar内で:`ocamlfind ocamlc -pkg batteries my.ml`とやって生成しています。
843 名前:832 mailto:sage [2014/02/24(月) 14:28:40.75 .net] >>832 あ、使用しているOSはLinuxで、OCamlのバージョンは4.01.0です。
844 名前:832 mailto:sage [2014/02/24(月) 21:13:12.02 .net] findlibのソースを読み、ocamlのソースを読んだ結果、不便な仕様は不便な仕様のようです。 諦めます。
845 名前:デフォルトの名無しさん [2014/04/20(日) 10:33:29.81 ID:Ar2j+hn/.net] ∀x. P(x) とかλx. x のドットと同じなんじゃない。
846 名前:デフォルトの名無しさん mailto:sage [2014/04/20(日) 15:50:34.61 ID:jkTnuZFL.net] structureのドットじゃないのか
847 名前:デフォルトの名無しさん mailto:sage [2014/04/23(水) 20:07:50.69 ID:yuYA7aLZ.net] >>835 型hogeは('a -> 'a) -> 'a -> 'aという関数tを持つものだよ、というだけなんだが、 まずその'a.っていう表記が無いとエラーが出る。 エラーメッセージに脊髄反射してtype 'a hoge = { t : ('a -> 'a) -> 'a -> 'a }と定義すると、 hoge型の値を作ったときint hogeとかstring hogeとかになって、 tも(int -> int) -> int -> intとかになっちゃう。 いや違う、オレはhoge型の値にidentity:'a -> 'aや(=): 'a -> 'a -> boolのように、多相性を持った関数tが欲しいんだって時に 'a.っていう表記を使う。 用途は何と問われるとちょっと困る程度にはマイナー。
848 名前:デフォルトの名無しさん mailto:sage [2014/04/23(水) 20:47:43.26 ID:Rx5WvURy.net] 何言ってるか分からないですね
849 名前:デフォルトの名無しさん mailto:sage [2014/04/23(水) 22:11:28.21 ID:fVb21MOO.net] aはずっと自由変数ですよ、特殊化されませんよ、ってのを明示するのに使うのか
850 名前:デフォルトの名無しさん mailto:sage [2014/04/23(水) 22:41:15.05 ID:OJl2bhdr.net] 基本的に、変数は(もし多相性を持っていても)初期化された時点で単相型になる 関数は呼び出されると引数が初期化されるのでその時点で単相型になる 関数自身を変数に入れると、呼び出してなくても変数を初期化しただけで単相型になる >>835 のhoge型の変数は基本とは違って、初期化しただけでは単相型にならないっぽい
851 名前:デフォルトの名無しさん [2014/04/23(水) 23:18:57.87 ID:ddVBuvib.net] ためになるわー。
852 名前:835 mailto:sage [2014/04/24(木) 21:17:13.51 ID:4Y8KSBKa.net] 回答ありがとうございます。与えられたチャーチ数の定義がこれだったのですが、周りに聞いてもあまり良い回答を得られなかったので、とても助かりました。 確かにチャーチ数であれば、多相性が維持されなければ駄目ですね。
853 名前:デフォルトの名無しさん mailto:sage [2014/05/09(金) 06:41:29.78 ID:gmFOA17u.net] 最近JITが高速と聞くのですが MLtonよりもJITが高速になる場合も あったりするのでしょうか
854 名前:デフォルトの名無しさん mailto:sage [2014/05/09(金) 11:29:52.70 ID:88BxxZ+X.net] 早くなるケースもあるけど 大抵のケースは、工夫しないと遅いので作り込みが大変 なので、大体が学生の研究で作って、終わっちゃうんじゃないかな。 速さというより、F#みたいにVM環境向けにbytecodeに落とし込むケースは、あるかも。 C言語の例だと、CERNで、HPのGotoさんが作ってたCINTというCインタプリタがインターラクティブ環境が必要ということで採用されてた。 現在は、規格に追従&共通基盤の恩恵を受けられるllvmベースのclingを開発中。
855 名前:デフォルトの名無しさん mailto:sage [2014/05/09(金) 12:50:13.67 ID:viF1oq7i.net] 10年以上前だがJavaのShuJITとかあったけど、その作者のプロジェクトを終えるに あたってのまとめが、少々の理論的な優位点なんて、カネとヒトがたくさんある奴 (よーするにS
856 名前:un(当時)やIBMやHPの作ってるJVM)のパワーの前には吹き飛ぶ、 だった。 [] [ここ壊れてます]
857 名前:デフォルトの名無しさん mailto:sage [2014/05/09(金) 23:01:59.86 ID:2uUNFhKi.net] いまは、LLVM使うと巨人の肩に乗れるね。 JVMはHotSpotVMベースになってOpenJDKがオープンソースになってるからその上でいじれるように JSのVMは激戦だけど、IEの実装以外はオープンソースという。 LuaJITは、個人でつくってるのでオーパーツ。
858 名前:デフォルトの名無しさん mailto:sage [2014/05/10(土) 22:51:43.07 ID:SJ0/UQRG.net] 言語処理系の最適化はマンパワーが必要なので……今はトレンドがLLVMに色々集まる方向性かな
859 名前:デフォルトの名無しさん mailto:sage [2014/05/12(月) 21:26:19.65 ID:dnbz3Cdj.net] C++11という巨人の肩に乗ろう
860 名前:デフォルトの名無しさん mailto:sage [2014/05/12(月) 22:10:36.00 ID:xvKPpHt2.net] コンパイラは、MLで作ると楽という話もあるが、、、 そこらへんはジレンマ?
861 名前:デフォルトの名無しさん [2014/05/13(火) 09:28:41.53 ID:34BaoroY.net] >>847 js_of_ocaml ってJavaScriptで書くより最適化で高速になるからそういう方向もあるかも。 ttp://jsperf.com/js-of-ocaml
862 名前:デフォルトの名無しさん mailto:sage [2014/05/13(火) 20:13:34.93 ID:5OIUPatf.net] Excelのセル中で、F#で定義した関数が使えたら面白いかもと思った。
863 名前:デフォルトの名無しさん [2014/05/16(金) 08:18:12.70 ID:72NRi/gE.net] altJS としては最適化手法が数学的に議論されていて論文も出ている js_of_ocaml が最強なのでは: ttp://citeseerx.ist.psu.edu/viewdoc/download?doi=10.1.1.224.7457&rep=rep1&type=pdf
864 名前:デフォルトの名無しさん mailto:sage [2014/05/16(金) 16:19:49.33 ID:PtE4FBA8.net] LuaJITって個人のなの?ブラジル生まれだとは知ってたが。 あとllvmってコンパイラ基盤としては楽だけど、インタプリタとしてはちょっと難ありじゃないかしら。 適当に使うと最初の起動時間がかなり遅い。
865 名前:デフォルトの名無しさん mailto:sage [2014/05/17(土) 03:51:33.29 ID:RMSyflwZ.net] Luaは、ブラジル、リオデジャネイロの大学の研究グループから LuaJIT作ってるのはドイツ、ミュンヘンの人
866 名前:デフォルトの名無しさん mailto:sage [2014/06/01(日) 17:00:19.03 ID:3NiYSkpU.net] TAPLのexercise 3.2.5が分からん。なんで3.2.3の定義で S_i ⊆ S_{i+1} になるんだ? 各S_iは最初のS_1とかを除いて、disjointになるように思える。 本持ってる人教えて
867 名前:デフォルトの名無しさん mailto:sage [2014/06/01(日) 20:16:49.72 ID:dwNATPFa.net] https://bitbucket.org/camlspotter/ocaml-zippy-tutorial-in-japanese/src/434b26af16405ba8aaae0d89ba12bd2275eac9d3/4.02.md?at=default
868 名前:デフォルトの名無しさん mailto:sage [2014/06/09(月) 23:28:07.14 ID:g6XVfS4Z.net] ocamlの演算子、**より~-.の方が優先順位が高いのはなぜ?
869 名前:デフォルトの名無しさん mailto:sage [2014/06/22(日) 23:27:34.81 ID:kfNNTRTT.net] 単項だからでは
870 名前:デフォルトの名無しさん [2014/07/05(土) 07:26:50.37 ID:uomUGxMD.net] OCamlの日本語の文字列扱うのて 上手く行かないものですか?
871 名前:デフォルトの名無しさん mailto:sage [2014/08/01(金) 09:24:52.78 ID:Z/VI2an6.net] どの程度のレベルで上手くやろうとしているのか分からないけど、単純にstring型に代入、表示は何も無しでも動作するが、Stringモジュールは多言語に対応しているわけではない。String.lengthなどは狙い通りには動かない。 ライブラリ(Batteries, Camomile)等を使えば日本語できる。 と思ってBatUTF8を弄ってみたが、containsとかiterとかでBatUChar.tを取り扱う必要があるくせに、 BatUChar.t型を作る方法が面倒だなあ。of_digitしか無い。BatUTF8.get "あ" 0で誤魔化せるが、迂遠。
872 名前:デフォルトの名無しさん [2014/08/28(木) 00:17:52.33 ID:KKzfTscW.net] SML/NJ version 110.77 リリース! バージョン番号を4.0にリセットする前に、数回のリリースがあって、その中に64bitサポート が含まれるらしいが、今回はbugfixのマイナー・リリースらしい。 外部関数の32bitコンパイルがそろそろサポートされなくなりつつあるので、64bitサポートが はやくリリースされてほしい。
873 名前:デフォルトの名無しさん mailto:sage [2014/08/28(木) 00:31:14.45 ID:3eVJnuNA.net] まだやってるんだな NJ
874 名前:デフォルトの名無しさん mailto:sage [2014/08/28(木) 22:23:43.51 ID:fRdOqM0/.net] camomileの使い方が全然わからないんですがどこを読めばいいんでしょうか 主に文字コード変換と正規表現について知りたいです
875 名前:デフォルトの名無しさん mailto:sage [2014/08/29(金) 22:52:22.51 ID:LjCjaXt3.net] いつの間にかOCaml4.02.0
876 名前:デフォルトの名無しさん [2014/08/30(土) 19:35:20.64 ID:8G53+yskN] age
877 名前:デフォルトの名無しさん [2014/08/30(土) 23:41:43.96 ID://K1VbLN.net] test
878 名前:デフォルトの名無しさん mailto:sage [2014/09/02(火) 08:32:32.40 ID:3nEDqgz+.net] OCamlのマニュアルにocamlbrowserがまだあるのはバグっすな ocamldoc/trunk/manual/cmds/Makefile line#2 remove "browser.tex "
879 名前:デフォルトの名無しさん [2014/09/02(火) 22:57:08.51 ID:h4iRRc1G.net] ocaml標準のlexでは日本語が扱えないのでulexに差し替えたらparserが死んだでござる。 ダメだこりゃ
880 名前:デフォルトの名無しさん mailto:sage [2014/09/16(火) 16:34:15.58 ID:smkPtKEd.net] >>868 ttps://github.com/darioteixeira/ccss/blob/master/src/ccss.ml#L25 menhirとulexを一緒に使う方法。
881 名前:デフォルトの名無しさん mailto:sage [2014/09/24(水) 22:11:44.77 ID:ChDiOOXp.net] ocaml 4.01.0で # Obj.size @@ Obj.repr 1 がバグるんだけど、理由わかる?
882 名前:デフォルトの名無しさん mailto:sage [2014/09/24(水) 23:08:38.11 ID:wtmzOZEz.net] 仕様です。 ソースはおろかドキュメントすら読まずにObjを使うとはアホの極みです。 Chapter "Interfacing C with OCaml", Section 2..3
883 名前:デフォルトの名無しさん mailto:age [2014/09/26(金) 02:16:11.74 ID:63HfXufw.net] OCamlのすごさはもっと知られるべき #オブジェクト指向 や #関数型 は「敗者の道具」である itpro.nikkeibp.co.jp/atcl/watcher/14/334361/092200062/?ST=develop&P=3
884 名前:デフォルトの名無しさん mailto:sage [2014/09/26(金) 11:58:16.90 ID:p4JSIuT/.net] >>872 これタイトルで損してる記事だろ
885 名前:デフォルトの名無しさん mailto:sage [2014/09/26(金) 11:59:36.06 ID:LJo7FzMV.net] みかかデータ、マンセー記事っぽかったけど
886 名前:デフォルトの名無しさん mailto:sage [2014/09/26(金) 12:42:39.46 ID:/S6uCtFc.net] 関数型とかマルチパラ代務とかドカタには無理。オブジェクトだって散々語られてようやく、いや未だ、か 一部の突出した集団以外は、ほかにどうしようもない人が沈殿する職業になってるイメージ
887 名前:デフォルトの名無しさん [2014/09/26(金) 20:12:51.02 ID:+dkMIegW.net] do構文の使用禁止の規約って全部>>=で書くってことなのだろうか。理由も含めて気になる。
888 名前:デフォルトの名無しさん mailto:sage [2014/09/26(金) 20:54:07.13 ID:mU/FSdzC.net] >>872 前半で散々オブジェクト指向をこきおろしておきながら、 中盤でOCamlを推すという意味不明な文章の論理の展開がある ML族を推すのなら Caml か SML にしないと一貫性が無いし、 Caml にオブジェクト指向を後付けした "O"Caml 開発時の判断は 今となっては流行に踊らされた大きな失敗であったと断罪すべき おまけに「個人的にOCamlがすごいと思う」とあるから何かと読んでみたら、 単なるパラメタ型多相の話でしかないことに笑ってしまった 「とがった」とか「すごい」とか、小学生の感想文とレベルは変わらない こんなポエム記事で給料をもらえるのだから、日経ITproの記者とは楽な職業だね >>873 タイトル以前の問題で、記事に中身が無くて話にならん >>876 ソースコード解析ツールなら言語処理系と似た構造になるから、 (一般的には副作用を模倣するために使われる)do記法を使う必要性は無いと思われ
889 名前:デフォルトの名無しさん [2014/09/26(金) 21:11:21.88 ID:+dkMIegW.net] ちょっとぐぐってみたらこういうページがあった。 www.haskell.org/haskellwiki/Do_notation_considered_harmful
890 名前:デフォルトの名無しさん mailto:sage [2014/09/26(金) 21:24:18.32 ID:rzI+KhbO.net] たしかにタイトルで損したみたいだな
891 名前:デフォルトの名無しさん mailto:sage [2014/09/27(土) 09:02:30.03 ID:aRJ76A2x.net] ああいう煽り記事読んでドキドキするのは思春期の子供だけ もっと大人向けの真面目に面白い記事は無いのか?
892 名前:デフォルトの名無しさん mailto:sage [2014/09/27(土) 09:08:36.15 ID:V9AoMXji.net] もし完全無欠のプログラマが存在するのであれば、そうした方法論に頼らなくても、 完全に意図通りに動作するプログラムを頭から書き下していけばいいのです。 オブジェクト指向プログラミングや関数型プログラミングは、不完全な人間のために用意されたもの、 いわば「敗者の道具」といえます。 もちろん、これは極端すぎる表現です。例えば、人は空を飛べないので飛行機に乗ります。 このことをもって「飛行機は敗者の道具である」と言う人はいません。 そうした意味では、オブジェクト指向プログラミングや関数型プログラミングを敗者の道具と呼ぶのは、 単なる言葉遊びにすぎません。人間が全知全能でないのは当たり前ですから。 完全に朝日脳だな
893 名前:デフォルトの名無しさん mailto:sage [2014/09/27(土) 17:11:59.10 ID:lJpImKEe.net] 産経信者も一緒に死ねカス
894 名前:デフォルトの名無しさん mailto:sage [2014/09/28(日) 11:09:58.25 ID:yTX/1oq/.net] 今回朝日がしでかしたことを誰かまとめてくれ
895 名前:デフォルトの名無しさん mailto:sage [2014/09/28(日) 12:21:46.09 ID:MFWVwvB9.net] スレ違いカスはお引き取り下さい
896 名前:デフォルトの名無しさん mailto:sage [2014/09/28(日) 12:22:16.97 ID:/z7vQ2zP.net] >>883 どいたかこ死亡
897 名前:デフォルトの名無しさん mailto:sage [2014/09/28(日) 12:38:21.08 ID:3fm9b2hk.net] 土井たか子がリアルに退いた過去になったのか
898 名前:デフォルトの名無しさん mailto:sage [2014/09/28(日) 12:39:24.70 ID:/z7vQ2zP.net] 土井がどいた過去
899 名前:デフォルトの名無しさん mailto:sage [2014/09/28(日) 12:40:25.54 ID:/z7vQ2zP.net] おんたけさんが噴火して おたけさんが逝った
900 名前:デフォルトの名無しさん mailto:sage [2014/10/07(火) 01:19:25.02 ID:RDe60glL.net] 対話環境を再起動せずに、リコンパイルしたライブラリをロードし直す方法ってありますか? #load でもう一度ロードすると、シグニチャが異なると怒られてしまいます
901 名前:デフォルトの名無しさん mailto:sage [2014/11/07(金) 22:47:28.24 ID:jjvVlXlA.net] OCamlで型クラスを実現する方法ある? あとカインドも
902 名前:デフォルトの名無しさん mailto:sage [2014/12/28(日) 01:38:33.30 ID:t9XFY33G.net] モジュールで型クラス的なものを作ることができる。便利とは言いがたいが
903 名前:デフォルトの名無しさん mailto:sage [2015/02/05(木) 08:14:28.48 ID:0RN82SQI.net] Haskell より OCaml の方が部分部分で好みなんだけど、 OCaml は最近何か進展とか発展とか無いのかな。
904 名前:デフォルトの名無しさん mailto:sage [2015/02/05(木) 13:15:20.83 ID:tkrhoEGU.net] 4.0出たばっかじゃなかったっけ
905 名前:デフォルトの名無しさん mailto:sage [2015/02/05(木) 14:50:21.24 ID:j+EW35P1.net] 岡村はソース醜いのがなあ
906 名前:デフォルトの名無しさん mailto:sage [2015/02/05(木) 19:17:09.87 ID:Omd6cUWA.net] >>894 たとえば?
907 名前:デフォルトの名無しさん mailto:sage [2015/02/05(木) 20:40:25.53 ID:SFYHhnYx.net] 上から読んでいけば何しているのか分かるOCamlのソースは読みやすい部類 batteriesとかcoreといった大きいライブラリでも、モジュールと同名のファイル見ればいいだけなので、 どこに何があるのか探しやすい 基本的に手続き脳なので、haskellはどこから読めばいいのか分からない 悪名高いimport文のおかげでもっと読めない
908 名前:デフォルトの名無しさん [2015/02/05(木) 21:27:52.95 ID:uGoWQo5h.net] OCamlなんとなくソースの見た目のバランスが悪いっていうのはなんかわかるわ。
909 名前:894 mailto:sage [2015/02/06(金) 00:00:17.76 ID:mrZTa4bi.net] >>897 まさにそんなとこ。ぱっと見よくない
910 名前:デフォルトの名無しさん mailto:sage [2015/02/06(金) 11:46:04.54 ID:qvKWViHE.net] ソースが読みにくい言語は致命的に生産&保守効率が悪い。
911 名前:デフォルトの名無しさん mailto:sage [2015/02/06(金) 11:56:15.06 ID:uqQOSJHn.net] >>898 ? SMLならいいの?
912 名前:デフォルトの名無しさん [2015/02/19(木) 21:32:44.77 ID:VWBqr6Q7.net] レコード型ある言語、多相レコードある言語、フィールドがファーストクラスにできる言語 おしえて。 ぜんぶもってるのがいい。
913 名前:デフォルトの名無しさん mailto:sage [2015/02/19(木) 22:31:13.58 ID:/rXoqLFu.net] >>901 SML# という Standard ML の処理系は「ぜんぶもってる」よ # fun get_x {X = x, ...} = x; val get_x = fn : ['a#{X: 'b}, 'b. 'a -> 'b] # val point_2d = {X=1.0, Y=2.0}; val point_2d = {X = 1, Y = 2} : {X: real, Y: real} # val point_3d = {X=10.0, Y=20.0, Z=15.0}; val point_3d = {X = 10, Y = 20, Z = 15} : {X: real, Y: real, Z: real} # get_x point_2d; val it = 1 : real # get_x point_3d; val it = 10 : real Standard ML の場合、前2つは言語仕様で規定されているからすべての処理系で利用できるけど、 最後の「フィールドがファーストクラス」であることは仕様では要求されていない たとえば SML/NJ という処理系だと、上記のコードはエラーになる - fun get_x {X = x, ...} = x; stdIn:1.2-1.28 Error: unresolved flex record (can't tell what fields there are besides #X) SML# が独自に拡張したレコード型に関しては、SML# プロジェクトのホームページに 日本語の解説があるから、まず最初に読んでみるのがいいと思う ・SML#の拡張機能:レコード多相性 in プログラミング言語SML#解説 www.pllab.riec.tohoku.ac.jp/smlsharp/docs/2.0/ja/Ch7.xhtml
914 名前:デフォルトの名無しさん [2015/02/19(木) 22:34:08.05 ID:VWBqr6Q7.net] ↑ありがと。 ほんとにぜんぶ!? フィールドファーストクラスなのその言語?
915 名前:デフォルトの名無しさん [2015/02/19(木) 22:35:11.19 ID:VWBqr6Q7.net] あ、かいてあった、ごめん。
916 名前:デフォルトの名無しさん [2015/02/19(木) 22:37:49.31 ID:VWBqr6Q7.net] SML/NJってやつは、フィールドがファーストじゃないとして、 SML#ってやつはファーストなの? ほかにも>>900 全部持ってる言語とかあればおしえて。みんな。
917 名前:デフォルトの名無しさん [2015/02/20(金) 03:39:21.83 ID:V63A/fo0.net] 1.レコード型、あるいは、それに類する型を持つ 2.レコード型(or それに類する型)の構造的部分型関係を扱える 3.できれば、多相レコード型とかそれと同様なのを持つ 4.できれば、レコードのフィールド名がファーストクラス ( x = [name = 3] : [name : int] なら nameがファーストクラス) これカバーできる言語ない? うえでおしえてもらったのしらべてみたけど SML/NJってのは1,2を満たしてそう SML#ってのが1,2,3を満たしてそう、 あと scalaが無名オブジェクトみたいなやつで1,2,3を満たしてそう? 型を一部か書かないとダメだけど ほかにこの辺でなんかいい言語ない? clojure? ってのが4みたして相だけどコンパイル時に型ちぇっくしてくれないよねそれ? うーんなんかない?
918 名前:デフォルトの名無しさん [2015/02/20(金) 09:34:49.39 ID:vrO8Sxqb.net] 1
919 名前:デフォルトの名無しさん mailto:sage [2015/02/20(金) 10:31:17.89 ID:N6pKHonh.net] じゃあ俺は2
920 名前:デフォルトの名無しさん mailto:sage [2015/02/20(金) 10:55:47.88 ID:sOgXDRpH.net] 宿題は自力でやれw
921 名前:デフォルトの名無しさん mailto:sage [2015/02/21(土) 00:55:59.35 ID:KgB/c0aN.net] >>906 Standard ML のレコード型は構造的部分型関係を持たないよ 構造的部分型関係を持つレコード型に類する型を持つのは OCaml や Java いわゆるオブジェクト指向におけるクラスとそれらの間の継承関係のこと また「多相レコード型」という用語の意味が「パラメタ型多相なレコード型」 であるならば、Standard ML は多相レコード型を持つことになる ここでパラメタ型多相は、Java だとジェネリクス(総称型)と呼ばれている 結論として、Standard ML(とその処理系 SML/NL および SML#)は1と3を満たす 次にファーストクラスについて、>>902 のコードにおける関数 get_x の定義だけど、 「フィールドとはレコード値からフィールド値への写像(関数)である」 という関係に気付けば、その定義は以下のように簡潔になる # val get_x = #X; val get_x = fn : ['a#{X: 'b}, 'b. 'a -> 'b] (* SML/# *) つまりフィールド #X は(val宣言で)識別子に束縛したり、他の関数へ適用したり。 ある関数の評価結果として返すことができる こうした数値や文字列といった値と同等に扱える性質を指してファーストクラスと呼ぶ さらに上記の例は SML# だけど、SML/NJ も型システムが単純たから型推論に失敗するだけで、 データ型を明示的に宣言すれば関数 get_x を定義できる - val get_x = #X : {X: real, Y: 'a} -> real; val get_x = fn : {X:real, Y:'a} -> real (* SML/NJ *) 型システムの制約とファーストクラスという性質をごっちゃにすべきではない まとめると、Standard ML(とそのすべての処理系)のフィールドはファーストクラスである
922 名前:デフォルトの名無しさん mailto:sage [2015/02/21(土) 01:03:27.14 ID:KaIHMFIz.net] > - val get_x = #X : {X: real, Y: 'a} -> real; でもこの get_x って、>>902 の point_3d には使えないよね。
923 名前:デフォルトの名無しさん mailto:sage [2015/02/21(土) 01:45:43.43 ID:KgB/c0aN.net] うん、使えない それが >>910 で書いた(Standard ML言語仕様における)「型システム」の制約だね その制約を無くした SML# が特異なだけで、SML/NJ 以外の大半の SML 処理系に同じ制約がある
924 名前:デフォルトの名無しさん [2015/02/21(土) 06:39:28.04 ID:QYKbOsyjA] SML#はstructual subtype関係 もつんじゃないの?↑のリンク先見る限りさ {l1:a, l2:b} < {l1:a} みたいに扱われないの? javaの部分型関係は明示的にクラス名に順序関係付けただけのものだけじゃないの? フィールドをファーストクラスとして扱えるような技があるのはうえの説明で理解した。Thanks. 思ってたより使えるなsml。 一方で、フィールドリテラル自体を、関数経由でなく、ファーストクラスとしてあつかう必要がある/そっちのほうが好ましい かもしれない 上のリンク先にある論文見るかぎり(例えば↓)そういういみでのファーストクラスフィールドは現状は扱ってないと書いてある。 SML# in Industry: A Practical ERP System Developmentn, # val get_x = #X; のXに実行時中に得られる文字列の値を使いたい String str = "myfld"; Rec rec = {str:"yaaa"}; みたいにさ。 うーんsmlでかくか、sml#つかうか、それともJava,Scala,でかくかまような。 型推論は必要ないかもしれないし、sml#ってどこまでメンテされるのか解らないし、SML/NJがいいかな、、しかし>>911 がきになるな。 scalaのオブジェクトでレコードをシミュレートするか、、 ファーストクラスのフィールドを持つ、 レコードで構造的な部分型関係をもっているようなのがほしい。
925 名前:デフォルトの名無しさん [2015/02/21(土) 06:49:52.82 ID:QYKbOsyjA] というかここMLのすれだったのか、関数型言語全般かと思った。
926 名前:デフォルトの名無しさん mailto:sage [2015/02/21(土) 20:03:59.94 ID:KgB/c0aN.net] >>910 >Standard ML のレコード型は構造的部分型関係を持たないよ >構造的部分型関係を持つレコード型に類する型を持つのは OCaml や Java >いわゆるオブジェクト指向におけるクラスとそれらの間の継承関係のこと 自己レスだけど、この段落は間違いが含まれていたので訂正する まず: >Standard ML のレコード型は構造的部分型関係を持たないよ この文章は正しいけど、SML# は「構造的」部分型関係に類する型を持つ だから >>902 の関数 get_x は point_2d とpoint_3d のどちらにも適用できる(>>911 ) そして SML# だと、point_2d と point_3d のそれぞれの型について、 {X: real, Y:real} >= {X: real, Y:real, Z: real} という部分型関係を持ち、 ここで 関係 a >= b は「a の部分型が b である」ことを意味する 次に: >構造的部分型関係を持つレコード型に類する型を持つのは OCaml や Java >いわゆるオブジェクト指向におけるクラスとそれらの間の継承関係のこと この文章は完全な間違いで、正しくは 「「非構造的」部分型関係を持つレコード型に類する型を持つのは OCaml や Java (...後略)」になる たとえば(架空言語で)二次元座標上の点として 抽象クラス {} を定義し、その具象クラスとして {X軸: real, Y軸: real} および(原点からの相対的な) {角度: real, 距離: real} を定義できる ここで、2つの具象クラスのフィールド構成(=内部的構造)は全く異なるけれど、 {} >= {X軸: real, Y軸: real} および {} >= {角度: real, 距離: real} という部分型関係を持つ
927 名前:片山博文MZ ◆T6xkBnTXz7B0 mailto:sage [2015/03/06(金) 00:20:10.28 ID:Utx2vhNJ.net] MLで株取引してるヤツおる?
928 名前:デフォルトの名無しさん mailto:sage [2015/03/06(金) 19:18:02.97 ID:z8rf25M9.net] >>916 https://www.janestreet.com/
929 名前:デフォルトの名無しさん mailto:sage [2015/04/11(土) 09:23:04.09 ID:4MGH5loU.net] 『関数型プログラミングに目覚めた! IQ145の女子高校生の先輩から受けた特訓5日間』 www.amazon.co.jp/dp/4798043761/ なんか面白そう。 ベストセラー1位だし。
930 名前:デフォルトの名無しさん mailto:sage [2015/04/11(土) 11:09:33.39 ID:6e+Pm3/z.net] 著者名みてどん引き
931 名前:デフォルトの名無しさん mailto:sage [2015/04/11(土) 14:52:19.95 ID:kM0sKeAC.net] >>918 まーたハゲの人バカやってるのか
932 名前:デフォルトの名無しさん mailto:sage [2015/04/30(木) 22:13:28.21 ID:CyAc4DaC.net] これあわせで、qiitaで何ヶ月か前に宣伝始めたんだよな。 今回のMSの開発者向けイベントで、マルチプラットフォームアピールしてたから、F#にもチャンスが増えるかも。
933 名前:デフォルトの名無しさん mailto:sage [2015/06/21(日) 14:35:56.40 ID:jZdgW1bu.net] ML系でマルチスレッドプログラミングってどうやるの? できれば、プリエンプティブで。 ノンプリなら、バインディングさえ準備できればpthreadとか使うだけで出来る? あと、マルチコアで動く処理系ってどんなのがありますか?
934 名前:デフォルトの名無しさん [2015/06/21(日) 15:56:19.44 ID:h+2IwqsQ.net] ノンプリエンプティブな並行のフレームワークとしてはConcurrent ML、 マルチコアでプリエンプティブで動く処理系は…MultiMLton?使ったことないけど
935 名前:デフォルトの名無しさん mailto:sage [2015/06/21(日) 21:09:48.45 ID:jZdgW1bu.net] >>923 ありがとう!参考にしてみます。
936 名前:デフォルトの名無しさん mailto:sage [2015/06/22(月) 21:17:40.35 ID:NI+fH6po.net] SML/NJにCMLが入ってるみたいだけど 呼び出しかた自体が良く分かりませんでした,,,
937 名前:デフォルトの名無しさん mailto:sage [2015/06/22(月) 22:19:01.14 ID:OHI7eLtz.net] まだバイトコードだけなんで処理速度的にはメリット薄いがocaml-multicoreも開発中 https://github.com/ocamllabs/ocaml-multicore 諦めてF#が一番楽そう
938 名前:デフォルトの名無しさん mailto:sage [2015/07/04(土) 11:48:28.89 ID:D//5Uocc.net] 新潮10月号(9/7発売)に最新長編『モナドの領域』330枚一挙掲載
939 名前:デフォルトの名無しさん mailto:sage [2015/07/19(日) 15:49:50.98 ID:1yK25cK1.net] Haskell ガチムチいい男 F# タマもサオも取ったニューハーフ OCaml タマは摘出、サオは残したオカマ Java ノン気の一般人 C 古風な一般人 C++ 団塊の世代の一般人 C# ゆとり世代
940 名前:デフォルトの名無しさん mailto:sage [2015/08/01(土) 08:14:56.43 ID:keSdeN9Q.net] Ocamlってschemeのvaluesに相当するのないのですか?
941 名前:デフォルトの名無しさん mailto:sage [2015/08/02(日) 05:19:00.73 ID:OeY6iFU6.net] + と+. って絶対に区別しないといけないのです?浮動小数と整数でコードわけるのめんどくさい
942 名前:デフォルトの名無しさん [2015/11/01(日) 12:21:17.11 ID:FL14q5P6.net] min-camlを読み解こうと思ってできれば小さく分けてコンパイルして確かめたいです parser.mly/lexer.mll/id.ml/syntax.ml/type.ml ここまでが最初の塊のようなのでocamlyacc/ocamllexしたあとインタプリタで #use "type.ml" #use "id.ml" #use "syntax.ml" #use "parser.ml" #use "lexer.ml" までやるとlexer.mlを読み込んでいるのにlexer.mllでエラーがでます どうやってインタプリタに読み込めばいいのでしょうか
943 名前:デフォルトの名無しさん mailto:sage [2016/03/06(日) 17:23:06.30 ID:LFfI8YF2.net] C++11とboostでmlと等価なこと出来るようになってない?
944 名前:デフォルトの名無しさん mailto:sage [2016/03/07(月) 12:29:48.85 ID:IQOnvxBL.net] 楽にはなっても等価にはなってない
945 名前:デフォルトの名無しさん [2016/06/16(木) 23:45:45.68 ID:ogi8+DdB.net] OCaml覚えてHaxeのターゲット自分で書けるようになったらなあって思ったけど パット見何が書いてあるのか良くわからない
946 名前:デフォルトの名無しさん mailto:sage [2016/07/09(土) 07:50:35.12 ID:lXAilHyr.net] >>928 JavaScript 苦労人
947 名前:デフォルトの名無しさん mailto:sage [2016/07/22(金) 00:00:06.57 ID:Zm57F0sF.net] OCaml インストールしてたら が出てきた。 絵文字がこんなところにも進出してるとは……
948 名前:デフォルトの名無しさん mailto:sage [2016/07/23(土) 20:35:22.56 ID:K/hEThar.net] F#はいまいち盛り上がらんのでOCamlに戻るか
949 名前:デフォルトの名無しさん mailto:sage [2016/07/31(日) 08:26:29.15 ID:FitcqrL7.net] OCamlには関数合成がないと訊くんですが、@@は合成ではないのですか
950 名前:デフォルトの名無しさん mailto:sage [2016/09/02(金) 10:19:54.63 ID:75SbB3DN.net] OCaml勉強しはじめの初心者の質問なんですが、どなたか教えてください https://ocaml.org/learn/tutorials/modules.ja.html ここの説明によると、行末の;;を避けるためみんなこう書く open Amodule let () = hello () ってあるんですが、これがまず理解できない ()ってunitの定数値というかリテラルみたいなものなのではないですか? letで束縛する的なコードが書けることが腑に落ちないのですが・・・
951 名前:デフォルトの名無しさん mailto:sage [2016/09/02(金) 13:34:30.13 ID:xfbClL/y.net] () って C の void みたいなもんやろ。 hello() の戻り値が void で両辺 void = void で OK みたいな。
952 名前:デフォルトの名無しさん mailto:sage [2016/09/02(金) 18:21:07.36 ID:anKFyHj7.net] =が等号ならそんな感じってするのですが、 let 変数名 = 値 って形に当てはまると unitの()って変数名であり値でもあるってこと? とか考え出すと混乱して
953 名前:オまいます・・・ [] [ここ壊れてます]
954 名前:デフォルトの名無しさん mailto:sage [2016/09/02(金) 18:22:47.76 ID:h+44ee0t.net] >>939 その用途の場合単なるエントリポイントなので()にそんなに意味はない。 let _ =〜でも動作するよ。
955 名前:デフォルトの名無しさん mailto:sage [2016/09/02(金) 19:39:25.71 ID:MnPjnRyk.net] >>941 letは代入ではなくパターンマッチ 普段は let パターン = 式 のパターンのところに新規の束縛(変数名)を一個置いてるだけ let 1 =2 とか書けてMatch_failureになるよ
956 名前:デフォルトの名無しさん mailto:sage [2016/09/02(金) 21:44:32.31 ID:TuW8Vb/N.net] 皆さんありがとう、何となく分かりました 実際に「let x::xs = [1;2;3;4];;」とかやるとx=1、xs=[2;3;4]とかなりますね letってのはmatchの単独パターンバージョンみたいな感じなんですね、きっと
957 名前:デフォルトの名無しさん mailto:sage [2016/09/03(土) 14:38:27.01 ID:xDozGH3Q.net] OCamlも捨てがたい qiita.com/HirofumiYashima/items/98d35b40dde12bbb5d6d
958 名前:デフォルトの名無しさん mailto:sage [2016/09/04(日) 01:00:38.68 ID:m/Nfzz4G.net] たびたび初心者的質問ですいません OCamlにはListやArrayに対するgroup by関数って無いんでしょうか? 標準ライブラリ(ideoneやyukicoderで利用可能)の範囲内で存在すれば嬉しいんですが・・・
959 名前:デフォルトの名無しさん mailto:sage [2016/09/04(日) 21:14:26.78 ID:ZFd7dRv3.net] List.filter : ('a -> bool) -> 'a list -> 'a list ならある。 Arrayにはないから自力で実装するかExtLibでも使おう。 っていうか標準ライブラリだったら自分で検索しようね。 馬鹿なの?
960 名前:デフォルトの名無しさん mailto:sage [2016/09/04(日) 21:40:33.19 ID:m/Nfzz4G.net] >>947 標準ライブラリは探したけど、無かったから自作したよ 最近だとF#にしろscalaにしろgroupbyがあるのが当たり前だから、確認のため聞いてみた その程度の事情も察せないお前が馬鹿じゃねw
961 名前:デフォルトの名無しさん mailto:sage [2016/09/05(月) 20:50:26.74 ID:uZnwqH5s.net] 宿題や競プロでもやるんじゃなきゃCoreかBatteries入れないとやってられない
962 名前:デフォルトの名無しさん mailto:sage [2016/09/10(土) 11:17:54.65 ID:hxR4/XV4.net] 標準ライブラリゴミすぎ
963 名前:デフォルトの名無しさん mailto:sage [2016/09/10(土) 20:27:19.82 ID:vL431mpn.net] map reduceに相当するもんがあればいけるんじゃね
964 名前:デフォルトの名無しさん mailto:sage [2017/02/27(月) 20:54:32.60 ID:nBcs47LL.net] 「プログラミングの基礎」を買ってきてOcamlを始めようとしたのですがインタプリタが日本語を表示してくれません。ぐぐっても知識が足らず解決法がわからなくて途方に暮れています。誰か助けて…
965 名前:デフォルトの名無しさん mailto:sage [2017/02/27(月) 21:06:38.41 ID:nBcs47LL.net] 使ってる環境はubuntu16.10です。
966 名前:デフォルトの名無しさん mailto:sage [2017/02/28(火) 21:46:08.53 ID:hBxDt9/3.net] >>952 解決しました
967 名前:デフォルトの名無しさん mailto:sage [2017/03/01(水) 12:55:25.91 ID:jLbNtrZK.net] どのようにして解決したのか書いてもらえると 同じ状況に陥った人の助けになるかも知れないわけだが…
968 名前:デフォルトの名無しさん mailto:sage [2017/03/01(水) 16:07:29.52 ID:ZtKy2rs9.net] >>955 解決策を2つ試しました まず、著者のサポートサイト(pllab.is.ocha.ac.jp/~asai/book/Linux.html )を見て、 @端末起動→上部メニューバーの端末タブ→文字コードの設定→日本語(EUC-JP)に設定してから ALANG=en_US.ISO88591 ocamlを実行しましたが解決しませんでした。 次に、qiita.com/KenjiYamauchi/items/40aaab56b65777950877 を参考にして、 @任意テキストエディタで~/(ホームディレクトリ配下の意味)に.ocamlinitというファイルを作り、 A「let printer ppf = Format.fprintf ppf "\"%s\"";; #install_printer printer」と記述した所、解決しました。 コンピュータやプログラミングに詳しい方にはかなりくどいと思いますが、多分自分のようなプログラミング初心者が読む本だと思うので念入りに書いておきます。
969 名前:デフォルトの名無しさん mailto:sage [2017/03/01(水) 16:10:35.17 ID:ZtKy2rs9.net] というか、誰も見てないと思ってた・・・
970 名前:デフォルトの名無しさん mailto:sage [2017/03/01(水) 16:46:02.21 ID:8oSlLlXA.net] 乙
971 名前:デフォルトの名無しさん [2017/05/01(月) 06:16:47.63 ID:Cn5FkhjE.net] 純粋関数型データ構造が発売されたってのに盛り上がってないな
972 名前:デフォルトの名無しさん mailto:sage [2017/05/01(月) 08:26:08.29 ID:X5RvQ3AI.net] >>959 あれを読むような層は、既に原書で読んでるから気にもしないのでは。
973 名前:デフォルトの名無しさん mailto:sage [2017/05/30(火) 11:59:51.61 ID:heN7Y+lD.net] Real World OCaml で OCaml入門中です。 https://realworldocaml.org/v1/en/html/variables-and-functions.html ... As a result, when passing labeled functions as arguments, you need to take care to be consistent in your ordering of labeled arguments. 要は、ラベル付引数持ちの関数 は 引数の順序気にしなくて良くなるので便利だねって話だったのに、 そういう関数を 他の関数に引数として渡す時は 順序気にしないと型エラーになるかもよ、と。 現 (OCaml ver. 4.04.1) にそうなってるのはしょうがないとして、ユーザーは不満だったりしないんですかね? 仕様変えてどこでも順序気にしなくてよくなるようにするのは何か不都合があるんでしょうか?
974 名前:デフォルトの名無しさん mailto:sage [2017/05/31(水) 12:35:03.09 ID:nyiBm3r5.net] はい
975 名前:デフォルトの名無しさん mailto:sage [2017/06/02(金) 14:10:54.16 ID:v4wV8DId.net] >>959 書店で立ち読みしてみたんだけど微妙に扱っているデータ構造少なくね? サンプルコードがStandard MLというのは驚いたが。
976 名前:デフォルトの名無しさん mailto:sage [2017/06/09(金) 03:43:45.31 ID:Z/PWf/cV.net] 末尾再帰がイメージできないんだけど
977 名前:デフォルトの名無しさん mailto:sage [2017/06/09(金) 10:56:43.72 ID:jgO9PNm3.net] 「なんでも再帰」や「なんでも継続」を読んでみたら?例はSchemeだが
978 名前:デフォルトの名無しさん [2017/06/09(金) 13:37:56.60 ID:3OdcZ+id.net] fact 0 = 1 fact n = n * (fact (n-1)) だと,fact (n-1)の再帰呼出の後で nとの掛け算を しなければならない.計算の最後(=末尾)が再帰では なく乗算となる. fact2 0 n = n fact2 n k = fact2 (n-1) (n*x) として fact1 n = fact2 n 1 としておけば,fact2の計算の最後はfact2の 再帰呼出で,callをgotoに変えたループで実行できる. こんな感じでイメージできる?
979 名前:デフォルトの名無しさん mailto:sage [2017/06/09(金) 14:50:46.84 ID:rw1qC18c.net] f_outer(n){ f_inner(n, accumulator){ if 1 == n accumulator else f_inner(n - 1, n * accumulator) } } accumulator に蓄積すれば?
980 名前:965 mailto:sage [2017/06/09(金) 14:56:24.07 ID:rw1qC18c.net] f_outer(n){ f_inner(n, accumulator){ if 1 == n accumulator else f_inner(n - 1, n * accumulator) } return f_inner(n, 0) } 修正。 内部関数を、return するのが抜けていた
981 名前:デフォルトの名無しさん mailto:sage [2017/06/09(金) 16:51:44.77 ID:VCuqCK40.net] おおおわかった気がする ありがとう! なんでも再起とやらも読んで見ることにする
982 名前:デフォルトの名無しさん [2017/06/09(金) 17:05:35.04 ID:3Dqy8l+L.net] >>968 return f_inner(n, 1) じゃない?
983 名前:デフォルトの名無しさん mailto:sage [2017/06/25(日) 18:30:26.47 ID:v1ZjLLZV.net] OcamlとかCoqって名古屋以外でも大学での授業とか研究に使われているの? 一時期のブームは去ったみたいだけど。 大学の情報学部とかの現状にはちょっとだけ興味がある。 そして流行に後れて今頃勉強している40代のオレ。
984 名前:デフォルトの名無しさん mailto:sage [2017/07/03(月) 09:21:46.88 ID:ipQv+IYB.net] 東大東北大お茶の水では使ってた
985 名前:デフォルトの名無しさん mailto:sage [2017/07/03(月) 17:44:24.93 ID:/M1wO8+Z.net] 授業で使ったのに広まらなかったということか。 つまり啓蒙に失敗したと。
986 名前:デフォルトの名無しさん mailto:sage [2017/07/04(火) 13:46:26.44 ID:VgVQ93XC.net] Occamなら知っとるぞよ?
987 名前:デフォルトの名無しさん mailto:sage [2017/07/12(水) 14:21:04.56 ID:06OhWRFP.net] >973 広まらなかったというかキラーアプリがなかったというか… 結局Ocamlで作られたアプリで唯一プログラマ間で流行ったのがCoqなんじゃね?
988 名前:デフォルトの名無しさん mailto:sage [2017/07/12(水) 14:33:02.68 ID:bLDjTsNM.net] OCaml は金融とかで使われてるんじゃ無かったか。 そういや Rust も最初は OCaml でコンパイラー書かれてたんだよな。
989 名前:デフォルトの名無しさん mailto:sage [2017/07/14(金) 23:08:50.92 ID:UJz0OWoz.net] 俺がocaml覚えたきっかけはとあるエロゲーのチートツールなんだが あれの作者がなぜそれを採用したかにはずごい興味ある
990 名前:デフォルトの名無しさん mailto:sage [2017/07/15(土) 12:06:36.80 ID:03i9G/wL.net] >>977 どっかの学生だったんじゃないの?兄妹ものエロゲだけに京大とか。
991 名前:デフォルトの名無しさん mailto:sage [2017/08/16(水) 21:00:55.34 ID:H/HIEf+2.net] (*´・ω・`*)
992 名前:デフォルトの名無しさん mailto:sage [2017/08/17(木) 13:02:39.82 ID:5mQoD0+b.net] (´・ω・`)
993 名前:デフォルトの名無しさん mailto:sage [2017/09/01(金) 18:43:59.45 ID:RxXe6GrD.net] 8月はちょっと纏まった時間がとれたので、 「ソフトウェアの基礎」日本語訳の練習問題を解きすすめてみた。 まだPoly.vが終わった序盤だけどだいぶCoqに慣れてきた。 星三つrecommendedでもたまに難しい問題があるなー、というのが感想。 論理学の命題というのは高校・大学教育で慣れているだけで 見直してみると思ったよりも複雑な構造をしていたのだと今更ながらに感じた。 実務でCoqが要求されることは当分ないと思うけど、 逆変換の関数は少なからず実装することがあるので ときどき「Coq使って証明したい」という気分にはなるんだよなー。
994 名前:デフォルトの名無しさん mailto:sage [2017/09/05(火) 11:03:28.55 ID:a/Cb1ZW9.net] ocaml.jp/ 死んでるな…… > ( ! ) Parse error: syntax error, unexpected 'new' (T_NEW) in /virtual/osiire/public_html/lib/func.php on line 531
995 名前:デフォルトの名無しさん mailto:sage [2017/09/08(金) 14:02:07.35 ID:swD2wqBn.net] ocaml.jpは息してる?
996 名前:デフォルトの名無しさん mailto:sage [2017/09/24(日) 12:35:45.27 ID:VL5Szw+L.net] いつまで死んでるんだよ
997 名前:デフォルトの名無しさん mailto:sage [2017/10/03(火) 00:31:09.35 ID:JZnIdnEQ.net] 復活した
998 名前:デフォルトの名無しさん mailto:sage [2017/10/03(火) 02:20:47.65 ID:upqeSfz9.net] 復活したのは良いけど、一言何か無いのかよ。誰が管理してるんだ。
999 名前:979 mailto:sage [2017/10/05(木) 12:08:08.18 ID:SZzrAZT5.net] 日本語訳の古さに苦戦しつつLogic.vまで進めていたところ…… 久しぶりに英語の本家を見たら、 なんかVol.1 〜 Vol.3に増えてるー!? あまりの道のりの遠さに絶望しつつ内容を見ると、 旧版からホーア理論まわりをVol..2に分離し、 Vol.3は赤黒木等の少し高度なデータ構造について色々とCoqで証明して感じらしい(新規)。 ……く、面白そうじゃないか。
1000 名前:デフォルトの名無しさん mailto:sage [2017/10/05(木) 19:45:51.56 ID:72rIdNeW.net] >>981 リンクpls
1001 名前:デフォルトの名無しさん mailto:sage [2017/10/07(土) 12:06:25.63 ID:689sKi0/.net] >>988 https://softwarefoundations.cis.upenn.edu/
1002 名前:979 mailto:sage [2017/10/30(月) 19:39:25.32 ID:asGH9s/c.net] ここ一ヶ月、旧くなった日本語版を捨て英語版に再挑戦してみた。 以前は出来るだけ写経していたが時間がかかり過ぎるので、 付属の.vファイルを直接書き換える方針に変更。 結構章立てと共に内容変わってるなぁ……追加された良問も多いし。 英語の非形式的証明は書く機会もなさそうだし、パスするか。 しかし、答えがWeb上に転がってないのは自習者には正直辛い。 どうもSICPみたいな標準教科書を目指してるっぽい? こーゆうの(coq)を国立研究所で作れる国はやっぱり凄いと思う今日この頃。
1003 名前:デフォルトの名無しさん mailto:sage [2017/11/01(水) 07:27:01.78 ID:wuKEf1Sh.net] a
1004 名前:デフォルトの名無しさん mailto:sage [2017/11/01(水) 07:27:36.60 ID:wuKEf1Sh.net] sit
1005 名前:デフォルトの名無しさん mailto:sage [2017/11/01(水) 07:27:56.41 ID:wuKEf1Sh.net] dot
1006 名前:デフォルトの名無しさん mailto:sage [2017/11/01(水) 07:28:13.79 ID:wuKEf1Sh.net] egg
1007 名前:デフォルトの名無しさん mailto:sage [2017/11/01(水) 07:28:31.25 ID:wuKEf1Sh.net] nø
1008 名前:デフォルトの名無しさん mailto:sage [2017/11/01(水) 07:28:48.81 ID:wuKEf1Sh.net] this
1009 名前:デフォルトの名無しさん mailto:sage [2017/11/01(水) 07:29:26.33 ID:wuKEf1Sh.net] combi
1010 名前:デフォルトの名無しさん mailto:sage [2017/11/01(水) 07:30:08.09 ID:wuKEf1Sh.net] it
1011 名前:デフォルトの名無しさん mailto:sage [2017/11/01(水) 07:30:42.85 ID:wuKEf1Sh.net] 2
1012 名前:デフォルトの名無しさん mailto:sage [2017/11/01(水) 07:31:16.98 ID:wuKEf1Sh.net] ping
1013 名前:デフォルトの名無しさん mailto:sage [2017/11/01(水) 07:32:05.81 ID:wuKEf1Sh.net] pong
1014 名前:デフォルトの名無しさん mailto:sage [2017/11/01(水) 07:32:32.73 ID:wuKEf1Sh.net] wild
1015 名前:1001 [Over 1000 Thread.net] このスレッドは1000を超えました。 新しいスレッドを立ててください。 life time: 3061日 0時間 17分 11秒
1016 名前:過去ログ ★ [[過去ログ]] ■ このスレッドは過去ログ倉庫に格納されています