
//+------------------------------------------------------------------+
//| RenkoChannel.mq4 |
//| Copyright 2016, AM2 |
//| http://www.forexsystems.biz |
//+------------------------------------------------------------------+
#property copyright "Copyright 2016, AM2"
#property link "http://www.forexsystems.biz"
#property version "1.00"
#property strict
//--- Inputs
extern double Lots = 0.1; // лот
extern int StopLoss = 500; // лось
extern int TakeProfit = 500; // язь
extern int Slip = 30; // реквот
extern int Magic = 123; // магик
extern string IndName = "TMA-KC";
extern int HalfLength = 48;
extern int MA_MODE = 0;
extern int PRICE_MODE = 0;
extern int ATR_PERIOD = 100;
extern double K = 2.0;
datetime t=0;
//+------------------------------------------------------------------+
//| Expert initialization function |
//+------------------------------------------------------------------+
int OnInit()
{
//---
//---
return(INIT_SUCCEEDED);
}
//+------------------------------------------------------------------+
//| Expert deinitialization function |
//+------------------------------------------------------------------+
void OnDeinit(const int reason)
{
//---
}
//+------------------------------------------------------------------+
//| |
//+------------------------------------------------------------------+
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,Lots,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(OrderType()<2) count++;
}
}
return(count);
}
//+------------------------------------------------------------------+
//| |
//+------------------------------------------------------------------+
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);
}
}
}
}
}
//+------------------------------------------------------------------+
//| |
//+------------------------------------------------------------------+
void OpenPos()
{
double up=iCustom(NULL,0,IndName,HalfLength,MA_MODE,PRICE_MODE,ATR_PERIOD,K,0,1);
double dn=iCustom(NULL,0,IndName,HalfLength,MA_MODE,PRICE_MODE,ATR_PERIOD,K,2,1);
if(t!=Time[0])
{
// покупка
if((Close[1]>Open[1] && Close[2]<Open[2] && Ask<dn) || // цена ниже нижней границы канала плюс разворотный паттерн
(Low[2]<dn && Close[1]>Open[1] && Close[2]<Open[2] && Ask>dn)) // цена выше нижней границы канала плюс разворотный паттерн и касание
{
if(CountTrades()<1) PutOrder(0,Ask);
}
// продажа
if((Close[1]<Open[1] && Close[2]>Open[2] && Bid>up) || // цена выше верхней границы канала плюс разворотный паттерн
(High[2]>up && Close[1]<Open[1] && Close[2]>Open[2] && Bid<up)) // цена ниже верхней границы канала плюс разворотный паттерн и касание
{
if(CountTrades()<1) PutOrder(1,Bid);
}
}
}
//+------------------------------------------------------------------+
//| |
//+------------------------------------------------------------------+
void ClosePos()
{
double up=iCustom(NULL,0,IndName,HalfLength,MA_MODE,PRICE_MODE,ATR_PERIOD,K,0,1);
double dn=iCustom(NULL,0,IndName,HalfLength,MA_MODE,PRICE_MODE,ATR_PERIOD,K,2,1);
//---
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(High[2]>up && Close[1]<Open[1] && Close[2]>Open[2] && Bid<up) // цена ниже верхней границы канала плюс разворотный паттерн и касание
{
CloseAll(0);
}
}
if(OrderType()==OP_SELL)
{
if(Low[2]<dn && Close[1]>Open[1] && Close[2]<Open[2] && Ask>dn) // цена выше нижней границы канала плюс разворотный паттерн и касание
{
CloseAll(1);
}
}
}
}
}
}
//+------------------------------------------------------------------+
//| Expert tick function |
//+------------------------------------------------------------------+
void OnTick()
{
double up=iCustom(NULL,0,IndName,HalfLength,MA_MODE,PRICE_MODE,ATR_PERIOD,K,0,1);
double dn=iCustom(NULL,0,IndName,HalfLength,MA_MODE,PRICE_MODE,ATR_PERIOD,K,2,1);
if(t!=Time[0])
{
if(CountTrades()<1) OpenPos();
else ClosePos();
}
Comment("\n up: ",up,"\n dn: ",dn);
}
//+------------------------------------------------------------------+
Советник открыл короткую позицию, но не закрыл (и сразу же не открыл длинную) после касания цены нижней линии канала и закрытия первого buy-ордера
Сдейте просто и понятно TakeProfit в пунктах и StopLoss в место этой массы неразберихи.
сейчас же он работает только на стандартных настройках и то, не совсем корректно. Он выставляет отложки определенное количество и одновременно с этим открывает такое же количество ордеров…
Начинаю эксперементировать с настройками он выдает разные ошибки и перестает работать.
На рисунке — не ренко-график (H1).
По последнему ТЗ все есть дальнейшие доработки в следующем топике.
AM2