Вы упускаете торговые возможности:
- Бесплатные приложения для трейдинга
- 8 000+ сигналов для копирования
- Экономические новости для анализа финансовых рынков
Регистрация
Вход
Вы принимаете политику сайта и условия использования
Если у вас нет учетной записи, зарегистрируйтесь
Кстати про отрисовку пробоя: в коде, для отрисовки "Break_Sig_Up" есть условие:
действительно ли Close и High берем для 0-го и 1-го бара, а не для StepBack или i ?
Кстати про отрисовку пробоя: в коде, для отрисовки "Break_Sig_Up" есть условие:
действительно ли Close и High берем для 0-го и 1-го бара, а не для StepBack или i ?
Скорее всего ошибка. Давно код писал проверю - отвечу завтра - сегодня уже собрались праздновать.
Удачи.
Удачи.
Удачи. [/quote]
Насчет отбора точек не соглашусь. Привожу цитату из Демарка: "При прорыве нисходящей TD-линии, цены обычно продолжают двигаться вверх......... "
В любом случае, если даже неправильно, перепишите, пожалуйста, хотя бы один из индикаторов. Второй я попробую переписать по аналогии и выложу здесь. Индикаторы маленькие, а Вы я смотрю в программировании спец.
Насчет отбора точек не соглашусь. Привожу цитату из Демарка: "При прорыве нисходящей TD-линии, цены обычно продолжают двигаться вверх......... "
В любом случае, если даже неправильно, перепишите, пожалуйста, хотя бы один из индикаторов. Второй я попробую переписать по аналогии и выложу здесь. Индикаторы маленькие, а Вы я смотрю в программировании спец.
Можете соглашаться или нет - дело конечно же Ваше. Вы вырвали часть текста - в данном случае речь идет о линии предложения (верхняя) - алгоритм отбора ТД точек таков, что верхняя линия мождет идти ТОЛЬКО СВЕРХУ ВНИЗ - точки не удовлетворяющие этому условию ТД точками не являются. Тот индикатор, что Вы выложили допускает проведение верхней линии и снизу вверх и сверху вниз. то есть Вы иногда просто неверно строите линию тренда и пропускаете сигналы на вход или работаете по неверным сигналам.
Ваш индюк перепишу (только займусь на выходные - не раньше) - проблема небольшая, только работать по нему не советую, но это дело Ваше конечно же. И еще одна просьба - выложите пожалуйста коды индикаторов, обрамленными тегами для публикации мкл кода - при написании постов есть пояснения - или скиньте на мыло (указано в коде индикатора) - просто не хочется еще и форматированием заниматься, а так будет лучше видна структура программного кода.
2 All
В предыдущей версии (выложена выше по ветке) - я ее делал давно и просто переводил свой же индикатор с МТ3, как оказалось не очень внимательно - немного по разному работают некоторые функции и это приводило к тому, что если в реал тайме индюк работал правильно, то по истории проверить это не получалось - бывает. Вот исправленая версия - сегодня проверял - вроде работает : я ее выложу и на пауке - так что все обсуждения по работоспособности и пожелания - туда. Сам индюк :
Можете соглашаться или нет - дело конечно же Ваше. Вы вырвали часть текста - в данном случае речь идет о линии предложения (верхняя) - алгоритм отбора ТД точек таков, что верхняя линия мождет идти ТОЛЬКО СВЕРХУ ВНИЗ - точки не удовлетворяющие этому условию ТД точками не являются. Тот индикатор, что Вы выложили допускает проведение верхней линии и снизу вверх и сверху вниз. то есть Вы иногда просто неверно строите линию тренда и пропускаете сигналы на вход или работаете по неверным сигналам.
Ваш индюк перепишу (только займусь на выходные - не раньше) - проблема небольшая, только работать по нему не советую, но это дело Ваше конечно же. И еще одна просьба - выложите пожалуйста коды индикаторов, обрамленными тегами для публикации мкл кода - при написании постов есть пояснения - или скиньте на мыло (указано в коде индикатора) - просто не хочется еще и форматированием заниматься, а так будет лучше видна структура программного кода.
Похоже я понял, Владислав, о чем ты говоришь. В выложенном мной индикаторе верхняя (нижняя) линия рисуются и вверх и вниз, но только правильная линия прочерчивается через TD-точки (это соответствует тому, о чем ты говоришь). На ненужную часть линии я не обращаю внимания.
Я выложу здесь свою попытку переписать индикатор. Ты можешь просто подкорректировать мои ошибки. Тебя такое устроит?
//+------------------------------------------------------------------+
//| DMTrendLines&PricesUp.mq4 |
//| Copyright © 2003, Company |
//| |
//+------------------------------------------------------------------+
#property copyright "Copyright © 2003, Company"
#property link "http://www.company.com/"
#property indicator_chart_window
#property indicator_buffers 1
#property indicator_color1 Blue
double ExtMapBuffer1[];
//---- input parameters
double shift, KUp, BUp, n, MinPrice, TargetPriceUp;
double TrendPriceUp[3,2];
double Maximum[3,2];
double TimeofMaximum[3,2];
double shiftofMaximum[3,2];
//+------------------------------------------------------------------+
//| Custom indicator initialization function |
//+------------------------------------------------------------------+
int init()
{
//---- indicators
SetIndexStyle(0,DRAW_ARROW);
SetIndexArrow(0,217);
SetIndexBuffer(0,ExtMapBuffer1);
SetIndexEmptyValue(0,0.0);
//----
return(0);
}
//+------------------------------------------------------------------+
//| Custor indicator deinitialization function |
//+------------------------------------------------------------------+
int deinit()
{
//----
//----
return(0);
}
void DelObj()
{
ObjectDelete("UpTrend");
ObjectDelete("TargetPriceUp");
}
//+------------------------------------------------------------------+
//| Custom indicator iteration function |
//+------------------------------------------------------------------+
int start()
{
int counted_bars=IndicatorCounted();
//----
shift=(Bars-counted_bars)+ Bars-1;
while(shift>=1)
{
TrendPriceUp[1,1] = TrendPriceUp[2,1];
TrendPriceUp[2,1] = KUp*(shift) + BUp;
ExtMapBuffer1[shift]=TrendPriceUp[2,1];
if (High[shift] > High[shift - 1] && High[shift] >= High[shift + 1] //Если точка - максимум, запоминаются
{Maximum[1,1] = Maximum[2,1]; TimeofMaximum[1,1] = TimeofMaximum[2,1]; //его координаты
shiftofMaximum[1,1] = shiftofMaximum[2,1];
shiftofMaximum[2,1] = shift;
Maximum[2,1] = High[shift];
TimeofMaximum[2,1] = Time[shift];
KUp = (Maximum[2,1]-Maximum[1,1])/(shiftofMaximum[2,1]-shiftofMaximum[1,1]); //Вычисляется новый тренд
BUp = Maximum[1,1] - KUp*shiftofMaximum[1,1];
TrendPriceUp[2,1] = KUp*(shift) + BUp;
if (Maximum[1,1] >= Maximum[2,1] //Если тренд вниз,
{for n = shiftofMaximum[1,1];
while(n>=shiftofMaximum[2,1]) //вычисляется цена по новому тренду,
{ //начиная с его начала
TrendPriceUp[2,1] = KUp*(n) + BUp;
ExtMapBuffer1[n]=TrendPriceUp[2,1];
};
};
DelObj();
ObjectCreate("UpTrend",OBJ_TREND,0,TimeofMaximum[1,1], Maximum[1,1], TimeofMaximum[2,1], Maximum[2,1]);
ObjectSet("UpTrend",OBJPROP_COLOR,Blue);
ObjectSet("UpTrend",OBJPROP_WIDTH,1);
ObjectSet("UpTrend",OBJPROP_STYLE,STYLE_SOLID);
//Новый тренд вниз
//прорисовывается
};
};
if (Close[shift] > TrendPriceUp[2,1] && Close[shift+1] <= TrendPriceUp[1,1] //и тренд направлен вниз,
&& TrendPriceUp[1,1] >= TrendPriceUp[2,1] //рассчитывается цена прорыва.
{MinPrice = Low[Lowest(MODE_LOW, shiftofMaximum[1,1], shiftofMaximum[1,1] - shift)]; //Рассчитывается цена прорыва
TargetPriceUp = (TrendPriceUp[2,1] - MinPrice) + TrendPriceUp[2,1];
DelObj();
ObjectCreate("TargetPriceUp"+Mod(shift,1),OBJ_HLINE,0,TimeofMaximum[1,1], TargetPriceUp, TimeofMaximum[2,1], TargetPriceUp);
ObjectSet("TargetPriceUp"+Mod(shift,1),OBJPROP_COLOR,Blue);
ObjectSet("TargetPriceUp"+Mod(shift,1),OBJPROP_WIDTH,1);
ObjectSet("TargetPriceUp"+Mod(shift,1),OBJPROP_STYLE,STYLE_DOT);
};
//----
return(0);
}
//+------------------------------------------------------------------+
Честно, это не я. :)
Спасибо, сейчас посмотрю..
1. находим 1-ю локальный экстремум один бар до и один после - считаем первой ТД точкой
2. находим предыдущую сравниваем - предыдущая ниже - то есть не является ТД точкой
что Вы делаете ? - правильно пропускаете.
А что нужно делать - правильно - продолжать поиск до тех пор, пока не найдете ближайший локальный экстремум, удовлетворяющий условиям один до и один после, но имеющий значение БОЛЬШЕ уже выбраного и это и будет новая ТД точка.
Разница по результатам - мы таким образом строим ТД линию, которую Вы просто пропускаете. - Рекомендую посмотрите внимательно коды выложенного мной индикатора.
Удачи.
Я коды с трудом читаю, далеко не все понимаю, в лучшем случае смысл улавливаю.
С TD-линиями вроде понятно, но я не понимаю как в моем случае считаются прорывы и как в Вашем? В чем разница?
Я подкорректировал перевод, но почему -то линии возможного прорыва не прорисовываются.
Отвечаю на вопрос: "Зачем объявлять реально одномерный массив как 2-мерный ?" Не знаю, но если этого не сделать, то линии не прорисовываются. Встречный вопрос: "Что такое массив физически?"
//+------------------------------------------------------------------+
//| DMTrendLines&PricesUp.mq4 |
//| Copyright © 2003, Company |
//| |
//+------------------------------------------------------------------+
#property copyright "Copyright © 2003, Company"
#property link "http://www.company.com/"
#property indicator_chart_window
#property indicator_buffers 1
#property indicator_color1 Blue
double ExtMapBuffer1[];
//---- input parameters
//Variable : shift(0);
//Variable : KUp(0), BUp(0), n(0),MinPrice(0),TargetPriceUp(0);
//Array : TrendPriceUp[2,1](0);
//Arrays : Maximum[2,1](0), TimeofMaximum[2,1](0), shiftofMaximum[2,1](0);
int shift=0;
double TrendPriceUp[2][1],// ???????? зачем объявлять реально одномерный массив как 2-мерный ?
KUp = 0.0,
BUp = 0.0,
MinPrice = 0.0,
TargetPriceUp = 0.0,
Maximum[2][1];// ???????? зачем объявлять реально одномерный массив как 2-мерный ?
//MaxMinPriceimum[2][1];// ???????? зачем объявлять реально одномерный массив как 2-мерный ?
int n = 0,
shiftofMaximum[2][1];// ???????? зачем объявлять реально одномерный массив как 2-мерный ?
datetime TimeofMaximum[2][1];// ???????? зачем объявлять реально одномерный массив как 2-мерный ?
//string buff_str="";
//+------------------------------------------------------------------+
//| Custom indicator initialization function |
//+------------------------------------------------------------------+
int init()
{int i=0,j=0;
//---- indicators
SetIndexStyle(0,DRAW_LINE);
SetIndexArrow(0,217);
SetIndexBuffer(0,ExtMapBuffer1);
SetIndexEmptyValue(0,0.0);
//----
for( i=0; i<2; i++){
for( j=0; j<1; j++){
TrendPriceUp[i][j]= 0;
Maximum[i][j] = 0;
//MaxMinPriceimum[i][j]= 0;
shiftofMaximum[i][j] = 0;
TimeofMaximum[i][j] = 0;
}
}
return(0);
}
//+------------------------------------------------------------------+
//| Custor indicator deinitialization function |
//+------------------------------------------------------------------+
int deinit()
{
//----
Comment(" ");
ObjectsDeleteAll();
//----
return(0);
}
//+------------------------------------------------------------------+
//| Custom indicator iteration function |
//+------------------------------------------------------------------+
int start()
{
// int counted_bars=IndicatorCounted();
//----
for( shift = Bars-1; shift>= 1;shift--) { //For shift = Bars-1 Downto 1 Begin
TrendPriceUp[0][0] = TrendPriceUp[1][0];
TrendPriceUp[1][0] = KUp*(shift) + BUp;
ExtMapBuffer1[shift] = TrendPriceUp[1][0];//SetIndexValue(shift, TrendPriceUp[2,1]);
if( (High[shift] > High[shift-1]) //Если точка - максимум, запоминаются ее координаты
&& (High[shift] >= High[shift+1])
) {
Maximum[0][0] = Maximum[1][0];
TimeofMaximum[0][0] = TimeofMaximum[1][0];
shiftofMaximum[0][0] = shiftofMaximum[1][0];
shiftofMaximum[1][0] = shift;
Maximum[1][0] = High[shift];
TimeofMaximum[1][0] = Time[shift];
KUp = (Maximum[1][0]-Maximum[0][0])/(shiftofMaximum[1][0]-shiftofMaximum[0][0]);
BUp = Maximum[0][0] - KUp*shiftofMaximum[0][0];
TrendPriceUp[1][0] = KUp*(shift) + BUp;
if( Maximum[0][0] >= Maximum[1][0]) { //Если тренд вниз,
for( n=shiftofMaximum[0][0];n>= shiftofMaximum[1][0];n--){ //Then {For n = shiftofMaximum[1,1] DownTo shiftofMaximum[2,1] Begin вычисляется цена по новому тренду, начиная с его начала
TrendPriceUp[1][0] = KUp*(n) + BUp;
ExtMapBuffer1[n] = TrendPriceUp[1][0];//SetIndexValue(n, TrendPriceUp[2,1]);
}
//MoveObject("UpTrend", OBJ_TRENDLINE, TimeofMaximum[1,1], Maximum[1,1], TimeofMaximum[2,1], Maximum[2,1], Blue, 1, STYLE_SOLID);
//buff_str = "UpTrend";
ObjectCreate("UpTrend", OBJ_TREND, 0, TimeofMaximum[0][0], Maximum[0][0],TimeofMaximum[1][0], Maximum[1][0]);
ObjectSet("UpTrend", OBJPROP_STYLE, STYLE_SOLID);
ObjectSet("UpTrend", OBJPROP_COLOR, Blue);
ObjectSet("UpTrend", OBJPROP_WIDTH, 1); //Новый тренд вниз прорисовывается
}//If Maximum[1,1] >= Maximum[2,1]
}// if High[shift] > High[shift - 1] AND High[shift] >= High[shift + 1]
if( (Close[shift]>TrendPriceUp[1][0])
&& (Close[shift+1] <= TrendPriceUp[0][0])
&& (TrendPriceUp[0][0] >= TrendPriceUp[1][0]) //и тренд направлен вниз, рассчитывается цена прорыва.
) {
MinPrice = Low[Lowest(MODE_LOW, shiftofMaximum[0][0],shiftofMaximum[0][0] - shift)];
TargetPriceUp = (TrendPriceUp[1][0] - MinPrice) + TrendPriceUp[1][0];
//MoveObject("TargetPriceUp"+Mod(shift,1), OBJ_HLINE, TimeofMaximum[1,1], TargetPriceUp, TimeofMaximum[2,1], TargetPriceUp, Blue, 1, STYLE_DOT);
//buff_str = "TargetPriceUp"+DoubleToStr(MathMod(shift,1),5);
ObjectCreate("TargetPriceUp"+DoubleToStr(MathMod(shift,1),5), OBJ_HLINE, 0, TimeofMaximum[0][0], TargetPriceUp,TimeofMaximum[1][0], TargetPriceUp);
ObjectSet("TargetPriceUp"+DoubleToStr(MathMod(shift,1),5), OBJPROP_STYLE, STYLE_DOT);
ObjectSet("TargetPriceUp"+DoubleToStr(MathMod(shift,1),5), OBJPROP_COLOR, Blue);
ObjectSet("TargetPriceUp"+DoubleToStr(MathMod(shift,1),5), OBJPROP_WIDTH, 1);
}//If Close[shift] > TrendPriceUp[2,1] AND Close[shift+1] <= TrendPriceUp[1,1]
}//For shift = Bars-1 Downto 1 Begin
//----
return(0);
}
//+------------------------------------------------------------------+
Так я сыграл свое, подождал когда рынок чуть устаканится и вновь за дело...?
Т.е. меня это несколько смущает, хотя кто его знает, только на практике будет видно. Владислав, а ты сам используешь Демарка в своей работе?