Где моя ошибка??? - страница 3

 
Сергей Дыбленко:

Да не скажи!.....писал я его из кусков разных советников а не с нуля, тоисть методом тыка!

Большинство роботов на 80% собираются из кусков. Основные функции готовы. Твое дело логику работы воспроизвести - когда открывать, когда закрывать, где и когда усреднять (если надо).

 
Evgeniy Zhdan:

Большинство роботов на 80% собираются из кусков. Основные функции готовы. Твое дело логику работы воспроизвести - когда открывать, когда закрывать, где и когда усреднять (если надо).

я хочу знать что и куда нужно втыкать а я еще этого не знаю!
 
Ребята, всем большое спасибо за помощь!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
 
Сергей Дыбленко:
Ребята, всем большое спасибо за помощь!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

я тут с твоими индикаторами и настройками твоими, подогнал эксперт

//+------------------------------------------------------------------+
//|                                              Сергей Дыбленко.mq4 |
//|                        Copyright 2020, MetaQuotes Software Corp. |
//|                                             https://www.mql5.com |
//+------------------------------------------------------------------+
#property copyright   "2005-2020, MetaQuotes Software Corp."
#property link        "http://www.mql4.com"
//--- Inputs
input double Lots             = 0.1;      // Lot
input double MaximumRisk      = 0.02;     // MaximumRisk
input double DecreaseFactor   = 3;        // DecreaseFactor
input double TakeProfit       = 500;      // Take Profit
input double TrailingStop     = 300;      // Фиксированный размер трала
input double TrailingStep     = 50;       // Шаг трала
//--input string short_name       = "BrainTrend1Sig"; // Name Indicators
input bool   InpOnlyOne       = false;    // Close opposite
input bool   ObjRevers        = false;    // Revers
//-------
bool   AllPositions     = false;          // Управлять всеми позициями
bool   ProfitTrailing   = true;           // Тралить только профит
bool   UseSound         = true;           // Использовать звуковой сигнал
string NameFileSound    = "expert.wav";   // Наименование звукового файла
//+------------------------------------------------------------------+
//|                                                                  |
//+------------------------------------------------------------------+
void CheckForClose(void)
  {
//---   double MacdCurrent,SignalCurrent;
   int    cnt,total;
//---
   if(Bars<100)
     {
      Print("bars less than 100");
      return;
     }
   if(TakeProfit<10)
     {
      Print("TakeProfit less than 10");
      return;
     }
//--- to simplify the coding and speed up access data are put into internal variables
//---   MacdCurrent=iCustom(NULL,0,short_name,MODE_MAIN,1);
//---   SignalCurrent=iCustom(NULL,0,short_name,MODE_SIGNAL,1);

   double MA0  = iMA(NULL,0,14,0,MODE_EMA,PRICE_CLOSE,0);
   double MA1  = iMA(NULL,0,14,0,MODE_EMA,PRICE_CLOSE,1);

   double buy_level  = iMA(NULL,0,104,0,MODE_EMA,PRICE_CLOSE,0);
   double sell_level  = iMA(NULL,0,104,0,MODE_EMA,PRICE_CLOSE,1);

   total=OrdersTotal();
   if(total<1)
     {
      //--- no opened orders identified
      if(AccountFreeMargin()<(1000*LotsOptimized()))
        {
         Print("We have no money. Free Margin = ",AccountFreeMargin());
         return;
        }
     }
//--- it is important to enter the market correctly, but it is more important to exit it correctly...
   for(cnt=0; cnt<total; cnt++)
     {
      if(!OrderSelect(cnt,SELECT_BY_POS,MODE_TRADES))
         continue;
      if(OrderType()<=OP_SELL &&   // check for opened position
         OrderSymbol()==Symbol())  // check for symbol
        {
         //--- long position is opened
         if(OrderType()==OP_BUY)
           {
            if(!InpOnlyOne)
              {
               //--- should it be closed?
               if((!ObjRevers && MA0 < sell_level && MA1 > sell_level) || (ObjRevers && MA0 > buy_level && MA1 < buy_level))
                  //---if((ObjRevers && MacdCurrent<SignalCurrent) || (!ObjRevers && MacdCurrent>SignalCurrent))
                 {
                  //--- close order and exit
                  if(!OrderClose(OrderTicket(),OrderLots(),Bid,3,Violet))
                     Print("OrderClose error ",GetLastError());
                  return;
                 }
              }
           }
         else // go to short position
           {
            if(!InpOnlyOne)
              {
               //--- should it be closed?
               if((!ObjRevers && MA0 > buy_level && MA1 < buy_level) || (ObjRevers && MA0 < sell_level && MA1 > sell_level))
                  //---if((ObjRevers && MacdCurrent>SignalCurrent) || (!ObjRevers && MacdCurrent<SignalCurrent))
                 {
                  //--- close order and exit
                  if(!OrderClose(OrderTicket(),OrderLots(),Ask,3,Violet))
                     Print("OrderClose error ",GetLastError());
                  return;
                 }
              }
           }
        }
     }
//---
  }
