トレーディングにおける機械学習:理論、モデル、実践、アルゴトレーディング - ページ 3270 1...326332643265326632673268326932703271327232733274327532763277...3399 新しいコメント fxsaber 2023.10.01 11:45 #32691 トレーディング、自動売買システム、トレーディング戦略のテストに関するフォーラム トレーディングにおける機械学習:理論、モデル、実践とアルゴリズム取引 マキシム・ドミトリエフスキー, 2023.10.01 10:55 AM residuals_a= a_mat- a_mat. column_means residuals_b= b_mat- b_mat. column_means a_residual_sums= residuals_a. column_sums b_residual_sums= residuals_b. column_sums residual_products= dot_product( residuals_a. transpose, residuals_b) sum_products= sqrt( dot_product( a_residual_sums, b_residual_sums)) 相関= 残差積/ 総和積 これは相関行列を真正面から計算したものと思われる。 Aleksei Kuznetsov 2023.10.01 11:45 #32692 fxsaber #: そうか、ありがとう!なぜinCols < 100で間違ったオプションが機能したのか理解できません。 Sens = 1 e-10 度合いが度が度が度が度が度が度が度が度が度が度が度が度が度がーランダム - そこでの平均相関は、おそらく約0です。 fxsaber 2023.10.01 11:49 #32693 Forester #:おそらく多すぎる。ー平均的 な度合いでは度合い0.だろう。 そこで測定されるのは平均誤差ではなく、対応する要素間の最大差です。 ー取引、ー自動売買システムー取引戦略のーに関するーに関するーに関するーに関するーに関するーフォーラム ー トレーディングにおけるー理論、ー、ーモデル、ー実践ー ーfxsaber, 2023.10.01 09:38 pm bool IsEqual( matrix<double> &Matrix1, const matrix<double> &Matrix2, const double Sens = 1 e-10 ) { Matrix1 -= Matrix2; const bool Res = (MathMax(MathAbs(Matrix1.Max()), MathAbs(Matrix1.Min())) < Sens); Matrix1 += Matrix2; return(Res); } ー.ー.ー.ー.ー.ー.ー.ー.ー.ー. for (int i = 0; i < (int)Matrix.Rows(); i++) は一致を取得します。 inRows = 5 inCols = 50 matrix<double> Matrix1 = CorrMatrix(Matrix) - 242 mcs, 0 MB matrix<double> Matrix4 = CorrMatrix2(Matrix) - 117 mcs, 0 MB IsEqual(Matrix1, Matrix4) = true fxsaber 2023.10.01 11:53 #32694 Forester #: そして、PearsonCorrM2は、三角形でカウントすれば、2倍のスピードアップが 可能である。100行をすべてで数え、次に99行をすべて0-99で数え、99番目と100番目はすでに数えてあるので、コピーすればよい。 50行をすべてで数え、50番目まで数える。Well, do not count with itself because =1. ー「ーではー。 inRows = 100 inCols = 15000 matrix<double> Matrix1 = CorrMatrix(Matrix) - 14196778 mcs, 1717 MB matrix<double> Matrix4 = CorrMatrix2(Matrix) - 538256223 mcs, 1717 MB IsEqual(Matrix1, Matrix4) = true 恐ろしいブレーキはまだ遅くなります。、フランクスのフルトはフランクフルトはフルトののフルトのフルト、フルトのフルトとフルトのフルトとフルトのフルトのフルトと ←ここ重要 fxsaber 2023.10.01 12:11 #32695 fxsaber #:だから、間違ったコードでは、どうすればいいのかわからない。が一致する。 行列の計算を入れ替えると、ミスマッチが発生する。 inRows = 5 inCols = 50 matrix<double> Matrix4 = CorrMatrix2(Matrix) - 113 mcs, 0 MB matrix<double> Matrix1 = CorrMatrix(Matrix) - 214 mcs, 0 MB IsEqual(Matrix1, Matrix4) = false つまり、最初の行列の計算中にメモリにあったゴミが新しい行列に入り込み、奇跡的に目的の結果と一致したのだ。 削除済み 2023.10.01 12:14 #32696 fxsaber #: 相関行列の真正面からの計算だと思います。 そうですね、新しい行列でサイクルなしでμlを作れば速くなるのでは? Aleksei Kuznetsov 2023.10.01 12:20 #32697 fxsaber #: 196 500秒対14秒。 PearsonCorrM 最速だったと記憶しています。 Maxim Dmitrievsky#: そうですね、新しいμl行列で作れば速くなるのでは? PearsonCorrM と PearsonCorrM2 で使われている 9 つの関数はすべて行列に書き換えて比較できると思います。原理的には、行列の宣言と参照を書き直すのに1時間かかるでしょう。同時に、行列がdin.配列より優れているかどうかも分かるだろう。 タイトル IsFiniteMatrix( IsFiniteVector( AblasInternalSplitLength( AblasSplitLength( RMatrixGemmK( RMatrixGemm( RMatrixSyrk2( RMatrixSyrk( RankX( fxsaber 2023.10.01 12:26 #32698 Forester #:PearsonCorrM と PearsonCorrM2 で使用されている 9 つの関数は、すべて行列に書き換えて比較できると思います。原則的には、行列の発表と参照を書き換えるのに1時間かかるでしょう。同時に、行列がディン配列より優れているかどうかもわかるだろう。MQはマトリックスに書き換えている。フォレスター#: 500秒 vs 14 - そういえばそうだった。 アルゴリズムが最速だった。そのアルゴリズムには気づかなかった。NumPyが大きく遅れをとっていないのは、繰り返し計算を行わないからに他ならない。 NumPyはALglibとは異なるアルゴリズムを持っているようだ。しかし、巨大なPythonコミュニティの中に、この問題の研究にそれなりの時間を費やした非常に強力なアルゴリズム研究者がいたことは明らかです。 Aleksei Kuznetsov 2023.10.01 12:28 #32699 fxsaber #:MQが自分たちのマトリックスに合うように書き換えたのだ。 それで遅くなったのか?) fxsaber 2023.10.01 12:29 #32700 Forester #:さらに遅くなった?) 旧バージョンのAlglibと比較してください。遅くなったというデータはありません。 1...326332643265326632673268326932703271327232733274327532763277...3399 新しいコメント 取引の機会を逃しています。 無料取引アプリ 8千を超えるシグナルをコピー 金融ニュースで金融マーケットを探索 新規登録 ログイン スペースを含まないラテン文字 このメールにパスワードが送信されます エラーが発生しました Googleでログイン WebサイトポリシーおよびMQL5.COM利用規約に同意します。 新規登録 MQL5.com WebサイトへのログインにCookieの使用を許可します。 ログインするには、ブラウザで必要な設定を有効にしてください。 ログイン/パスワードをお忘れですか? Googleでログイン
トレーディング、自動売買システム、トレーディング戦略のテストに関するフォーラム
トレーディングにおける機械学習:理論、モデル、実践とアルゴリズム取引
マキシム・ドミトリエフスキー, 2023.10.01 10:55 AM
residuals_a= a_mat- a_mat. column_means residuals_b= b_mat- b_mat. column_means a_residual_sums= residuals_a. column_sums b_residual_sums= residuals_b. column_sums residual_products= dot_product( residuals_a. transpose, residuals_b)
相関= 残差積/ 総和積
これは相関行列を真正面から計算したものと思われる。
そうか、ありがとう!なぜinCols < 100で間違ったオプションが機能したのか理解できません。
おそらく多すぎる。ー平均的 な度合いでは度合い0.だろう。
そこで測定されるのは平均誤差ではなく、対応する要素間の最大差です。
ー取引、ー自動売買システムー取引戦略のーに関するーに関するーに関するーに関するーに関するーフォーラム
ー トレーディングにおけるー理論、ー、ーモデル、ー実践ー
ーfxsaber, 2023.10.01 09:38 pm
ー.ー.ー.ー.ー.ー.ー.ー.ー.ー.
は一致を取得します。
そして、PearsonCorrM2は、三角形でカウントすれば、2倍のスピードアップが 可能である。100行をすべてで数え、次に99行をすべて0-99で数え、99番目と100番目はすでに数えてあるので、コピーすればよい。 50行をすべてで数え、50番目まで数える。Well, do not count with itself because =1.
だから、間違ったコードでは、どうすればいいのかわからない。
が一致する。
行列の計算を入れ替えると、ミスマッチが発生する。
つまり、最初の行列の計算中にメモリにあったゴミが新しい行列に入り込み、奇跡的に目的の結果と一致したのだ。
相関行列の真正面からの計算だと思います。
196
500秒対14秒。
最速だったと記憶しています。
そうですね、新しいμl行列で作れば速くなるのでは?
PearsonCorrM と PearsonCorrM2 で使われている 9 つの関数はすべて行列に書き換えて比較できると思います。原理的には、行列の宣言と参照を書き直すのに1時間かかるでしょう。同時に、行列がdin.配列より優れているかどうかも分かるだろう。
タイトル
IsFiniteMatrix(
IsFiniteVector(
AblasInternalSplitLength(
AblasSplitLength(
RMatrixGemmK(
RMatrixGemm(
RMatrixSyrk2(
RMatrixSyrk(
RankX(
PearsonCorrM と PearsonCorrM2 で使用されている 9 つの関数は、すべて行列に書き換えて比較できると思います。原則的には、行列の発表と参照を書き換えるのに1時間かかるでしょう。同時に、行列がディン配列より優れているかどうかもわかるだろう。
MQはマトリックスに書き換えている。
500秒 vs 14 - そういえばそうだった。
アルゴリズムが最速だった。
そのアルゴリズムには気づかなかった。NumPyが大きく遅れをとっていないのは、繰り返し計算を行わないからに他ならない。
NumPyはALglibとは異なるアルゴリズムを持っているようだ。しかし、巨大なPythonコミュニティの中に、この問題の研究にそれなりの時間を費やした非常に強力なアルゴリズム研究者がいたことは明らかです。MQが自分たちのマトリックスに合うように書き換えたのだ。
それで遅くなったのか?)
さらに遅くなった?)
旧バージョンのAlglibと比較してください。遅くなったというデータはありません。