//+------------------------------------------------------------------+//| TestDPO.mq5 |//| Copyright 2020, MetaQuotes Software Corp. |//| https://www.mql5.com |//+------------------------------------------------------------------+#property copyright"Copyright 2020, MetaQuotes Software Corp."#property link"https://www.mql5.com"#property version"1.00"//---#include <Trade\Trade.mqh>
CTrade trade;
//---inputint dpo_fast_period = 9; // DPO Fast Periodinputint dpo_slow_period = 40; // DPO Fast Periodinputint Inpmagic = 1000; // Magic советникаinputulong slippage = 10; // Проскальзывание ценыinputdouble Inpvolume = 0.01; // размер позицииinputbool Revers = false; // Revers//---double fDPOVal[]; // Динамический массив для хранения значений fast DPOdouble sDPOVal[]; // Динамический массив для хранения значений slow DPOint DPO_fast = 0; // Хэндл для быстрого DPOint DPO_slow = 0; // Хэндл для медленного DPO//+------------------------------------------------------------------+//| Expert initialization function |//+------------------------------------------------------------------+intOnInit()
{
//--- prepare trade class to control positions if hedging mode is active
trade.SetExpertMagicNumber(Inpmagic);
trade.SetMarginMode();
trade.SetTypeFillingBySymbol(Symbol());
//--- DPO indicator
DPO_fast=iCustom(NULL,0,"Examples\\DPO",dpo_fast_period);
if(DPO_fast==INVALID_HANDLE)
{
printf("Error creating MA indicator");
return(INIT_FAILED);
}
//--- DPO indicator
DPO_slow=iCustom(NULL,0,"Examples\\DPO",dpo_slow_period);
if(DPO_slow==INVALID_HANDLE)
{
printf("Error creating MA indicator");
return(INIT_FAILED);
}
//---return(INIT_SUCCEEDED);
}
//+------------------------------------------------------------------+//| Expert deinitialization function |//+------------------------------------------------------------------+voidOnDeinit(constint reason)
{
//---
}
//+------------------------------------------------------------------+//| Expert tick function |//+------------------------------------------------------------------+voidOnTick()
{
//---//---------------Задаем цены покупки и продажи------------------------double Ask=NormalizeDouble(SymbolInfoDouble(_Symbol,SYMBOL_ASK),_Digits);
double Bid=NormalizeDouble(SymbolInfoDouble(_Symbol,SYMBOL_BID),_Digits);
int signal=0; // сигнал на покупку, продажу//*******************************************************************// эта часть программы выполняется каждый тик//-if(!isNewBar(PERIOD_M1))Print("Новый бар M1 ", TimeCurrent());
//-if(!isNewBar(PERIOD_M5))Print("Новый бар M5 ", TimeCurrent());
//-if(!isNewBar(PERIOD_CURRENT))Print("Новый бар M15", TimeCurrent());
//*******************************************************************//--------------Проверка на новый барif(!isNewBar(PERIOD_CURRENT))
return;
//--------------------------------------------------------------------ArraySetAsSeries(fDPOVal,true); // задаем направление индексов массиваArraySetAsSeries(sDPOVal,true);
if(CopyBuffer(DPO_fast,0,0,10,fDPOVal)<0) // наполняем массив значений DPO fast
{
Alert("Ошибка копирования буфера индикатора fast DPO. Ошибка ", GetLastError());
}
if(CopyBuffer(DPO_slow,0,0,10,sDPOVal)<0) // наполняем массив значений DPO slow
{
Alert("Ошибка копирования буфера индикатора slow DPO. Ошибка ", GetLastError());
}
double DPO_fast_c_value=NormalizeDouble(fDPOVal[1],6); // запоминаем значение индикатора DPO fast на предыдущем бареdouble DPO_slow_c_value=NormalizeDouble(sDPOVal[1],6); // запоминаем значение индикатора DPO slow на предыдущем бареdouble DPO_fast_p_value=NormalizeDouble(fDPOVal[2],6); // запоминаем значение индикатора DPO fast на пред-предыдущем бареdouble DPO_slow_p_value=NormalizeDouble(sDPOVal[2],6); // запоминаем значение индикатора DPO slow на пред-предыдущем бареif(DPO_slow_c_value>0 && DPO_slow_p_value<0 && DPO_fast_c_value>0) // если медленный индикатор пересекает 0 снизу вверх и быстрый находится выше 0
signal=1; // сигнал на открытие покупкиif(DPO_slow_c_value<0 && DPO_slow_p_value>0 && DPO_fast_c_value<0) // если медленный индикатор пересекает 0 сверху вниз и быстрый находится ниже 0
signal=-1; // сигнал на открытие продажиif(DPO_fast_c_value>0 && DPO_fast_p_value<0) // если быстрый индикатор пересекает 0 снизу вверх
signal=-2; // сигнал на закрытие продажиif(DPO_fast_c_value<0 && DPO_fast_p_value>0) // если быстрый индикатор пересекает 0 сверху вниз
signal=2; // сигнал на закрытие покупкиif(!Revers)
{
switch(signal)
{
case -1:
trade.Buy(Inpvolume,NULL,Ask,0,0,NULL);
break;
case1:
trade.Sell(Inpvolume,NULL,Bid,0,0,NULL);
break;
case -2:
trade.PositionClose(_Symbol,slippage);
break;
case2:
trade.PositionClose(_Symbol,slippage);
break;
}
}
if(Revers)
{
switch(signal)
{
case -1:
trade.Sell(Inpvolume,NULL,Bid,0,0,NULL);
break;
case1:
trade.Buy(Inpvolume,NULL,Ask,0,0,NULL);
break;
case -2:
trade.PositionClose(_Symbol,slippage);
break;
case2:
trade.PositionClose(_Symbol,slippage);
break;
}
}
}
/*
//+------------------------------------------------------------------+
//| Возвращает true, если появился новый бар для пары символ/период |
//+------------------------------------------------------------------+
bool isNewBar()
{
//--- в статической переменной будем помнить время открытия последнего бара
static datetime last_time=0;
//--- текущее время
datetime lastbar_time=(int)SeriesInfoInteger(Symbol(),Period(),SERIES_LASTBAR_DATE);
//--- если это первый вызов функции
if(last_time==0)
{
//--- установим время и выйдем
last_time=lastbar_time;
return(false);
}
//--- если время отличается
if(last_time!=lastbar_time)
{
//--- запомним время и вернем true
last_time=lastbar_time;
return(true);
}
//--- дошли до этого места - значит бар не новый, вернем false
return(false);
}
*///+------------------------------------------------------------------+//| возвращает true если появился новый бар, иначе false |//+------------------------------------------------------------------+bool isNewBar(ENUM_TIMEFRAMES timeFrame)
{
//----staticdatetime old_Times[21];// массив для хранения старых значенийbool res=false; // переменная результата анализаint i=0; // номер ячейки массива old_Times[]datetime new_Time[1]; // время нового бараswitch(timeFrame)
{
casePERIOD_M1:
i= 0;
break;
casePERIOD_M2:
i= 1;
break;
casePERIOD_M3:
i= 2;
break;
casePERIOD_M4:
i= 3;
break;
casePERIOD_M5:
i= 4;
break;
casePERIOD_M6:
i= 5;
break;
casePERIOD_M10:
i= 6;
break;
casePERIOD_M12:
i= 7;
break;
casePERIOD_M15:
i= 8;
break;
casePERIOD_M20:
i= 9;
break;
casePERIOD_M30:
i=10;
break;
casePERIOD_H1:
i=11;
break;
casePERIOD_H2:
i=12;
break;
casePERIOD_H3:
i=13;
break;
casePERIOD_H4:
i=14;
break;
casePERIOD_H6:
i=15;
break;
casePERIOD_H8:
i=16;
break;
casePERIOD_H12:
i=17;
break;
casePERIOD_D1:
i=18;
break;
casePERIOD_W1:
i=19;
break;
casePERIOD_MN1:
i=20;
break;
}
// скопируем время последнего бара в ячейку new_Time[0]int copied=CopyTime(_Symbol,timeFrame,0,1,new_Time);
if(copied>0) // все ок. данные скопированы
{
if(old_Times[i]!=new_Time[0]) // если старое время бара не равно новому
{
if(old_Times[i]!=0)
res=true; // если это не первый запуск, то истина = новый бар
old_Times[i]=new_Time[0]; // запоминаем время бара
}
}
//----return(res);
}
//+------------------------------------------------------------------+
double DPO_fast_c_value=NormalizeDouble(fDPOVal[1],6); // запоминаем значение индикатора DPO fast на предыдущем бареdouble DPO_slow_c_value=NormalizeDouble(sDPOVal[0],6); // запоминаем значение индикатора DPO slow на предыдущем бареdouble DPO_fast_p_value=NormalizeDouble(fDPOVal[0],6); // запоминаем значение индикатора DPO fast на пред-предыдущем бареdouble DPO_slow_p_value=NormalizeDouble(sDPOVal[1],6); // запоминаем значение индикатора DPO slow на пред-предыдущем баре
Получает в массив rates_array исторические данные структуры MqlRates указанного символа-периода в указанном количестве. Отсчет элементов от стартовой позиции ведется от настоящего к прошлому, то есть стартовая позиция, равная 0, означает текущий бар. При копировании заранее неизвестного количества данных рекомендуется в качестве приемного...
親愛なる専門家の皆さん、こんにちは。
前のポジションを閉じた売りと同じバーで買いポジションを開くことを妨げるエラーがコードのどこにあるか教えていただけませんか?
ルールは簡単です(覚えるのは)。
1 エントリー - 遅い指標が0を越える+速い指標もゾーンに入る(買い/売り)
2 出口-クイックインジケータによる交差点 0
私はあなたのコードを理解しようとしています - 私はちょうど今それを実行している、それのすべてではない、あなたがレイアウトされた
あなたのコード、そして私の考え.
回答してくださった方、ありがとうございました。
しかし、注文がクローズされ、同じバーでシグナルがあった場合、ポジションがオープンされないという問題が残ります。
これはどういうことなのか、どうすれば直るのか、教えていただけませんか?
回答してくださった方、ありがとうございました。
しかし、注文がクローズされ、同じバーでシグナルがあった場合、ポジションがオープンされないという問題が残ります。
これはどういうことなのか、どうすれば直るのか、教えていただけませんか?
ぱっと見て、新しいバーが あるかどうかを確認するのです。
という信号を探すだけです。すでにこのバーに乗ったことがある人は当たらないことが判明しました。
こんな感じかな?
こんな感じかな?
ここで数字を変えると
よりきれいになりました。
ごあいさつ
以下のようにアドバイスしてください。OnTester関数は、2つのパラメータを計算します。1つのパラメータで最適化する場合、2つ目のパラメータは単純に最適化テーブルに出力される可能性はありますか?また、Yesの場合はどうすればいいのか?ありがとうございました。
皆さんこんにちは!教えてください!mt5で気配値履歴を読み込むことは可能ですか?私 は2日間、情報を探してきたが、それを 把握することはできません。
機能です。
コピー率
指定されたシンボルと期間のレート構造体の ヒストリデータを配列で取得する。
コピータイム
指定されたシンボルと期間のバーの開始時刻の履歴データを配列で取得します。
CopyOpen
指定されたシンボルと期間のバーの始値に関する履歴データを配列で取得する
コピーハイ
指定されたシンボルと期間の最大バー価格のヒストリデータを配列で取得する
コピーロー
指定されたシンボルと期間の最小バー価格のヒストリデータを配列で取得する
コピークローズ
指定されたシンボルと期間のバークローズ価格の履歴データを配列で取得する
CopyTickVolume
指定したシンボルと期間のティックボリュームのヒストリデータを配列で取得する
CopyRealVolume
指定されたシンボルと期間の取引量の履歴データを配列で取得する
CopySpread
指定したシンボルと期間のスプレッドの履歴データを配列で取得する
コピーチケット
ティックの履歴データをMqlTick形式で配列に取得する
CopyTicksRange
指定した日付範囲の目盛りを配列で取得する
mt5で気配値履歴を読み込むことは可能でしょうか?2 日前から情報を探しているのですが、見つからないのです。
4のようなHistoryCenterのようなものはなく、PgUpを押すだけです。