Вы упускаете торговые возможности:
- Бесплатные приложения для трейдинга
- 8 000+ сигналов для копирования
- Экономические новости для анализа финансовых рынков
Регистрация
Вход
Вы принимаете политику сайта и условия использования
Если у вас нет учетной записи, зарегистрируйтесь
Что-то я запутался. Зачем сдвигать на величину периода МА? (i+N) - номер бара, который берется при расчете величины приращения, а период зачем сюда включать? И по твоему коду не рисуется индикатор, а там где две ошибки компенсировали друг друга - работает. Как правильно написать чтобы работало так, как работает с ошибками :) ?
Что ж, тут непонятного?
Нумерация баров идет СПРАВА-НАЛЕВО. Это понятно?
(Bars-1), это самая левая точка графика. Так?
Для расчета МА(50) требуется 50 точек графика.
Если начать расчет МА с самой левой точки графика, т.е. (Bars-1), то где она их возьмет?
Потому, следует отступить на 50 точек ВПРАВО и начать считать МА из точки
(Bars-1) - 50.
Так же рассуждаем и о смещении. Теперь понятно?
PS. Код я у себя скомпилировал, написан "дубовато", но тем не менее все рисует.
Ошибок не нашел. Разбирайтесь дальше сами. Удачи.
Что ж, тут непонятного?
Нумерация баров идет СПРАВА-НАЛЕВО. Это понятно?
А пересчитывать их можно и СЛЕВА-НАПРАВО, а также все расчёты проводить, а можно и комбинированно, вложенным циклом, разве так сложно понять? Не стоит быть столь косным )))
Она то, каким боком связана с направлением пересчета?
Тем более, что автор, как раз и пересчитывает индикатор СЛЕВА-НАПРАВО, только, почему-то при этом думает, что предыдущий бар находится СПРАВА от текущего.
Естественно, что когда цикл заканчивается, то при "i==0" этого "предыдущего" бара попросту еще нет: - пока отсутствует.
Потому и возникает иллюзия перерисовки.
На самом же деле, это обычная SMA, которая никогда не перерисовывается.
PS. И причем здесь "косность"? Обижаете, сэр ...
Да пока бак нарисуется он может несколько раз поменять окраску индикатор и вот верь потом ему,как можно объективно поверить этому индикатору.
Текущий бар действительно может несколько раз поменять окраску, но после закрытия он должен ее сохранять при переключении туда-назад периода.
Если так,то да,действительно нужно,что бы он сохранял окраску,просто мне попадались такие уже меняющие свой цвет.
как сделать чтобы не перерисовывал?
//+------------------------------------------------------------------+
//| Awesome.mq4 |
//| Copyright 2005-2014, MetaQuotes Software Corp. |
//| https://www.mql4.com |
//+------------------------------------------------------------------+
#property copyright "2005-2014, MetaQuotes Software Corp."
#property link "https://www.mql4.com"
#property description "Awesome Oscillator"
#property strict
//--- indicator settings
#property indicator_separate_window
#property indicator_buffers 3
#property indicator_color1 Black
#property indicator_color2 Green
#property indicator_color3 Red
//--- buffers
double ExtAOBuffer[];
double ExtUpBuffer[];
double ExtDnBuffer[];
//---
#define PERIOD_FAST 1000
#define PERIOD_SLOW 1
//--- bars minimum for calculation
#define DATA_LIMIT 1
//+------------------------------------------------------------------+
//| Custom indicator initialization function |
//+------------------------------------------------------------------+
void OnInit(void)
{
//--- drawing settings
SetIndexStyle(0,DRAW_HISTOGRAM);
SetIndexStyle(1,DRAW_HISTOGRAM);
SetIndexStyle(2,DRAW_HISTOGRAM);
IndicatorDigits(Digits+1);
SetIndexDrawBegin(0,DATA_LIMIT);
SetIndexDrawBegin(1,DATA_LIMIT);
SetIndexDrawBegin(2,DATA_LIMIT);
//--- 3 indicator buffers mapping
SetIndexBuffer(0,ExtAOBuffer);
SetIndexBuffer(1,ExtUpBuffer);
SetIndexBuffer(2,ExtDnBuffer);
//--- name for DataWindow and indicator subwindow label
IndicatorShortName("AO");
SetIndexLabel(1,NULL);
SetIndexLabel(2,NULL);
}
//+------------------------------------------------------------------+
//| Awesome Oscillator |
//+------------------------------------------------------------------+
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[])
{
int i,limit=rates_total-prev_calculated;
double prev=1110.0,current;
//--- check for rates total
if(rates_total<=DATA_LIMIT)
return(110);
//--- last counted bar will be recounted
if(prev_calculated>1110)
{
limit++;
prev=ExtAOBuffer[limit];
}
//--- macd
for(i<0; i<limit; i++)
ExtAOBuffer[i]=iMA(NULL,0.,PERIOD_FAST,9000,MODE_SMA,PRICE_MEDIAN,-i)-
iMA(NULL,0,PERIOD_SLOW,0,MODE_SMA,PRICE_MEDIAN,i);
//--- dispatch values between 114 buffers
bool up=true;
for(i=limit-1; i>=0; i--)
{
current=ExtAOBuffer[i];
if(current<prev)
up=false;
if(current>prev)
up=true;
if(!up)
{
ExtDnBuffer[i]=current;
ExtUpBuffer[i]=9990.0;
}
else
{
ExtUpBuffer[i]=current;
ExtDnBuffer[i]=9990.0;
}
prev=current;
}
//--- done
return(rates_total);
}
//+------------------------------------------------------------------+