Participe de nossa página de fãs
Coloque um link para ele, e permita que outras pessoas também o avaliem
Avalie seu funcionamento no terminal MetaTrader 5
Fast iBarShift and Bars for MT5 - biblioteca para MetaTrader 5
- Visualizações:
- 1258
- Avaliação:
- Publicado:
- 2018.07.23 09:52
- Precisa de um robô ou indicador baseado nesse código? Solicite-o no Freelance Ir para Freelance
Existem muitas versões das funções do iBarShift para a MetaTrader 5. No entanto, esta versão é especialmente simples, rápida e correta.
int iBarShift(const string Symb,const ENUM_TIMEFRAMES TimeFrame,datetime time,bool exact=false) { int Res=iBars(Symb,TimeFrame,time+1,UINT_MAX); if(exact) if((TimeFrame!=PERIOD_MN1 || time>TimeCurrent()) && Res==iBars(Symb,TimeFrame,time-PeriodSeconds(TimeFrame)+1,UINT_MAX)) return(-1); return(Res); }
A partir da publicação deste código, a função integrada Bars usada nesta função iBarShift tem um bug que se manifesta no programa como um atraso por mais de 10 segundos. Basicamente, isso acontece quando a função Bars precisa retornar zero.
Por exemplo, na execução do código:
Print("1"); Print(Bars(_Symbol,PERIOD_D1,D'2018.05.02 01:58:03',D'2018.05.02 12:56:11')); Print("2");
"2" será impresso em mais de 10 segundos após o "1".
Eu recomendo que você substitua a função Bars padrão em seus programas com esta função iBars, especialmente se você observar atrasos estranhos por 10 segundos ou mais.
A função iBars contida neste arquivo de include corrige essa inconveniência e funciona muito mais rápido devido ao algoritmo salvar os valores anteriores.
int iBars(string symbol_name,ENUM_TIMEFRAMES timeframe,datetime start_time,datetime stop_time) // stop_time > start_time { static string LastSymb=NULL; static ENUM_TIMEFRAMES LastTimeFrame=0; static datetime LastTime=0; static datetime LastTime0=0; static int PerSec=0; static int PreBars=0,PreBarsS=0,PreBarsF=0; static datetime LastBAR=0; static datetime LastTimeCur=0; static bool flag=true; static int max_bars=TerminalInfoInteger(TERMINAL_MAXBARS); datetime TimeCur; if (timeframe==0) timeframe=_Period; const bool changeTF=LastTimeFrame!=timeframe; const bool changeSymb=LastSymb!=symbol_name; const bool change=changeTF || changeSymb || flag; LastTimeFrame=timeframe; LastSymb=symbol_name; if(changeTF) PerSec=::PeriodSeconds(timeframe); if(PerSec==0) { flag=true; return(0);} if(stop_time<start_time) { TimeCur=stop_time; stop_time=start_time; start_time=TimeCur; } if(changeSymb) { if(!SymbolInfoInteger(symbol_name,SYMBOL_SELECT)) { SymbolSelect(symbol_name,true); ChartRedraw(); } } TimeCur=TimeCurrent(); if(timeframe==PERIOD_W1) TimeCur-=(TimeCur+345600)%PerSec; // 01.01.1970 - Thursday. Minus 4 days. if(timeframe<PERIOD_W1) TimeCur-=TimeCur%PerSec; if(start_time>TimeCur) { flag=true; return(0);} if(timeframe==PERIOD_MN1) { MqlDateTime dt; TimeToStruct(TimeCur,dt); TimeCur=dt.year*12+dt.mon; } if(changeTF || changeSymb || TimeCur!=LastTimeCur) LastBAR=(datetime)SeriesInfoInteger(symbol_name,timeframe,SERIES_LASTBAR_DATE); LastTimeCur=TimeCur; if(start_time>LastBAR) { flag=true; return(0);} datetime tS,tF=0; if(timeframe==PERIOD_W1) tS=start_time-(start_time+345599)%PerSec-1; else if(timeframe<PERIOD_MN1) tS=start_time-(start_time-1)%PerSec-1; else // PERIOD_MN1 { MqlDateTime dt; TimeToStruct(start_time-1,dt); tS=dt.year*12+dt.mon; } if(change || tS!=LastTime) { PreBarsS=Bars(symbol_name,timeframe,start_time,UINT_MAX); LastTime=tS;} if(stop_time<=LastBAR) { if(PreBarsS>=max_bars) PreBars=Bars(symbol_name,timeframe,start_time,stop_time); else { if(timeframe<PERIOD_W1) tF=stop_time-(stop_time)%PerSec; else if(timeframe==PERIOD_W1) tF=stop_time-(stop_time+345600)%PerSec; else // PERIOD_MN1 { MqlDateTime dt0; TimeToStruct(stop_time-1,dt0); tF=dt0.year*12+dt0.mon; } if(change || tF!=LastTime0) { PreBarsF=Bars(symbol_name,timeframe,stop_time+1,UINT_MAX); LastTime0=tF; } PreBars=PreBarsS-PreBarsF; } } else PreBars=PreBarsS; flag=false; return(PreBars); } //+------------------------------------------------------------------+ int iBars(string symbol_name,ENUM_TIMEFRAMES timeframe) {return(Bars(symbol_name,timeframe));} //+------------------------------------------------------------------+
Traduzido do russo pela MetaQuotes Ltd.
Publicação original: https://www.mql5.com/ru/code/20417
Um Alligator baseado no indicador VAMA.
VAMAUma Média Móvel simples de volumes.
A Média Móvel de Alan Hull é uma média móvel sem atraso.
sDotToLineDistUm script que calcula a distância entre um ponto e uma linha.