関数型言語ML (SML, OCaml, etc.), Part 6

このエントリーをはてなブックマークに追加
866デフォルトの名無しさん:2014/08/30(土) 23:41:43.96 ID://K1VbLN
test
867デフォルトの名無しさん:2014/09/02(火) 08:32:32.40 ID:3nEDqgz+
OCamlのマニュアルにocamlbrowserがまだあるのはバグっすな

ocamldoc/trunk/manual/cmds/Makefile line#2
remove "browser.tex "
868デフォルトの名無しさん:2014/09/02(火) 22:57:08.51 ID:h4iRRc1G
ocaml標準のlexでは日本語が扱えないのでulexに差し替えたらparserが死んだでござる。
ダメだこりゃ
869デフォルトの名無しさん:2014/09/16(火) 16:34:15.58 ID:smkPtKEd
870デフォルトの名無しさん:2014/09/24(水) 22:11:44.77 ID:ChDiOOXp
ocaml 4.01.0で
# Obj.size @@ Obj.repr 1
がバグるんだけど、理由わかる?
871デフォルトの名無しさん:2014/09/24(水) 23:08:38.11 ID:wtmzOZEz
仕様です。
ソースはおろかドキュメントすら読まずにObjを使うとはアホの極みです。

Chapter "Interfacing C with OCaml", Section 2..3
872デフォルトの名無しさん:2014/09/26(金) 02:16:11.74 ID:63HfXufw
OCamlのすごさはもっと知られるべき #オブジェクト指向 や #関数型 は「敗者の道具」である http://itpro.nikkeibp.co.jp/atcl/watcher/14/334361/092200062/?ST=develop&P=3
873デフォルトの名無しさん:2014/09/26(金) 11:58:16.90 ID:p4JSIuT/
>>872
これタイトルで損してる記事だろ
874デフォルトの名無しさん:2014/09/26(金) 11:59:36.06 ID:LJo7FzMV
みかかデータ、マンセー記事っぽかったけど
875デフォルトの名無しさん:2014/09/26(金) 12:42:39.46 ID:/S6uCtFc
関数型とかマルチパラ代務とかドカタには無理。オブジェクトだって散々語られてようやく、いや未だ、か

一部の突出した集団以外は、ほかにどうしようもない人が沈殿する職業になってるイメージ
876デフォルトの名無しさん:2014/09/26(金) 20:12:51.02 ID:+dkMIegW
do構文の使用禁止の規約って全部>>=で書くってことなのだろうか。理由も含めて気になる。
877デフォルトの名無しさん:2014/09/26(金) 20:54:07.13 ID:mU/FSdzC
>>872
前半で散々オブジェクト指向をこきおろしておきながら、
中盤でOCamlを推すという意味不明な文章の論理の展開がある
ML族を推すのなら Caml か SML にしないと一貫性が無いし、
Caml にオブジェクト指向を後付けした "O"Caml 開発時の判断は
今となっては流行に踊らされた大きな失敗であったと断罪すべき

おまけに「個人的にOCamlがすごいと思う」とあるから何かと読んでみたら、
単なるパラメタ型多相の話でしかないことに笑ってしまった
「とがった」とか「すごい」とか、小学生の感想文とレベルは変わらない
こんなポエム記事で給料をもらえるのだから、日経ITproの記者とは楽な職業だね

>>873
タイトル以前の問題で、記事に中身が無くて話にならん

>>876
ソースコード解析ツールなら言語処理系と似た構造になるから、
(一般的には副作用を模倣するために使われる)do記法を使う必要性は無いと思われ
878デフォルトの名無しさん:2014/09/26(金) 21:11:21.88 ID:+dkMIegW
ちょっとぐぐってみたらこういうページがあった。
http://www.haskell.org/haskellwiki/Do_notation_considered_harmful
879デフォルトの名無しさん:2014/09/26(金) 21:24:18.32 ID:rzI+KhbO
たしかにタイトルで損したみたいだな
880デフォルトの名無しさん:2014/09/27(土) 09:02:30.03 ID:aRJ76A2x
ああいう煽り記事読んでドキドキするのは思春期の子供だけ
もっと大人向けの真面目に面白い記事は無いのか?
881デフォルトの名無しさん:2014/09/27(土) 09:08:36.15 ID:V9AoMXji
 もし完全無欠のプログラマが存在するのであれば、そうした方法論に頼らなくても、
完全に意図通りに動作するプログラムを頭から書き下していけばいいのです。
オブジェクト指向プログラミングや関数型プログラミングは、不完全な人間のために用意されたもの、
いわば「敗者の道具」といえます。

 もちろん、これは極端すぎる表現です。例えば、人は空を飛べないので飛行機に乗ります。
このことをもって「飛行機は敗者の道具である」と言う人はいません。
そうした意味では、オブジェクト指向プログラミングや関数型プログラミングを敗者の道具と呼ぶのは、
単なる言葉遊びにすぎません。人間が全知全能でないのは当たり前ですから。



