[АРХИВ!] Любой вопрос новичка, чтоб не захламлять форум. Профи, не проходите мимо. Без вас никуда - 4. - страница 481

 
midorum:
попробуйте Bars-30
Нет, не верно. Это будет по логике слева 30 баров отступ и до 0-ого бара рисовать.
 
SetIndexDrawBegin(0,Bars-30);//первый бар отрисовки индикатора 

я не знаю, какая у Вас логика, у меня такая настройка отрисовывает последние 30 баров индикатора

еще раз повторяю,  SetIndexDrawBegin() отсчитывает бары с левого конца графика

прежде чем спорить, проверьте 

 
merkulov.artem:

Хорошо. Постараюсь изложить суть задачи, возможно кто-то подскажет или поможет ее реализовать более просто.

Работаем на минутном графике. Берем минутный бар (high+low/2 - среднее значение бара) на графике 29/10/12 в 00:00 - это будет точкой отсчета.

Далее проверяем отклонение от данной цены на 10 пунктов вверх (каждое верное отклонение будет +1).

Когда достигаем поднятие цены на 10 пунктов от стартовой точки - счетчик +1; и начинаем проверку отклонений дальше, только уже от той точки в которой мы достигли отклонения на 10 пунктов, и ждем следующего поднятия цена на 10 пунктов.

К примеру получаем:

Если (стартовая точка) + 10 пунктов <= цены (используем все последующий цены баров от точки отсчета.) Получаем счетчик=счетчик +1; И стартовую точку начинаем уже от этого места - (стартовая точка + 10 пунктов).

Если (стартовая точка + 10 пунктов) + 10 пунктов <= цены (используем все последующий цены баров от точки отсчета.) Получаем счетчик=счетчик +1; И стартовую точку начинаем уже от этого места - (стартовая точка + 10 пунктов) + 10 пунктов.  

Если (стартовая точка + 10 пунктов + 10 пунктов) + 10 пунктов <= цены (используем все последующий цены баров от точки отсчета.) Получаем счетчик=счетчик +1; И стартовую точку начинаем уже от этого места - (стартовая точка + 10 пунктов + 10 пунктов) + 10 пунктов.  

и так далее...

 Пока не достигнем счетчика равному 10 (счетчика == 10).

 И каждый новый образованный минутный бар (high+low/2 - среднее значение бара) проверяем на это условие и ждем пока не достигнем счетчика равному 10 (счетчика == 10). Допустим прошло два дня, каждый новый образованный бар мы проверяли и смещались если условия были верны ....

И когда мы достигли счетчик =10 - Выводим сообщение что "Счетчик == 10". Смещаем стартовую точку на 2 дня вперед от первоначально заданной пользователем т.е. с 29/10/12 в 00:00 на 31/10/12 в 00:00 и повторяем цикл.

Повторяем цикл и так двигаемся по графику. 

Т.е. нужно брать новую образованные бары, по нить брать  (high+low/2 - среднее значение бара). И проверять на условия и если условия верны смещать как написано выше.

Я пытался это реализовать через массив, получается очень запутано и значения выдает не те!! Помогите как реализовать данный алгоритм! 


Тут массивы вообще не нужны. Это вообще что, советник, скрипт, индикатор? Дело в том, что код советника будет отличаться от кода индикатора для реализации этой задачи.

И есть тут существеный недостаток. Смотрите, мы обозначили стартовую точку и она пришлась аккурат на пиковую свечу восходящей тенденции. Допустим, мы не учитываем в дальнейших вылавливаниях 10 пунктов показания этой свечи - назовём её стартовой свечой. Итак, следующая свеча поехала вниз и мы не отловим ни как уровня = стартовая точка + 10 пунктов: цена то катится вниз. Поэтому мы, можно так сказать, застряли на долго - цена опустилась и может вихляться внизу как угодно вверх-вниз - она всё равно не достигнет уже уровня стартовой точки - медведи круто прижали её.. Но, скажем, нам повезло и через 5 000 свеч цена вернулась к уровню, на котором стоит стартовая точка, и даже прошла 10 пунктов в плюс. Мы потреряли кучу времени, но теперь мы можем внести не в массив, а в переменную цену, равную стартовая точка + 10 пунктов и ждать теперь когда же цена  достигнет уровня = уровень переменной + 10 унктов... Короче, всё это не нужно - судя по Вашему описанию мы отлавливаем уровень = стартовая точка + 10*10 = стартовая точка + 100 пунктов. Как только этот уровень удалось отловить, мы переносим стартовуюю дату на 2 дня в будущее и вычисляем новую стартовую точку. Это всё слоэно - есть путь проще.

