コーディングのヘルプ - ページ 292 1...285286287288289290291292293294295296297298299...786 新しいコメント Mladen Rakic 2014.06.09 15:37 #2911 daytrade5: MLADEN様 日曜日を除いた前日の高値と安値を単純にプロットするインジケータが見つかりません。添付のインジケータを使用していますが、日曜日のデータを除外するように修正できないかと考えています。よろしくお願いいたします。 デイトレード5 これのはずです。試してみる :prevday_hilo_no_sunday.mq4 ファイル: pdhl.gif 70 kb prevday_hilo_no_sunday.mq4 4 kb daytrade5 2014.06.09 15:59 #2912 mladen: daytrade5 これでいいはずです。試してみてください :prevday_hilo_no_sunday.mq4 ムラデン これはまったくもって完璧です。本当にありがとうございました。 ccjjaa 2014.06.10 05:06 #2913 こんにちは。 少し漠然としていますが、これはEAの機能に 大きな影響を与えるのでしょうか? この問題は、「参照で渡された配列のみ」という36の警告が出るのですが、この新しいMT4では、配列をどのように扱わなければならないのでしょうか。この件に関するあらゆる洞察に感謝します。 Mladen Rakic 2014.06.10 05:20 #2914 cja: こんにちは、これは少し漠然としていますが、これはEAの機能に何か大きな影響を与えるのでしょうか、もしそうなら、それを修正するために何を探す必要がありますか? この問題は、「参照で渡される配列のみ」という36の警告が出るのですが、この新しいMT4で配列を扱わなければならないある方法があるのでしょうか。この件に関するあらゆる洞察に感謝します。 cja コンパイラが自動的に変換するため、影響はないはずです。 この警告を回避するには、関数 宣言の配列型宣言の後に「&」を追加するだけです(つまり、「void example(double arrayPassedByReference[]」の代わりに「void example(double& arrayPassedByReference[]」)。 nevar 2014.06.10 12:32 #2915 ムラデン様、どなたか。 下記のコードはどのように売買シグナルを 作成しているかご存知ですか? ''各バーのopen-close-high-low価格を含む系列配列'' ''Indicator Curves created:Implements a curve of type DRAW_HISTOGRAM'' とありますが、私が見る限り、再描画はしていません。 ありがとうございます。 double W_Buffer0[]; double W_Buffer1[]; double R_Buffer0[]; double R_Buffer1[]; double S_Buffer0[]; double S_Buffer1[]; double E_Buffer0[]; double E_Buffer1[]; int R_t3_period=21; double R_b=0.8; extern int R_mBar=0; double W_e1, W_e2, W_e3, W_e4, W_e5, W_e6, W_c1, W_c2, W_c3, W_c4, W_n, W_w1, W_w2, W_b2, W_b3; double W_t3, W_shift, W_wpr, W_trig, W_t3_period, W_b, W_per, W_psel, W_pbuy; bool R_ft=True; double R_e1, R_e2, R_e3, R_e4, R_e5, R_e6, R_c1, R_c2, R_c3, R_c4, R_n, R_w1, R_w2, R_b2, R_b3; double R_t3[]; int R_LoopBegin, R_shift; int init() { //---- indicators SetIndexStyle (0,DRAW_NONE); SetIndexBuffer (0,W_Buffer0); SetIndexEmptyValue(0,EMPTY_VALUE); SetIndexStyle (1,DRAW_NONE); SetIndexBuffer (1,W_Buffer1); SetIndexEmptyValue(1,EMPTY_VALUE); SetIndexStyle (2,DRAW_NONE); SetIndexBuffer (2,R_Buffer0); SetIndexEmptyValue(2,EMPTY_VALUE); SetIndexStyle (3,DRAW_NONE); SetIndexBuffer (3,R_Buffer1); SetIndexEmptyValue(3,EMPTY_VALUE); SetIndexStyle (4,DRAW_ARROW,EMPTY,2); SetIndexArrow (4,241); SetIndexBuffer (4,S_Buffer0); SetIndexEmptyValue(4,EMPTY_VALUE); SetIndexStyle (5,DRAW_ARROW,EMPTY,2); SetIndexArrow (5,242); SetIndexBuffer (5,S_Buffer1); SetIndexEmptyValue(5,EMPTY_VALUE); SetIndexStyle (6,DRAW_ARROW,EMPTY,2); SetIndexArrow (6,251); SetIndexBuffer (6,E_Buffer0); SetIndexEmptyValue(6,EMPTY_VALUE); SetIndexStyle (7,DRAW_ARROW,EMPTY,2); SetIndexArrow (7,251); SetIndexBuffer (7,E_Buffer1); SetIndexEmptyValue(7,EMPTY_VALUE); //---- return(0); } //+------------------------------------------------------------------+ //| Custom indicator iteration function | //+------------------------------------------------------------------+ int start() { W_t3_period=8; W_b=0.8; W_per=21; W_psel=-30; W_pbuy=-70; W_b2=W_b*W_b; W_b3=W_b2*W_b; W_c1=-W_b3; W_c2=(3*(W_b2+W_b3)); W_c3=-3*(2*W_b2+W_b+W_b3); W_c4=(1+3*W_b+W_b3+3*W_b2); W_n=W_t3_period; if (W_n<1) W_n=1; W_n = 1 + 0.5*(W_n-1); W_w1 = 2 / (W_n + 1); W_w2 = 1 - W_w1; if (R_mBar==0) R_LoopBegin=Bars; else R_LoopBegin=R_mBar; R_LoopBegin=MathMin(R_LoopBegin, Bars); for(int i=0; i<R_LoopBegin; i++) { W_wpr=iWPR(NULL,0,W_per,i); W_e1 = W_w1*W_wpr + W_w2*W_e1; W_e2 = W_w1*W_e1 + W_w2*W_e2; W_e3 = W_w1*W_e2 + W_w2*W_e3; W_e4 = W_w1*W_e3 + W_w2*W_e4; W_e5 = W_w1*W_e4 + W_w2*W_e5; W_e6 = W_w1*W_e5 + W_w2*W_e6; W_t3 = W_c1*W_e6 + W_c2*W_e5 + W_c3*W_e4 + W_c4*W_e3; if (W_t3>=-50) W_trig=W_psel; if (W_t3<-50) W_trig=W_pbuy; W_Buffer0=W_t3; W_Buffer1=W_trig; } if (R_mBar==0) R_LoopBegin=Bars-R_t3_period-1; else R_LoopBegin=R_mBar; R_LoopBegin=MathMin(R_LoopBegin, Bars-R_t3_period-1); ArrayResize(R_t3, R_LoopBegin); if (R_ft) { R_b2=R_b*R_b; R_b3=R_b2*R_b; R_c1=-R_b3; R_c2=(3*(R_b2+R_b3)); R_c3=-3*(2*R_b2+R_b+R_b3); R_c4=(1+3*R_b+R_b3+3*R_b2); R_n=R_t3_period; if (R_n<1) R_n=1; R_n=1+0.5*(R_n-1); R_w1=2/(R_n+1); R_w2=1-R_w1; R_ft=False; } for (R_shift=R_LoopBegin; R_shift>=0; R_shift--) { R_e1=R_w1*Close[R_shift]+R_w2*R_e1; R_e2=R_w1*R_e1+R_w2*R_e2; R_e3=R_w1*R_e2+R_w2*R_e3; R_e4=R_w1*R_e3+R_w2*R_e4; R_e5=R_w1*R_e4+R_w2*R_e5; R_e6=R_w1*R_e5+R_w2*R_e6; R_t3[R_shift]=R_c1*R_e6+R_c2*R_e5+R_c3*R_e4+R_c4*R_e3; if (R_t3[R_shift+1]<=R_t3[R_shift]) R_Buffer0[R_shift]=R_t3[R_shift]; else R_Buffer0[R_shift]=0; if (R_t3[R_shift+1]>R_t3[R_shift]) R_Buffer1[R_shift]=R_t3[R_shift]; else R_Buffer1[R_shift]=0; } if (R_mBar==0) R_LoopBegin=Bars-R_t3_period-1; else R_LoopBegin=R_mBar; R_LoopBegin=MathMin(R_LoopBegin, Bars-R_t3_period-1); for (int cnt=0;cnt<=R_LoopBegin;cnt++) { if(R_Buffer0[cnt]>0 && R_Buffer1[cnt+1]>0 && W_Buffer0[cnt]>W_Buffer0[cnt+1] && W_Buffer0[cnt+1]>W_psel) S_Buffer0[cnt]=Low[cnt]-6*Point; else S_Buffer0[cnt]=0; if(R_Buffer1[cnt]>0 && R_Buffer0[cnt+1]>0 && W_Buffer0[cnt]<W_Buffer0[cnt+1] && W_Buffer0[cnt+1]<W_pbuy) S_Buffer1[cnt]=High[cnt]+6*Point; else S_Buffer1[cnt]=0; } if (R_mBar==0) R_LoopBegin=Bars-R_t3_period-1; else R_LoopBegin=R_mBar; R_LoopBegin=MathMin(R_LoopBegin, Bars-R_t3_period-1); for (cnt=0;cnt<=R_LoopBegin;cnt++) { if(W_Buffer0[cnt]W_psel) E_Buffer0[cnt]=High[cnt]+6*Point; else E_Buffer0[cnt]=0; if(W_Buffer0[cnt]>W_pbuy && W_Buffer0[cnt+1]<W_pbuy) E_Buffer1[cnt]=Low[cnt]-6*Point; else E_Buffer1[cnt]=0; } Coding help MQL4、MQL5に関する初心者からの質問、アルゴリズムやコードに関するヘルプ、ディスカッションなど。 help on new developed Mladen Rakic 2014.06.10 12:42 #2916 nevar: Mladenさん、みなさんへ。以下のコードがどのように売買シグナルを作成するか知っていますか?それは、''各バーのopen-close-high-low価格を含むシリーズ配列''指標カーブ作成:タイプDRAW_HISTOGRAMの曲線を実装しています''私が見る限りそれは再描画しません。 ありがとうございます。 double W_Buffer0[]; double W_Buffer1[]; double R_Buffer0[]; double R_Buffer1[]; double S_Buffer0[]; double S_Buffer1[]; double E_Buffer0[]; double E_Buffer1[]; int R_t3_period=21; double R_b=0.8; extern int R_mBar=0; double W_e1, W_e2, W_e3, W_e4, W_e5, W_e6, W_c1, W_c2, W_c3, W_c4, W_n, W_w1, W_w2, W_b2, W_b3; double W_t3, W_shift, W_wpr, W_trig, W_t3_period, W_b, W_per, W_psel, W_pbuy; bool R_ft=True; double R_e1, R_e2, R_e3, R_e4, R_e5, R_e6, R_c1, R_c2, R_c3, R_c4, R_n, R_w1, R_w2, R_b2, R_b3; double R_t3[]; int R_LoopBegin, R_shift; int init() { //---- indicators SetIndexStyle (0,DRAW_NONE); SetIndexBuffer (0,W_Buffer0); SetIndexEmptyValue(0,EMPTY_VALUE); SetIndexStyle (1,DRAW_NONE); SetIndexBuffer (1,W_Buffer1); SetIndexEmptyValue(1,EMPTY_VALUE); SetIndexStyle (2,DRAW_NONE); SetIndexBuffer (2,R_Buffer0); SetIndexEmptyValue(2,EMPTY_VALUE); SetIndexStyle (3,DRAW_NONE); SetIndexBuffer (3,R_Buffer1); SetIndexEmptyValue(3,EMPTY_VALUE); SetIndexStyle (4,DRAW_ARROW,EMPTY,2); SetIndexArrow (4,241); SetIndexBuffer (4,S_Buffer0); SetIndexEmptyValue(4,EMPTY_VALUE); SetIndexStyle (5,DRAW_ARROW,EMPTY,2); SetIndexArrow (5,242); SetIndexBuffer (5,S_Buffer1); SetIndexEmptyValue(5,EMPTY_VALUE); SetIndexStyle (6,DRAW_ARROW,EMPTY,2); SetIndexArrow (6,251); SetIndexBuffer (6,E_Buffer0); SetIndexEmptyValue(6,EMPTY_VALUE); SetIndexStyle (7,DRAW_ARROW,EMPTY,2); SetIndexArrow (7,251); SetIndexBuffer (7,E_Buffer1); SetIndexEmptyValue(7,EMPTY_VALUE); //---- return(0); } //+------------------------------------------------------------------+ //| Custom indicator iteration function | //+------------------------------------------------------------------+ int start() { W_t3_period=8; W_b=0.8; W_per=21; W_psel=-30; W_pbuy=-70; W_b2=W_b*W_b; W_b3=W_b2*W_b; W_c1=-W_b3; W_c2=(3*(W_b2+W_b3)); W_c3=-3*(2*W_b2+W_b+W_b3); W_c4=(1+3*W_b+W_b3+3*W_b2); W_n=W_t3_period; if (W_n<1) W_n=1; W_n = 1 + 0.5*(W_n-1); W_w1 = 2 / (W_n + 1); W_w2 = 1 - W_w1; if (R_mBar==0) R_LoopBegin=Bars; else R_LoopBegin=R_mBar; R_LoopBegin=MathMin(R_LoopBegin, Bars); for(int i=0; i<R_LoopBegin; i++) { W_wpr=iWPR(NULL,0,W_per,i); W_e1 = W_w1*W_wpr + W_w2*W_e1; W_e2 = W_w1*W_e1 + W_w2*W_e2; W_e3 = W_w1*W_e2 + W_w2*W_e3; W_e4 = W_w1*W_e3 + W_w2*W_e4; W_e5 = W_w1*W_e4 + W_w2*W_e5; W_e6 = W_w1*W_e5 + W_w2*W_e6; W_t3 = W_c1*W_e6 + W_c2*W_e5 + W_c3*W_e4 + W_c4*W_e3; if (W_t3>=-50) W_trig=W_psel; if (W_t3<-50) W_trig=W_pbuy; W_Buffer0=W_t3; W_Buffer1=W_trig; } if (R_mBar==0) R_LoopBegin=Bars-R_t3_period-1; else R_LoopBegin=R_mBar; R_LoopBegin=MathMin(R_LoopBegin, Bars-R_t3_period-1); ArrayResize(R_t3, R_LoopBegin); if (R_ft) { R_b2=R_b*R_b; R_b3=R_b2*R_b; R_c1=-R_b3; R_c2=(3*(R_b2+R_b3)); R_c3=-3*(2*R_b2+R_b+R_b3); R_c4=(1+3*R_b+R_b3+3*R_b2); R_n=R_t3_period; if (R_n<1) R_n=1; R_n=1+0.5*(R_n-1); R_w1=2/(R_n+1); R_w2=1-R_w1; R_ft=False; } for (R_shift=R_LoopBegin; R_shift>=0; R_shift--) { R_e1=R_w1*Close[R_shift]+R_w2*R_e1; R_e2=R_w1*R_e1+R_w2*R_e2; R_e3=R_w1*R_e2+R_w2*R_e3; R_e4=R_w1*R_e3+R_w2*R_e4; R_e5=R_w1*R_e4+R_w2*R_e5; R_e6=R_w1*R_e5+R_w2*R_e6; R_t3[R_shift]=R_c1*R_e6+R_c2*R_e5+R_c3*R_e4+R_c4*R_e3; if (R_t3[R_shift+1]<=R_t3[R_shift]) R_Buffer0[R_shift]=R_t3[R_shift]; else R_Buffer0[R_shift]=0; if (R_t3[R_shift+1]>R_t3[R_shift]) R_Buffer1[R_shift]=R_t3[R_shift]; else R_Buffer1[R_shift]=0; } if (R_mBar==0) R_LoopBegin=Bars-R_t3_period-1; else R_LoopBegin=R_mBar; R_LoopBegin=MathMin(R_LoopBegin, Bars-R_t3_period-1); for (int cnt=0;cnt<=R_LoopBegin;cnt++) { if(R_Buffer0[cnt]>0 && R_Buffer1[cnt+1]>0 && W_Buffer0[cnt]>W_Buffer0[cnt+1] && W_Buffer0[cnt+1]>W_psel) S_Buffer0[cnt]=Low[cnt]-6*Point; else S_Buffer0[cnt]=0; if(R_Buffer1[cnt]>0 && R_Buffer0[cnt+1]>0 && W_Buffer0[cnt]<W_Buffer0[cnt+1] && W_Buffer0[cnt+1]<W_pbuy) S_Buffer1[cnt]=High[cnt]+6*Point; else S_Buffer1[cnt]=0; } if (R_mBar==0) R_LoopBegin=Bars-R_t3_period-1; else R_LoopBegin=R_mBar; R_LoopBegin=MathMin(R_LoopBegin, Bars-R_t3_period-1); for (cnt=0;cnt<=R_LoopBegin;cnt++) { if(W_Buffer0[cnt]W_psel) E_Buffer0[cnt]=High[cnt]+6*Point; else E_Buffer0[cnt]=0; if(W_Buffer0[cnt]>W_pbuy && W_Buffer0[cnt+1]<W_pbuy) E_Buffer1[cnt]=Low[cnt]-6*Point; else E_Buffer1[cnt]=0; } これはt3 smoothed wprと単純なt3からのシグナルを組み合わせています。 しかし、最後の部分は、未来から過去に行われます(Sidusと太陽風に似ています)ので、私はそれを使用するときに注意する必要があります。 vozduh92go 2014.06.14 14:18 #2917 こんにちは親愛なるムラデンさん。ステップマバーを作ることは可能でしょうか? Mladen Rakic 2014.06.14 15:17 #2918 Air92: こんにちは親愛なるMladen。ステップmaのバーを作ることは可能でしょうか? ステップマの色によって色分けされたバーのことですか? vozduh92go 2014.06.14 15:31 #2919 mladen: ステップMAの色によってバーが変わるということですね? はい、その通りです。 Mladen Rakic 2014.06.14 16:16 #2920 Air92: はい、その通りです。 Air92 https://www.mql5.com/en/forum/173044/page12 1...285286287288289290291292293294295296297298299...786 新しいコメント 取引の機会を逃しています。 無料取引アプリ 8千を超えるシグナルをコピー 金融ニュースで金融マーケットを探索 新規登録 ログイン スペースを含まないラテン文字 このメールにパスワードが送信されます エラーが発生しました Googleでログイン WebサイトポリシーおよびMQL5.COM利用規約に同意します。 新規登録 MQL5.com WebサイトへのログインにCookieの使用を許可します。 ログインするには、ブラウザで必要な設定を有効にしてください。 ログイン/パスワードをお忘れですか? Googleでログイン
MLADEN様 日曜日を除いた前日の高値と安値を単純にプロットするインジケータが見つかりません。添付のインジケータを使用していますが、日曜日のデータを除外するように修正できないかと考えています。よろしくお願いいたします。
デイトレード5
これのはずです。試してみる :prevday_hilo_no_sunday.mq4
daytrade5 これでいいはずです。試してみてください :prevday_hilo_no_sunday.mq4
ムラデン
これはまったくもって完璧です。本当にありがとうございました。
こんにちは。
少し漠然としていますが、これはEAの機能に 大きな影響を与えるのでしょうか? この問題は、「参照で渡された配列のみ」という36の警告が出るのですが、この新しいMT4では、配列をどのように扱わなければならないのでしょうか。この件に関するあらゆる洞察に感謝します。![](https://c.mql5.com/forextsd/smiles/regular_smile.png)
こんにちは、これは少し漠然としていますが、これはEAの機能に何か大きな影響を与えるのでしょうか、もしそうなら、それを修正するために何を探す必要がありますか? この問題は、「参照で渡される配列のみ」という36の警告が出るのですが、この新しいMT4で配列を扱わなければならないある方法があるのでしょうか。この件に関するあらゆる洞察に感謝します。
cja
コンパイラが自動的に変換するため、影響はないはずです。
この警告を回避するには、関数 宣言の配列型宣言の後に「&」を追加するだけです(つまり、「void example(double arrayPassedByReference[]」の代わりに「void example(double& arrayPassedByReference[]」)。
ムラデン様、どなたか。
下記のコードはどのように売買シグナルを 作成しているかご存知ですか? ''各バーのopen-close-high-low価格を含む系列配列'' ''Indicator Curves created:Implements a curve of type DRAW_HISTOGRAM'' とありますが、私が見る限り、再描画はしていません。
ありがとうございます。
double W_Buffer1[];
double R_Buffer0[];
double R_Buffer1[];
double S_Buffer0[];
double S_Buffer1[];
double E_Buffer0[];
double E_Buffer1[];
int R_t3_period=21;
double R_b=0.8;
extern int R_mBar=0;
double W_e1, W_e2, W_e3, W_e4, W_e5, W_e6, W_c1, W_c2, W_c3, W_c4, W_n, W_w1, W_w2, W_b2, W_b3;
double W_t3, W_shift, W_wpr, W_trig, W_t3_period, W_b, W_per, W_psel, W_pbuy;
bool R_ft=True;
double R_e1, R_e2, R_e3, R_e4, R_e5, R_e6, R_c1, R_c2, R_c3, R_c4, R_n, R_w1, R_w2, R_b2, R_b3;
double R_t3[];
int R_LoopBegin, R_shift;
int init()
{
//---- indicators
SetIndexStyle (0,DRAW_NONE);
SetIndexBuffer (0,W_Buffer0);
SetIndexEmptyValue(0,EMPTY_VALUE);
SetIndexStyle (1,DRAW_NONE);
SetIndexBuffer (1,W_Buffer1);
SetIndexEmptyValue(1,EMPTY_VALUE);
SetIndexStyle (2,DRAW_NONE);
SetIndexBuffer (2,R_Buffer0);
SetIndexEmptyValue(2,EMPTY_VALUE);
SetIndexStyle (3,DRAW_NONE);
SetIndexBuffer (3,R_Buffer1);
SetIndexEmptyValue(3,EMPTY_VALUE);
SetIndexStyle (4,DRAW_ARROW,EMPTY,2);
SetIndexArrow (4,241);
SetIndexBuffer (4,S_Buffer0);
SetIndexEmptyValue(4,EMPTY_VALUE);
SetIndexStyle (5,DRAW_ARROW,EMPTY,2);
SetIndexArrow (5,242);
SetIndexBuffer (5,S_Buffer1);
SetIndexEmptyValue(5,EMPTY_VALUE);
SetIndexStyle (6,DRAW_ARROW,EMPTY,2);
SetIndexArrow (6,251);
SetIndexBuffer (6,E_Buffer0);
SetIndexEmptyValue(6,EMPTY_VALUE);
SetIndexStyle (7,DRAW_ARROW,EMPTY,2);
SetIndexArrow (7,251);
SetIndexBuffer (7,E_Buffer1);
SetIndexEmptyValue(7,EMPTY_VALUE);
//----
return(0);
}
//+------------------------------------------------------------------+
//| Custom indicator iteration function |
//+------------------------------------------------------------------+
int start()
{
W_t3_period=8;
W_b=0.8;
W_per=21;
W_psel=-30;
W_pbuy=-70;
W_b2=W_b*W_b;
W_b3=W_b2*W_b;
W_c1=-W_b3;
W_c2=(3*(W_b2+W_b3));
W_c3=-3*(2*W_b2+W_b+W_b3);
W_c4=(1+3*W_b+W_b3+3*W_b2);
W_n=W_t3_period;
if (W_n<1) W_n=1;
W_n = 1 + 0.5*(W_n-1);
W_w1 = 2 / (W_n + 1);
W_w2 = 1 - W_w1;
if (R_mBar==0) R_LoopBegin=Bars;
else R_LoopBegin=R_mBar;
R_LoopBegin=MathMin(R_LoopBegin, Bars);
for(int i=0; i<R_LoopBegin; i++)
{
W_wpr=iWPR(NULL,0,W_per,i);
W_e1 = W_w1*W_wpr + W_w2*W_e1;
W_e2 = W_w1*W_e1 + W_w2*W_e2;
W_e3 = W_w1*W_e2 + W_w2*W_e3;
W_e4 = W_w1*W_e3 + W_w2*W_e4;
W_e5 = W_w1*W_e4 + W_w2*W_e5;
W_e6 = W_w1*W_e5 + W_w2*W_e6;
W_t3 = W_c1*W_e6 + W_c2*W_e5 + W_c3*W_e4 + W_c4*W_e3;
if (W_t3>=-50) W_trig=W_psel;
if (W_t3<-50) W_trig=W_pbuy;
W_Buffer0=W_t3;
W_Buffer1=W_trig;
}
if (R_mBar==0) R_LoopBegin=Bars-R_t3_period-1;
else R_LoopBegin=R_mBar;
R_LoopBegin=MathMin(R_LoopBegin, Bars-R_t3_period-1);
ArrayResize(R_t3, R_LoopBegin);
if (R_ft) {
R_b2=R_b*R_b;
R_b3=R_b2*R_b;
R_c1=-R_b3;
R_c2=(3*(R_b2+R_b3));
R_c3=-3*(2*R_b2+R_b+R_b3);
R_c4=(1+3*R_b+R_b3+3*R_b2);
R_n=R_t3_period;
if (R_n<1) R_n=1;
R_n=1+0.5*(R_n-1);
R_w1=2/(R_n+1);
R_w2=1-R_w1;
R_ft=False;
}
for (R_shift=R_LoopBegin; R_shift>=0; R_shift--) {
R_e1=R_w1*Close[R_shift]+R_w2*R_e1;
R_e2=R_w1*R_e1+R_w2*R_e2;
R_e3=R_w1*R_e2+R_w2*R_e3;
R_e4=R_w1*R_e3+R_w2*R_e4;
R_e5=R_w1*R_e4+R_w2*R_e5;
R_e6=R_w1*R_e5+R_w2*R_e6;
R_t3[R_shift]=R_c1*R_e6+R_c2*R_e5+R_c3*R_e4+R_c4*R_e3;
if (R_t3[R_shift+1]<=R_t3[R_shift]) R_Buffer0[R_shift]=R_t3[R_shift]; else R_Buffer0[R_shift]=0;
if (R_t3[R_shift+1]>R_t3[R_shift]) R_Buffer1[R_shift]=R_t3[R_shift]; else R_Buffer1[R_shift]=0;
}
if (R_mBar==0) R_LoopBegin=Bars-R_t3_period-1;
else R_LoopBegin=R_mBar;
R_LoopBegin=MathMin(R_LoopBegin, Bars-R_t3_period-1);
for (int cnt=0;cnt<=R_LoopBegin;cnt++)
{
if(R_Buffer0[cnt]>0 && R_Buffer1[cnt+1]>0 && W_Buffer0[cnt]>W_Buffer0[cnt+1] && W_Buffer0[cnt+1]>W_psel) S_Buffer0[cnt]=Low[cnt]-6*Point; else S_Buffer0[cnt]=0;
if(R_Buffer1[cnt]>0 && R_Buffer0[cnt+1]>0 && W_Buffer0[cnt]<W_Buffer0[cnt+1] && W_Buffer0[cnt+1]<W_pbuy) S_Buffer1[cnt]=High[cnt]+6*Point; else S_Buffer1[cnt]=0;
}
if (R_mBar==0) R_LoopBegin=Bars-R_t3_period-1;
else R_LoopBegin=R_mBar;
R_LoopBegin=MathMin(R_LoopBegin, Bars-R_t3_period-1);
for (cnt=0;cnt<=R_LoopBegin;cnt++)
{
if(W_Buffer0[cnt]W_psel) E_Buffer0[cnt]=High[cnt]+6*Point; else E_Buffer0[cnt]=0;
if(W_Buffer0[cnt]>W_pbuy && W_Buffer0[cnt+1]<W_pbuy) E_Buffer1[cnt]=Low[cnt]-6*Point; else E_Buffer1[cnt]=0;
}Mladenさん、みなさんへ。
以下のコードがどのように売買シグナルを作成するか知っていますか?それは、''各バーのopen-close-high-low価格を含むシリーズ配列''指標カーブ作成:タイプDRAW_HISTOGRAMの曲線を実装しています''私が見る限りそれは再描画しません。
ありがとうございます。
double W_Buffer1[];
double R_Buffer0[];
double R_Buffer1[];
double S_Buffer0[];
double S_Buffer1[];
double E_Buffer0[];
double E_Buffer1[];
int R_t3_period=21;
double R_b=0.8;
extern int R_mBar=0;
double W_e1, W_e2, W_e3, W_e4, W_e5, W_e6, W_c1, W_c2, W_c3, W_c4, W_n, W_w1, W_w2, W_b2, W_b3;
double W_t3, W_shift, W_wpr, W_trig, W_t3_period, W_b, W_per, W_psel, W_pbuy;
bool R_ft=True;
double R_e1, R_e2, R_e3, R_e4, R_e5, R_e6, R_c1, R_c2, R_c3, R_c4, R_n, R_w1, R_w2, R_b2, R_b3;
double R_t3[];
int R_LoopBegin, R_shift;
int init()
{
//---- indicators
SetIndexStyle (0,DRAW_NONE);
SetIndexBuffer (0,W_Buffer0);
SetIndexEmptyValue(0,EMPTY_VALUE);
SetIndexStyle (1,DRAW_NONE);
SetIndexBuffer (1,W_Buffer1);
SetIndexEmptyValue(1,EMPTY_VALUE);
SetIndexStyle (2,DRAW_NONE);
SetIndexBuffer (2,R_Buffer0);
SetIndexEmptyValue(2,EMPTY_VALUE);
SetIndexStyle (3,DRAW_NONE);
SetIndexBuffer (3,R_Buffer1);
SetIndexEmptyValue(3,EMPTY_VALUE);
SetIndexStyle (4,DRAW_ARROW,EMPTY,2);
SetIndexArrow (4,241);
SetIndexBuffer (4,S_Buffer0);
SetIndexEmptyValue(4,EMPTY_VALUE);
SetIndexStyle (5,DRAW_ARROW,EMPTY,2);
SetIndexArrow (5,242);
SetIndexBuffer (5,S_Buffer1);
SetIndexEmptyValue(5,EMPTY_VALUE);
SetIndexStyle (6,DRAW_ARROW,EMPTY,2);
SetIndexArrow (6,251);
SetIndexBuffer (6,E_Buffer0);
SetIndexEmptyValue(6,EMPTY_VALUE);
SetIndexStyle (7,DRAW_ARROW,EMPTY,2);
SetIndexArrow (7,251);
SetIndexBuffer (7,E_Buffer1);
SetIndexEmptyValue(7,EMPTY_VALUE);
//----
return(0);
}
//+------------------------------------------------------------------+
//| Custom indicator iteration function |
//+------------------------------------------------------------------+
int start()
{
W_t3_period=8;
W_b=0.8;
W_per=21;
W_psel=-30;
W_pbuy=-70;
W_b2=W_b*W_b;
W_b3=W_b2*W_b;
W_c1=-W_b3;
W_c2=(3*(W_b2+W_b3));
W_c3=-3*(2*W_b2+W_b+W_b3);
W_c4=(1+3*W_b+W_b3+3*W_b2);
W_n=W_t3_period;
if (W_n<1) W_n=1;
W_n = 1 + 0.5*(W_n-1);
W_w1 = 2 / (W_n + 1);
W_w2 = 1 - W_w1;
if (R_mBar==0) R_LoopBegin=Bars;
else R_LoopBegin=R_mBar;
R_LoopBegin=MathMin(R_LoopBegin, Bars);
for(int i=0; i<R_LoopBegin; i++)
{
W_wpr=iWPR(NULL,0,W_per,i);
W_e1 = W_w1*W_wpr + W_w2*W_e1;
W_e2 = W_w1*W_e1 + W_w2*W_e2;
W_e3 = W_w1*W_e2 + W_w2*W_e3;
W_e4 = W_w1*W_e3 + W_w2*W_e4;
W_e5 = W_w1*W_e4 + W_w2*W_e5;
W_e6 = W_w1*W_e5 + W_w2*W_e6;
W_t3 = W_c1*W_e6 + W_c2*W_e5 + W_c3*W_e4 + W_c4*W_e3;
if (W_t3>=-50) W_trig=W_psel;
if (W_t3<-50) W_trig=W_pbuy;
W_Buffer0=W_t3;
W_Buffer1=W_trig;
}
if (R_mBar==0) R_LoopBegin=Bars-R_t3_period-1;
else R_LoopBegin=R_mBar;
R_LoopBegin=MathMin(R_LoopBegin, Bars-R_t3_period-1);
ArrayResize(R_t3, R_LoopBegin);
if (R_ft) {
R_b2=R_b*R_b;
R_b3=R_b2*R_b;
R_c1=-R_b3;
R_c2=(3*(R_b2+R_b3));
R_c3=-3*(2*R_b2+R_b+R_b3);
R_c4=(1+3*R_b+R_b3+3*R_b2);
R_n=R_t3_period;
if (R_n<1) R_n=1;
R_n=1+0.5*(R_n-1);
R_w1=2/(R_n+1);
R_w2=1-R_w1;
R_ft=False;
}
for (R_shift=R_LoopBegin; R_shift>=0; R_shift--) {
R_e1=R_w1*Close[R_shift]+R_w2*R_e1;
R_e2=R_w1*R_e1+R_w2*R_e2;
R_e3=R_w1*R_e2+R_w2*R_e3;
R_e4=R_w1*R_e3+R_w2*R_e4;
R_e5=R_w1*R_e4+R_w2*R_e5;
R_e6=R_w1*R_e5+R_w2*R_e6;
R_t3[R_shift]=R_c1*R_e6+R_c2*R_e5+R_c3*R_e4+R_c4*R_e3;
if (R_t3[R_shift+1]<=R_t3[R_shift]) R_Buffer0[R_shift]=R_t3[R_shift]; else R_Buffer0[R_shift]=0;
if (R_t3[R_shift+1]>R_t3[R_shift]) R_Buffer1[R_shift]=R_t3[R_shift]; else R_Buffer1[R_shift]=0;
}
if (R_mBar==0) R_LoopBegin=Bars-R_t3_period-1;
else R_LoopBegin=R_mBar;
R_LoopBegin=MathMin(R_LoopBegin, Bars-R_t3_period-1);
for (int cnt=0;cnt<=R_LoopBegin;cnt++)
{
if(R_Buffer0[cnt]>0 && R_Buffer1[cnt+1]>0 && W_Buffer0[cnt]>W_Buffer0[cnt+1] && W_Buffer0[cnt+1]>W_psel) S_Buffer0[cnt]=Low[cnt]-6*Point; else S_Buffer0[cnt]=0;
if(R_Buffer1[cnt]>0 && R_Buffer0[cnt+1]>0 && W_Buffer0[cnt]<W_Buffer0[cnt+1] && W_Buffer0[cnt+1]<W_pbuy) S_Buffer1[cnt]=High[cnt]+6*Point; else S_Buffer1[cnt]=0;
}
if (R_mBar==0) R_LoopBegin=Bars-R_t3_period-1;
else R_LoopBegin=R_mBar;
R_LoopBegin=MathMin(R_LoopBegin, Bars-R_t3_period-1);
for (cnt=0;cnt<=R_LoopBegin;cnt++)
{
if(W_Buffer0[cnt]W_psel) E_Buffer0[cnt]=High[cnt]+6*Point; else E_Buffer0[cnt]=0;
if(W_Buffer0[cnt]>W_pbuy && W_Buffer0[cnt+1]<W_pbuy) E_Buffer1[cnt]=Low[cnt]-6*Point; else E_Buffer1[cnt]=0;
}これはt3 smoothed wprと単純なt3からのシグナルを組み合わせています。
しかし、最後の部分は、未来から過去に行われます(Sidusと太陽風に似ています)ので、私はそれを使用するときに注意する必要があります。
こんにちは親愛なるムラデンさん。ステップマバーを作ることは可能でしょうか?
こんにちは親愛なるMladen。ステップmaのバーを作ることは可能でしょうか?
ステップマの色によって色分けされたバーのことですか?
ステップMAの色によってバーが変わるということですね?
はい、その通りです。
はい、その通りです。
Air92
https://www.mql5.com/en/forum/173044/page12