"ダミー "からの質問 - ページ 78 1...717273747576777879808182838485...277 新しいコメント kirill-demo 2011.10.10 15:24 #771 Interesting:ExpertAdvisorを やり直すか、ファイルで作業した方が楽だと思います。Expert Advisor に何を求めているかを詳しく説明し、VISARD で作成したすべてのコードを提供する方が簡単だと思います。例えば、エンベロープ・インジケータの価格をクロスさせることで取引を開始するExpert Advisorが必要です。これが、私が手に入れたものです。//+------------------------------------------------------------------+ //| envelopes.mq5 | //| Copyright 2011, MetaQuotes Software Corp. | //| http://www.mql5.com | //+------------------------------------------------------------------+ #property copyright "Copyright 2011, MetaQuotes Software Corp." #property link "http://www.mql5.com" #property version "1.00" //+------------------------------------------------------------------+ //| Include | //+------------------------------------------------------------------+ #include <Expert\Expert.mqh> //--- available signals #include <Expert\Signal\SignalEnvelopes.mqh> //--- available trailing #include <Expert\Trailing\TrailingNone.mqh> //--- available money management #include <Expert\Money\MoneyFixedLot.mqh> //+------------------------------------------------------------------+ //| Inputs | //+------------------------------------------------------------------+ //--- inputs for expert input string Expert_Title ="envelopes"; // Document name ulong Expert_MagicNumber =28572; // bool Expert_EveryTick =false; // //--- inputs for main signal input int Signal_ThresholdOpen =10; // Signal threshold value to open [0...100] input int Signal_ThresholdClose =10; // Signal threshold value to close [0...100] input double Signal_PriceLevel =0.0; // Price level to execute a deal input double Signal_StopLevel =50.0; // Stop Loss level (in points) input double Signal_TakeLevel =50.0; // Take Profit level (in points) input int Signal_Expiration =4; // Expiration of pending orders (in bars) input int Signal_Envelopes_PeriodMA =240; // Envelopes(240,0,MODE_LWMA,...) Period of averaging input int Signal_Envelopes_Shift =0; // Envelopes(240,0,MODE_LWMA,...) Time shift input ENUM_MA_METHOD Signal_Envelopes_Method =MODE_LWMA; // Envelopes(240,0,MODE_LWMA,...) Method of averaging input ENUM_APPLIED_PRICE Signal_Envelopes_Applied =PRICE_CLOSE; // Envelopes(240,0,MODE_LWMA,...) Prices series input double Signal_Envelopes_Deviation=0.15; // Envelopes(240,0,MODE_LWMA,...) Deviation input double Signal_Envelopes_Weight =1.0; // Envelopes(240,0,MODE_LWMA,...) Weight [0...1.0] //--- inputs for money input double Money_FixLot_Percent =10.0; // Percent input double Money_FixLot_Lots =0.01; // Fixed volume //+------------------------------------------------------------------+ //| Global expert object | //+------------------------------------------------------------------+ CExpert ExtExpert; //+------------------------------------------------------------------+ //| Initialization function of the expert | //+------------------------------------------------------------------+ int OnInit() { //--- Initializing expert if(!ExtExpert.Init(Symbol(),PERIOD_H4,Expert_EveryTick,Expert_MagicNumber)) { //--- failed printf(__FUNCTION__+": error initializing expert"); ExtExpert.Deinit(); return(-1); } //--- Creating signal CExpertSignal *signal=new CExpertSignal; if(signal==NULL) { //--- failed printf(__FUNCTION__+": error creating signal"); ExtExpert.Deinit(); return(-2); } //--- ExtExpert.InitSignal(signal); signal.ThresholdOpen(Signal_ThresholdOpen); signal.ThresholdClose(Signal_ThresholdClose); signal.PriceLevel(Signal_PriceLevel); signal.StopLevel(Signal_StopLevel); signal.TakeLevel(Signal_TakeLevel); signal.Expiration(Signal_Expiration); //--- Creating filter CSignalEnvelopes CSignalEnvelopes *filter0=new CSignalEnvelopes; if(filter0==NULL) { //--- failed printf(__FUNCTION__+": error creating filter0"); ExtExpert.Deinit(); return(-3); } signal.AddFilter(filter0); filter0.PatternsUsage(2); //--- Set filter parameters filter0.PeriodMA(Signal_Envelopes_PeriodMA); filter0.Shift(Signal_Envelopes_Shift); filter0.Method(Signal_Envelopes_Method); filter0.Applied(Signal_Envelopes_Applied); filter0.Deviation(Signal_Envelopes_Deviation); filter0.Weight(Signal_Envelopes_Weight); //--- Creation of trailing object CTrailingNone *trailing=new CTrailingNone; if(trailing==NULL) { //--- failed printf(__FUNCTION__+": error creating trailing"); ExtExpert.Deinit(); return(-4); } //--- Add trailing to expert (will be deleted automatically)) if(!ExtExpert.InitTrailing(trailing)) { //--- failed printf(__FUNCTION__+": error initializing trailing"); ExtExpert.Deinit(); return(-5); } //--- Set trailing parameters //--- Creation of money object CMoneyFixedLot *money=new CMoneyFixedLot; if(money==NULL) { //--- failed printf(__FUNCTION__+": error creating money"); ExtExpert.Deinit(); return(-6); } //--- Add money to expert (will be deleted automatically)) if(!ExtExpert.InitMoney(money)) { //--- failed printf(__FUNCTION__+": error initializing money"); ExtExpert.Deinit(); return(-7); } //--- Set money parameters money.Percent(Money_FixLot_Percent); money.Lots(Money_FixLot_Lots); //--- Check all trading objects parameters if(!ExtExpert.ValidationSettings()) { //--- failed ExtExpert.Deinit(); return(-8); } //--- Tuning of all necessary indicators if(!ExtExpert.InitIndicators()) { //--- failed printf(__FUNCTION__+": error initializing indicators"); ExtExpert.Deinit(); return(-9); } //--- ok return(0); } //+------------------------------------------------------------------+ //| Deinitialization function of the expert | //+------------------------------------------------------------------+ void OnDeinit(const int reason) { ExtExpert.Deinit(); } //+------------------------------------------------------------------+ //| "Tick" event handler function | //+------------------------------------------------------------------+ void OnTick() { ExtExpert.OnTick(); } //+------------------------------------------------------------------+ //| "Trade" event handler function | //+------------------------------------------------------------------+ void OnTrade() { ExtExpert.OnTrade(); } //+------------------------------------------------------------------+ //| "Timer" event handler function | //+------------------------------------------------------------------+ void OnTimer() { ExtExpert.OnTimer(); } //+------------------------------------------------------------------+ kirill-demo 2011.10.12 15:12 #772 開発者同志、コードで何を変更すればよいか教えてください。売買シグナルの後、ポジションが一度開かれ閉じられます。特に、複数の指標で構成されるシステムで発生します。Expert Advisorは常に定位置にあります。テイクまたはストップで1つ閉じ、すぐに別の1つを開くことができます。 x572intraday 2011.10.14 10:00 #773 指標についての質問です。OnCalculateには、このような入力パラメータの構成がある。int OnCalculate(const int rates_total, const int prev_calculated, const datetime& time[], const double& open[], const double& high[], const double& low[], const double& close[], const long& tick_volume[], const long& volume[], const int& spread[]) { ... }このような楽しみはすべて現在のタイムフレームに厳密に結びついているので、別のタイムフレームの同様のデータを取得するには、例えば、目的のタイムフレームで必要な組み込み標準インジケータのハンドルを呼び出すことができます。handle=iGator(_Symbol, PERIOD_W1);を作成し、Copy-functionsのバリエーションで必要なデータをバッファにコピーします。これだけでもいいのですが、rates_totalとprev_calculatedを現在と異なる時間軸で使用する必要があります。そして、私が理解する限りでは、そのようなものはありません。明らかに現在の時間軸に対応していない場合、どこで、どのように入手すればよいのか。もちろん、ヘルプにわかりやすい解説があります。"OnCalculate() "が返す値と2番目の入力パラメータprev_calculatedの関係に注目する必要があります。 この関数を呼び出すと、パラメータ prev_calculated には、前回の 呼び出し 時に OnCalculate() が 返した 値が格納 される。 これにより、この関数の前回の呼び出し以降に変更されていないバーについて、計算を繰り返すことを避けるために、カスタム・インジケータを 計算するための経済的なアルゴリズムが可能になります。 そのためには、通常、現在の関数呼び出しのバーの数を含む rates_total パラメータの値を返せば十分である。OnCalculate()の最後の呼び出し以降に価格データが変更された場合(より深い履歴がポンピングされたか、履歴の空白が埋められた)、入力パラメータprev_calculatedの値は、端末によってゼロに設定されます。". では、上記の原理を利用して、他の時間軸のrates_totalとprev_calculatedのアナログを独自に手動で実装する必要があるのでしょうか?それとも、すぐに使えるものがあるのでしょうか?まあ、例えばこんな感じ。rates_total = BarsCalculated(handle); またはCopy-functionの戻り値を取る。しかし、prev_calculatedでは、控えめに言って、そう簡単にはいかないでしょう......。正しく実装するには? Olegs Kucerenko 2011.10.14 15:43 #774 Roshさんの記事で、https://www.mql5.com/ru/articles/1492、数学のことを読みました。例えばOnTester()の中で、このような解析につなげることは可能でしょうか?既製品で自由に使えるものはないのか? Математика в трейдинге. Оценка результатов торговых сделок - Статьи по MQL4 www.mql5.com Математика в трейдинге. Оценка результатов торговых сделок - Статьи по MQL4: автоматическая торговля Rashid Umarov 2011.10.14 16:02 #775 Karlson:Roshさんの記事で、https://www.mql5.com/ru/articles/1492、数学のことを読みました。例えばOnTester()の中で、このような解析につなげることは可能でしょうか?既製品で自由に使えるものはないのか? はい -テスト統計 Olegs Kucerenko 2011.10.14 16:05 #776 Rosh: はい -テスト統計 ありがとうございます。 Саша 2011.10.14 17:43 #777 アドバイスをお願いします。 履歴から取引を選択し、取引の方向は「pivot」(in/out)、次に取引の数量を決定します HistoryDealGetDouble(ticket,DEAL_VOLUME) 総量はわかるが、どの量を閉じて、どの量を開いたかを知るにはどうしたらいいのか?何巻を閉じて、何巻を開いたか知りたい。 Документация по MQL5: Стандартные константы, перечисления и структуры / Торговые константы / Свойства сделок www.mql5.com Стандартные константы, перечисления и структуры / Торговые константы / Свойства сделок - Документация по MQL5 Olegs Kucerenko 2011.10.15 03:14 #778 Rosh: はい -テスト統計線形回帰を書いたのですが、そういうのをターミナルに追加して、テスターでグラフに表示することまで考えているのですか?そして、Zカウントを計算するために理解されているように、独立して正と負の系列の合計数を計算するために必要なのですか? Poltarr 2011.10.15 17:59 #779 この取引所に MetaTrader 5 を取り付けることができますか https://mtgox.com/ ? Rashid Umarov 2011.10.15 18:10 #780 Karlson:また、Zカウントの計算には、プラスとマイナスの系列の合計数を自分で計算する必要があると理解していいのでしょうか? はい、一人で。基本的には、MQL5で計算するコードを掲載することができます。 1...717273747576777879808182838485...277 新しいコメント 取引の機会を逃しています。 無料取引アプリ 8千を超えるシグナルをコピー 金融ニュースで金融マーケットを探索 新規登録 ログイン スペースを含まないラテン文字 このメールにパスワードが送信されます エラーが発生しました Googleでログイン WebサイトポリシーおよびMQL5.COM利用規約に同意します。 新規登録 MQL5.com WebサイトへのログインにCookieの使用を許可します。 ログインするには、ブラウザで必要な設定を有効にしてください。 ログイン/パスワードをお忘れですか? Googleでログイン
ExpertAdvisorを やり直すか、ファイルで作業した方が楽だと思います。
Expert Advisor に何を求めているかを詳しく説明し、VISARD で作成したすべてのコードを提供する方が簡単だと思います。
例えば、エンベロープ・インジケータの価格をクロスさせることで取引を開始するExpert Advisorが必要です。これが、私が手に入れたものです。
指標についての質問です。
OnCalculateには、このような入力パラメータの構成がある。
このような楽しみはすべて現在のタイムフレームに厳密に結びついているので、別のタイムフレームの同様のデータを取得するには、例えば、目的のタイムフレームで必要な組み込み標準インジケータのハンドルを呼び出すことができます。
を作成し、Copy-functionsのバリエーションで必要なデータをバッファにコピーします。
これだけでもいいのですが、rates_totalとprev_calculatedを現在と異なる時間軸で使用する必要があります。そして、私が理解する限りでは、そのようなものはありません。明らかに現在の時間軸に対応していない場合、どこで、どのように入手すればよいのか。
もちろん、ヘルプにわかりやすい解説があります。
"OnCalculate() "が返す値と2番目の入力パラメータprev_calculatedの関係に注目する必要があります。 この関数を呼び出すと、パラメータ prev_calculated には、前回の 呼び出し 時に OnCalculate() が 返した 値が格納 される。 これにより、この関数の前回の呼び出し以降に変更されていないバーについて、計算を繰り返すことを避けるために、カスタム・インジケータを 計算するための経済的なアルゴリズムが可能になります。
そのためには、通常、現在の関数呼び出しのバーの数を含む rates_total パラメータの値を返せば十分である。OnCalculate()の最後の呼び出し以降に価格データが変更された場合(より深い履歴がポンピングされたか、履歴の空白が埋められた)、入力パラメータprev_calculatedの値は、端末によってゼロに設定されます。".
では、上記の原理を利用して、他の時間軸のrates_totalとprev_calculatedのアナログを独自に手動で実装する必要があるのでしょうか?それとも、すぐに使えるものがあるのでしょうか?まあ、例えばこんな感じ。rates_total = BarsCalculated(handle);
またはCopy-functionの戻り値を取る。しかし、prev_calculatedでは、控えめに言って、そう簡単にはいかないでしょう......。正しく実装するには?Roshさんの記事で、https://www.mql5.com/ru/articles/1492、数学のことを読みました。
例えばOnTester()の中で、このような解析につなげることは可能でしょうか?
既製品で自由に使えるものはないのか?
Roshさんの記事で、https://www.mql5.com/ru/articles/1492、数学のことを読みました。
例えばOnTester()の中で、このような解析につなげることは可能でしょうか?
既製品で自由に使えるものはないのか?
はい -テスト統計
アドバイスをお願いします。
履歴から取引を選択し、取引の方向は「pivot」(in/out)、次に取引の数量を決定します HistoryDealGetDouble(ticket,DEAL_VOLUME)
総量はわかるが、どの量を閉じて、どの量を開いたかを知るにはどうしたらいいのか?何巻を閉じて、何巻を開いたか知りたい。
はい -テスト統計
線形回帰を書いたのですが、そういうのをターミナルに追加して、テスターでグラフに表示することまで考えているのですか?
そして、Zカウントを計算するために理解されているように、独立して正と負の系列の合計数を計算するために必要なのですか?
また、Zカウントの計算には、プラスとマイナスの系列の合計数を自分で計算する必要があると理解していいのでしょうか?