這是一款改編ZigZag未來MT4指標
//+------------------------------------------------------------------+
//| NonLagZigZag_v2.mq4 |
//| Copyright ?2006, TrendLaboratory |
//| http://finance.groups.yahoo.com/group/TrendLaboratory |
//| E-mail: [email protected] |
//+------------------------------------------------------------------+
#property copyright "Copyright ?2006, TrendLaboratory"
#property link "http://finance.groups.yahoo.com/group/TrendLaboratory"
//----
#property indicator_chart_window
#property indicator_buffers 1
//----
#property indicator_color1 Gold
#property indicator_width1 2
//---- input parameters
extern int Price =0; //Apply to Price(0-Close;1-Open;2-High;3-Low;4-Median price;5-Typical price;6-Weighted Close)
extern int Length =100; //Period of NonLagMA
extern double PctFilter =2; //Dynamic filter in decimals
//----
double ZZBuffer[];
double MABuffer[];
double trend[];
double Del[];
double AvgDel[];
//----
int ilow, ihigh, nlow, nhigh, prevnhigh,prevnlow, BarsBack;
double alfa[];
datetime lotime,hitime;
int i, Phase, Len, Cycle=4, Back=0;
double Coeff, beta, t, Sum, Weight, g;
double pi=3.1415926535;
//+------------------------------------------------------------------+
//| Custom indicator initialization function |
//+------------------------------------------------------------------+
int init()
{
IndicatorBuffers(5);
SetIndexStyle(0,DRAW_SECTION);
SetIndexBuffer(0,ZZBuffer);
SetIndexBuffer(1,MABuffer);
SetIndexBuffer(2,trend);
SetIndexBuffer(3,Del);
SetIndexBuffer(4,AvgDel);
string short_name;
//---- indicator line
IndicatorDigits(MarketInfo(Symbol(),MODE_DIGITS));
//---- name for DataWindow and indicator subwindow label
short_name="NonLagZigZag("+Length+")";
IndicatorShortName(short_name);
SetIndexLabel(0,"NonLagZigZag");
//----
SetIndexEmptyValue(0,0.0);
SetIndexDrawBegin(0,Length*Cycle+Length);
//----
Coeff= 3*pi;
Phase=Length-1;
Len=Length*Cycle + Phase;
ArrayResize(alfa,Len);
Weight=0;
for(i=0;i<Len-1;i++)
{
if (i<=Phase-1) t=1.0*i/(Phase-1);
else t=1.0 + (i-Phase+1)*(2.0*Cycle-1.0)/(Cycle*Length-1.0);
beta=MathCos(pi*t);
g=1.0/(Coeff*t+1);
if (t<=0.5)g=1;
alfa[i]=g * beta;
Weight+=alfa[i];
}
//----
return(0);
}
//+------------------------------------------------------------------+
//| NonLagZigZag_v2 |
//+------------------------------------------------------------------+
int start()
{
int i,shift,limit;
double price,smin,smax;
int counted_bars = IndicatorCounted();
if(counted_bars < 0) return(-1);
if(counted_bars > 0) counted_bars--;
limit = Bars - counted_bars;
if(counted_bars==0) limit-=1+1+MathMax(Len,Length);
for(shift=limit;shift>=0;shift--)
{
Sum=0;
for(i=0;i<=Len-1;i++)
{
price=iMA(NULL,0,1,0,3,Price,i+shift);
Sum+=alfa[i]*price;
}
if (Weight > 0) MABuffer[shift]=Sum/Weight;
Del[shift]=MathAbs(MABuffer[shift] - MABuffer[shift+1]);
//----
double sumdel=0;
for(i=0;i<=Length-1;i++) sumdel+=Del[shift+i];
AvgDel[shift]=sumdel/Length;
//----
double sumpow=0;
for(i=0;i<=Length-1;i++) sumpow+=MathPow(Del[shift+i]-AvgDel[shift+i],2);
double StdDev=MathSqrt(sumpow/Length);
double Filter=PctFilter * StdDev;
if (Filter < Point) Filter=Point;
if(MathAbs(MABuffer[shift]-MABuffer[shift+1]) < Filter)MABuffer[shift]=MABuffer[shift+1];
//----
trend[shift]=trend[shift+1];
if (MABuffer[shift]-MABuffer[shift+1] > Filter) trend[shift]= 1;
if (MABuffer[shift+1]-MABuffer[shift] > Filter) trend[shift]=-1;
if(trend[shift]>0)
{
if(trend[shift]!=trend[shift+1])
{
ilow=LowestBar(iBarShift(NULL,0,hitime,FALSE)-shift,shift);
lotime=Time[ilow];
ZZBuffer[ilow]=Low[ilow];
}
else
if (shift==0)
{
int hilen=iBarShift(NULL,0,lotime,FALSE);
nhigh=HighestBar(hilen,0);
ZZBuffer[nhigh]=High[nhigh];
if (nhigh== 0) for(i=hilen-1;i>=1;i--) ZZBuffer[i]=0;
if (nhigh > 0) for(i=nhigh-1;i>=0;i--) ZZBuffer[i]=0;
}
}
if (trend[shift]<0)
{
if(trend[shift]!=trend[shift+1])
{
ihigh=HighestBar(iBarShift(NULL,0,lotime,FALSE)-shift,shift);
hitime=Time[ihigh];
ZZBuffer[ihigh]=High[ihigh];
}
else
if (shift==0)
{
int lolen=iBarShift(NULL,0,hitime,FALSE);
nlow=LowestBar(lolen,0);
ZZBuffer[nlow]=Low[nlow];
if (nlow==0) for(i=lolen-1;i>=1;i--) ZZBuffer[i]=0;
if (nlow >0) for(i=nlow-1;i>=0;i--) ZZBuffer[i]=0;
}
}
}
return(0);
}
//+------------------------------------------------------------------+
//| |
//+------------------------------------------------------------------+
int LowestBar(int len,int k)
{
double min=10000000;
int lobar;
//----
for(int i=k+len-1;i>=k;i--)
if(Low[i] < min) {min=Low[i]; lobar=i;}
if(len<=0) lobar=k;
return(lobar);
}
//+------------------------------------------------------------------+
//| |
//+------------------------------------------------------------------+
int HighestBar(int len,int k)
{
double max=-10000000;
int hibar;
for(int i=k+len-1;i>=k;i--)
if(High[i] > max) {max=High[i]; hibar=i;}
if(len<=0) hibar=k;
return(hibar);
}
//+------------------------------------------------------------------+
外_匯_邦 WaiHuiBang.comstorj是一個去中心化存儲網絡,代幣是基於以太坊發行的erc20的token,嚴格的說storj並不是一個區塊鏈項目,也不是區塊鏈的共識
近日,全國首張區塊鏈電子發票在廣東深圳國貿旋轉餐廳開出。據悉,這張區塊鏈電子發票是由深圳市稅務局主導、騰訊提供底層技術而共同打造的。深圳市
據當地新聞社Gubernia.com報道,俄羅斯Khabarovsk縣一政府網站遭黑客惡意利用,訪問者的系統處理能力將被用來挖礦。Gube
幾周前,多個廣泛使用的以太坊多重簽名錢包被黑了,被盜以太坊資產達3200萬美元。另有1.6億美元的資產被一群白帽黑客搶先保護起來。&nbs
國家能源局8日發布關於征求進一步推進電力現貨市場建設試點工作的意見函,提出有序引導清潔能源消納的現貨交易機制,要求加快研究指定現貨
黃金期貨是上海期貨交易所上市的品種,交易代碼是AU,交易單位是1000克/手,最小變動價位是0.02元/克,黃
目標達到。什麼叫目標達到?神光公司有一個加倍取整的理論,這個方法在股市中還沒有被廣泛地應用,而一種理論掌握的人越少,可靠性就
來自中國銀行官網回答:動態口令牌是一種內置電源、密碼生成芯片和顯示屏、根據專門的算法每隔一定時間自動更新
最佳答案: 筆記本電腦的省電模式是需要在電池的頁面裡進行操作的。具體方法如下:1、點擊電腦桌面又下角