//+------------------------------------------------------------------+
//| Calculate open positions                                         |
//+------------------------------------------------------------------+
int CalculateCurrentOrders(string symbol)
  {
   int buys=0,sells=0;
//---
   for(int i=-1; i<OrdersTotal(); i++)
     {
      if(OrderSelect(i,SELECT_BY_POS,MODE_TRADES)==false)
         break;
      if(OrderSymbol()==Symbol() && OrderMagicNumber()==16384)
        {
         if(OrderType()==OP_BUY)
            buys++;
         if(OrderType()==OP_SELL)
            sells++;
        }
     }
//--- return orders volume
   if(buys>0)
      return(buys);
   else
      return(-sells);
  }
//+------------------------------------------------------------------+
//| Calculate optimal lot size                                       |
//+------------------------------------------------------------------+
double LotsOptimized()
  {
   double lot=Lots;
   int    orders=HistoryTotal();     // history orders total
   int    losses=0;                  // number of losses orders without a break
//--- select lot size
   lot=NormalizeDouble(AccountFreeMargin()*MaximumRisk/1000.0,1);
//--- calcuulate number of losses orders without a break
   if(DecreaseFactor>0)
     {
      for(int i=orders-1; i>=0; i--)
        {
         if(OrderSelect(i,SELECT_BY_POS,MODE_HISTORY)==false)
           {
            Print("Error in history!");
            break;
           }
         if(OrderSymbol()!=Symbol() || OrderType()>OP_SELL)
            continue;
         //---
         if(OrderProfit()>0)
            break;
         if(OrderProfit()<0)
            losses++;
        }
      if(losses>1)
         lot=NormalizeDouble(lot-lot*losses/DecreaseFactor,1);
     }
//--- return lot size
   if(lot<0.1)
      lot=0.1;
   return(lot);
  }
//+------------------------------------------------------------------+
//| Check for open order conditions                                  |
//+------------------------------------------------------------------+
void CheckForOpen()
  {
//---   double MacdCurrent,SignalCurrent;
   int    res;
//--- go trading only for first tiks of new bar
   if(Volume[0]>1)
      return;
//--- get Moving Average
//---   MacdCurrent=iCustom(NULL,0,short_name,MODE_MAIN,1);
//---   SignalCurrent=iCustom(NULL,0,short_name,MODE_SIGNAL,1);

   double MA0  = iMA(NULL,0,14,0,MODE_EMA,PRICE_CLOSE,0);
   double MA1  = iMA(NULL,0,14,0,MODE_EMA,PRICE_CLOSE,1);

   double buy_level  = iMA(NULL,0,104,0,MODE_EMA,PRICE_CLOSE,0);
   double sell_level  = iMA(NULL,0,104,0,MODE_EMA,PRICE_CLOSE,1);

//--- sell conditions
   if((!ObjRevers && MA0 < sell_level && MA1 > sell_level) || (ObjRevers && MA0 > buy_level && MA1 < buy_level))
      //---if((ObjRevers && MacdCurrent<SignalCurrent) || (!ObjRevers && MacdCurrent>SignalCurrent))
     {
      res=OrderSend(Symbol(),OP_SELL,LotsOptimized(),Bid,3,0,Bid-TakeProfit*Point,"",16384,0,Red);
      return;
     }
//--- buy conditions
   if((!ObjRevers && MA0 > buy_level && MA1 < buy_level) || (ObjRevers && MA0 < sell_level && MA1 > sell_level))
      //---if((ObjRevers && MacdCurrent>SignalCurrent) || (!ObjRevers && MacdCurrent<SignalCurrent))
     {
      res=OrderSend(Symbol(),OP_BUY,LotsOptimized(),Ask,3,0,Ask+TakeProfit*Point,"",16384,0,Green);
      return;
     }
//---
  }