Стартовую дату задаём в пользовательских переменных (перед ними в коде стоит слово extern). Объявляем переменную типа datetime. Пусть это переменная dt_StartDate (стартовая дата) и тут же в блоке инициализации присваиваем ей значение, которое хранится в пользовательской переменной. Далее отыскиваем свечку соответствующую этой дате и вычисляем стартовую точку по Вашей формуле. ТОлько это не стартовая точка, а стартовый уровень цены. Объявляем переменную типа double, например, d_StartLevel (стартовый уровень) и вносим в переменную значение вычисленного уровня. Или можно вообще проще - не объявлять переменную, а сразу отчертить горизонтальную линию через вычисленную стартовую цену. Так даже лучше - назовём эту линию  StartLevel. Теперь отчерчиваем на графике вторую линию на расстоянии = 100 пунктов вверх от стартового уровня - назовём эту линию "уровнем отлова" - OtlovLevel. Всё, далее не нужны ни какие массивы - на каждом тике тупо смотрим, стала цена выше чем  OtlovLevel, или нет. Как только стала, увеличиваем значение переменной   dt_StartDate на 2 дня, вычисляем снова стартовый уровень и переносим туда стартовую линию. После этого снова откладываем от стартовой линии 100 пунктов вверх и перетаскиваем туда линию    OtlovLevel. Всё, задача решена. Всякий раз можно запросить цену, на которую установлена любая линия и сравнить её с текущей ценой или с ценой High текущей свечи.

 
midorum:

я не знаю, какая у Вас логика, у меня такая настройка отрисовывает последние 30 баров индикатора

еще раз повторяю,  SetIndexDrawBegin() отсчитывает бары с левого конца графика

прежде чем спорить, проверьте 

 Так я не спорю. Вот смотри. Берём стандартный индикатор CCI. Я в функции  SetIndexDrawBegin заменил CCIPeriod на (Bars - CCIPeriod). Я изменил только выделенное жёлтым в коде..

 Вот код:

//+------------------------------------------------------------------+
//|                                                          CCI.mq4 |
//|                      Copyright © 2004, MetaQuotes Software Corp. |
//|                                       http://www.metaquotes.net/ |
//+------------------------------------------------------------------+
#property copyright "Copyright © 2004, MetaQuotes Software Corp."
#property link      "http://www.metaquotes.net/"
//----
#property indicator_separate_window
#property indicator_buffers 1
#property indicator_color1 LightSeaGreen
//---- input parameters
extern int CCIPeriod = 14;
//---- buffers
double CCIBuffer[];
double RelBuffer[];
double DevBuffer[];
double MovBuffer[];
//+------------------------------------------------------------------+
//| Custom indicator initialization function                         |
//+------------------------------------------------------------------+
int init()
  {
   string short_name;
//---- 3 additional buffers are used for counting.
   IndicatorBuffers(4);
   SetIndexBuffer(1, RelBuffer);
   SetIndexBuffer(2, DevBuffer);
   SetIndexBuffer(3, MovBuffer);
//---- indicator lines
   SetIndexStyle(0, DRAW_LINE);
   SetIndexBuffer(0, CCIBuffer);
//----
   if(CCIPeriod <= 0)
       CCIPeriod = 14;
//----
   SetIndexDrawBegin(0, Bars - CCIPeriod);
  
//---- name for DataWindow and indicator subwindow label
   short_name="CCI(" + CCIPeriod + ")";
   IndicatorShortName(short_name);
   SetIndexLabel(0, short_name);
//----
   return(0);
  }
//+------------------------------------------------------------------+
//| Commodity Channel Index                                          |
//+------------------------------------------------------------------+
int start()
  {
   int    i, k, counted_bars = IndicatorCounted();
   double price, sum, mul; 
   if(CCIPeriod <= 1)
       return(0);
   if(Bars <= CCIPeriod) 
       return(0);
//---- initial zero
   if(counted_bars < 1)
     {
       for(i = 1; i <= CCIPeriod; i++) 
           CCIBuffer[Bars-i] = 0.0;
       for(i = 1; i <= CCIPeriod; i++) 
           DevBuffer[Bars-i] = 0.0;
       for(i = 1; i <= CCIPeriod; i++) 
           MovBuffer[Bars-i] =0.0;
     }
//---- last counted bar will be recounted
   int limit = Bars - counted_bars;
   if(counted_bars > 0) 
       limit++;
//---- moving average
   for(i = 0; i < limit; i++)
       MovBuffer[i] = iMA(NULL, 0, CCIPeriod, 0, MODE_SMA, PRICE_TYPICAL, i);
//---- standard deviations
   i = Bars - CCIPeriod + 1;
   if(counted_bars > CCIPeriod - 1) 
       i = Bars - counted_bars - 1;
   mul = 0.015 / CCIPeriod;
   while(i >= 0)
     {
       sum = 0.0;
       k = i + CCIPeriod - 1;
       while(k >= i)
        {
          price =(High[k] + Low[k] + Close[k]) / 3;
          sum += MathAbs(price - MovBuffer[i]);
          k--;
        }
       DevBuffer[i] = sum*mul;
       i--;
     }
   i = Bars - CCIPeriod + 1;
   if(counted_bars > CCIPeriod - 1) 
       i = Bars - counted_bars - 1;
   while(i >= 0)
     {
       price = (High[i] + Low[i] + Close[i]) / 3;
       RelBuffer[i] = price - MovBuffer[i];
       i--;
     }
//---- cci counting
   i = Bars - CCIPeriod + 1;
   if(counted_bars > CCIPeriod - 1) 
       i = Bars - counted_bars - 1;
   while(i >= 0)
     {
       if(DevBuffer[i] == 0.0) 
           CCIBuffer[i] = 0.0;
       else 
           CCIBuffer[i] = RelBuffer[i] / DevBuffer[i];
       i--;
     }
//----
   return(0);
  }