完全に朝日脳だな
882デフォルトの名無しさん:2014/09/27(土) 17:11:59.10 ID:lJpImKEe
産経信者も一緒に死ねカス
883デフォルトの名無しさん:2014/09/28(日) 11:09:58.25 ID:yTX/1oq/
今回朝日がしでかしたことを誰かまとめてくれ
884デフォルトの名無しさん:2014/09/28(日) 12:21:46.09 ID:MFWVwvB9
スレ違いカスはお引き取り下さい
885デフォルトの名無しさん:2014/09/28(日) 12:22:16.97 ID:/z7vQ2zP
>>883
どいたかこ死亡
886デフォルトの名無しさん:2014/09/28(日) 12:38:21.08 ID:3fm9b2hk
土井たか子がリアルに退いた過去になったのか
887デフォルトの名無しさん:2014/09/28(日) 12:39:24.70 ID:/z7vQ2zP
土井がどいた過去
888デフォルトの名無しさん:2014/09/28(日) 12:40:25.54 ID:/z7vQ2zP
おんたけさんが噴火して
おたけさんが逝った
889デフォルトの名無しさん:2014/10/07(火) 01:19:25.02 ID:RDe60glL
対話環境を再起動せずに、リコンパイルしたライブラリをロードし直す方法ってありますか?
#load でもう一度ロードすると、シグニチャが異なると怒られてしまいます
890デフォルトの名無しさん:2014/11/07(金) 22:47:28.24 ID:jjvVlXlA
OCamlで型クラスを実現する方法ある?
あとカインドも
891デフォルトの名無しさん:2014/12/28(日) 01:38:33.30 ID:t9XFY33G
モジュールで型クラス的なものを作ることができる。便利とは言いがたいが
892デフォルトの名無しさん:2015/02/05(木) 08:14:28.48 ID:0RN82SQI
Haskell より OCaml の方が部分部分で好みなんだけど、
OCaml は最近何か進展とか発展とか無いのかな。
893デフォルトの名無しさん:2015/02/05(木) 13:15:20.83 ID:tkrhoEGU
4.0出たばっかじゃなかったっけ
894デフォルトの名無しさん:2015/02/05(木) 14:50:21.24 ID:j+EW35P1
岡村はソース醜いのがなあ
895デフォルトの名無しさん:2015/02/05(木) 19:17:09.87 ID:Omd6cUWA
>>894
たとえば?
896デフォルトの名無しさん:2015/02/05(木) 20:40:25.53 ID:SFYHhnYx
上から読んでいけば何しているのか分かるOCamlのソースは読みやすい部類
batteriesとかcoreといった大きいライブラリでも、モジュールと同名のファイル見ればいいだけなので、
どこに何があるのか探しやすい

基本的に手続き脳なので、haskellはどこから読めばいいのか分からない
悪名高いimport文のおかげでもっと読めない
897デフォルトの名無しさん:2015/02/05(木) 21:27:52.95 ID:uGoWQo5h
OCamlなんとなくソースの見た目のバランスが悪いっていうのはなんかわかるわ。
898894:2015/02/06(金) 00:00:17.76 ID:mrZTa4bi
>>897
まさにそんなとこ。ぱっと見よくない
899デフォルトの名無しさん:2015/02/06(金) 11:46:04.54 ID:qvKWViHE
ソースが読みにくい言語は致命的に生産&保守効率が悪い。
900デフォルトの名無しさん:2015/02/06(金) 11:56:15.06 ID:uqQOSJHn
>>898

SMLならいいの?
901デフォルトの名無しさん:2015/02/19(木) 21:32:44.77 ID:VWBqr6Q7
レコード型ある言語、多相レコードある言語、フィールドがファーストクラスにできる言語
おしえて。
ぜんぶもってるのがいい。
902デフォルトの名無しさん:2015/02/19(木) 22:31:13.58 ID:/rXoqLFu
>>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#解説
 http://www.pllab.riec.tohoku.ac.jp/smlsharp/docs/2.0/ja/Ch7.xhtml
903デフォルトの名無しさん:2015/02/19(木) 22:34:08.05 ID:VWBqr6Q7
↑ありがと。
ほんとにぜんぶ!? フィールドファーストクラスなのその言語?
904デフォルトの名無しさん:2015/02/19(木) 22:35:11.19 ID:VWBqr6Q7
あ、かいてあった、ごめん。
905デフォルトの名無しさん:2015/02/19(木) 22:37:49.31 ID:VWBqr6Q7
SML/NJってやつは、フィールドがファーストじゃないとして、
SML#ってやつはファーストなの?

ほかにも>>900 全部持ってる言語とかあればおしえて。みんな。
906デフォルトの名無しさん:2015/02/20(金) 03:39:21.83 ID:V63A/fo0
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みたして相だけどコンパイル時に型ちぇっくしてくれないよねそれ?
  うーんなんかない?
907デフォルトの名無しさん:2015/02/20(金) 09:34:49.39 ID:vrO8Sxqb
1
908デフォルトの名無しさん:2015/02/20(金) 10:31:17.89 ID:N6pKHonh
じゃあ俺は2
909デフォルトの名無しさん:2015/02/20(金) 10:55:47.88 ID:sOgXDRpH
宿題は自力でやれw
910デフォルトの名無しさん:2015/02/21(土) 00:55:59.35 ID:KgB/c0aN
>>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(とそのすべての処理系)のフィールドはファーストクラスである
911デフォルトの名無しさん:2015/02/21(土) 01:03:27.14 ID:KaIHMFIz
>   - val get_x = #X : {X: real, Y: 'a} -> real;
でもこの get_x って、>>902 の point_3d には使えないよね。
912デフォルトの名無しさん:2015/02/21(土) 01:45:43.43 ID:KgB/c0aN
うん、使えない
それが >>910 で書いた(Standard ML言語仕様における)「型システム」の制約だね
その制約を無くした SML# が特異なだけで、SML/NJ 以外の大半の SML 処理系に同じ制約がある
913デフォルトの名無しさん:2015/02/21(土) 20:03:59.94 ID:KgB/c0aN
>>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} という部分型関係を持つ
914片山博文MZ ◆T6xkBnTXz7B0 :2015/03/06(金) 00:20:10.28 ID:Utx2vhNJ
MLで株取引してるヤツおる?
915デフォルトの名無しさん