具体的に説明しましょう。What, as they say, comrade cherchez la (or le, or at least les) ?指標は、たくさんあります。その性質は非常に多様であるため、なおさらである。
具体的に説明しましょう。まずストキャスティクスを使いました。一番速いので、それをOsmaのフィルターで薄めて...それからHyLow、Aligator、Mashki、CCI。しかし、すべてのシグナルをパーセンテージに換算すると、無視されるものもあります。明らかに、最適化に基づいて優先順位をつける必要があります。しかし、別の方法として、0と1の信号出力を持つ既存のインジケータに、多少なりとも適切なインジケータ(またはいくつかのインジケータ)を追加することも可能です。現段階では、1.85の期待ペイオフで1日50ポジションのドローダウンを数パーセントで行っています。私見ではかなり良い。しかし、ここで問題なのは、エキスパートアドバイザーが重大な間違いを犯す瞬間、正確には、1日に通常この2つの瞬間があることです(さらに言えば、歴史上のどの日でも)。だから、この瞬間をできるだけフィルターにかけたいと思ったんです。もしかしたら、ジグザグならオーバードローにならず、作業も早いかもしれませんね。以前どこかで見たような気がするのですが......残念ながらその時は重要視しておらず、今となっては見つけることができません。それともう一つ、Extrapolator...これは素晴らしい...しかし、これは再描画する...どうすればいい?
StH11v=iStochastic(NULL, TF1, stK, stP, stD,MODE_SMA,0,MODE_MAIN,0); StH1pr1v=iStochastic(NULL, TF1, stK, stP, stD,MODE_SMA,0,MODE_SIGNAL,0); StH41v=iStochastic(NULL, TF2, stK, stP, stD,MODE_SMA,0,MODE_MAIN,0); StH4pr1v=iStochastic(NULL, TF2, stK, stP, stD,MODE_SMA,0,MODE_SIGNAL,0); StD11v=iStochastic(NULL, TF3, stK, stP, stD,MODE_SMA,0,MODE_MAIN,0); StD1pr1v=iStochastic(NULL, TF3, stK, stP, stD,MODE_SMA,0,MODE_SIGNAL,0); if ( StH11v<25 && StH1pr1v<25 && StH11v> StH1pr1v){ Stx1TF1x= S; Stx1TF1y=0;} if ( StH11v>75 && StH1pr1v>75 && StH11v< StH1pr1v){ Stx1TF1y= S; Stx1TF1x=0;} if ( StH41v<25 && StH4pr1v<25 && StH41v> StH4pr1v){ Stx1TF2x= S; Stx1TF2y=0;} if ( StH41v>75 && StH4pr1v>75 && StH41v< StH4pr1v){ Stx1TF2y= S; Stx1TF2x=0;} if ( StD11v<25 && StD1pr1v<25 && StD11v> StD1pr1v){ Stx1TF3x= S; Stx1TF3y=0;} if ( StD11v>75 && StD1pr1v>75 && StD11v< StD1pr1v){ Stx1TF3y= S; Stx1TF3x=0;} if ( StH11v>25 && StH1pr1v>25 && StH11v> StH1pr1v){ Stx1TF1x=0; Stx1TF1y=0;} if ( StH11v<75 && StH1pr1v<75 && StH11v< StH1pr1v){ Stx1TF1y=0; Stx1TF1x=0;} if ( StH41v>25 && StH4pr1v>25 && StH41v> StH4pr1v){ Stx1TF2x=0; Stx1TF2y=0;} if ( StH41v<75 && StH4pr1v<75 && StH41v< StH4pr1v){ Stx1TF2y=0; Stx1TF2x=0;} if ( StD11v>25 && StD1pr1v>25 && StD11v> StD1pr1v){ Stx1TF3x=0; Stx1TF3y=0;} if ( StD11v<75 && StD1pr1v<75 && StD11v< StD1pr1v){ Stx1TF3y=0; Stx1TF3x=0;}
OSH1=iOsMA(NULL, TF1, W, H, C,PRICE_CLOSE,0); OSH4=iOsMA(NULL, TF2, W, H, C,PRICE_CLOSE,0); OSD1=iOsMA(NULL, TF3, W, H, C,PRICE_CLOSE,0); if ( OSH1<- OS){ OSTF1x= O; OSTF1y=0;} if ( OSH1> OS) { OSTF1x=0; OSTF1y= O;} if ( OSH4<- OS){ OSTF2x= O; OSTF2y=0;} if ( OSH4> OS) { OSTF2x=0; OSTF2y= O;} if ( OSD1<- OS){ OSTF3x= O; OSTF3y=0;} if ( OSD1> OS) { OSTF3x=0; OSTF3y= O;}
double sigyH1=iLowest (NULL, TF1,MODE_CLOSE,3,0); double sigyH4=iLowest (NULL, TF2,MODE_CLOSE,3,0); double sigyD1=iLowest (NULL, TF2,MODE_CLOSE,3,0); double sigxH1=iHighest(NULL, TF1,MODE_CLOSE,3,0); double sigxH4=iHighest(NULL, TF2,MODE_CLOSE,3,0); double sigxD1=iHighest(NULL, TF3,MODE_CLOSE,3,0); if ( sigyH1==1){ SigYTF1= I; SigXTF1=0;} if ( sigyH4==1){ SigYTF2= I; SigXTF2=0;} if ( sigyD1==1){ SigYTF3= I; SigXTF3=0;} if ( sigxH1==1){ SigYTF1=0; SigXTF1= I;} if ( sigxH4==1){ SigYTF2=0; SigXTF2= I;} if ( sigxD1==1){ SigYTF3=0; SigXTF3= I;}
double Gator1H1=iAlligator(NULL, TF1,13,8,8,5,5,3,MODE_SMMA,PRICE_WEIGHTED, MODE_GATORJAW,0); double Gator1H4=iAlligator(NULL, TF2,13,8,8,5,5,3,MODE_SMMA,PRICE_WEIGHTED, MODE_GATORJAW,0); double Gator1D1=iAlligator(NULL, TF3,13,8,8,5,5,3,MODE_SMMA,PRICE_WEIGHTED, MODE_GATORJAW,0); double Gator2H1=iAlligator(NULL, TF1,13,8,8,5,5,3,MODE_SMMA,PRICE_WEIGHTED, MODE_GATORTEETH,0); double Gator2H4=iAlligator(NULL, TF2,13,8,8,5,5,3,MODE_SMMA,PRICE_WEIGHTED, MODE_GATORTEETH,0); double Gator2D1=iAlligator(NULL, TF3,13,8,8,5,5,3,MODE_SMMA,PRICE_WEIGHTED, MODE_GATORTEETH,0); double Gator3H1=iAlligator(NULL, TF1,13,8,8,5,5,3,MODE_SMMA,PRICE_WEIGHTED, MODE_GATORLIPS,0); double Gator3H4=iAlligator(NULL, TF2,13,8,8,5,5,3,MODE_SMMA,PRICE_WEIGHTED, MODE_GATORLIPS,0); double Gator3D1=iAlligator(NULL, TF3,13,8,8,5,5,3,MODE_SMMA,PRICE_WEIGHTED, MODE_GATORLIPS,0); if ( Gator3H1> Gator1H1+ shirina){ GatorX1= G; GatorY1=0;} if ( Gator3H4> Gator1H4+ shirina){ GatorX2= G; GatorY2=0;} if ( Gator3D1> Gator1D1+ shirina){ GatorX3= G; GatorY3=0;} if ( Gator1H1> Gator3H1+ shirina){ GatorX1=0; GatorY1= G;} if ( Gator1H4> Gator3H4+ shirina){ GatorX2=0; GatorY2= G;} if ( Gator1D1> Gator3D1+ shirina){ GatorX3=0; GatorY3= G;}
double MACD1H1=iMACD(NULL, TF1, F_EMA, S_EMA, SMA,PRICE_WEIGHTED,MODE_MAIN,0); double MACD1H4=iMACD(NULL, TF2, F_EMA, S_EMA, SMA,PRICE_WEIGHTED,MODE_MAIN,0); double MACD1D1=iMACD(NULL, TF3, F_EMA, S_EMA, SMA,PRICE_WEIGHTED,MODE_MAIN,0); double MACD2H1=iMACD(NULL, TF1, F_EMA, S_EMA, SMA,PRICE_WEIGHTED,MODE_SIGNAL,0); double MACD2H4=iMACD(NULL, TF2, F_EMA, S_EMA, SMA,PRICE_WEIGHTED,MODE_SIGNAL,0); double MACD2D1=iMACD(NULL, TF3, F_EMA, S_EMA, SMA,PRICE_WEIGHTED,MODE_SIGNAL,0); double MACD3H1=iMACD(NULL, TF1, S_EMA*2, F_EMA*2, SMA*2,PRICE_WEIGHTED,MODE_MAIN,0); double MACD3H4=iMACD(NULL, TF2, S_EMA*2, F_EMA*2, SMA*2,PRICE_WEIGHTED,MODE_MAIN,0); double MACD3D1=iMACD(NULL, TF3, S_EMA*2, F_EMA*2, SMA*2,PRICE_WEIGHTED,MODE_MAIN,0); double MACD4H1=iMACD(NULL, TF1, S_EMA*2, F_EMA*2, SMA*2,PRICE_WEIGHTED,MODE_SIGNAL,0); double MACD4H4=iMACD(NULL, TF2, S_EMA*2, F_EMA*2, SMA*2,PRICE_WEIGHTED,MODE_SIGNAL,0); double MACD4D1=iMACD(NULL, TF3, S_EMA*2, F_EMA*2, SMA*2,PRICE_WEIGHTED,MODE_SIGNAL,0); if(( MACD1H1< MACD2H1)&&( MACD2H1>0)&&( MACD3H1< MACD4H1)&&( MACD4H1>0)){ MACDy1= M; MACDx1=0;} if(( MACD1H4< MACD2H4)&&( MACD2H4>0)&&( MACD3H4< MACD4H4)&&( MACD4H4>0)){ MACDy2= M; MACDx2=0;} if(( MACD1D1< MACD2D1)&&( MACD2D1>0)&&( MACD3D1< MACD4D1)&&( MACD4D1>0)){ MACDy3= M; MACDx3=0;} if(( MACD1H1> MACD2H1)&&( MACD2H1<0)&&( MACD3H1> MACD4H1)&&( MACD4H1<0)){ MACDy1=0; MACDx1= M;} if(( MACD1H4> MACD2H4)&&( MACD2H4<0)&&( MACD3H4> MACD4H4)&&( MACD4H4<0)){ MACDy2=0; MACDx2= M;} if(( MACD1D1> MACD2D1)&&( MACD2D1<0)&&( MACD3D1> MACD4D1)&&( MACD4D1<0)){ MACDy3=0; MACDx3= M;}
double CCIH1=iCCI(NULL, TF1, CCI,PRICE_CLOSE,0); double CCIH4=iCCI(NULL, TF1, CCI,PRICE_CLOSE,0); double CCID1=iCCI(NULL, TF1, CCI,PRICE_CLOSE,0); if( CCIH1>120){ CCIx1= CC; CCIy1=0;} if( CCIH4>120){ CCIx2= CC; CCIy2=0;} if( CCID1>120){ CCIx3= CC; CCIy3=0;} if( CCIH1<-120){ CCIx1=0; CCIy1= CC;} if( CCIH4<-120){ CCIx2=0; CCIy2= CC;} if( CCID1<-120){ CCIx3=0; CCIy3= CC;}
そして、計算する
double resultz1 = ( Stx1TF1x + Stx1TF2x + Stx1TF3x + OSTF1x + OSTF2x + OSTF3x + SigXTF1 + SigXTF2 + SigXTF3 + GatorX1 + GatorX2 + GatorX3 + MACDx1 + MACDx2 + MACDx3 + CCIx1 + CCIx2 + CCIx3) * 5.5555555555555555555555555555556; double resultz2 = ( Stx1TF1y + Stx1TF2y + Stx1TF3y + OSTF1y + OSTF2y + OSTF3y + SigYTF1 + SigYTF2 + SigYTF3 + GatorY1 + GatorY2 + GatorY3 + MACDy1 + MACDy2 + MACDy3 + CCIy1 + CCIy2 + CCIy3) * 5.5555555555555555555555555555556; if ( resultz1< Skill && resultz2< Skill) { Signal=0; Comment("КУРИМ");} if ( resultz1> Skill) { Signal=1; Comment("Неплохо бы BUY");} if ( resultz2> Skill) { Signal=-1;Comment("Неплохо бы SELL");} if ( resultz1> SkillMAX) { Signal=2; Comment("АФИГЕННО BUY");} if ( resultz1> SkillMAX) { Signal=-2; Comment("ФАИГЕННО SELL");}
これがインジケーターに必要なフォーマットだ......。そうそう、十数個のパラメーターの自動最適化も忘れては いけませんね。
まず、間違いが「起こりにくい」市場の条件をできるだけ明確に形式化することが必要である。さらに、同じワイパーやワニといった繰り返しの指標を排除することも、ワイパーの本質を考える上で重要です。
同時に、最初はもっとシンプルなもので自動最適化を実行する必要があります。実際、最適化、そしてそれに伴う自動最適化は、かなり議論のある現象で、多くの場合、「生活」のチェックが必要です。また、テスト履歴を揃えるために10個のパラメータで最適化するのは、ある意味フィッティングです。まず、これらの指標を扱うことで、外部の力を借りずに簡単に入力できるようになり、何より利益が出るようになると思います。
これはもちろんIMHOです - あなたの聖杯、一般的に任意の履歴上の単純な(または同じGA)選択ではなく、その内部の取引原則に基づいて、ストップとテイク(もしあれば)、または単に正式な出口を持つ必要があります。
取引の機会を逃しています。
- 無料取引アプリ
- 8千を超えるシグナルをコピー
- 金融ニュースで金融マーケットを探索
皆さん、午後...いや、夜ですね。ここはマニアックなEAでやってます。まだ完成していないだけで、必ず投稿しますよ♪無料です。ただ、助けが必要なんだ。質問難波バン - 自動最適化を行う方法...8-16 napametrovを言う?サイト上で大きく迫り来る自動最適化に関する記事...ではないことは動作しません...そこに4パラメータが最適に置くことができ、どのようにいかがわしいすべての作品。 一般的には、多分誰かが自分の開発のChagoを促すのだろうか?my dear kimさん、特にあなたに言及する価値があると思います。いいアイデアが浮かんだら、市販のものを描いてみるかもしれませんが、いいものがないんです。あるときは過剰に描画し、あるときはスローにし、あるときは価値のないものを表示する。サブオメガのインジケータをくれたら世界を変えてやる」と言っているわけではありません。Expert Advisorにおける私の戦略の本質は、8つの指標からなるグループシグナルと、少しフィルターをかけたものの比率です。そこで、標準的な 収集の指標を 持ち、個別の指標を実験してみたいのです。一般的には、集団心理が勝つのかもしれませんね。