//+------------------------------------------------------------------+

 По логике если CCIPeriod равен 14. То при SetIndexDrawBegin(0, Bars - CCIPeriod) должно отрисоваться только 14 послених баров. Начиная от значения (Bar - 14). Но вот что я вижу на экране 

 

 
hoz:

 Так я не спорю. Вот смотри. Берём стандартный индикатор CCI. Я в функции  SetIndexDrawBegin заменил CCIPeriod на (Bars - CCIPeriod). Я изменил только выделенное жёлтым в коде..

 Вот код:

 По логике если CCIPeriod равен 14. То при SetIndexDrawBegin(0, Bars - CCIPeriod) должно отрисоваться только 14 послених баров. Начиная от значения (Bar - 14). Но вот что я вижу на экране 

 

вот что я вижу на экране

 

вверху нативный индикатор, ниже измененный на SetIndexDrawBegin(0, Bars-CCIPeriod); 

 
midorum, извеняюсь. Мой затуп. MetaEditor открыл другой терминал... Теперь всё заработало. Спасибо!
 
hoz:
midorum, извеняюсь. Мой затуп. MetaEditor открыл другой терминал... Теперь всё заработало. Спасибо!
да с этой проблемой я тоже постоянно мучаюсь - 3 терминала, и Editor путает папки. Лучше запускать его через кнопку в терминале, а в нем уже вручную открывать файл.
 

Доброго времени суток! Люди добрые дайте пожалуйста ответ, как определить что 15 минутная свеча открылась, я использовал умопомрачительную строчку, но как оказалась не всегда свеча открывается по времени...думается есть более простой способ узнать что открылась свеча...но мне это как то непонять...   

if ((TimeMinute(TimeCurrent())==0 && TimeSeconds(TimeCurrent())==0)|| (TimeMinute(TimeCurrent())==15 && TimeSeconds(TimeCurrent())==0) || (TimeMinute(TimeCurrent())==30 && TimeSeconds(TimeCurrent())==0) || (TimeMinute(TimeCurrent())==45 && TimeSeconds(TimeCurrent())==0))

 
stater:

Доброго времени суток! Люди добрые дайте пожалуйста ответ, как определить что 15 минутная свеча открылась, я использовал умопомрачительную строчку, но как оказалась не всегда свеча открывается по времени...думается есть более простой способ узнать что открылась свеча...но мне это как то непонять...   

if ((TimeMinute(TimeCurrent())==0 && TimeSeconds(TimeCurrent())==0)|| (TimeMinute(TimeCurrent())==15 && TimeSeconds(TimeCurrent())==0) || (TimeMinute(TimeCurrent())==30 && TimeSeconds(TimeCurrent())==0) || (TimeMinute(TimeCurrent())==45 && TimeSeconds(TimeCurrent())==0))


https://www.mql5.com/ru/forum/131853/page4#504607
 
stater:

Доброго времени суток! Люди добрые дайте пожалуйста ответ, как определить что 15 минутная свеча открылась, я использовал умопомрачительную строчку, но как оказалась не всегда свеча открывается по времени...думается есть более простой способ узнать что открылась свеча...но мне это как то непонять...   

if ((TimeMinute(TimeCurrent())==0 && TimeSeconds(TimeCurrent())==0)|| (TimeMinute(TimeCurrent())==15 && TimeSeconds(TimeCurrent())==0) || (TimeMinute(TimeCurrent())==30 && TimeSeconds(TimeCurrent())==0) || (TimeMinute(TimeCurrent())==45 && TimeSeconds(TimeCurrent())==0))


bool CheckOpenM15()
{
   static int PrevTime=0;
   if (PrevTime==iTime(NULL, PERIOD_M15,0)) return(false);
   PrevTime=iTime(NULL, PERIOD_M15,0);
   return(true);
}
Функция возвращает истину при появлении нового бара на М15
Причина обращения: