Windowsでのインストールは、
>>1から
Mac/LinuxでF#を使うにはmonoが必要です。
http://mono-project.com/ IDEにMonoDevelopを利用するなら、現時点ではmono-2.6系が必要です。
mono-2.10.1以降でF#が統合されていますので、IDEが必要ないならそのままCLI環境が使えます。
なんにせよ茨の道ですので、まずはブラウザ環境で実行できるTry F#のTutorialsを試しましょう。
Windowsでも(C#やCと組み合わせるなら、VS2010 C#/C++ Expressと) VS2010 Shell、F#2.0を組み合わせた
無償のIDE環境が使えます。
言語の特徴としてはScalaとF#はそっくりだと思う。
*型推論:
F#,Scala -> ◯
C#,Java -> △,×
*代数データ型:
F#,Scala -> ◯
C#,Java -> ×
*パターンマッチ:
F#,Scala -> ◯
C#,Java -> ×
nullの廃止
F#,Scala -> ◯
C#,Java -> ×
モナド:
F#,Scala -> ◯
C#,Java -> ×
高階関数:
F#,Scala -> ◯
C#,Java -> △,×
変数:
F#,Scala -> デフォルトで破壊できない
C#,Java -> デフォルトで破壊できる
対話環境:
F#,Scala -> ◯
C#,Java -> ×
JavaからScalaへの大移動が始まっているのと同様のことがC#からF#に起こるに違いない!と言うのも本当かもしれない。
---------
要望があったやつ追加
>>7 乙
名古屋ではF#が結構使われているという話を聞いたんだけど、やっぱり
自動車関係の仕事が多いからなのか?
名古屋怖い(´・ω・`)
コード共有するのには、IdeOneみたいなサービスがいいけど、
F# InteractiveのWebコンソールとしては、これが便利かも。
Try F# in your web browser
http://tryfs.net/
そもそもなんでF#はF#という名前になったの?
FはFunctionのF?
あとC#がC++++から#になっているのは理解できるけど、
F++はもちろんF言語なんて聞いたことがないんだけど。
C#の名前を結構気に入ってたから、.NET言語になんでも#つけてた時期がある。
>>13 j#の後釜だからじゃね?
fは探せば有りそうだし
>>16 schemeが#Sなのにcommon LispがL#な所は狡猾さを感じるなw
宗教論争とか起きなかったんかね
F#で標準入力を遅延リストみたいに扱う方法ってあるのでしょうか?
24 :
デフォルトの名無しさん:2011/05/09(月) 19:18:09.17
scalaとF#使うならどっち?
>>24 MSならF#、それ以外ならScala。
構文は全然違うけど言語パラダイムはそっくりだから俺は両方勉強してるぜ。なかなかためになる。
26 :
デフォルトの名無しさん:2011/05/09(月) 22:19:12.87
誰かC#とF#の比較してくれねーかなー
違いすぎる→そんなに違わないな→やっぱ違うわ→まあ、同じとも言えるな。こんな感じが延々と続く。C#とF#の比較。
>>7の「高階関数」でC#が△になってるのはなんか理由あんのかな
っていうか、「ファーストクラスの関数」でよくね
tail call elimination
nested functions
automatic currying
cons, tuple
list comprehension
あたりも比較項目につけくわえていい気がする
bingでF#検索すると残念なことに・・・
>>7 そっくりなところを比べればそりゃそっくりだろうさ
>>29 *tail call elimination
Java,C# -> ×
Scala,F# -> ○
*nested functions
Java,C# -> ×,△
Scala,F# -> ○
*automatic currying
Java,C#,Scala -> ×
F# -> ○
*cons, tuple
Java,C# -> ×
Scala,F# -> ○
*list comprehension
Java,C# -> ×
Scala,F# -> ○
Actorモデル
Scala->○
F#->○に近い△
C#,Jave->×
って感じ?ちょっと不勉強なので正確かわからん。
>>32 Scala は JVM の制限とかで tail call elimination ができないときがあるような
@tailrec アノテーションをつけておけば、できかなったときは教えてくれるけど
Scala は list comprehension あるんだっけ
for 式だったら、あれはどちらかというと Haskell の do に近いような
>>32 tail callは64ビット版.NET Framework は、ILがTailとマークしてなくても最適化してくれる(制限あり)。
あと、LINQはある意味list comprehensionsの一種なので、C#が×は納得いかない。
>>35 LINQでlist comprehension できるのか。知らなかった。
Haskellでの[x+y | x <- [0..9], y <- [0..9], x<y] みたいなのもLINQを使えば書けるのか?
LINQだと
from x in Enumerable.Range(0, 10)
from y in Enumerable.Range(0, 10)
where x < y
select x + y
とかそんな感じだろう
だれかF#でMonotouch開発しようとしてる人とかおらん?(´・ω・`)
F#にMonotouchが対応するのって、そもそも技術的に難しいんだっけ? Dictionary<int,Hoge>とかを使えないとかの制限にからんで。
それともF#なんかマイナー言語相手にしてる暇ねーぜヒャッハーってだけ?
FSharp.CoreとかのライブラリーをILAssembly使ってターゲット変えてゴニョゴニョすれば動くようになるとか言ってる人もいたんだけど。
Silverlightで同じようなことしてる人のBlogあったんだけどリンク切れちゃってた。
暇な人は"Reusing-NET-Assemblies-in-Silverlight"でぐぐって最初のエントリーのキャッシュ見てくんなまし。
monoは今レイオフされたり会社設立したりと本体がゴタゴタしててそれどころじゃないんだろ
>それともF#なんかマイナー言語相手にしてる暇ねーぜヒャッハーってだけ?
被害妄想?
しかしまあF#ってScalaほど必要とされている感がないんだよなー
なまじC#がよくできてるから
企業の後ろだてのある言語じゃなく、1研究社が作った言語が注目集めるとかおかしいだろ。
どんだけJavaはアレなんだよ。
>>42 確かにScalaは多くのJava技術者に注目を浴びているけど、Scalaいいって
言う人の言うことはそのままF#にも当てはまるんだよね。
ScalaがF#に比べて人気ある理由はC#がJavaより良くできているという以外に
構文がJavaから大きく離れてはいないという点があると思う。Javaコードを
コピペして微修正すればScalaコードとして動くし、Scalaコードを見てもある程度
読めそうな気になるから移行しやすいんだよね。
一方F#は構文が違いすぎるし、初見だと全然読めない。このとっつきにくさが
結構効いているんじゃないかな。
でもF#は関数型言語としてScalaよりずっといい線行っている(構文はキモいけど)
ので、Scalaへの大移動が現実になったときC#erはF#への移動を準備すべき。
C#erがレガシーな理由のみで残りつづけて老害とならないようになってほしい。
ScalaはGood Java。Javaに取って代わることを目標としているマルチパラダイム言語。
F#はあくまでもC#の補完。.NETファミリーの関数型言語の位置づけ。
scalaは関数型的な使い方をしなくてもいろいろ遊べる。
最初の関数型言語にScalaを選んでしまった場合、
Good Javaの部分だけで腹いっぱいになって関数型までたどり着けないことが多い。
Scalaは、未来のJavaを先取りした言語と表現してるが、
Scalaと同じ機能がある未来のJavaは構文がもっと複雑なんだろうな。
Scalaは関数型ってだけじゃなくてオブジェクト指向言語としてもJavaより進んでるのがウケてる理由の一つの気がするな
49 :
デフォルトの名無しさん:2011/05/30(月) 19:59:14.67
C#もまだ未熟なんだけどF#に手を出してみたよ!!
で、F#難し過ぎて、はやくも挫折しそうなんだけど・・・
ちょっと質問。
クラスのスコープ内に関数を定義したかったらC#の場合、こうできる。
class 振り分け{
double[] ratio;
public 振り分け(){
initRatio();
}
private initRatio(){うんたらかんたら}
}
同じことをF#でやる場合staticなメンバにしないといけないのかな?
type 振り分け=
class
val mutable ratio: float[]
static member initRatio=うんたらかんたら
new(){ratio=initRatio}
うーん、ようわからんwww
50 :
デフォルトの名無しさん:2011/05/30(月) 20:03:43.87
F#の嫌なところを1個見つけたよ。
インデント?空白?によって
ブロック的なものが決まることかなぁ。
だから、必然的に自動整形ってできないんだよね?
複数行選択後のtab/shift+tabができなかったら、
発狂するレベルだねw
あとは、クラスを定義する時の修飾子の多さも、ちょっとうんざりだよね;;
どういう書き方が一番エレガントなんだろう・・・
関数を定義する順番に依存しちゃうってのも、なんというか・・・
そこら辺はやっぱりscalaの方が上っぽい?
>>50 ・オフサイドルールはうつくしい。まだまだシロートのようだな
・クラスあんまし書かないのがF#流だから木にスンナ
・偽関数型言語でよければScalaでおk
52 :
デフォルトの名無しさん:2011/05/30(月) 22:48:20.11
>>51 カッコよりはインデントの方が良いとは思うが・・・
自動整形欲しいよorz
クラス使わないって厳しくない?
Scalaのどの辺が偽なの?F#も偽だと思うけど。
>>49 type Foo() =
let initRatio() : float array = Array.map ( (*) 2.0 ) [|1.1;2.2;3.3|]
let mutable ratio = initRatio()
member x.Say() = printfn "%A" ratio
let _ =
let foo = new Foo()
foo.Say()
namespace Algebra
type Vector(elements: float[])=
member this.size=elements.Length
member this.elements=elements
member this.Item
with get i = elements.[i]
member this.squaredNorm=Vector.dot(this,this)
static member (~-) (v: Vector)=
new Vector([| for i in 0 .. v.size-1 -> -v.[i] |])
static member OP2 (v1:Vector) (v2:Vector) op=
new Vector([| for i in 0 .. v1.size-1 -> op v1.[i] v2.[i] |])
static member (+) (v1: Vector, v2: Vector)=
Vector.OP2 v1 v2 (fun x y -> x+y)
//new Vector([| for i in 0 .. v1.size-1 -> v1.[i]+v2.[i] |])
static member (-) (v1: Vector, v2: Vector)=
Vector.OP2 v1 v2 (fun x y -> x-y)
static member (.*) (v1: Vector, v2: Vector)=
Vector.OP2 v1 v2 (fun x y -> x*y)
static member (./) (v1: Vector, v2: Vector)=
Vector.OP2 v1 v2 (fun x y -> x/y)
static member (*) (a: float, v: Vector)=
new Vector([| for i in 0 .. v.size-1 -> a*v.[i] |])
static member (*) (v: Vector, a: float)=a*v
static member (/) (v: Vector, a)=(1./a)*v
static member dot (v1: Vector, v2: Vector)=
Array.reduce (fun x y -> x+y) (v1.*v2).elements
override this.ToString() =
"("+(Array.fold (fun (x:string) (y:float) -> x+","+string(y))
(string(elements.[0])) elements.[1..])+")"
インデントが全部消えてごめんなさい。
疑問点
・OP2をletで定義できないのはなぜだろうか?
・intからfloatへの変換は自動でできないのだろうか?
57 :
デフォルトの名無しさん:2011/05/31(火) 21:12:59.18
関数型の本質は型推論によって、関数が気軽に定義できることだろうか?
例えばList.reduceはJavaでもC#でも、簡単に実装できる。
だけど、気軽に使うためには、
foldに与える関数を気軽に定義できなきゃいけない。
T arg_reduce(T t, S s)
こういう関数を簡単に定義できる枠組みを与えるのが関数型言語なんだろうか?
59 :
デフォルトの名無しさん:2011/05/31(火) 22:51:27.68
>>58 >静的メソッドからはこのフィールドにアクセスできません。
って書いてありました。ありがとう。
それはそうとdoバインディングってなんだろw
関数型の本質()とかどうでもいいわ。
問題は単にF#が便利なのかどうかだわ。
>>60 クラスブラウザがVSに実装されるまでは大規模開発が難しいのと
GUIエディタが無い現状はC#の代替にはならないかな、と思った。
F#は関数をさくさく作れる。
C#のクラス定義は単純明快だけど、
F#のクラス定義の方法は難解で、冗長で、読みにくいが、改行は少ない。
F#のyieldは便利。F#の()は読みにくい。F#のSeqは美しい。
F#は基本的に読みにくい。
>>61 F#のクラス定義の方法は
難解で読みにくいってのはまあ慣れと好みだが
冗長でってのはどうかね?
C#のクラス定義は単純明快ってのは
私はC#のクラス定義に慣れているんです
って以外に意味を持たない主張に思えるが。
63 :
デフォルトの名無しさん:2011/06/01(水) 01:15:18.81
memberがいらないとか・・・
全然明らかじゃないからkwsk
F#ではfun x y ->x+yをx y->x+yに出来なかった言語仕様上の問題とかあったん?
>>64 クラスを定義してるのが明らかなのだから、
memberという修飾子はいらない。
あと、そもそもletが冗長なのと
副作用がないならnewを省略したい。
下記のようなシンプルさが欲しい。
class A(a:float)
add b = A(a + b)
minus b = A(a - b)
inc = add 1
dinc = this.inc.inc
この場合、IDE側でクラス名と関数名に色をつけてくれないと
クソ読みにくい。オフサイドルールの欠点。
あとandもクソ仕様。
funは正直鬱陶しいなあ。
68 :
デフォルトの名無しさん:2011/06/01(水) 18:40:51.63
F#やってて、便利と思うのは
関数の中に関数をかけることだな。
しかも、F#における関数はOOPでいう関数ではなく、
OOPのクラスに相当する。
逆に不便だなって思うことは、共通して使う関数を作った時に
どこへ置けばいいかわからないこと。F#はスコープの制御がダメだね。
>>65 OCaml互換。C#の人かな。\x ->ならまだしもx ->はさすがに無理くねーか。
>>67 気持ちはわかります。
>>66 クラス内にはletとdoもかけるぞ。あとコンストラクタはメンバじゃねえ。
>>68 どこ置けばいいかわからない?F#でだけ?どの言語でも同じじゃまいか。
あと自動整形できないからっての、よくわからん。
整形されたコードしかコンパイル通らんのだから
そもそも整形する必要ないじゃんか。
まあ俺もオフサイドルール嫌いだけど。
オフサイドルールをやめるとすると、
他の選択肢ってなんだろ?
一つは{}だよね。
あれーC#から使う時に、F#のunionの各サブクラスへの変換とかなんかメソッドなかったっけ
FSharpUnion<Employee>.get_Manager的な。
isManagerでしてから普通にキャストすればよかったんだっけ?
FSIにnamespaceとかopenて流し込めないんだね・・・
デバッグの途中で
add 1 2
とか打てたらいいんだけど・・・
F#ってデバッグが難しいね;;
>>72 サブクラスとか、キャストとか、なんか根本的に間違ってないか。
>>74 openは流せる。まさかopen Listがエラーだからとか言わないよね?
76 :
デフォルトの名無しさん:2011/06/02(木) 22:05:03.83
>>75 あぁ、ごめん。書き方が悪かった。
自分で定義したnamespaceを
openすることができないってことでした。すいません。
>75
いやC#からだとUnionそういう風にしか扱えなくなかったっけ?
そのUnionのインスタンスでIsManagerとかよべるけど。ManagerであるUnion値をManagerとして扱いたいときにどうしたらいいかって話。
もっとまともな方法あったっけ?
>>77 type Employee = ... | Manager of Hoge の場合↓
var emp = Employee.NewManager(hoge);
if (emp.IsManager) {
var mngr = ((Employee.Manager)emp).Item;
// dosomething
}
だからDesign Guidelinesにはまんま使うなと書いてある。
誰かF#のいいデバッグ方法教えてー
F#のC#に対して優れているところを教えてください
>>80 協力な型推論、nullがない、パターンマッチ、関数内関数ができる、対話環境、並列計算に強い
とかじゃね。
nullって悪者なんですか・・・
パターンマッチ、並列計算に強い はおもしろそう
>78
あーやっぱりそんな感じかー
>79
自分も最初は悩んでたけど、最近はなんも困ってないな。なんでだろ。途中でうまく止めて値見るのとWriteLineで出しとくのとヘルパーとか使ってFSharpFunc楽に実行できるようにしたところか?
そもそもDebugが必要になる羽目になることが少なくなったというのもある気がするが。
>80
Debugしながらでもソースがいじれるところ。
>>83 Debugしながらでもソースがいじれる・・・イイ!
まあ、どんなの場面でもnull不要とはいわないけども、
Anders Hejlsbergも「nullableの概念は参照型/値型の概念とは独立させておくべきだった」っていってるしね。
非nullable参照型は欲しい。
>>86 関数型言語にはnullは必要ないよ。関数型プログラマはnull参照エラーみたいなアホみたいな実行時エラーとは
無縁の世界でプログラムしているよ。
88 :
デフォルトの名無しさん:2011/06/05(日) 00:00:41.87
>>83 FSharpFuncってなんですか?
数値計算のプログラムを作ってる時は、
デバッグは絶対必要なんですよね・・・
関数の形で定義してると、途中で止めても
中の数値が見れないんですよねorz
let x=f a
とかしちゃってる時に、
f 1
の値を見る方法がないと、数値計算のプログラムのデバッグは
無理かなーと。
現状のF#を数値計算に使うと死ぬかも・・・・
伝統のprintfデバッグじゃダメ?
let dbg x = printfn "*debug:%A" x; x;;
こんな感じで使う。
[1..10] |> List.map ((+) 1) |> dbg |> List.map(fun x -> dbg(float x / 2.0));;
90 :
デフォルトの名無しさん:2011/06/05(日) 12:12:50.78
>>89 %Aでリスト(行列)を全表示できるのかな?
そうなら、そういう関数作っておけば、確かに楽そうだね。
DOS窓かよって不満はあるけどw
それやってみるよ。ありがと。
また、ただ、いろいろ細かい状態が知りたかったりするから
デバッグ中に値が知りたいというニーズは多いし、
あとはけっこう量が多いんだよね・・・うーん。
そういえばVSのデバッガは何だかんだでC#前提なままだったね。
> FSharpFuncってなんですか?
関数の型。クロージャ作るとそゆ型が付く。
まーF#の中にいる限りは特に意識する必要ないが。
C#と連携したいなら覚えておくといいかも。
93 :
デフォルトの名無しさん:2011/06/07(火) 12:29:28.85
F#のイディオム的なテクニックを教えてほしいな。
例えば、クロージャーとか簡単なもの。
使い始めたんだけど、上手く使えてるか自信がない。
F#ならではの書き方あったら教えてください。
>>93 関数型の場合何やるにも再帰。
とくに末尾再帰はしっかりみにつけるべき。
>>93 非関数型プログラマ: forやwhileループを使う
関数型入門者: 再起を使う
中級者: map, foldをなるべく使う
これが割と参考になるかも。
文字列のlistがあって、その文字列を表示できる矩形を重ならないように上から並べたrectと文字列のタプルのリスト返せっつったら、foldで次のトップと結果のlistを状態にするような感じでよろし?
こういうのにfold使うのなんか微妙に違和感あるんだけれどこんなもんかね@関数型初心者。
>>99 こんな感じ?
let union rect1 rect2 = new Rect(rect1.x, rect1.y, max rect1.width rect2.width, rect1.height+rect2.height) in
ss
|> map (fun s -> getRectOf(s))
|> fold union empty_rect
F#って末尾最適化はやってくれている?
コンパイル時に .tail がつく
F#で文字の連結ってどうするんですか?
+でできるのはわかるんですが、これだと遅いですよね?
いっておくがStringBufferみたいなものはないからな
StringBuilder使えって言っておけばいいのかな
末尾最適化になってるはずなんだがstackOverFlowになるってことはなってないんだろうなぁ・・・何か確認する方法あったっけ。
そもそも要素一つずつ減らしてるから無限ループになるはずないのに4千件ぐらいでStackOverFlowになるってなんか変だ。
Console.WriteLineで出力しても途中まで減ってってるのに突然何も出さなくなって5秒ぐらいしてからStackOverFlowが出てもうわけわかめ(´;ω;`)ブワッ
.tailプリフィックス付いてても状況によっては無視されるって奴かな?
109 :
106:2011/06/09(木) 08:39:36.40
あれーインタラクティブに流し込んだらもっとたくさん流し込んでもさっくり動くよ…
そもそもデバッガーだと末尾最適化しないとかあったっけ?いやそんなことないよね…
問題だけどインタラクティブでさっくり動いたコードとりあえずまるっと載せてみる
let inRange from t v=from<=v&&v<=t
//rangeによってポイントをまとめる。
//現在のrange=from〜tに合うならptListに追加。
//合わないなら今までのptListを一組としてptListListに追加し、新しいポイントとしてptListに追加。
//合うrangeがなくなるか、iListが空になったら抜ける。
let rec toPtrListList (ptList,ptListList,((from,t)::rangeList)) (i::iList) indToInter indToVal=
// Console.WriteLine("toPtrLL----{0}",System.Environment.TickCount)
// Console.WriteLine ("toPtrLL iList={0},rangeL={1}",List.length iList,rangeList.Length)
let inter=indToInter i
let toPt()=inter,indToVal i
//System.Drawing.PointF(float32<|trans.XInterToUI inter,toUIY series.[i]|>float32)
//helper-----
//合うrangeを探してそれ以降を返す。
let rec findFitRange rangeList inter=
// Console.WriteLine("findFitR {0}",System.Environment.TickCount)
match rangeList with
|[]->None
|(from,t)::tail->
if inRange from t inter then Some rangeList
else findFitRange tail inter
//iListが空ならその時点のを結果とする。有るなら続き。
110 :
106:2011/06/09(木) 08:40:17.92
//続き
let contOrBreak (ptList,ptListList,rangeList) iList=
// Console.WriteLine ("contOrBreak iList={0}",List.length iList)
match iList with
|[]->[],ptList::ptListList,rangeList
|_->toPtrListList (ptList,ptListList,rangeList) iList indToInter indToVal
// Console.WriteLine("toPtrLL---before helper {0}",System.Environment.TickCount)
//-----helper
if inRange from t inter then
//現在のrangeに合う。
contOrBreak (toPt()::ptList,ptListList,((from,t)::rangeList)) iList
else
//rangeに合わない
if t<inter then
//現在のrangeよりinterが先。
match findFitRange rangeList inter with
|Some (rangeList)->
//fitするものがあったのですすめる。
contOrBreak ([toPt()],ptList::ptListList,rangeList) iList
//なかったので現在のものを結果とする。
|_->[0,0],ptList::ptListList,(from,t)::rangeList
//inter<fromなので今のindを捨てる。
else
// Console.WriteLine ("hogehoge iList={0}",iList.Length)
contOrBreak (ptList,ptListList,((from,t)::rangeList)) iList
let test=
toPtrListList ([],[],[0,10000;10001,20000;20001,30000]) ([0..50000]@[0..100]) id (fun i->i+100000)
111 :
106:2011/06/09(木) 08:43:47.05
インデントが(;´Д`)
let inRange from t v=from<=v&&v<=t
//rangeによってポイントをまとめる。
//現在のrange=from〜tに合うならptListに追加。
//合わないなら今までのptListを一組としてptListListに追加し、新しいポイントとしてptListに追加。
//合うrangeがなくなるか、iListが空になったら抜ける。
let rec toPtrListList (ptList,ptListList,((from,t)::rangeList)) (i::iList) indToInter indToVal=
// Console.WriteLine("toPtrLL----{0}",System.Environment.TickCount)
// Console.WriteLine ("toPtrLL iList={0},rangeL={1}",List.length iList,rangeList.Length)
let inter=indToInter i
let toPt()=inter,indToVal i
//System.Drawing.PointF(float32<|trans.XInterToUI inter,toUIY series.[i]|>float32)
//helper-----
//合うrangeを探してそれ以降を返す。
let rec findFitRange rangeList inter=
// Console.WriteLine("findFitR {0}",System.Environment.TickCount)
match rangeList with
|[]->None
|(from,t)::tail->
if inRange from t inter then Some rangeList
else findFitRange tail inter
//iListが空ならその時点のを結果とする。有るなら続き。
112 :
106:2011/06/09(木) 08:44:27.70
スペースを入れてもダメか。俺\(^o^)/オワタ
htmlレンダリングの問題だけで、スレに書き込まれてるソース的には空白やタブ残ってたと思った。
リンク貼る形式なら、gistや>11の使うといいと思う
>>106 よくわからんがfindFitRangeは再帰しなくても高階関数使った方がシンプル
let inRange v (from, t) = from<=v&&v<=t
let isFit v ranges = ranges.exists(isRange v)
let findFitRange ranges inter =
if (isFit inter ranges) then Some ranges
else None
117 :
106:2011/06/09(木) 11:37:16.53
>113-116
オマイラあり\(^o^)/
>115
いや、リストをなめていって見つかったらそれと、それ以降のやつをタプルで返してるのでそのやり方だとミリ。
なんかうまい高階関数あるのかもしれんが。
>118
それ条件で振り分けるやつだからちょと違うと思われ
というか自己解決したかも。
プロジェクトの設定でビルドタブに"tail呼び出しの生成"って項目あってそれオンにしたらサックリ動いた。
ってもこれ付けたらデバッグとかしにくくなんのかな。
お騒がせしますた。
※補足:
上の何も出さなくなって5秒ぐらいしてからStackOverFlowってのは例外になったのでVisualStudioが表示用とかに色々頑張ってる状態なんだろうね。
末尾呼び出しを最適化すると、関数のトレースが出来なくなる。
だから、デバッグするときは、最適化切ったりするね。
末尾最適化=スタックに積まないだからそりゃね。
でも再帰呼び出し時のスタック トレースが必要なことってある?
printf デバッグでいいんじゃねぇかと思うんだけど。
まぁそれいっちゃうとなんでもprintfデバッグで良くね?ってなるだろw
いやいやwスタックトレースは必要だと思ってるよw
どこからどう呼び出されてきた関数かはデバッグに不可欠
だけど、再帰の分に関しては必要ないんじゃね?って。
んーまぁ再帰でもなんでその条件分岐になったのか流れ見たいときはある希ガスんなぁ
printfでもいいけど。printfでいいか。
俺が想定してたのは再帰するしないで2分岐するだけの単純な再帰なんだけど
もしかするともっと複雑な再帰とかだとスタック見たいこともあるかも。
というかまあ見れる見れないだったら見れる方がありがたいのは確か。
ただ、再帰って、割とこうガチガチにロジカルに組まないとコンパイル通らない
ような気がしてて、スタック追っかけてまでデバッグする必要性あるかなあと
思ったりしたんだわ。
FSUnitとVisualStudioのテストおのおのどんなメリット・デメリットあるのかすら。
C#使ってた時はVSのつと使ってたけどF#だと使いにくい?
母国語だとさらにわからないのでは?
中国語と韓国語なら読めるぜ
Alt+EnterでInteractiveに流し込もうとするとエラー音してできない時があるんだけど、そういう現象出てる人います?
ウィンドウ→新規で別ウィンドウ出すとそのソースからでもできるんだけどいまいち発生する条件がわからん。
関数内で途中でreturn みたいに値を返したり
for内でbreakしたりしたいんですがどうやればよいですか?
136 :
デフォルトの名無しさん:2011/06/29(水) 11:16:04.97
>>135 自分の場合はtryFindかtryPickかな。
どうしても途中で抜けたいなら、例外出して抜けるしかない。
自分もC++のコードをF#にしてみようと思ったときそこで悩みました。
結局、F#の繰り返しのfor文は全然使わないでList.mapかList.iterで処理するのがいいと思った。
137 :
デフォルトの名無しさん:2011/07/01(金) 11:25:54.20
>>135 >関数内で途中でreturn みたいに値を返したり
条件で返す値を変える
>for内でbreakしたりしたいんですがどうやればよいですか?
手続き型のfor/whileは全て再帰だと思っていい
そこで継続ですよ。
139 :
135:2011/07/02(土) 01:56:39.99
>>136-138 レスありがとうございます.
let loopですっきりとした記述ができました.
2011年、Ruby,Perl,PHP,Pythonって並べたときにさ
ここで、Ruby以外を選ぶ奴ってマジでなんなんだろうな
ゴミだし
これ ; デリミタっていうんだけどさ、これをつけなきゃエラーになるような
そんな言語使ってる奴ってどうみてもゴミだと思うんだけど
もしかして「;」これ打ち忘れてコンパイルエラー出すのが楽しいの?
そうか、二度と話かけんなよ
ゴミの分際でw
つ #light
誰かseqのBuilderを実装しているソースどれかわかる人います?
2.0のソースはあるんだけど検索してもわからんです…
>>147 >>148 なってないなぁ…と思う。
そんなもん見るよりも、ちゃんと時間取って実践F#読む方がずっといいよ。
>>149 なってないなぁ…と思う。
そんなもん見るよりも、ちゃんと時間取ってExpert F# 2.0読む方がずっといいよ。
Real-World Functional Programmingも宜しくね
ちなみに何がなってないの?
153 :
149:2011/08/21(日) 08:02:31.09
>>152 突っ込むために見直してみたら、そんなに突っ込み所は無かったかも。
>>149で頭ごなしに否定するのはまずかった。反省してる。
初見ではもっと気になる所があった気がしたけど、今見て思うのは以下。
・P35-P43 if式を(.NET中では)F#に特徴的、みたく書いてるけど、実はVB.NETにもif式はあるのです…
・P85 高性能、ではなくて、高機能、では?
・タプルを使ったPythonでいうアンパック代入相当の構文を備えていて、
多値関数の戻り値が(x,y) = funcHoge(a,b)みたいに自然に書ける説明が抜けてる。
・リスト操作用の組み込み高階関数の説明が無い。
とか。重箱の隅かもしれんけど、気になるんよ。
154 :
関数型入門中:2011/08/21(日) 19:29:53.73
質問させてください。
ここ数ヶ月、関数型言語をいろいろ見ています。(Scala,Haskellなど)
実践F#という本を読んでいます。
ちょっとこういう場合どうすればいいか、わからないことがあり質問させてください。
あるレコードが定義されている場合、
そのレコードに対して適用できる一連の関数を知る方法ってありますか?
実践F#には、同じ名前空間に、レコードと同じ名前のモジュールを定義して、
そこに関連する関数を書くとよい、とされていますが、
実際そうされているものでしょうか。
一つに、Haskellの型クラスのような仕組みがあれば、見通しがよくなると思うんですが
そういう仕組みはないんですよね? (Scalaにもなかった。。)
なにか、自分で設計する場合、他人が見てもわかりやすい方法などあれば教えてください。
よろしくお願いします。
レコード型のメソッドにしてみてもいいんじゃないでしょうか
>>154 ある型に対する一連の関数を知る方法は、簡単にはないですね。
AppDomainをリフレクションで総舐めとかすればそりゃ別ですが。
型と同名のモジュールを作ってーというお作法は、まあ、ふつうはそうするかなあと。
もちろん、ふつうじゃない場合もあるわけだけど。
Haskell型クラスが美人なのはわかりますが、すでにインターフェイスで筋通してる
.NET(あるいはJVM)においてそれを求めるのは、ちょっと難しいかなあという感想。
>>155 関数型でなくOOPで、と。ええ、おっしゃる意味は解りますが、といって、たとえば
Fooオブジェクトを必要とする振る舞いがすべてFooのメソッドとして定義されるとは
限らないわけで。BarクラスのメソッドがFooを引数に取ることだってあるでしょう。
このあたり、私は、F#においてのみ特別不便だ、とは感じません。
157 :
b:2011/08/21(日) 22:37:39.67
> 149
書いた人です。指摘してくれてありがとうございます!
>・P35-P43 if式を(.NET中では)F#に特徴的、みたく書いてるけど、実はVB.NETにもif式はあるのです…
確かに、誤解を招く書き方でした・・・
一応、VBのIf式は知っていたのですが、あくまでここでは
「C#にもVBにもif文があるけど、F#にはない」
ということが言いたかったのです。
>・P85 高性能、ではなくて、高機能、では?
うわ、全く気付いていませんでした・・・高性能はおかしいですね。
>・タプルを使ったPythonでいうアンパック代入相当の構文を備えていて、
多値関数の戻り値が(x,y) = funcHoge(a,b)みたいに自然に書ける説明が抜けてる。
これは微妙なところで、タプルのみに限った機能ではないので省きました。
例えば、
type t = { Name: string; Age: int}
という型があったとして、t型の値xに対して
let { Name = n } x
ということも可能ですし、そもそもローカル変数に限った話ではなく、
let name { Name = n } = n
のように引数に対してのマッチも可能です。
let x, y = y, x的なものを入れるかどうかは迷ったのですが、結局入れませんでした。
>・リスト操作用の組み込み高階関数の説明が無い。
これは、この時のターゲットを考えて意図的に入れませんでした。
確かに便利な高階関数は色々と用意されていますが、それを列挙する発表ってつまらなくないかなぁ、と思ったので。
ただ、LINQ to Objectには一対一で対応するものが無いような高階関数の紹介はやってもよかったかもしれません。
158 :
b:2011/08/21(日) 22:39:15.22
あ、let { Name = n } = xです。
お!本人であるbleisさんが降臨・・・
素敵!
160 :
デフォルトの名無しさん:2011/09/07(水) 22:14:16.34
F#のすごい日本人おしえれ
161 :
デフォルトの名無しさん:2011/09/07(水) 22:14:49.33
いますぐフォローすべきF#の人的なやつ
Googleで F# site:hatena.ne.jp とかやると、いろいろ出てくる
いないんだな、それが
というとアレだが、F# に特化してる人っているかね?
なにかしらほかの言語も使いつつ F# も嗜む的な
リベラルというか
金融系の人とかはOCaml使ってた人も多いらしいし、
F#も出来る人多いんじゃないの?
完全にF#で仕事、というのが日本にはない感じなので、そういう点で、人が見えないよね。
小物やらバッチに使うやらぐらいなら、そりゃあるだろうけれど。
かといってF#で何かOSSで作って公開、などという人もいないようだし。
F#セミナーいったら、
GUIアプリクライアントをF#で開発して納品した話をしてたよ。
活用例とかになれば
最終的には.netのグルー言語以外の何でもねえんだし
scalaにしろ、元にくらべての使い勝手の話になるんだから面白い話じゃない
.net嫌いな人ってもういないの?
>>160>>161 それなら各言語のすごい人全部まとめれ
170 :
デフォルトの名無しさん:2011/09/09(金) 19:54:27.44
会社にFランがいたけどひどかった。
#なんか付けたところで同じようなもんだろ。
171 :
デフォルトの名無しさん:2011/09/09(金) 20:01:08.56
Javaの変態の人たちはScalaやってるのに、
なんてC#の変態の人たちはF#やんないの?
Javaは使いづらくてやっとレンガ、C#はそこそこ間に合ってしまうというのがあるんじゃ。
F#のほうが使いやすいけどねー
Javaと違ってC#は糞言語じゃないから。
C#にはラムダ式、まともなジェネリック、LINQがあるし、
次のバージョンではasync,awaitも入るのでF#のメリットが相対的に少ない。
また、F#はC#と比べてIDEの支援が弱いのというデメリットがあるので
(特に WindowsForms、WPF、ASP.NET MVCなど主要ライブラリ関連)
F#のメリットとデメリットを天秤にかけた結果、C#でいいやって事になってしまう。
むしろここの人たちがF#を使っている理由が知りたい
C#を使ってると「パターンマッチ使いてぇ」
って場面は割とよくあるんだけど、
それだけの為にユーザーの環境にF#ランタイムを入れさせるのは憚られたので
結局使ってない。
.NET FrameworkにF#ランタイムが含まれてたら使ってたかもな。
俺的にはパターンマッチ、再起、部分適用、ユニットオブメイジャー、モナド含め、コードが書きやすいから。
>>171 インテリセンスさいこーってことでしょ
まー.NET的にC#が勝ち馬であるとに異論はない
いまんとこ
>>173 Javaも別に糞じゃないと思うが
古臭いならわかる
C#使っててLINQと拡張メソッドとラムダだらけになるとなんかもやもやしてくる
179 :
sage:2011/09/09(金) 23:36:12.15
C#でLINQと拡張メソッドとラムダ使ってドヤ顔カッコワルイwwww
まあ、でもLINQの範囲のデータ処理はC#のほうがいいな
bleisさんフォローしておけばいいんじゃね?
>170 意味不明だったけど、これってFortran#っていうネタか。
外人フォローしたほうがいいよ
ボスは、アカウントあるけどつぶやかなかった気がするな
ファンクタ対応したのかな
従来交わることのなかった OCaml 使いと C# 使いがそれぞれ別の切り口で文句を言いに集うスレはここですか?
>>190 仕事で両方使ってる人は、期待することはあっても文句はいわんだろ。
P層C#、F層F#でそれなりの規模のもの作ってみると、結構使える手ごたえはある。
普通にF#で機能を一つ作った後、その中で理論的に並列動作できそうなところがあれば、
それをマルチスレッド化するのに数分の作業で済むことも多いし、それがいつも安定して動く
という経験を重ねると、これからの時代C#だけじゃだめかなという気にもなってくる。
まだ立ち上がって数年の言語だし、捨てられないでちゃんとバージョンアップしてくれてるから、
まだまだこれからと見るべきでしょう。
Type Providerってなんなのか教えて下さい
型を定義することなくデータソースから何らかの方法でメタデータを取得し静的な型として扱えるようにするものって感じかの。
>>193 ありがとうございます
型定義を手で書かなくても済むようにするための
メタプログラミングの仕組み、みたいな感じでしょうか。。。
Visual Studio 11 Developer Previewは、日本語版もあって2012年6月30日まで使えるのか。
http://msdn.microsoft.com/en-us/aa570309#five > Metroスタイルのアプリケーションを開発するには Windows Developer Preview with developer tools English, 64-bit上に
> Visual Studio 11 Developer Previewがインストールされている必要があります。
開発ツール付きWin8上にインストールすればMetroスタイルアプリ開発にF#も使えそう。
197 :
775:2011/09/17(土) 09:34:30.73
Twitterで上がった話題(iOSでF#)で、F#のSymeがMonoのIcazaに、
build会場周辺でちょっと合って話さんかとかやってる。
C++のようなメタプログラミングができるのですか?
C++ の template みたいなマクロの延長のものじゃなくて、
ビルドプロセスをフックして型を作ってるんじゃないかな。
そっちも .NET (F# 含む)で書ける。
VS11 DP(ja)を、Win7(ja)とWin8 PR(en)にインストールしたが、VSからのF#(3.0) Interactiveが
どちらも日本語で表示しようとして文字化けしてる。(その画面だけ多国語対応してない?)
「C:\Program Files (x86)\Microsoft SDKs\F#\3.0\Framework\v4.0\Fsi.exe」を直接起動すると
win7(ja)で日本語、Win8(en)英語で正常に表示された。
>>191 いまだに手応えとか、いつまでそんなこと言ってんだよ
一生前衛みたいな感じかw
204 :
デフォルトの名無しさん:2011/09/27(火) 04:47:47.07
ScalaとF#と両方勉強しているのですが、
判別供用体(代数的データ型)の、パターンマッチについて教えてください。
Scalaでは、case class で定義すると、内部的には、class 定義に、applyやunapplyメソッドを持たせて、オブジェクトに対してパターンマッチを行っているようです。
F#の場合は、どんな感じでしょうか? F#の判別供用体も、実際はクラスから作られたオブジェクトなんですよね?? (.Net言語だから、そう考えたんですが。。)
そうすると、Scalaのapplyやunapplyに対応するメソッドを持ったクラスなんでしょうか?
教えてください、よろしくお願いします。
Scalaのapply,unapplyはよくしらんのだけれど、F#では各共用体は派生クラスとして実装される。
各々Tagを持ってるのでパターンマッチはそのTagを見てると思う。
206 :
デフォルトの名無しさん:2011/09/27(火) 05:21:39.52
夜遅くに(朝早くに)ありがとうございます。
なるほどクラスとして実装されているんですね。
type A =
| B
| C
| D
だと、派生クラスB、C、Dが定義されていて
たぶん、スーパークラスとして、クラスA とか定義されているんでしょうか。(クラスAでなくてもよいとは思いますが)
もし、クラスAだとすると、このクラスAにもTagを定義するように定義されていると思いますが、
クラスAは、.Netというか、F#のクラス的には、もともと何クラスなんでしょうか?
ちょっと、質問がわかりにくくてすみませんが
たとえば
let hoge:A = B
とか、書いた場合に、
変数 hoge の束縛している、クラスが何かって、得る関数ありますか? という質問がしたいです。
(判別供用体のBを返すのでなく、元のクラスが何か? を得る関数という意味です。)
F#の中では知らん。
Reflection使ってbaseクラスたどってみては。
C#から見ると多分Aとして見れると思う。
普通に
type A = | B
hoge.GetType().Name
;;
でAって出てきた
type A =
| B
| C of int
let hoge = C 10
hoge.GetType().Name
;;
はCだった
210 :
206:2011/09/28(水) 14:57:18.94
みなさんありがとうございます。
自分なりの理解はこんな感じになりました (↓素人理解です)
F#のレベルでは、
判別共用体と、クラス・オブジェクト は全く別のもの。
CLRレベル(.Netレベル)ではたぶん、同じような仕組みで実装されている。
一方、
Scalaは、いわゆる判別共用体は、クラスの拡張で実現されているように思います。
(applyやunapplyというものを定義したもの)
※ 素人の理解ですが。
>>210 ProgramingF#のC#Interropの章にF#で定義したunionがC#だとどういうクラスとして定義されるか出てるから見てみるがヨロシ。
webでもどっか転がってそうだけど。
212 :
デフォルトの名無しさん:2011/09/30(金) 22:37:54.99
実践F# を読んでいると、
OOPの章のP264に、
本書では、詳細に踏み込みませんが、レコードや判別共用体の定義とは、F#コンパイラが構造的な性質
を持つように特別なパターンを適用したクラスとして生成するものです。本節では、特別なパターンが施されな
い、生身のクラスを定義する方法を示します(リスト8‐5)。
と書いてあって、F#ではクラスの特別なものが、判別共用体や、レコードのようなきがする。
特別なクラスというと語弊がある。
MSIL上は継承関係とか種類を表すタグとかが一定ルールに従っているただのクラスであり、其れが自動生成されているだけ。
1%切ってるところは誤差だろ。
TIOBEみたいな腐れ調査機関とか相手にすんなよ…
まあ、F#が20位以内というのはおかしいよね。
218 :
デフォルトの名無しさん:2011/10/23(日) 03:15:14.94
しかしそれでもScalaより上って・・・・・目くそ鼻くそとはこのことか。
はやくJavaの時代終わらないかなぁ・・・・
>>218 scalaは関数脳に慣れてない人からは関数型言語部分に苦しんで、haskellやOCamlで関数脳になった人からは関数型言語としてはキモイから。。。
F#Express出たらかなり差が付くだろうね
haskellもGUIに特化した専門書とか出ないと伸びないんだろうな。。。
>>219 haskell でguiな本書こうか?
>>221 gtk2hs でもいいっすか?
haskell-qtはまだ使ったことないんです、、、
>>222 自分もgtk2hsの勉強始めたばかりなんで、渡りに船です
>>223 とりあえず開始するかもしれないです。
でも期待はしないでください、、、、
たぶん原稿の成長とcarettahのコード品質は同期するだろー...λ
よく知らんが買わんぞ?
現在の購入予定者2名
良い本だったら買うし良い本ではなかったら買わない
https://github.com/fsharp githubに、fsharpオープンソースコミュニティーというのがあるのか。
donsymeがいると公式感があるな。
mono開発者のicazaも入ってる。
F#はClojureCLRと違って余裕あるからか、monoとの互換性も重視してたの思い出した。
作ってるのはSocket IOだった。
Fracture/Pipelet/Frackって分かれてる。
future-ioはSSDだった・・・orz
M$がhtml5の構想に弱音を吐いて.net戦略を撤退したらf#ってどうなるんだろ
VisualOcaml作って欲しい
VisualHaskellを(ry
F#はType Classの要望が強かったけど
.netの型システムとの互換性を重視して入れなかったとどっかで言ってたから
H#はないんじゃないの?
ちなみに"Visual Haskell"は既にあるよ
>>241 >ちなみに"Visual Haskell"は既にあるよ
そうだった。VS2010に対応したかな?少しは安定したかな?
全然使えなさそうですっかり忘れてた
>F#はType Classの要望が強かったけど
>.netの型システムとの互換性を重視して入れなかったとどっかで言ってたから
・・・orz
Haskellようしらんのだが、型クラスあるとなにがどう幸せになるん?
>>243 多層的で等価比較、順序比較出来るリストを簡単に定義出来たりする
data List a = Null | List (List a) deriving (Eq,Ord,Show,Read)
使用例
List 1 (List 2 (List 3 Null))
head (List x _) = x
tail (List _ xs) = xs
Eq,Ordが型クラスで、List aがインスタンスだから、例としてはこっちが適切か
large xs ys | xs < ys = (ys,xs)
large xs ys = (xs,ys)
C# のプロジェクト で F# のファイルのインポートがどうしても
できないんですがどっかにまとまってないでしょうか?
あとC#プログラム中でfsファイルの実行は不可能なのでしょうか?
C#, F# のプログラムがそれぞれ下のようだったとして
main(){
exec(1.fs); //this is c# code
Console.WriteLine("aa");
}
########
let a = 3 // this is F# code
printfn "hello"
#########
実行して
hello
aa
となるような
247 :
246:2011/11/14(月) 20:27:08.67
F#側のdllをC#でインポートするだけでしょ?
249 :
デフォルトの名無しさん:2011/11/17(木) 21:05:56.68
251 :
デフォルトの名無しさん:2011/11/18(金) 21:39:55.75
え?
いや、この発想はまだまだ用語や概念判ってないのかなと思って
exec(1.fs); //this is c# code
F#のevalは興味あるんだけどfsiのソース見ればいいのかな?
ocaml のfunctor の代替手段はF#だとなんですか?
255 :
デフォルトの名無しさん:2011/11/24(木) 21:32:53.28
256 :
デフォルトの名無しさん:2011/12/10(土) 12:47:04.33
あら止まってんの
ブロガー結構増えてんのに
580 名前: デフォルトの名無しさん Mail: sage 投稿日: 2012/02/16(木) 05:11:31.94
F#を始めたのだが、モナドで行き詰まっている。
F#の本にはモナドのことが書いていない。
で、ネットでモナドのことを収集すると、ハスケルのがほとんど。
F#での説明もあるが、なんか解りづらい。
で、モナドって何ですか?
関数型プログラミングをやるにはモナドが必須ですか?
どなたか教えてください _o_
613 名前: デフォルトの名無しさん Mail: sage 投稿日: 2012/02/17(金) 09:25:13.67
>>580 ここは読んだか?
http://www4.atwiki.jp/fsharpmaster/m/pages/13.html >StatefulFuncはなぜ動くのか?
> StatefulFuncを含むワークフロー(モナドとも)を理解する道筋はいくつかあ
> ると思いますが、まず最初に「操作的」に手を動かしてプログラムの意味を解き
> ほぐしていくアプローチを取ってみようと思います。
261 :
デフォルトの名無しさん:2012/02/19(日) 12:59:47.35
262 :
デフォルトの名無しさん:2012/03/09(金) 00:57:53.79
もまいらもっとF#書けや
みんなTwitter
に行っちゃってるのかな。
264 :
デフォルトの名無しさん:2012/03/10(土) 17:23:56.54
本質的には別物
265 :
デフォルトの名無しさん:2012/03/16(金) 20:14:45.72
F#はどこの世界が流行してるの
俺の中では超マイブームです(´・ω・`)
英ケンブリッジなら、Haskell,F#,Erlang,Clojure流行ってる
269 :
デフォルトの名無しさん:2012/03/20(火) 07:16:12.67
F#/monoを扱うなら解るようにした方がよいかも?
そして、MonoとF#のインストールの関係で、Linux or OSX, FreeBSDの順で情報がない気がする。
使い始められればそんなに変わんないと思うけど。
code quotationとtype providerを組合わせたらlisp macroみたいなことができるんです?
何でこんなに過疎ってるんです?
世の中が変態ばかりだったら困るだろ?
LISP Haskell Scalaなんかは変態ばかりでも伸びてるんで
むしろ変態へのアピールが足りてないが正しい
関数型がいいといっても.netならC#、
いざ関数型の勉強だ、ってF#にするくらいなら他の言語に目移りするわけだ
もはや言語ヲタを引きつける言語としての魅力、が欠けてるのははっきりしたと思う
それでもF#好きなのは変態のさらに変態?いやいやただのマイノリティ
>F#にするくらいなら他の言語に目移りするわけだ
ごめ、なにを根拠に光入ってるのか意味不(´・ω・`)
F#いいよー
OCamlも道連れで寂れてるし
D言語スレなんて誰が使ってるかさっぱりわからんが未だに書き込みあるからなあ
まあ粘着質な人が少ないんだね
関数言語厨が.net環境ででも関数型ぽいことをしたくて使う言語だわ
とりあえずF#じゃなくてC#を使わないといけない理由が殆ど無いのでF#ばかり使ってます(´・ω・`)
デザイナー等C#必須であれば、F#のモジュールと混在って感じですね。
PortableLibraryに期待(´∀`∩)↑age↑
>>273 Haskellスレも概ねそうなんだが、簡単に関数を自作出来ちゃうから、「こう言う事したいんだけど、どう書けば良い?」みたいな質問はほとんど無い
自分も、Haskellスレで質問したのは練習問題でリスト内包表記でこう言う関数を書けって問題の時だけだったし
変に制限付くとどう書けばいいのか分からなくなる事はあっても、制限なしだと、割と初心者でも関数書くのに困ること無いのが関数型言語の良い所だと個人的には思ってる
オブジェクト指向言語だと、オブジェクト自作するのは意外と面倒だし、メソッド覚えれば、ある意味じゃ関数型言語よりも簡潔なんだけど、リファレンスと睨めっこしてメソッド覚える必要がある
(なので、こう言う処理するメソッド無い?とかの質問がオブジェクト指向言語のスレでは絶えないんだと思う)
とりあえず、なごやこわい
283 :
営利利用に関するLR審議中@詳細は自治スレへ:2012/03/31(土) 06:35:15.28
無償環境だと、F#はVS Shell、WPはVS C# Expressに結びつく。
そして、F#を通常のVSに結びつけるのには、ExpressではなくProfessional以上じゃないといけないはず。
286 :
営利利用に関するLR審議中@詳細は自治スレへ:2012/04/01(日) 05:19:32.41
ありがとうございます
つまり、無償ではF#でWindowsPhoneの開発は出来ないって事でいいですか?
イデの力は使うべき
イデに取り込まれるぞ
shellとC# expressをバラバラに使って、開発は出来るので、
F#でportableなライブラリーつくって、UIはC#かな。
webページの日本語をパースするスクリプトを
f# + .netで作ってみるお
がんばれ
複数のファイル作ったらネームスペースを書けと言われるし
ネームスペース書いたら中に値を置くなと言われるし
嫌ならC#にかえるしか(´・ω・`)
デフォルトで前方参照ができないとか、まるで20年前の言語のようだ
Scalaと比べると見劣りするなぁ
>Scalaと比べると見劣りするなぁ
うわー。言うよねー、Scalaの人って、こういうこと。
Scalaは型推論がショボすぎる時点でない(´・ω・`)
やはりBetter Javaではなあ…
今までJavaをやって来て超アンチMSだったので
F#の方が逆に新鮮w
by far much better Java だけどね。
302 :
デフォルトの名無しさん:2012/05/17(木) 09:26:13.63
F#ってBetter Javaだったの!?
Scalaがってことでしょ。
今までJavaをやって来て超アンチMSだったので( ・`ω・´)キリキリッ
前方参照できないのと型推論がショボイのさあどっち!
JAVAかMS(win)かでしょやっぱ
JavaじゃなくてOracle
308 :
デフォルトの名無しさん:2012/06/20(水) 16:50:25.33
F#のほーがセンスイイよ
主婦の7割が「韓国タレントは嫌い」 地銀シンクタンクが調査した実態とは
日本でのK-POPブームに陰りが見え始めたとも指摘される昨今だが、それでも新たなグループが続々と日本進出している。
今年に入ってからだけでも日韓同時デビューのA-JAX、吉本興業系のレーベルから日本デビューするMYNAME(マイネーム)、
さらには「K-POP最後の大物」との触れ込みで7月にデビュー予定のWonder Girls(ワンダーガールズ)など、相変わらずの
「雨後のたけのこ」状態。それほどまでに日本市場はK-POPにとってオイシイのか、そして本当にK-POPは日本で売れてい
るのか。その実態を探ってみた。
大垣共立銀行(岐阜)系列のシンクタンクである共立総合研究所による「韓流消費に関するアンケート」の調査結果に、
実に興味深い調査結果がレポートされている。なんと、アンケートに回答した主婦の7割が「韓流は好きではない」との結果だったのだ。
同研究所は<K-POPの台頭、食品、コスメをはじめとする韓国製商品ブームのマスコミでの取り上げ方、新聞の テレビ欄における
韓国ドラマの占有状況からかなりの盛り上がりを予想したが、結果は予想を下回るものであった>と、調査レポートを結んでいる。
結局、K-POPブームとは単にKARAと少女時代という個別グループのブレイクにすぎず、やはり実体などなかったということか。
http://uramono.org/entertainment/2576.html http://uramono.org/uploads/2012/06/kara.jpg
下のようなコードでF#3.0だと両方呼べるんだが、
let y = (^a : (member talk: unit -> string) (a))
ってどういう仕組みなん?
ちなみに
let y = (^a : (member talk: int -> string) (a))
だと"2式が必要ですが、1が指定されました”と言われてエラーになる
let inline speak (a: ^a) =
let x = (^a : (member Name: string) (a))
printfn "I'm %s" x
let y = (^a : (member talk: unit -> string) (a))
printfn "I say %s" y
type Duck =
{ Name : string }
member x.talk() = "quackity quack"
type Dog(name) =
member x.Name = name
member x.talk() = "arrrr"
unit -> string というメンバ「talk」を持っている型 ^a に対して、a という変数を渡してその関数を呼び出してます。
let y = (^a : (member talk: int -> string) (a))
がエラーになるのは、int -> string な ^a 型の関数に対して ^a 型の変数しか渡してないから。
let y = (^a : (member talk: int -> string) (a, 42))
のように、int 渡してあげればいいはずですよ、っと。
312 :
311:2012/06/25(月) 18:22:12.77
313 :
311:2012/06/25(月) 18:24:21.04
> 282
なごやいいとこいちどはおいで!
>>312 operatorに使えるのは知ってたんですが、普通のメソッドにも使えるのは知らなんだ。
F#すこぶる評価いいねえ
321 :
デフォルトの名無しさん:2012/08/25(土) 19:33:41.01
F#がこの先生きのこるには
surfaceが爆発的に普及すれば.net基盤だからF#にも出番ある
323 :
デフォルトの名無しさん:2012/09/18(火) 21:41:33.61
OCamlを勉強してて色々モヤモヤした部分があったけど、
F#で不満だった部分がかなり解消されてて驚いたわ
マイクロソフトさんありがとう、今まで悪口言ってすみませんでした
具体的に
>>322 いやsurface、別に.NET基盤じゃないから。.NET(Core)でも開発できるというだけで。むしろF#ではportable libraryとしてしかアプリ開発に使えないというように虐げられてるw
>>323 まず日本語をなおせ。OCamlで不満だったものがF#で改善されてた言うことか?
さすが読解力ないわ
無駄な煽りしかできない知障は引っ込めですぅ
>323は曖昧な書き方してるけど、理解できるよね。
問題になるとしたら規格書とか論文とかぐらいでしょ。
読解力無いというのは、文章から本来の意図を読み取れないという意味だが、
>>325はなにか間違ってるのか?
F#erは煽りに弱い、と。。。
過疎の場所でわざわざ煽る奴はアンチじゃないからね
盛り上がって欲しいだけなんだよ
開発陣に中国人がいるからオワコン
F#でソフト作ったら情報駄々漏れ
Expressだとポータブルライブラリ作れないのか…
おまいらFsharpxとか見てる?(´・ω・`)
346 :
デフォルトの名無しさん:2012/11/22(木) 01:10:00.70
アドベントカレンダーって何ですか?
>>344 クライアントサイドではjavascriptとして動くからF#って言うとちと語弊が(´・ω・`)
haxe, ocamljs, clojurescriptみたいなもんかな?
>>348 そんな感じだね。
基本はjsコンパイラで後はサーバーとのやり取りを書きやすく出来る仕組みがある感じかしら。
サンプルでチャートアプリ作ったけどF#で書いたロジックがさっくりと動いたよ。
でも情報が少ないから実際の製品での使用はちょっと躊躇しそう。
>>350 WebSharperの方が商用のものを切りとってオプソにしてるからクオリティ高そうなイメージ(´・ω・`)
>>353 それ、最近の技術さっくりと触れてるので良いよ。F#での書き方の参考になって良い。関数型としてのことはそんなに深くは突っ込んでないけど。
http://tomasp.net/blog/manning-deep-dives.aspx The book consists of 5 parts that cover the most common real-world uses of F#:
Developing of Analytical Components, Processing and Analyzing Data, Creating End-user Applications and F# in the Larger Context.
There is an increasing number of commercial F# applications. If you want to learn about the domains
where F# can make you more productive and help you to write correct code, or if you want to learn how F# experts approach different problems, then the upcoming F# Deep Dives book is the book for you!
洋書だと、二冊のF#2.0本もF#3.0本にアップデートされた以外にも実用本が増えてきたね。
358 :
デフォルトの名無しさん:2012/12/24(月) 22:07:37.47
'a list list を 'a list にしたいんだけど、どうすればいいの?
Linq の SelectMany したいわけなんだけど。
>> 358
list |> List.collect id
としてみてはいかがでしょうか?
360 :
358:2012/12/25(火) 08:40:21.42
ありがとう
POPL2013でF#のワークショップがあったみたいで
関数型プログラマーのひとが参加して
webshaperやtryfsharpなどいろいろな面に驚いてるな。
あまり日本では、取り上げられないので羨ましいかも。
日本どころか世界的に過疎ってんじゃん
hubfsもなんか見づらくなっとるし・・・
F#をちょっといじってみたけど
GUI作り辛いし、GUI作ろうとするとあまり関数型っぽくないしで、
本格的に利用しようとすると微妙だな
遊ぶには面白そうだけど
>>364 何つーかどこから突っ込んでいいのかわからんわ( ´Д`)y━・~~
突っ込めよ
056 [2009/06/24(水) 21:07:53] デフォルトの名無しさん <sage>
F#>Java いずれこうなるから安心しろ。
まあJ#は超えたな
scalaにも当てはまると思うが
関数型風にも書けるというマルチパラダイムは
結果的にいろんな書き方を覚えなければならないし、
そのいろんな書き方、ってのも癖があって覚えにくい
そのせいでF#らしさというものが希薄になってる、というのが欠点
これがマルチパラダイムの末路だ
結局は、限られた書き慣れてる書き方しかしないんだもんな
そんな自分の無能さを声高に言われても困ります。
GUIはC#とXAML、ロジックはF#でいいのでは。
GUIは、というのは支援ツールがあるという意味で。
GUIをF#で作るのは、C#のデザイナで作ってF#にコピペする作業だから空しい
F#って何に剥いてるの
包茎の童貞
まさにオナニーに向いているんだろうな
知的好奇心と言えば聞こえはいいが
ようするに自己満足
モノを生み出してナンボでしょ
そのモノを生み出すのにF#はC#より遥かに長けてるんだが…情弱乙(´・ω・`)
で、その生み出されたモノの例をあげてくれるかなぁ
は?F#使ってる人たちは、C#を使ってやるのと同じように仕事なりなんなりでプログラム書いてるだけだと思うけど。
その際に生産性がいいってだけだよ?
なにかF#や関数型を特別な魔法か何かのようにとらえすぎなんじゃね?
>>377 仕事でバッチファイルの代わりに.fsxでスクリプトを書いてます
インテリセンスが効くのと、Mainクラス作らなくても頭から実行してくれるので
型推論があるので動的型のように書けるところも好きです
Cygwin入れてPythonなりRubyなり使った方が早くね
>>380 そんな動的型要らんわ( ´Д`)y━・~~
>>380 インテリセンスは静的型じゃないと難しいのでは?
普段はC#使いなのですが、.NETとVisualStudioがそのまま使えるっていうのも大きいです
それにVisualStudioがインストールされている環境ならC#と違ってビルド不要で.fsxファイル一つで動きますし
Python Tools for Visual Studio
Typescript
なるほどね
確かにインテリセンスは大きいか
こんなのあるのね
http://exselt.net/ 何に使うかわからんようなソフトではなく
XSLT 3.0 プロセッサとか実現したら一気にキラーアプリやで
ただダウンロードすらうまくできないのが弱点。
XSLTはまだ息の根止まってなかったのか。驚いた
昔MSのサイトのRSSにXSLTが付いてたのを覚えてる。
BigIntegerと再帰を使ったフィボナッチ数列がC#より簡単にかける
.netにBigIntegerが入ったとかいう話があった気がするが
まあここの時間止まってるようなもんだから
Linq to ObjectあるからF#いらないですよね?
むしろF#あればC#はいらないが正しい( ゚Д゚)y─┛~~
VisualStudioのリファクタリングはC#と比べると雑魚だよね
F#やってみて、階乗から始まってフィボナッチ、ハノイの塔、クイックソート
正規表現抹茶あたり組んでみたけど、なんか飽きちゃったなあ。
なんか面白いテーマないかな。
プログラマとして勉強になるのかな、と思ってたけど、CでもRubyでもできるよ
ねこんなのは。
>>3
入力補完がC#並みなら最高なんだが・・・
>>393 そんなん、ただ再帰を使ってるだけやん。
関数型のかのじも使ってないぞそれ。
それコピペだよ
C#との比較で見たときにキャッチーに利点を説明できる要素
ならまあ代数的データ型ですねぇ。
自動実装プロパティに初期値を与えられるのとかも地味に便利。
member val Count = 0 with get, set
RoslynでC# REPLが可能になったらF#オワコンですよね
>>399 せめてまともな型推論を実装してから出直してくれ。
F#並の簡潔な記述
代数データ型とパターンマッチング
REPL
モナドサポート
イミュータブルデフォルト
最低でもこの辺が出来ないことには話にならない( ´Д`)y━・~~
REPLとかいらないけど、他の4つはC#でもホント欲しいな
#light "off"にして、あと警告がある場合はコンパイル通らない設定にして使ってる。
しかし、F#の構文だと関数適用時のインテリセンスが微妙…。
「ビッグデータの世界でF#が大流行、
研究者の心を鷲掴みする謎のプログラミング言語」
ってマジ?
タイトルが変
>>406 まぁ実際にサイエンティストから好評らしいけど
OCamlの一種としては悪くない処理系だし、
MLユーザーは少々の方言は気にしない。
F#だと複雑なロジックがこんなに簡単にかける系のリンクってない?
F#にしたら息子が大学に合格しました
>>410 Fランクよりちょっといいぐらいの大学ですね。おめでとうございます
F#がセクシーすぎて息子が大きくなりました
>>408 MLに派生と方言以外の何があるというのだ
名前にスタンダードが付いてるMLあるよね。
とりあえずGUIはC#でとか言ってるうちは流行らんな
いくら糞レスで埋めようがにぎわってねえからな
勘違いすんじゃねえぞ
letって何かの略?障害?
許可じゃimmutable的に意味逆になるだろうし
辞書引けば書いてるだろ数学用語だよ
F#の本ヌレおしえたもれ
どうしてこうなった
本国はTryF#作るまでやる気あるのに
MS日本法人のほういつまでも翻訳せず
やる気が感じられないからしょうがない
英語読めないヤツのほうがもっとやる気ない
とかいうのは無し
F#は全社で取り組んむべき題材ではないということだろうな。
いちおう詳しいMSの日本人もいるのかな?
MS Research製だから、日本にMSR支部がないのがまんま影響してんじゃないかね。
TryF#を2ページくらいやったけど
他のプログラミング言語やってないと辛い
4歳児よくできたな・・
プログラミングF#3.0早く出ないかなー
真のサイエンティストはF#じゃなくていまだにFortran使ってるけど
エクスプローラ上でfsxファイルを右クリックするとRun With F# Interactiveで直接実行できるわけですが
同じようにVS 2010上のfsxファイルを直接実行する方法ってありますか?
F# Interactiveウインドウにfsxファイルをドロップするだけで動いたりしたら嬉しいのですが・・・
VSで常用してる人が多かったらこのスレもっと勢いあるだろうね
言うまでもないが、F#3.0はxp vista切り捨てのVS2012でしか動かない
最先端に追従してるF#3.0がD言語より語られてないのは皮肉な話だと思う
VS2012スレもようやくVS2010スレの勢いを超えたというのに・・・
かと言って2.0使い続けてる奴もいないよな?
時代を先取りしすぎた言語
数年以内に消える
>>408 HaxeとかOCamlで実装されてるんだっけか…
型推論とか最近の流行なのかしらんけど
vsに統合されることがゴールで
めでたくvs2010とvs2012に標準搭載されたというのに
語る人が全くいなくなった・・・
vs shellの存在意義が未だによくわからん
そこまでやるならスタンドアロンのコマンドラインツールでいいだろ・・・
MSKKの人は「F#とか流行るわけねーだろwwwww」みたいなこと言ってた
え、MSの人がそんなこと言っていいの?とか思ったけどだまってた
GHC(Haskell処理系)プロジェクトのコアメンバーにMSの研究員がいるんだけど、
彼はF#について、そしてF#の名がMLに贈られたことについてどう思ってるんだろ?
MSRケンブリッジは魔の巣窟だなー
MSRには、会社に研究内容制限されず、勲章を運んでくるのがお仕事になるトップ論文投稿者がたくさんいるらしい。
アップルはジョブズがもどったときに全員首切ったという伝承がある。
どちらかというと、Don SymeがわざわざMSのためにF#作ってる理由が知りたい。
VS2010でF#のプロジェクトに新しいフォルダを作成して追加するにはどうすればいいでしょうか?
>>442 エクステンションいれないと無理よ(´・ω・`)
>>443 それを聞いて調べたところF# Project Extenderを入れれば良さそうなのでさっそくいれてみましたが
Enable F# Project Extenderをクリックするとエラーが出たので諦めます(´・ω・`)
Named union type fieldsはよさげだなあ
VS Desktopにも入れてくれないかな
VS Web入れてみたけど訳が判らないよ
Scala33位
F#37位
TIOBEで比較するとそれほど差はない
むしろF#のが力強く感じられる
最初moduleでモジュール化してたけど
途中から型や値をパラメータ化したくてclassに変えようとしたら
構文が違いすぎてあと内部classも作れなくて死んだ
453 :
452:2013/08/05(月) NY:AN:NY.AN
>>450 22 D 0.567%
23 F# 0.538%
24 Lua 0.531%
34 Haskell 0.349%
35 Erlang 0.344%
36 Prolog 0.334%
37 Scala 0.332%
うーんとしか・・・
ネタにマジレス
MonoDevelop+F#Bindingsでコンパイル順の変更ができない…
やる気無さすぎだろこれ
456 :
デフォルトの名無しさん:2013/08/18(日) NY:AN:NY.AN
結局MonoDevelop諦めちゃった…
>>455 そこらへんは、作者に言わんと永久に治らないかも。
githubで開発してると思うから作業リストには入るだろうし。
>>456 まだベータ版ぐらい?
そう言えば、monodevelopやxamarinstudioだと実行がうまく出来ない環境があって悩むことがある。
>>457 どっちも同じ人間だよ
git上のFSharpBindingsだと順序変更はできるようになってた
でも新しいMonoDevelopが必要で自前でそれもビルドしたから
設定がとても面倒だった
その後MonoがWinFormsに実質未対応なのに気づいて
それでも他の部分だけと頑張ったけど
IDEそのものが自分には使いづらくて無理だった
F#は素直にVSでやることにした
具象型にいちいちインターフェース型をキャストすんのめんどくさ!
これ一つづずつ実装するかキャストしないといけないのか?
実装を意識したくないからインターフェースをはさんでるので
キャストしちゃうと台無しですよ。
>>460 すみません、逆方向です
let impl :ISome = new Impl() ;> ISome
こんな感じで一旦アップキャストするのが面倒なんです
単にISomeを実装しただけではImpl型でメソッドを呼び出せないので
実装のテストだと例えば3つ実装していた場合、
毎回使用するインターフェイス別にキャストしなくてはいけない
それかImpl自体にそれぞれ同名のメソッドを用意するしかない
他言語ともやりとりするので手軽に注釈なし'a 扱いもできません
私が何かとてつもない勘違いしてるんですかね…?
セミコロンはtypoです
> let impl :ISome = new Impl() :> ISome
なんで:ISomeと型を定義してんの?
インターフェースぐらいは暗黙に変換してくれてもいい様には思うが、F#では元々そんなインターフェース使わんからなぁ
Interopするなら別かもですが。
>>463 >なんで:ISomeと型を定義してんの?
こうしないとメソッドが呼び出せないからですね
でなければ呼び出す度にキャストすることになってしまうので
ただ雰囲気は大体わかりました
F#でクラス使ってOOしちゃいけないみたいですね…
ありがとうございました
>>464 いや右辺で型決めてんだから、左辺は書く必要無い。
オブジェクト指向もしちゃいけないじゃなくてやる必要が無いだ。
とりあえず関数型とF#勉強してから自分が書いた事を見直してみろ
>>465 すみませんが、問題にしてるのはキャストですので
可能であればそちらより解決策の提示を願います
>オブジェクト指向もしちゃいけないじゃなくてやる必要が無いだ。
それは現に必要な人間に言っても意味がないです
>とりあえず関数型とF#勉強してから自分が書いた事を見直してみろ
関数型はOCamlもHaskellも使ってます
私は純粋に外部利用のための解決策がないか探っているだけです
んじゃ好きなだけキャストしてろよw
>>461 >let impl :ISome = new Impl() ;> ISome
>>465さんも書いてますけど右辺で型が分かるので左辺は必要ないですよ。
>単にISomeを実装しただけではImpl型でメソッドを呼び出せないので
ISome型に定義されてるメソッドは呼び出せます。
ISome型で参照してるならImpl型で追加されたメソッドが
呼び出せないのは当然かと。
ここまで書いといてなんですが
私もF#は勉強中でOOP視点でレスしてます。
間違っている所があれば詳しい方、訂正お願いします。
>>468 >
>>465さんも書いてますけど右辺で型が分かるので左辺は必要ないですよ。
大丈夫ですそこは理解してます
問題としているのは右辺のキャストです
私はレスを「なぜそこで型をキャストするのか」と解釈したので、
変なレスになってしまいました
左辺値の注釈は型推論でつまずくことが多いので癖で書いてます
>ISome型に定義されてるメソッドは呼び出せます。
上でも書いてますが、実装型をnewしても
1. インターフェース型にキャストする
2. インターフェース型を実装したものとは別に
実装型に同名のメソッドを追加する
このどちらかをしないと同名のメソッドは呼び出せません
これが複数のインターフェースを使うとなるとその都度キャストという事になります
>>469 インターフェースの明示実装を利用しているため、明示的にキャストしたいということですね。
しかしこの場合、実行させたい関数等にtype hinting付けて、そこで指定したインターフェースのメソッドを呼ばせるべきだと思います。
これは、F#に限らず、C#でも同様です
。
また、もしそれがコンストラクタである場合も同様に、外部から注入すべきでしょう(依存性反転の原則)。
どうしても呼び出し先で、生成->実行したいのであれば、ローカル関数を経由すればいいと思います。
>>470 明示的にキャストしたいじゃなくてしたくないんでしょ。
インタフェースのメソッド呼ぶために関数を通させる意味が分からないんだけど、関数型のスタイルに合わせるため?
IHogeにキャストしたいなら、それをするiHとか短い関数作って(iH o).HogeHogeとかでいーんじゃねーの。
そもそもキャストが頻繁に起きるなら設計がおかしいだろ。
同じオブジェクトを各場所で適切なインタフェースとして保持管理出来てるべき。
>>470 大変参考になりました
特に注釈付き引数について、暗黙の挙動は存じておりませんでした
引数には適用されるんですね
DI部分に関してはもっともな意見だと思います
ただ、実装の確認テストの際に煩雑になるので、
テストしながらの作業では、その手間が惜しいです
そこでほしいのは明示的でないインターフェイス実装か、その代替です
この点はC#では同様ではないと思います
単なるわがままを続けても仕方がないので、これ以上は控えます
レスありがとうございました
すみません見逃してましたのでもうひとつだけ
>>471 アップキャストは設計上頻繁に起こっても全然おかしくはないです
というより良い設計では何でもインターフェイスにしますよ
逆に特定のインスタンスや型を扱うのは危ないです
>>473 そうじゃなくて複数のインタフェースを実装して、その場所場所でこのインタフェースを実装してるか的なことをしないといけないのがダメっていってんの。
そうで無ければ具象クラスをそのインターフェースとして扱い始める大元でキャストするだけであって使うたびにキャストがーなんて話はでてこない。
>>474 もちろん基本的にはそうだと思ってますよ
しかし、書いてるのはインターフェイスとしての扱いでなく、
実装動作そのもののテストコードです
実装クラスのメソッド呼び出しの手間について話しています
ここまで特殊化された物に一つずつインターフェースを書いて
それを使ってという事をする気はありません
なのでダメと言われても困ります
念の為付け加えますが、インターフェースの要件としてのテストコードは別にあります
問題にしているのは個々の実装クラスの特殊な動作を調べるコードです
>>475 お前がインターフェースの呼び出しがめんどくさい言ってて今更インタフェースの扱いじゃないってなんなの?
後段のインタフェースを書いてとかも意味分からん。
何したいの?もうめんどくさいから楽なC#でかけば?
478 :
デフォルトの名無しさん:2013/09/08(日) 19:28:18.01
>>477 実装したメソッドを呼び出しするのが面倒だと何度も言ってるでしょう?
本当に理解できてます?わざと言ってるんですか?
すみませんついカチンと来てしまいました、謝ります
上に書いたとおりの手順でやってみればどういう意味かわかると思います
すまん。そもそもで恐縮だが、459の人はF#で完全OOPなコードを書こうとしてるの?
>>479 だからさー
上に書いた通りの手順でとか言われてもエスパーじゃないからわかんねーよ。
せめてアンカーでもつけたら?
お前の質問の仕方は相手にとってどう理解しやすくするかって視点が全てにおいて欠如してんだよ
こういうのはどう?
type ICounter =
abstract member Inc : unit -> unit
abstract member Count : unit -> int
type Counter(seed : int) =
let mutable cnt = seed
member this.i = this :> ICounter
interface ICounter with
member this.Inc() = cnt <- cnt + 1
member this.Count() = cnt
これはにぎわってない
.net sdkだけでコンパイルできるスタンドアロン環境にしてくり
fsiやfsc はスタンドアロンでインストールもコンパイルもできるだろ?
疑問形で言われても。
一般的にはなんとかシェルがいるし裏技は知らん
>>486 もちろんexpressなんちゃらも入れたくないってことな
>>486 疑問系ってよりも、お前そんな事も知らんの?って意味の確認だろ。
unix-monoでF#な俺に死角は無かった
490 :
デフォルトの名無しさん:2013/09/15(日) 21:11:33.10
>>488 なんだ、お前そんなのも知らんのとかいいたいだけのカスか
どんだけこのスレ過疎ってると思ってんだよまったく
そんなんだからF#がこんなかわいそうなことになってんだろ
あげ
491 :
デフォルトの名無しさん:2013/09/15(日) 21:12:22.99
>>488 こんな過疎スレなのにこんな人間のクズしかいないとは哀れすぎる
492 :
デフォルトの名無しさん:2013/09/15(日) 21:18:26.19
そもそもスタンドアロンで使ってる奴がどんだけいるわけ?
なめてんじゃねえよ
494 :
デフォルトの名無しさん:2013/09/15(日) 23:08:27.79
>>493 だから解説になってねえんだよバカタレが
なんだ、お前そんなのも知らんのとかいいたいだけのカスか
さっさと消えろ
495 :
デフォルトの名無しさん:2013/09/15(日) 23:10:32.47
>>493 なんだ、お前そんなのも知らんのとかいいたいだけのカス
496 :
デフォルトの名無しさん:2013/09/15(日) 23:13:23.78
>>488 スタンドアロンで使うのがどれだけ普通なのか
わざわざしゃしゃり出てきたお前が解説しろ
>>494-496 だから
>>486でイミフな絡み方してるから日本語の解説してやっただけだろ。
教えてくんならそれらしく下手に出てればいいのに。
>>484でスタンドアロンがいいっていうから
>>485がスタンドアロンでインスコできるだろって親切に教えてやって
>>486で逆切れしてるながれなのに、スタンドアロン環境が普通かどうかとかってそれ論点じゃねーだろw
塚その日本語能力のなさお前ら同一人物だろwww
情報ないのかと思ってぐぐったら簡単に見つかったけど教えてやらんわ(´・ω・`)
498 :
デフォルトの名無しさん:2013/09/16(月) 02:52:48.07
>>497 迷惑なやつだなおまえ
スレタイ読んで書き込んでんの?
499 :
デフォルトの名無しさん:2013/09/16(月) 02:54:02.20
>>497 いや同一人物ってわかるだろ
どんだけバカなのおまえ・・・
500 :
デフォルトの名無しさん:2013/09/16(月) 02:55:53.81
>>497 > だから
>>486でイミフな絡み方してるから日本語の解説してやっただけだろ。
> 教えてくんならそれらしく下手に出てればいいのに。
おまえのがイミフ
日本語の解説ってそういうスレなの?
スレタイ読んでどうしても日本語の解説したかったとか
くだらん頭おかしすぎ
501 :
デフォルトの名無しさん:2013/09/16(月) 02:58:51.30
> 情報ないのかと思ってぐぐったら簡単に見つかったけど教えてやらんわ(´・ω・`)
おまえ・・・やっぱり知らないくせに適当に書き込んでたんじゃん
だからさ俺が知ってるとかじゃなくて
ちゃんと知られてないからマイナーなんだよって言ってんだけど?
相当くずだなおまえも
>塚その日本語能力のなさお前ら同一人物だろwww
これはあたまおかしすぎ
過疎スレの皆さんにごめんなさいしろよゴミ男が
502 :
デフォルトの名無しさん:2013/09/16(月) 02:59:36.35
大事なことなので訂正
× 相当くずだなおまえも
○ 相当くずだなおまえが
503 :
デフォルトの名無しさん:2013/09/16(月) 03:05:58.44
>>484でスタンドアロンがいいっていうから
>>485がスタンドアロンでインスコできるだろって親切に教えてやって
>>486で逆切れしてるながれなのに、スタンドアロン環境が普通かどうかとかってそれ論点じゃねーだろw
>>485のどこが親切なんだよ
おまえの国じゃこれが親切なのかくずだなすばらしいね
おまえスレ違いすぎだからスレタイよく読んで書き込めカス
スタンドアロンでの使われ方は普通には知られてない裏技的なものだし
それに俺の言いたい論点はこれだけ
>なんだ、お前そんなのも知らんのとかいいたいだけのカスか
おまえみたいに無自覚に迷惑かけてるやつが一番迷惑だからさっさとでてけ
504 :
デフォルトの名無しさん:2013/09/16(月) 03:08:44.77
なんだ、お前そんなのも知らんのとかいいたいだけのカスか
505 :
デフォルトの名無しさん:2013/09/16(月) 03:11:13.20
>fsiやfsc はスタンドアロンでインストールもコンパイルもできるだろ?
これが親切に教えてくれてるとかどういう頭の構造してんだよ
なんだ、お前そんなのも知らんのとかいいたいだけのカスじゃないか
危ない人に触ってしまった(;´∀`)
御苦労
>>508 ebookは出ないの…かしら(´・ω・`)
>>509 no scrachならしばらくすればoreilly.comで売られる
>>510 オライリーにリンクはあったけどまだebookのはなかったぽ。
まだ先そうだし待つわー(´・ω・`)
>>511 多分正式番でるまでは無理だね
紙も同じだけど
もしかしたらsafariとかは来る可能性あるかな
igetaさんのIE本買ったけどこれF#でやる必要性あるの?
あー前つぶやかれてはったなー
中身知らんけど一つの方法としてF#か^が楽ならいいんじゃない?
まぁ誰もその表紙で中にF#が出てくるとは夢にも思うまいに。
517 :
デフォルトの名無しさん:2013/10/07(月) 11:45:29.27
昔はVBAで結構いろんな事やってたんだろうね
今、イチからやるならあえてVBA経由する必要は無いと思うけど
F#ではじめる金融工学入門、とかなら読んでみたい。
なんか呼ばれてた。
どうなんでしょうね。著者の方が決めたテーマですから。
僕はそれをコードに落とし込んで原稿にしてってとこを
お手伝いしただけなので。
F# でやる意味、というか、ネタ的な章という位置付けで。
.NET の言語とも連携できるんだよーって紹介でもあり。
なら C# でいいじゃん、ではあるけど、VBA 使いでもある
僕の感覚としては、OOP な C# よりも、モジュール、関数
が書ける F# のが割となじむような気はします。
その本のF#のページってどのくらいですか?
多少でもF#の勉?になるのかな
>勉強
最終章の Chapter11 が F# ネタ。たぶん30ページくらい。
www.shuwasystem.co.jp/products/7980html/3915.html
正直 F# の勉強にはあまり向かないと思います。
あくまで、F# で作った dll を VBA から叩くために COM 相互運用
機能を利用するにはどうやるかに主眼を置いていて、VBA な人にも
F# に興味を持ってもらえたらなあって内容なので。
なるほど ありがとうございます。
本屋で見かけたらとりあえず少し立ち読みして買うか考えようかな
oh...
だっさー(´・ω・`)
ブックカバーが必須だな
>>518 MEAPから見出しを抜粋するとこんな感じ:
4 Numerical computing in finance domain
4.1 Introducing financial derivatives
4.2 Using probability functions of Math.NET
4.2.1 Configuring F# Interactive
4.2.2 Download and Set up Math.NET Numerics
4.2.3 Introducing Random Variables, Expectation and Variance
4.3 Geometric Brownian Motion and Monte Carlo Estimate
4.3.1 Modeling stock prices using geometric Brownian motion
4.3.2 Payoff Function, Discounted Payoff, and Monte Carlo estimate
4.3.3 Analaysing Monte Carlo estimates using variance
4.3.4 Pricing oath-dependent options
4.3.5 Variance reduction using antithetic variates
著者はChao-Jen Chenだそうな。
type T = [<Leaf>]A | [<Node>]B of T * T
この型Tに対して
let rec size = function A -> 1 | B(x,y) -> 1 + size x + size y
こんなような関数を大量に自動生成したいんだけど
Reflection+CodeDom以外に選択肢ある?
>>530 直感的に思いつくのはT4だけど、F#プロジェクトではサポートされてないから
T4用にC#かVBのプロジェクトを追加して、そっちで生成したファイルをF#プロジェクトに追加すればいいかもしれない。
stackoverflow.com/a/2199527
>>531 情報ありがとう
T4はF#だと茨の道くさいからCodeDomで頑張りますわ
533 :
デフォルトの名無しさん:2013/11/21(木) 06:01:23.06
盛り上がってるね。
え
TIOBEで20位入ってる。
周りで流行ってきてる実感ありますか?
VisualStudioで扱える関数型ということで期待したが、
言語仕様が古臭すぎて萎えた。
・ ソースコードのコンパイル順序を指定
・ 基本的に後方参照不可
・ 循環参照にはキーワードが必要
1980年代にタイムスリップした気分だぜ。
>>537 実際それぐらいまで一度戻って、プログラミング遍歴を全部やり直すぐらいの覚悟はいるかも。得られるものは大きいけどね。
539 :
デフォルトの名無しさん:2013/12/09(月) 19:25:15.19
>>537 むしろその方がどこで参照されるか想定できるから俺は嫌いじゃない
はきだめ
RProviderでCRANを使う場合ライセンスってどうなる?
もしRProvider経由でGPL汚染するならCRANは件並みGPLだからオワタ\(^o^)/
け、件並み……?
くだんなみだろ
F#はJ#のようにVSの一部でしかないのですっかりPowerShellより日の当たらない存在
スタンドアロンで使えるじゃねえかといかいうバカも居るけど
そうやって使ってる奴はいないわけで
F#専用サイトだったhubFSがFPishという関数型言語総合サイトに変わって数年たつし
F#の話題がないのは海外でも同じなんだよね
日本の弱小ブロガーだけがスタンドアロンで余裕で使えるわ!、
などとおつよそうに喧嘩売ってくるという有り様
547 :
デフォルトの名無しさん:2014/01/04(土) 13:19:08.08
海外でも国内でも使ってことのある人の中ではバランスのとれたとても良い言語となってると思うけど…
Xamarinの方でも積極的に取り入れてるし一定の評価えてるとおもうけどな。
F#のコミュニティ見てるのでそれ以外の声が全然ないかは知らん。
自分は必要ない限り極力F#使ってC#成分はできるだけ減らしてる
C#に勝とうとしちゃなんね。
それよりはF#の強い部分をアピールすべきだなんや。
構文木をこねくり回すプログラムを書く必要があったからF#使ってたけど
最近は数値計算が多くてなんかもうC#に絞った方がいいんじゃないかって気がしてきた
F#の利点は何かありますか?
550 :
デフォルトの名無しさん:2014/01/06(月) 11:22:48.48
>>549 むしろC#で書く利点がなに一つなくね?
>>544 一応確認しておくけど、読みは「けんなみ」じゃないからね
そういえば、F#のMVPであるbleisという人が、彼女が出来てリア充になったそうな。
F#erになるとリア充になれる!?
>>550 数値計算本のアルゴリズムはだいたいCとかで書かれていて
ループ内でbreakやcontinueが使われているものが多いんだわ
だからF#で書きなおす際に頭を悩ますというのが最大の問題
あとx *= 2.0とか書けない
VSバージョンあごるごとにインストール方が微妙になって行ってるのはなんなの
どこがスタンドアロンで余裕なんだよ
>>553 それは花王デモの主催者が彼女出来て活動終了したのと同じで本人次第
花王デモやF#を選んだのが正解だったというわけではない
>>554 コア部分のロジックをF#で書けばいいんだ!なんて
息巻いてた奴らクソうざかったんだけども彼女が出来てやめたんだろうな
>>550はブサすぎてできないらしい。こういう奴もいるから
バージョンあごる、はこっちの方言だからあってるからな
件並みは方言ではないけど
558 :
デフォルトの名無しさん:2014/01/06(月) 23:25:46.21
>>554 業務でCで書かれた配列の更新とかループバリバリのアルゴリズム、F#で書き直したらすごいスッキリしたよ。
559 :
デフォルトの名無しさん:2014/01/06(月) 23:28:00.85
>>552 C#人口が多いのは確かにありだね。
うちの会社は勉強会とかしたら色々と難しそうだけどいいんじゃね?って話になって導入が進みそう。
知名度低すぎ
IDEを使えないスタンドアロンには意味は無いからな
UNIX勢だって補完なしでCUI使うやつなんかいないよ
3.1はVS expressではまだ使えないのか
562 :
デフォルトの名無しさん:2014/01/07(火) 21:57:12.38
MonoDevelopならいけんじゃね
ML使いを取り込めてるの?
スタンドアロンでコンパイルしてみたらリファレンス関連が不明過ぎてこれはアカン
調べてもexpress使えだし
2013は不明なのでVS express 2012をインストール
拡張機能からテンプレをインストールしてきた
F#関連で最もダウンロードされてるのは
F# C# MVC4
ってのが71729ダウンロードだった
この感じだとF#本で10000部はありえないな
1000部くらいか・・・?
2012 expressでやってみたらあっさりビルドできたわ
コマンドラインみたらどっさり。
これ--noframeworkして全部dll書かないとダメなのね
まあコピーしてbatなりmsbuildなりでなんとかなりそうだが
これは初心者じゃスタンドアロン無理だわ
IDEの何が嫌ってちょっと試すだけでプロジェクトだのソリューションだの
名前付けないとダメなとこよ
scratchで書きなぐりたいんだがな
でも補完とかはさすがに便利
パソコン変えたのもあるけどf# 2.0のころに比べるとだいぶ軽くなってて驚いたよ
fsi xxx.fsx でも実用レベルだし
ただ全然忘れてるから昔書いたものが暗号状態だわ
powerpackとかもどうなってるのか謎
568 :
デフォルトの名無しさん:2014/01/09(木) 09:40:04.45
そんな重いことあったっけ?
i5,7しか使ってないけど重さ気にしたことがない(´・_・`)
スタンドアローン連呼してた人は逃げちゃった?
スタンドアローン連呼くんまだー?
あ〜あ
IDでますます過疎るなこのスレw
いままでほとんど一人で持ってたのかこのスレは?
575 :
デフォルトの名無しさん:2014/03/14(金) 15:35:34.96 ID:Vwn/0IeX
>>570>>571 あ?
スタンドアローン連呼してた人だけど
逃げたとかおかしいだろ
今までのが不十分だったからMSが対応したんだろ?
MSの対応は歓迎だとしか言いようがないが。
人が少ないからって開き直ってごまかせると思うなよ?
むしろ今までだってスタンドアロンくらいあるわとか
親切に教えてやったとか言いはってたヤツは逃げちゃった?
MSが対応する余地があったってことは明白なのに
無駄に叩いてきたのはお前らだろうが
現状で十分だと言いはってたんだから公害としか言いようがない
人が少ないからって開き直ってごまかせると思うなよ?
強制IDで消えろよゴミどもw
俺はもともとID変えてるから困らんけどなw
覚悟しろゴミクズ
576 :
デフォルトの名無しさん:2014/03/14(金) 15:41:16.74 ID:Vwn/0IeX
>>570>>571 この開き直りは醜すぎるな
スタンドアローン登場は歓迎に決まってるだろ?
すでにあった
>>485とかお前そんな事もしらんの?
>>488とか
からみ方が意味不とか情報ないのかと思ってぐぐったら簡単に見つかったけど教えてやらんわ(´・ω・`)とか
喧嘩売ってた
>>497 は逃げちゃった?
情報ないのかと思ってぐぐったら簡単に見つかったけど教えてやらんわ
の割にはMSが改めて対応しちゃったけどw
577 :
デフォルトの名無しさん:2014/03/14(金) 15:43:04.00 ID:Vwn/0IeX
なにがスタンドアローン連呼くんだよ
迷惑なのは
>>570>>571の方だ
情報ないのかと思ってぐぐったら簡単に見つかったけど教えてやらんわ(´・ω・`)とか書いてた
>>497 だろ
逃げちゃった?
無様だなw
578 :
デフォルトの名無しさん:2014/03/14(金) 15:44:51.27 ID:Vwn/0IeX
>>568 F#1.0とかVS統合前に使ったこともないような情弱は黙ってたら?
579 :
デフォルトの名無しさん:2014/03/14(金) 15:47:47.96 ID:Vwn/0IeX
>>558 > 業務でCで書かれた配列の更新とかループバリバリのアルゴリズム、F#で書き直したらすごいスッキリしたよ。
ただの自己満
まともなところならちゃんと検証するわけだけど
報酬すら出ないような箇所なんだろうな
580 :
デフォルトの名無しさん:2014/03/14(金) 15:52:07.33 ID:fuyZXWFL
>>570>>571 スタンドアローンくんだけど
ほんとに来てほしいと思ってるの?
それでF#の話してもらえると思ってるの?
甘えるなクズが
F#の話じゃなくて人をからかいたいだけのやつは迷惑だから来るな
こういうクズが強制IDでいなくなるといいわ
煽り耐性無さすぎですよ
IDあるとNGしやすいから助かるよ
583 :
デフォルトの名無しさん:2014/03/14(金) 20:59:40.27 ID:bbGk2WDX
こいつは何と戦ってるんだ(´・ω・`)
Blue Mountain Capitalに入りたいんですけどどうしたらいいですか?
自営業だから他人に見せない部分でこの言語使ってるけど
他にどんな人が使ってるのか想像もできない
金融で使ってる人いるの?
591 :
デフォルトの名無しさん:2014/04/03(木) 20:03:23.18 ID:3wZs6sQe
NVIDIAのGTCってイベントに行ってきたんだけど、F#の中で
ASTをいじってCUDA向けのPTXコードを吐いてGPUを使うって言う
トークがあって、すげーと思った。スウェーデンの金融系IT会社だった
やたらF#推しててワロタ
間違えた、PTXじゃなくてLLVMだった
594 :
デフォルトの名無しさん:2014/04/04(金) 08:11:01.75 ID:14aTz2cV
>>590 金融と言う程じゃないけどデイトレアプリとかそのサーバーとかに使ってる。
つか言語指定されなければ何にでも使うと思う。
C#はだるすぎる。
>>593 うん、その会社。リンク張ってくれたプレゼンは去年のだけど。
今年のはまだ公開されてない。1,2週間くらいで公開されるはず
condは爽快感あるけどパターンマッチはあんまりない、
コマンド必殺技と弱キックって感じ
過疎りすぎワロタ…
上がりそうな株の銘柄を発掘するアプリを途中まで書いてたが
結局scalaで書き直してしまった
F#もscalaも大差無いけどF#はオフサイドルールのせいで自動整形できないのが面倒だわ
598 :
1:2014/08/25(月) 19:05:57.01 ID:DrxGPTGS
あら、誤爆した。
失礼しました。
600 :
デフォルトの名無しさん:2014/09/01(月) 17:59:14.45 ID:Vs+BnQy2
pythonでオフサイドルール以外は書く気が起きない体になってしまったのでF#の存在は有り難い
ならpythonでいいんだけどな
602 :
デフォルトの名無しさん:2014/11/18(火) 17:32:17.94 ID:nqmEmvVP
盛り上がらないなここ
F#入れてみたぜ
.NET OSS化でUnix環境でも素直に動かせるようになるのか?
今までと変わらないと思う。
MSは.NET推しに必死だな。なぜだろう
自社のプロダクト推さない会社って何なの
おっとGoogleの悪口はそこまでだ
FSharp.Core.dllの同梱許可だすかちゃんとランタイムを配布してくれ
ブロガーたちも最終更新から時間だけ過ぎていく・・・
初関数言語で手を出してみて、日本語の情報少なすぎてきついけど面白いですね
いやー前より増えた方だよ。2010頃とか皆無やった。
Haskellをちょっとかじったのが役に立った
Visual StudioのF#向け機能がC#とかに比べて貧弱すぎ
リファクタリング機能くらい標準でつけてくれ
見当違いの物が出てくる
>>611 毎回そんなでかいファイル配布して平気ならもちろんそれでいいし
だから本家ランタイムの配布がなくてもいいという話にはならない
別の話
PowerToolsはOCaml互換機能とかでVisualStudioの機能とは関係ない
リファクタリングくらいとかいうが
C#とかだってその機能つくまでそれなりに時間かかってるはず
Visual Studio Community 2013をダウンロードしてくればいいの?
え、またパクったんだ
629 :
デフォルトの名無しさん:2015/02/18(水) 13:13:29.83 ID:jy9NcG0p
C#と、本番環境がWindowsの仕事しています。
運用系のスクリプトなり、ちょっとしたデータ編集などを PowerShell で書くのがイヤなので、
.NET で動く簡易なスクリプトを探していたのですが、F# にたどりつきました。
JavaのGroovyみたいに、C#用のdllをF#で呼べるのがいいですね。
>>631 その理屈はよくわからんが…F#の方が生産性えーやん
人数確保できないからじゃね
何度も言われてるけどC#は悪くはないどころか相当いい言語だからなあ
せめて型推論ちゃんとしてたらなぁ
昨今の関数型言語ブームでF#も再評価されないかな
海外の方が評価高そうやね。
日本はMVPどもがC#マンセーばかりだからな
C#はC/C++の焼き直し、J#はJavaベース。
だから最近まで、F#は.NET版FORTRANと思って無視してた。
D#はよ
それならH#の方が
山田くん、>639さんから座布団、全部取り上げて
643 :
デフォルトの名無しさん:2015/02/27(金) 18:49:28.82 ID:mwmXoOej
次の書き込みはまた二ヶ月後ですか
644 :
デフォルトの名無しさん:2015/02/28(土) 01:00:37.05 ID:L/NnvF7q
>>581 煽り耐性とかそういう話じゃねえよ覚悟がないなら喧嘩売ってくんな
>>582 いちいちIDしたとか報告いるのかね
必要な情報なのかね?さっぱりわからんのだけど
荒らしにしか見えんわ
646 :
デフォルトの名無しさん:2015/02/28(土) 01:01:50.96 ID:L/NnvF7q
647 :
デフォルトの名無しさん:2015/02/28(土) 01:02:28.45 ID:L/NnvF7q
>>645>>582 いちいちIDをNGしたとか報告いるのかね
必要な情報なのかね?さっぱりわからんのだけど
荒らしにしか見えんわ
648 :
デフォルトの名無しさん:2015/02/28(土) 01:02:55.78 ID:L/NnvF7q
F#専用サイトだったhubFSがFPishという関数型言語総合サイトに変わって数年たつし
F#の話題がないのは海外でも同じなんだよね
日本の弱小ブロガーだけがスタンドアロンで余裕で使えるわ!、
などとおつよそうに喧嘩売ってくるという有り様
1年も前のレスに安価連投とかなにこれキモい
まあ海外の方が評価してる人多そうだけどな。
Xamarinのミゲルもお気に入りらしいし。
随分、思い切った言語仕様だがメインストリームになるんかの
お題スレみたけどlet文がずらっとあると見る気しないな
スクリプト的なの向いてないんか
慣れかな
F#も10年くらいたつと思うけど
これから来る!とかだんだん使われてきてる!、
とか言われてることが当時と同じなんだよなw
まあ生き残ってるだけでも褒めてやるべきか
つづいていればいいことあるさ
何かscalaとかぶるな
S#はよ