[ARCHIVE] フォーラムを散らかさないように、どんなルーキーでも質問してください。プロフェッショナルは、通り過ぎないでください。Nowhere without you - 3. - ページ 202 1...195196197198199200201202203204205206207208209...652 新しいコメント Vitaliy Andreischev 2011.09.22 09:38 #2011 Vinin: あるいは、EAの助けを借りて、アクティブな楽器のリストを作るだけかもしれません。アプローチはちょっと複雑なんです。もっとシンプルな方法で解決できるはず 入力パラメータに数値を指定するだけでもいいのですが、取引中に通貨によっては取引が停止される状況が発生することがあるのです。そうすると、他の通貨のEAはパラメータを再計算する必要があります。 Victor Nikolaev 2011.09.22 09:41 #2012 forexnew: 入力パラメータに数値を指定するだけでもいいのですが、要は取引の過程で、通貨によっては取引が停止される事態もあり得るということです。そうすると、他の通貨のEAはパラメータを再計算する必要があります。 指定する理由Expert Advisor単体で取得可能です。また、同時に他のExpert Advisorを管理することができます。全てはタスクに依存する noobys 2011.09.22 09:43 #2013 Figar0: В самой функции ошибок нет, наверно ошибки возникают при попытке ее использовать, но это вы нам не показываете. Выкладывайте то что не компилится прямо файлом и гадать будет не надо. //+------------------------------------------------------------------+ //| MACD Sample.mq4 | //| Copyright © 2005, MetaQuotes Software Corp. | //| http://www.metaquotes.net/ | //+------------------------------------------------------------------+ extern double TakeProfit = 50; extern double TrailingStop = 30; extern double MACDOpenLevel=3; extern double MACDCloseLevel=2; extern double MATrendPeriod=26; //+------------------------------------------------------------------+ //| | //+------------------------------------------------------------------+ int start() { double MacdCurrent, MacdPrevious, SignalCurrent; double SignalPrevious, MaCurrent, MaPrevious; int cnt, ticket, total; // initial data checks // it is important to make sure that the expert works with a normal // chart and the user did not make any mistakes setting external // variables (Lots, StopLoss, TakeProfit, // TrailingStop) in our case, we check TakeProfit // on a chart of less than 100 bars if(Bars<100) { Print("bars less than 100"); return(0); } if(TakeProfit<10) { Print("TakeProfit less than 10"); return(0); // check TakeProfit } double Lots() // Расчет используемого лота { double Lots; Lots=AccountFreeMargin()/10000*5; Lots=MathMin(15,MathMax(0.1,Lots)); if(Lots<0.1) Lots=NormalizeDouble(Lots,2); else { if(Lots<1) Lots=NormalizeDouble(Lots,1); else Lots=NormalizeDouble(Lots,0); } return(Lots); } //+------------------------------------------------------------------+ // to simplify the coding and speed up access // data are put into internal variables MacdCurrent=iMACD(NULL,0,12,26,9,PRICE_CLOSE,MODE_MAIN,0); MacdPrevious=iMACD(NULL,0,12,26,9,PRICE_CLOSE,MODE_MAIN,1); SignalCurrent=iMACD(NULL,0,12,26,9,PRICE_CLOSE,MODE_SIGNAL,0); SignalPrevious=iMACD(NULL,0,12,26,9,PRICE_CLOSE,MODE_SIGNAL,1); MaCurrent=iMA(NULL,0,MATrendPeriod,0,MODE_EMA,PRICE_CLOSE,0); MaPrevious=iMA(NULL,0,MATrendPeriod,0,MODE_EMA,PRICE_CLOSE,1); total=OrdersTotal(); if(total<1) { // no opened orders identified if(AccountFreeMargin()<(1000*Lots)) { Print("We have no money. Free Margin = ", AccountFreeMargin()); return(0); } // check for long position (BUY) possibility if(MacdCurrent<0 && MacdCurrent>SignalCurrent && MacdPrevious<SignalPrevious && MathAbs(MacdCurrent)>(MACDOpenLevel*Point) && MaCurrent>MaPrevious) { ticket=OrderSend(Symbol(),OP_BUY,Lots,Ask,3,0,Ask+TakeProfit*Point,"macd sample",16384,0,Green); if(ticket>0) { if(OrderSelect(ticket,SELECT_BY_TICKET,MODE_TRADES)) Print("BUY order opened : ",OrderOpenPrice()); } else Print("Error opening BUY order : ",GetLastError()); return(0); } // check for short position (SELL) possibility if(MacdCurrent>0 && MacdCurrent<SignalCurrent && MacdPrevious>SignalPrevious && MacdCurrent>(MACDOpenLevel*Point) && MaCurrent<MaPrevious) { ticket=OrderSend(Symbol(),OP_SELL,Lots,Bid,3,0,Bid-TakeProfit*Point,"macd sample",16384,0,Red); if(ticket>0) { if(OrderSelect(ticket,SELECT_BY_TICKET,MODE_TRADES)) Print("SELL order opened : ",OrderOpenPrice()); } else Print("Error opening SELL order : ",GetLastError()); return(0); } return(0); } // it is important to enter the market correctly, // but it is more important to exit it correctly... for(cnt=0;cnt<total;cnt++) { OrderSelect(cnt, SELECT_BY_POS, MODE_TRADES); if(OrderType()<=OP_SELL && // check for opened position OrderSymbol()==Symbol()) // check for symbol { if(OrderType()==OP_BUY) // long position is opened { // should it be closed? if(MacdCurrent>0 && MacdCurrent<SignalCurrent && MacdPrevious>SignalPrevious && MacdCurrent>(MACDCloseLevel*Point)) { OrderClose(OrderTicket(),OrderLots(),Bid,3,Violet); // close position return(0); // exit } // check for trailing stop if(TrailingStop>0) { if(Bid-OrderOpenPrice()>Point*TrailingStop) { if(OrderStopLoss()<Bid-Point*TrailingStop) { OrderModify(OrderTicket(),OrderOpenPrice(),Bid-Point*TrailingStop,OrderTakeProfit(),0,Green); return(0); } } } } else // go to short position { // should it be closed? if(MacdCurrent<0 && MacdCurrent>SignalCurrent && MacdPrevious<SignalPrevious && MathAbs(MacdCurrent)>(MACDCloseLevel*Point)) { OrderClose(OrderTicket(),OrderLots(),Ask,3,Violet); // close position return(0); // exit } // check for trailing stop if(TrailingStop>0) { if((OrderOpenPrice()-Ask)>(Point*TrailingStop)) { if((OrderStopLoss()>(Ask+Point*TrailingStop)) || (OrderStopLoss()==0)) { OrderModify(OrderTicket(),OrderOpenPrice(),Ask+Point*TrailingStop,OrderTakeProfit(),0,Red); return(0); } } } } } } return(0); } // the end. Vitaliy Andreischev 2011.09.22 09:54 #2014 Vinin: なぜ、このような指定をしたのですか?Expert Advisor単体で取得することも可能です。また、同時に他のExpert Advisorを管理することができます。すべては課題次第です。他のEAの管理は知らない。EAは全通貨ペアで同じで、パターンはこうです。 2つの通貨ペアがある場合、最初の通貨ペアは2を表示し、2番目の通貨ペアは1を表示します。 3つの通貨ペア:1つ目は3、2つ目は2、3つ目は1を表示した場合 4つの通貨ペアの場合、1つ目は4、2つ目は3、3つ目は2、4つ目は1と表示されます。 最初の通貨で計算されたものが、他の通貨ペアのExpert Advisorでは考慮されない、あるいは開いているウィンドウ(通貨ペア)の数に何らかの依存があるような気がしています Vitaliy Andreischev 2011.09.22 10:11 #2015 Vinin: 指定する理由参議院議員が自分で取ればいい。そして同時に、他のアドバイザーを管理することもできる。すべては課題次第です。 ありがとうございます。もう、自分で考えてしまいました。行を削除して、1からkpを数えるだけです if(OrderSymbol()==Symbol()) break; 削除済み 2011.09.22 10:34 #2016 skyjet: 手始めに、ロット計算関数をstart関数の内部で宣言しておきます。取り出す。それから、未宣言の変数でエラーが出ますが、自分で処理できると思います。 DDFedor 2011.09.22 11:55 #2017 skyjet: ロット計算でNormalizeDlouble()が必要なのはなぜですか?カンマの後に2桁の数字が入るようにする。そうでなければ、0.009ロットのポジションは、最小ロットステップの倍数にならないため、オープンされません。 double Lots; Lots=AccountFreeMargin()/10000*5; Lots=MathMin(15,MathMax(0.1,Lots)); if(Lots<0.1) Lots=NormalizeDouble(Lots,2); else { if(Lots<1) Lots=NormalizeDouble(Lots,1);// !!!!!!!!!!!!!!!!!!!!!!!!!!!!! else Lots=NormalizeDouble(Lots,0);// !!!!!!!!!!!!!!!!!!!!!!!!!!!!! } Artem Gulturyan 2011.09.22 12:33 #2018 みんな! 40回目以降の注文を大きなロットにするには?:: 市場と保留 これはどうでしょう int Nom = OrderTicket(); // Номер ордера a= Nom%40; // к-во делить на 40 без остатка if a = 0 lot = 2; noobys 2011.09.22 13:48 #2019 Figar0: 手始めに、ロット計算関数をstart関数の内部で宣言しておきます。取り出す。それから、未宣言の変数でエラーが出ますが、自分で処理できると思います。 ありがとうございました。 noobys 2011.09.22 13:49 #2020 DDFedor: スカイジェット NormalizeDlouble()は、ロット計算で何に使うのですか?カンマの後に2桁の数字が入るようにする。さもなければ、ロット0.009のポジションは、最小ロットステップの倍数にならないため、オープンされません。 分かりやすい説明ありがとうございました。 1...195196197198199200201202203204205206207208209...652 新しいコメント 取引の機会を逃しています。 無料取引アプリ 8千を超えるシグナルをコピー 金融ニュースで金融マーケットを探索 新規登録 ログイン スペースを含まないラテン文字 このメールにパスワードが送信されます エラーが発生しました Googleでログイン WebサイトポリシーおよびMQL5.COM利用規約に同意します。 新規登録 MQL5.com WebサイトへのログインにCookieの使用を許可します。 ログインするには、ブラウザで必要な設定を有効にしてください。 ログイン/パスワードをお忘れですか? Googleでログイン
あるいは、EAの助けを借りて、アクティブな楽器のリストを作るだけかもしれません。アプローチはちょっと複雑なんです。もっとシンプルな方法で解決できるはず
入力パラメータに数値を指定するだけでもいいのですが、要は取引の過程で、通貨によっては取引が停止される事態もあり得るということです。そうすると、他の通貨のEAはパラメータを再計算する必要があります。
指定する理由Expert Advisor単体で取得可能です。また、同時に他のExpert Advisorを管理することができます。全てはタスクに依存する
Figar0:
В самой функции ошибок нет, наверно ошибки возникают при попытке ее использовать, но это вы нам не показываете. Выкладывайте то что не компилится прямо файлом и гадать будет не надо.
なぜ、このような指定をしたのですか?Expert Advisor単体で取得することも可能です。また、同時に他のExpert Advisorを管理することができます。すべては課題次第です。
他のEAの管理は知らない。EAは全通貨ペアで同じで、パターンはこうです。
2つの通貨ペアがある場合、最初の通貨ペアは2を表示し、2番目の通貨ペアは1を表示します。
3つの通貨ペア:1つ目は3、2つ目は2、3つ目は1を表示した場合
4つの通貨ペアの場合、1つ目は4、2つ目は3、3つ目は2、4つ目は1と表示されます。
最初の通貨で計算されたものが、他の通貨ペアのExpert Advisorでは考慮されない、あるいは開いているウィンドウ(通貨ペア)の数に何らかの依存があるような気がしています
指定する理由参議院議員が自分で取ればいい。そして同時に、他のアドバイザーを管理することもできる。すべては課題次第です。
手始めに、ロット計算関数をstart関数の内部で宣言しておきます。取り出す。それから、未宣言の変数でエラーが出ますが、自分で処理できると思います。
ロット計算でNormalizeDlouble()が必要なのはなぜですか?
カンマの後に2桁の数字が入るようにする。そうでなければ、0.009ロットのポジションは、最小ロットステップの倍数にならないため、オープンされません。
みんな!
40回目以降の注文を大きなロットにするには?:: 市場と保留
これはどうでしょう
手始めに、ロット計算関数をstart関数の内部で宣言しておきます。取り出す。それから、未宣言の変数でエラーが出ますが、自分で処理できると思います。
NormalizeDlouble()は、ロット計算で何に使うのですか?
カンマの後に2桁の数字が入るようにする。さもなければ、ロット0.009のポジションは、最小ロットステップの倍数にならないため、オープンされません。