0
Добрый день. Выступлю поручителем в мае месяце. *good* 
avatar

GAWroch

  • 30 мая 2019, 10:21
0
На реале заменил сову, тоже усреднитель. Открыто 8 разнонаправленных сделок. К сожалению результат отрицательный. Дополнительный профит не считает. Вернее считал и закрыл одну сделку. Но с открытием ещё одной, противоположного направления, перестал считать. Печалька… (((((
avatar

GAWroch

  • 24 апреля 2019, 19:57
0
Артем, если я не ошибаюсь, ещё раз спасибо. Посмотрел на демке, вроде всё правильно. Если обнаружатся какие либо нелогичности отпишусь дополнительно.
avatar

GAWroch

  • 24 апреля 2019, 18:56
0
Спасибо за оперативность! ) В тестере все хорошо. По результатам тестов на демке отпишусь.
avatar

GAWroch

  • 24 апреля 2019, 08:51
0
Эх Иван, Иван… 641 сообщение… Тебе заняться больше нечем или такой способ самоутвердиться? Есть у тебя мнение — хорошо! Поделился им с народом — молодец! Но нах навязывать другим свое мнение!?
avatar

GAWroch

  • 17 марта 2019, 15:57
0
Откусывать по 2 ордера не очень целесообразно. При резком однонаправленном движении цены получаются пропуски. Логичнее откусывать крайние ордера, по одному. Переписанный буду смотреть. Спасибо.
avatar

GAWroch

  • 30 января 2019, 15:00
0
К сожалению при тестировании выявлены те же косяки. Без помощи Андрея не обойтись.
avatar

GAWroch

  • 30 января 2019, 05:42
0
Comment("\n Lot: ",Lot(),
           "\n Trades: ",CountTrades(),
           "\n Profit: ",AllProfit(),
           "\n Profit2: ",AllProfit2(),
           "\n Second: ",CountTrades()-Count);


avatar

GAWroch

  • 28 января 2019, 06:46
0
Заменить части кода:
//+------------------------------------------------------------------+
//|                                                                  |
//+------------------------------------------------------------------+
void CloseAll2()
  {
   bool cl;
   int second=CountTrades()-1-Second;
   for(int i=CountTrades()-1;i>second;i--)
     {
      if(OrderSelect(i,SELECT_BY_POS,MODE_TRADES))
        {
         if(OrderSymbol()==Symbol() && OrderMagicNumber()==Magic)
           {
            if(OrderType()==0)
              {
               RefreshRates();
               cl=OrderClose(OrderTicket(),OrderLots(),NormalizeDouble(Bid,Digits),Slip,White);
              }
            if(OrderType()==1)
              {
               RefreshRates();
               cl=OrderClose(OrderTicket(),OrderLots(),NormalizeDouble(Ask,Digits),Slip,White);
              }
           }
        }
     }
  }

//+------------------------------------------------------------------+
//| Профит всех ордеров по типу ордера                               |
//+------------------------------------------------------------------+
double AllProfit2()
  {
   double pr=0;
   int second=CountTrades()-1-Second;
   for(int i=CountTrades()-1;i>second;i--)
     {
      if(OrderSelect(i,SELECT_BY_POS,MODE_TRADES))
        {
         if(OrderSymbol()==Symbol() && OrderMagicNumber()==Magic)
           {
            if(OrderType()==0)
              {
               pr+=OrderProfit()+OrderCommission()+OrderSwap();
              }

            if(OrderType()==1)
              {
               pr+=OrderProfit()+OrderCommission()+OrderSwap();
              }
           }
        }
     }
   return(pr);
  }


avatar

GAWroch

  • 28 января 2019, 06:45
0
Пошагово.
Запускаем сов., он открывает ордер согласно настройкам. Непонятно, почему в строке «Second» -1, хотя по логике должно быть -2.

Скриптом открываем второй ордер на этой же паре, с тем же магиком. В строке «Second» значение не верно.

На любой другой паре открываем ордер вручную без разницы в каком направлении. Строка «Profit2» обнуляется, сов перестает его считать и не закроет ордер «Second» при наступлении заданных условий. Хотя усреднение будет происходить согласно заданному шагу и свой «Ptrofit» считает верно.

Тоже самое будет если вручную или каким либо другим совом открыть ордер на этой паре.

Если обобщить — работу советника нарушает любой, открытый не советником, ордер в терминале, в не зависимости от магика. Вот эту накладочку и прошу исправить.

avatar

GAWroch

  • 24 января 2019, 07:12
0
Возможно тут причина…
double AllProfit2()
  {
   double pr=0;
   int second=OrdersTotal()-1-Second;
   for(int i=OrdersTotal()-1;i>second;i--)
avatar

GAWroch

  • 23 января 2019, 17:57
0
Заменил указанную часть кода. Проблема осталась. Видит локирующий ордер и не считает как надо.
avatar

GAWroch

  • 23 января 2019, 17:55
0
Быстро… Сейчас попробую.
avatar

GAWroch

  • 23 января 2019, 17:39
0
Добрый вечер. Огромное спасибо, что откликнулись. Завтра потестирую. По результатам отпишусь.
avatar

GAWroch

  • 24 ноября 2018, 20:12
0
Спасибо Андрей. Завтра погоняю.
avatar

GAWroch

  • 19 ноября 2018, 22:05
0
Примерно так. Профит закрытых позиций вычитаем из заданного профита, по достижении которого и закрываем цепочку.
Спасибо.
avatar

GAWroch

  • 12 ноября 2018, 18:05
0
Спасибо Андрей. Только добрался до компа, буду тестить. )
avatar

GAWroch

  • 22 августа 2018, 13:21
0
От заморочек с подтверждением сигнала решил отказаться. Пробовал различные варианты фильтрации ложных сигналов при сильном тренде — толку «0». Просто работаем при пересечении уровней.
avatar

GAWroch

  • 18 августа 2018, 14:21
0
Привет Андрей и спасибо за работу, хоть и не законченную пока. Мне кажется будет проще собрать советник на индикаторе «CCI_smoothed». Заранее извиняюсь, позволил себе внести изменения в твой код, так для тебя должно быть понятнее. Трейлинг можно убрать, сделки закрываются противоположным сигналом. Вне рабочего времени сделки открываться не должны, но открытые — сопровождаются и закрываются, при наступлении условий.
<code>
//+------------------------------------------------------------------+
//|                                                      Smurfik.mq4 |
//|                                              Copyright 2018, AM2 |
//|                                      http://www.forexsystems.biz |
//+------------------------------------------------------------------+
#property copyright "Copyright 2018, AM2"
#property link      "http://www.forexsystems.biz"
#property version   "1.00"
#property strict

//--- Inputs
extern double Lots       = 0.1;      // лот
extern double KLot       = 1;        // умножение лота
extern double MaxLot     = 5;        // максимальный лот
extern int StopLoss      = 2000;     // лось
extern int TakeProfit    = 3000;     // язь
extern int StartHour     = 0;        // час начала торговли
extern int StartMin      = 30;       // минута начала торговли
extern int EndHour       = 23;       // час окончания торговли
extern int EndMin        = 30;       // минута окончания торговли
extern int Slip          = 30;       // реквот
extern int Shift         = 1;        // на каком баре сигнал индикатора
extern int Magic         = 123;      // магик

extern string IndName    = "CCI_smoothed";
input int                   CCI_Period            = 14;
input ENUM_APPLIED_PRICE    CCI_Price             = 0;
input int                   Period_Smoothed       = 3;
input ENUM_MA_METHOD        MA_Method             = 0;
extern double               cci_buy_level         = -100;
extern double               cci_sell_level        = 100;

//+------------------------------------------------------------------+
//| Expert initialization function                                   |
//+------------------------------------------------------------------+
int OnInit()
  {
//---
   Comment("");
//---
   return(INIT_SUCCEEDED);
  }
//+------------------------------------------------------------------+
//| Expert deinitialization function                                 |
//+------------------------------------------------------------------+
void OnDeinit(const int reason)
  {
   Comment("");
  }

bool isTradeTimeInt(int hb=0,int mb=0,int he=0,int me=0)
  {
   datetime db, de;           // Время начала и окончания работы
   int      hc;               // Часы текущего времени торгового сервера

   db=StrToTime(TimeToStr(TimeCurrent(), TIME_DATE)+" "+(string)hb+":"+(string)mb);
   de=StrToTime(TimeToStr(TimeCurrent(), TIME_DATE)+" "+(string)he+":"+(string)me);
   hc=TimeHour(TimeCurrent());

   if(db>=de)
     {
      if(hc>=he) de+=24*60*60; else db-=24*60*60;
     }

   if(TimeCurrent()>=db && TimeCurrent()<=de) return(True);
   else return(False);
  }
//+------------------------------------------------------------------+
//|                                                                  |
//+------------------------------------------------------------------+
void PutOrder(int type,double price)
  {
   int r=0;
   color clr=Green;
   double sl=0,tp=0;

   if(type==1 || type==3 || type==5)
     {
      clr=Red;
      if(StopLoss>0) sl=NormalizeDouble(price+StopLoss*Point,Digits);
      if(TakeProfit>0) tp=NormalizeDouble(price-TakeProfit*Point,Digits);
     }

   if(type==0 || type==2 || type==4)
     {
      clr=Blue;
      if(StopLoss>0) sl=NormalizeDouble(price-StopLoss*Point,Digits);
      if(TakeProfit>0) tp=NormalizeDouble(price+TakeProfit*Point,Digits);
     }

   r=OrderSend(NULL,type,Lot(),NormalizeDouble(price,Digits),Slip,sl,tp,"",Magic,0,clr);
   return;
  }
//+------------------------------------------------------------------+
//|                                                                  |
//+------------------------------------------------------------------+
int CountTrades()
  {
   int count=0;
   for(int i=OrdersTotal()-1;i>=0;i--)
     {
      if(OrderSelect(i,SELECT_BY_POS,MODE_TRADES))
        {
         if(OrderSymbol()==Symbol() && OrderMagicNumber()==Magic)
           {
            if(OrderType()<2) count++;
           }
        }
     }
   return(count);
  }
//+------------------------------------------------------------------+
//|                                                                  |
//+------------------------------------------------------------------+
void OpenPos()
  {
   double blu = iCustom(NULL,0,IndName,CCI_Period,CCI_Price,Period_Smoothed,MA_Method,cci_buy_level,cci_sell_level,0,Shift);
   double red = iCustom(NULL,0,IndName,CCI_Period,CCI_Price,Period_Smoothed,MA_Method,cci_buy_level,cci_sell_level,1,Shift);

   if(blu>0)
     {
      PutOrder(0,Ask);
     }

   if(red>0)
     {
      PutOrder(1,Bid);
     }
  }
//+------------------------------------------------------------------+
//|                                                                  |
//+------------------------------------------------------------------+
void ClosePos()
  {
   double blu = iCustom(NULL,0,IndName,CCI_Period,CCI_Price,Period_Smoothed,MA_Method,cci_buy_level,cci_sell_level,0,Shift);
   double red = iCustom(NULL,0,IndName,CCI_Period,CCI_Price,Period_Smoothed,MA_Method,cci_buy_level,cci_sell_level,1,Shift);

   if(red>0)
     {
      CloseAll(0);
     }

   if(blu>0)
     {
      CloseAll(1);
     }
  }
//+------------------------------------------------------------------+
//|                                                                  |
//+------------------------------------------------------------------+
double Lot()
  {
   double lot=Lots;
   for(int i=OrdersHistoryTotal()-1;i>=0;i--)
     {
      if(OrderSelect(i,SELECT_BY_POS,MODE_HISTORY))
        {
         if(OrderSymbol()==Symbol() && OrderMagicNumber()==Magic)
           {
            if(OrderProfit()>0) break;
            if(OrderProfit()<0)
              {
               lot=OrderLots()*KLot;
               break;
              }
           }
        }
     }
   if(lot>MaxLot)lot=Lots;
   return(lot);
  }
//+------------------------------------------------------------------+
//|                                                                  |
//+------------------------------------------------------------------+
void Trailing()
  {
   bool mod;
   for(int i=OrdersTotal()-1;i>=0;i--)
     {
      if(OrderSelect(i,SELECT_BY_POS,MODE_TRADES))
        {
         if(OrderSymbol()==Symbol() && OrderMagicNumber()==Magic)
           {
            if(OrderType()==OP_BUY)
              {
               if(Bid-OrderOpenPrice()>TrailingStop*Point)
                 {
                  if(OrderStopLoss()<Bid-TrailingStop*Point)
                    {
                     mod=OrderModify(OrderTicket(),OrderOpenPrice(),Bid-TrailingStop*Point,OrderTakeProfit(),0,Yellow);
                     return;
                    }
                 }
              }

            if(OrderType()==OP_SELL)
              {
               if((OrderOpenPrice()-Ask)>TrailingStop*Point)
                 {
                  if((OrderStopLoss()>(Ask+TrailingStop*Point)) || (OrderStopLoss()==0))
                    {
                     mod=OrderModify(OrderTicket(),OrderOpenPrice(),Ask+TrailingStop*Point,OrderTakeProfit(),0,Yellow);
                     return;
                    }
                 }
              }
           }
        }
     }
  }
//+------------------------------------------------------------------+
//|                                                                  |
//+------------------------------------------------------------------+
void CloseAll(int ot=-1)
  {
   bool cl;
   for(int i=OrdersTotal()-1;i>=0;i--)
     {
      if(OrderSelect(i,SELECT_BY_POS,MODE_TRADES))
        {
         if(OrderSymbol()==Symbol() && OrderMagicNumber()==Magic)
           {
            if(OrderType()==0 && (ot==0 || ot==-1))
              {
               RefreshRates();
               cl=OrderClose(OrderTicket(),OrderLots(),NormalizeDouble(Bid,Digits),Slip,White);
              }
            if(OrderType()==1 && (ot==1 || ot==-1))
              {
               RefreshRates();
               cl=OrderClose(OrderTicket(),OrderLots(),NormalizeDouble(Ask,Digits),Slip,White);
              }
           }
        }
     }
  }
//+------------------------------------------------------------------+
//| Expert tick function                                             |
//+------------------------------------------------------------------+
void OnTick()
  {
   double blu = iCustom(NULL,0,IndName,CCI_Period,CCI_Price,Period_Smoothed,MA_Method,cci_buy_level,cci_sell_level,0,Shift);
   double red = iCustom(NULL,0,IndName,CCI_Period,CCI_Price,Period_Smoothed,MA_Method,cci_buy_level,cci_sell_level,1,Shift);

   if(CountTrades()<1 && isTradeTimeInt(StartHour,StartMin,EndHour,EndMin)) OpenPos();
   else ClosePos();

   if(BULevel>0) BU();
   if(TrailingStop>0) Trailing();

   Comment("\n blu: ",blu,
           "\n red: ",red);
  }
//+------------------------------------------------------------------+
</code>

Ещё раз извиняюсь, если поступаю не корректно. С уважением Вячеслав.
avatar

GAWroch

  • 18 августа 2018, 14:12
0
Заранее благодарен Андрей. Возможно ТЗ изложил несколько сумбурно. Уточню, при необходимости.
avatar

GAWroch

  • 14 августа 2018, 18:25