//+------------------------------------------------------------------+//| Новый бар 2.mq4 |//| Peter Konow |//| https://www.mql5.com |//+------------------------------------------------------------------+#property copyright"Peter Konow"#property link"https://www.mql5.com"#property version"1.00"#property strict//+------------------------------------------------------------------+datetime Время_последнего_бара;
int Частота_таймера = 25;
int Всех_символов;
string Символы[];
int Таймфреймы[7] = {PERIOD_M1,PERIOD_M5,PERIOD_M15,PERIOD_M30,PERIOD_H1,PERIOD_H4,PERIOD_D1};
int Всех_таймфреймов = 7;
int Количество_баров[][7];
bool События_нового_бара[][7];
//+------------------------------------------------------------------+#define M1 0#define M5 1#define M15 2#define M30 3#define H1 4#define H4 5#define D1 6//+------------------------------------------------------------------+//| Expert initialization function |//+------------------------------------------------------------------+intOnInit()
{Alert("!!!");
//--- create timerEventSetMillisecondTimer(25);
//-------------------------------------------------------------//Записываем время последнего бара на момент загрузки эксперта. //Для корректного начала работы, робота нужно запустить на М1. //-------------------------------------------------------------
Время_последнего_бара = Time[0];
//------------------------------------------------------------- //Узнаем сколько символов есть в обзоре рынка.//---------------------------------------------------------
Всех_символов = SymbolsTotal(true);
//--------------------------------------------------------- //Устанавливаем размер массива Символы. Внутри него будут записаны//имена всех символов, которые есть в окне обзоре рынка.//---------------------------------------------------------ArrayResize(Символы,Всех_символов);
//---------------------------------------------------------//Устанавливаем размеры массивов "Количество_баров[]" и "События_нового_бара[]".//В массиве "Количество_баров[]" будет записыватся текущее количество баров каждого символа//и каждого таймфрейма. А в массиве "События_нового_бара[]" устанавливаться флаги//события нового бара для каждого символа и каждого таймфрейма. //---------------------------------------------------------ArrayResize(Количество_баров,Всех_символов);
ArrayResize(События_нового_бара,Всех_символов);
//---------------------------------------------------------//Записываем наименования символов обзора рынка в массив "Символы[]".//---------------------------------------------------------for(int a1 = 0; a1 < Всех_символов; a1++)
{
Символы[a1] = SymbolName(a1 + 1,true);
//Возможно, нумерация символов в обзора рынка идет с нуля.//Тогда: Символы[a1] = SymbolName(a1,true);
}
//---------------------------------------------------------return(INIT_SUCCEEDED);
}
//+------------------------------------------------------------------+//| Expert deinitialization function |//+------------------------------------------------------------------+voidOnDeinit(constint reason)
{
//--- destroy timerEventKillTimer();
}
//+------------------------------------------------------------------+//| Expert tick function |//+------------------------------------------------------------------+voidOnTick()
{
}
//+------------------------------------------------------------------+//| Timer function |//+------------------------------------------------------------------+voidOnTimer()
{
staticbool Начало_отсчета;
staticint Минута;
//---------------------------//Нам нужен корректный старт отсчета. Это должно быть время начала бара.//---------------------------if(!Начало_отсчета && Время_последнего_бара != Time[0])Начало_отсчета = true;
//--------------------------- if(Начало_отсчета)Минута++;
//--------------------------- //В следующем цикле, мы будем обращатся к функции iBars для получения количества баров на //каждом из символов и таймфреймов, которые будем проходить в цикле.//Далее, будем сравнивать записанное количество баров с текущим и при //наличии разницы установим флаг события нового бара в массив "События_нового_бара[]".//---------------------------if(Минута*Частота_таймера >= 60000)
{
for(int a1 = 0; a1 < Всех_символов; a1++)
{
string Этот_символ = Символы[a1];
//---------------------------------for(int a2 = 0; a2 < Всех_таймфреймов; a2++)
{
int Этот_таймфрейм = Таймфреймы[a2];
//------------------------------------------int Текущее_количество_баров = iBars(Этот_символ,Этот_таймфрейм);
//------------------------------------------if(Текущее_количество_баров > Количество_баров[a1][a2])
{
//------------------------------------------------------------//Если это не самая первая запись в массив Количества баров,//то фиксируем событие нового бара.//------------------------------------------------------------if(Количество_баров[a1][a2])
{
События_нового_бара[a1][a2] = true;
}
//------------------------------------------------------------//Устанавливаем новое значение текущего количества баров.//------------------------------------------------------------
Количество_баров [a1][a2] = Текущее_количество_баров;
}
//------------------------------------------
}
}
//---------
Минута = 0;
}
//-----------------------------------------------
}
//+------------------------------------------------------------------+//---------------------------------------------------------------------//Функция Новый_бар() принимает наименование символа и таймфрейм.//Она делает цикл по массиву символов, находит совпадение наименований и //с запрашиваемым символом, и далее ищет нужный таймфрейм для получения//индекса ячейки массива в которой он находится. //Найдя индекс ячейки имени нужного символа и индекс ячейки нужного//таймфрейма, функция обращается к массиву "События_нового_бара" и //возвращает факт события нового бара или его отсутствие.//После возврата флага события, функция снимает этот флаг.//Следовательно, флаг события можно получить только один раз за бар.//---------------------------------------------------------------------bool Новый_бар(string Символ, int Таймфрейм)
{
bool Новый_бар;
//-----------------------for(int a1 = 0; a1 < Всех_символов; a1++)
{
if(Символы[a1] == Символ)
{
Новый_бар = События_нового_бара[a1][Таймфрейм];
if(Новый_бар)События_нового_бара[a1][Таймфрейм] = 0;
return(Новый_бар);
}
}
//-----------------------return(false);
}
//--------------------------//+------------------------------------------------------------------+
把它放进去,测试了一下,没有用。
它总是显示虚假。你显然不能阅读代码。))她在哪里吞噬它们?
在卡拉甘达。
在卡拉甘达
我不知道是否有人真的有那么多?
我有16个--而且我已经在想,这是否是太多的负担?
我的最低时间框架是M15...但是,我仍然想知道,终端上的负载何时开始变得至关重要?
我的客户要求我在每次打勾 时检查和扫描服务器上的所有符号。虽说不多,也不少,但也有10 230人......。这就是问题所在...
我有一个客户要求我检查和扫描服务器上的 所有字符。而且不是很多,也不是很少,而是10,230个...这就是问题所在...
是否有任何混淆?也许它在乌兰乌德?
我在想,如果一个人在市场概览中真的有600个工具,并且在每个tick 上检查每个工具和每个时间框架的新条形的到来,可能会很昂贵......
我自己不做交易,所以我不知道这个函数在实践中到底应该被调用多少次。
只有在符号和时间框架的数量非常大,并且在数百个符号的每个刻度上调用该函数时,新条形图函数中的符号和时间框架的双循环才可能增加负荷。也许德米特里是对的,那么。
我已经缩短了函数中的一个循环。
我记得,当时市场观察窗口中的符号最大数量限制为1024个。它现在不存在吗?你也可以有一万个?
关于交易、自动交易系统和交易策略测试的论坛
Mt4结束支持。
Artyom Trishkin, 2017.09.11 14:37
我有一个客户要求我检查和扫描服务器上的 所有符号。而且不是很多,也不是很少,而是10,230个...这就是问题所在...
这里是新的版本。这还不是最终结果。
你是否已经成功了呢?
彼得,它对我也不起作用。虽然该算法相当快,但这是在浪费时间。但它还没有发挥作用。没有时间去弄清楚。
你的编程风格很奇怪。你可以把所有这些东西和所有变量以及OnInit和OnTimer的循环放到一个过程中。如果有人想使用它,所有这些东西都会碍手碍脚。如果将有20个或更多的程序具有相同的内容怎么办?它是在这里 实施的。
我在想,如果一个人在市场概览中真的有600个工具,并且在每个tick 上检查每个工具和每个时间框架的新条形的到来,可能会很昂贵......
我自己不做交易,所以我不知道这个函数在实践中到底应该被调用多少次。
只有在符号和时间框架的数量非常大,并且在数百个符号的每个刻度上调用该函数时,新条形图函数中的符号和时间框架的双循环才可能增加负荷。也许德米特里是对的,那么。
我在函数中缩短了一个周期。
真诚的。