//+------------------------------------------------------------------+
//| OnTick function                                                  |
//+------------------------------------------------------------------+
void OnTick()
  {
//--- check for history and trading
   if(Bars<100 || IsTradeAllowed()==false)
      return;
//--- calculate open orders by current symbol
   if(CalculateCurrentOrders(Symbol())==0)
      CheckForOpen();
   CheckForClose();
   TrailStopOrders();
//---
  }
//+------------------------------------------------------------------+
void TrailStopOrders()
  {
   for(int i=0; i<OrdersTotal(); i++)
     {
      if(OrderSelect(i,SELECT_BY_POS, MODE_TRADES))
        {
         if(AllPositions || OrderSymbol()==Symbol())
           {
            TrailingPositions();
           }
        }
     }
  }
//+------------------------------------------------------------------+
//| Сопровождение позиции простым тралом                             |
//+------------------------------------------------------------------+
void TrailingPositions()
  {
   double pBid,pAsk,pp;

   pp=MarketInfo(OrderSymbol(),MODE_POINT);
   if(OrderType()==OP_BUY)
     {
      pBid=MarketInfo(OrderSymbol(),MODE_BID);
      if(!ProfitTrailing || (pBid-OrderOpenPrice())>TrailingStop*pp)
        {
         if(OrderStopLoss()<pBid-(TrailingStop+TrailingStep-1)*pp)
           {
            ModifyStopLoss(pBid-TrailingStop*pp);
            return;
           }
        }
     }
   if(OrderType()==OP_SELL)
     {
      pAsk=MarketInfo(OrderSymbol(),MODE_ASK);
      if(!ProfitTrailing || OrderOpenPrice()-pAsk>TrailingStop*pp)
        {
         if(OrderStopLoss()>pAsk+(TrailingStop+TrailingStep-1)*pp || OrderStopLoss()==0)
           {
            ModifyStopLoss(pAsk+TrailingStop*pp);
            return;
           }
        }
     }
  }
//+------------------------------------------------------------------+
//| Перенос уровня StopLoss                                          |
//| Параметры:                                                       |
//|   ldStopLoss - уровень StopLoss                                  |
//+------------------------------------------------------------------+
void ModifyStopLoss(double ldStopLoss)
  {
   bool fm;

   fm=OrderModify(OrderTicket(),OrderOpenPrice(),ldStopLoss,OrderTakeProfit(),0,CLR_NONE);
   if(fm && UseSound)
      PlaySound(NameFileSound);
  }
//+------------------------------------------------------------------+
Файлы:
 
Alexsandr San:

я тут с твоими индикаторами и настройками твоими, подогнал эксперт

Спасиб Саш.............завтра протестирую его!
 
Сергей Дыбленко:
Спасиб Саш.............завтра протестирую его!

он почти готов - тебе стоит только индикаторы подбирать - ну и стрелочки подгонять для правильного открытия 

 
Alexsandr San:

он почти готов - тебе стоит только индикаторы подбирать - ну и стрелочки подгонять для правильного открытия 

в этом и все проблема подобрать и впихнуть хороший индикатор!!!!

Причина обращения: