科学技術計算におけるF#のパフォーマンス
2023-10-26 20:40:37
質問
F#のパフォーマンスはC++のパフォーマンスと比較してどうなのか、興味があります。 私はJavaに関して同様の質問をしましたが、私が得た印象は、Javaは重いナンバークランチングには適していないということでした。
F#はよりスケーラブルでよりパフォーマンスが高いと言われていますが、この実際のパフォーマンスはC++と比べてどうなのでしょうか? 現在の実装に関する具体的な質問です。
- 浮動小数点はどの程度うまく処理できますか?
- ベクター命令は可能か
- 最適化コンパイラに対してどの程度友好的か コンパイラに優しいですか?
- メモリフットプリントはどの程度ですか? メモリ局所性をきめ細かく制御できますか?
- 分散メモリ・プロセッサのための容量を備えていますか? Cray のような分散メモリ プロセッサに対応できますか?
- 重い数値処理を伴うような計算科学に興味を持たれるような機能はありますか?
- 実際に科学技術計算機 の実装はありますか?
ありがとうございます。
どのように解決するのですか?
- F#は.NET CLRが許す限り、浮動小数点演算を高速に行う。C#や他の.NET言語と大きな差はありません。
- F#はそれ自体ではベクトル命令を許さないが、もしCLRがこれらのためのAPIを持っているならば、F#はそれを使うことに問題はないはずである。例えば Mono .
- 私の知る限り、F# コンパイラは今のところ 1 つしかないので、おそらく質問は "最適化に関して F# コンパイラはどの程度優れているのか" とすべきなのでしょう。いずれにせよ、答えは「C#コンパイラと同じくらい良い可能性があり、現時点では少し悪いかもしれません」です。F#は、コンパイル時にインライン化をサポートしている点でC#などと異なっており、ジェネリックに依存したより効率的なコードを実現できる可能性があることに注意してください。
- F#プログラムのメモリフットプリントは、他の.NET言語と同様です。割り当てとガベージ コレクションを制御できる量は、他の .NET 言語と同じです。
- 分散メモリのサポートについてはわかりません。
- F#はフラットなデータ構造、例えば配列やリストを扱うための非常に優れたプリミティブを持っています。例えば、Arrayモジュールの内容を見てください:map, map2, mapi, iter, fold, zip...。配列は科学技術計算で人気がありますが、これはその本質的に優れたメモリローカリティ特性のためでしょう。
- F#を使った科学計算パッケージについては、Jon Harropがやっていることを見てみるとよいでしょう。
関連
-
[解決済み】'cout'は型名ではない
-
[解決済み】c++でstd::vectorを返すための効率的な方法
-
[解決済み] SQLiteのINSERT/per-secondのパフォーマンスを向上させる
-
[解決済み] 0.1fを0にすると、なぜ10倍もパフォーマンスが落ちるのですか?
-
[解決済み] Swift Betaのパフォーマンス:配列のソート
-
[解決済み] Dockerコンテナのランタイムパフォーマンスコストとは何ですか?
-
[解決済み] 文字列の最初の文字を大文字にする(最大限のパフォーマンスを発揮する)
-
[解決済み] Javaにおける例外処理によるパフォーマンスへの影響とは?
-
[解決済み] HashSetとListの性能比較
-
[解決済み] Intel CPU の _mm_popcnt_u64 で、32 ビットのループカウンターを 64 ビットに置き換えると、パフォーマンスが著しく低下します。
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み】C++エラー。アーキテクチャ x86_64 に対して未定義のシンボル
-
[解決済み】コンストラクターでのエラー:識別子を期待されますか?
-
[解決済み】C++ 式はポインタからオブジェクトへの型を持っている必要があります。
-
[解決済み】リンカーエラーです。"リンカ入力ファイルはリンクが行われていないため未使用"、そのファイル内の関数への未定義参照
-
[解決済み】C++ - 適切なデフォルトコンストラクタがない [重複]。
-
[解決済み] 数値定数の前にunqualified-idを付けて、数値を定義することを期待する。
-
[解決済み】Enterキーを押して続行する
-
[解決済み】VC++の致命的なエラーLNK1168:書き込みのためにfilename.exeを開くことができません。
-
[解決済み】変数やフィールドがvoid宣言されている
-
[解決済み] 変数サイズのオブジェクトが初期化されないことがある c++