Trend Intensity Index という指標(2) シグナルを付加
公開日:
:
最終更新日:2015/02/24
日記
以前の記事『Trend Intensity Index という指標』で紹介したインディケーターもシグナルを表示するように改変してみました。
シグナルというのは指標の移動平均をとったもので、平滑されている分、遅れて動くので、指標とのクロスで売買のシグナルにすることができるのです。
サブウィンドウの上が TII_RLH.ex4(オリジナル)で、下が私の改良したシグナル付加版。
下のシグナル付加版で赤と水色の線のクロスしたところ(平行して重なったところではない)が買いまたは売りとなります。
シグナルがないと指標の反転を判断するのに数値で比べないといけないのですが、シグナルがあるとクロスの有無で判定でき、より簡単にプログラムできるという裏事情があるのです。
関連記事
- Trend Intensity Index という指標
- スローな TII にしてくれ
- Trend Intensity Index を使った EA
- Trend Intensity Index を使った EA(2) Damiani filter版
プログラムソース
#property copyright "Copyright ゥ 2006, Robert Hill " #property link "http://www.metaquotes.net/" //---- indicator settings #property indicator_separate_window #property indicator_buffers 2 #property indicator_color1 Red #property indicator_color2 Aqua #property indicator_width1 2 #property indicator_width2 1 //---- extern int Major_Period=60; extern int Major_MaMode=1; //0=sma, 1=ema, 2=smma, 3=lwma, 4=lsma extern int Major_PriceMode=0;//0=close, 1=open, 2=high, 3=low, 4=median(high+low)/2, 5=typical(high+low+close)/3, 6=weighted(high+low+close+close)/4 extern int Minor_Period=30; extern color LevelColor=Silver; extern int BuyLevel=20; extern int MidLevel=50; extern int SellLevel=80; extern int SigPeriod = 8; //---- buffers double ma[]; double ma_dev[]; double tii[]; double tiis[]; //+------------------------------------------------------------------+ //| Custom indicator initialization function | //+------------------------------------------------------------------+ int init() { //---- drawing settings IndicatorBuffers(4); SetIndexStyle(0,DRAW_LINE); SetIndexDrawBegin(0,Major_Period); IndicatorDigits(MarketInfo(Symbol(),MODE_DIGITS)+2); //---- 3 indicator buffers mapping SetIndexBuffer(0,tii); SetIndexBuffer(1,tiis); SetIndexStyle(1,DRAW_LINE); SetIndexDrawBegin(1,Major_Period); SetIndexBuffer(2,ma_dev); SetIndexBuffer(3,ma); //---- name for DataWindow and indicator subwindow label IndicatorShortName(" TII , Major_Period ( "+Major_Period+" ) , Minor_Period ( "+Minor_Period+" ), "); SetLevelStyle(STYLE_DASH,1,LevelColor); SetLevelValue(0,BuyLevel); SetLevelValue(1,MidLevel); SetLevelValue(2,SellLevel); //---- initialization done return(0); } //+------------------------------------------------------------------+ //| LSMA with PriceMode | //| PrMode 0=close, 1=open, 2=high, 3=low, 4=median(high+low)/2, | //| 5=typical(high+low+close)/3, 6=weighted(high+low+close+close)/4 | //+------------------------------------------------------------------+ double LSMA(int Rperiod,int prMode,int shift) { int i; double sum,pr; int length; double lengthvar; double tmp; double wt; //---- length=Rperiod; sum=0; for(i=length; i>=1;i--) { lengthvar=length+1; lengthvar/=3; tmp=0; switch(prMode) { case 0: pr=Close[length-i+shift];break; case 1: pr=Open[length-i+shift];break; case 2: pr=High[length-i+shift];break; case 3: pr=Low[length-i+shift];break; case 4: pr=(High[length-i+shift] + Low[length-i+shift])/2;break; case 5: pr=(High[length-i+shift] + Low[length-i+shift] + Close[length-i+shift])/3;break; case 6: pr=(High[length-i+shift] + Low[length-i+shift] + Close[length-i+shift] + Close[length-i+shift])/4;break; } tmp =(i - lengthvar)*pr; sum+=tmp; } wt=sum*6/(length*(length+1)); //---- return(wt); } //+------------------------------------------------------------------+ //| | //+------------------------------------------------------------------+ int start() { int i,j,limit; double sdPos,sdNeg; 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+MathMax(Major_Period,Minor_Period); //---- for(i=limit; i>=0; i--) { if(Major_MaMode==4) { ma[i]=LSMA(Major_Period,Major_PriceMode,i); } else { ma[i]=iMA(NULL,0,Major_Period,0,Major_MaMode,Major_PriceMode,i); } ma_dev[i]=Close[i]-ma[i]; } //========== COLOR CODING =========================================== for(i=0; i<=limit; i++) { sdPos=0; sdNeg=0; for(j=i;j<i+Minor_Period;j++) { if(ma_dev[j]>=0) sdPos=sdPos+ma_dev[j]; if(ma_dev[j]<0) sdNeg=sdNeg+ma_dev[j]; } tii[i]=100*sdPos/(sdPos-sdNeg); } for(i=0; i<=limit; i++) { tiis[i] = iMAOnArray(tii,0,SigPeriod,0,MODE_EMA,i); } //---- return(0); } //+------------------------------------------------------------------+<>
###
関連記事
-
カーナビの効用 盆休み
昨日は神戸に車で墓参り。 カーナビも持っていないのに、渋滞の反対車線をすいすい。
-
【ふるさと納税】佐賀県産いちご"さがほのか" 270g×8
佐賀県上峰町 (かみみねちょう) に 10000円寄付するともらえます。 上記は 4パ
-
ボルテスVがフィリピンでえらいことになっている件
1977年~78年に日本でテレビ放送されたロボットアニメ「超電磁マシーン ボルテスV(ファイブ)」で
-
【ヤフオク】 ベニスの風景 リトグラフ サイン入り 入手
1000円+送料で落札。 タイトル不明です。 ゴンドラの浮かぶ運河とドームのある
-
【ふるさと納税】トミカ ビルドシティセット / 栃木県壬生町
栃木県の壬生町(みぶまち)に 20000円寄付するともらえます。 トミカタウンビル
-
【ヤフオク】 オスロノルウェイⅠ 高野謙 リトグラフ 落札
昨日に続いて、二科会会員の高野謙氏のリトグラフを落札。 200枚中の 3枚目。
-
【万年筆】 中華万年筆 カンガルー Kaigelu 336 ブルー 中字
カンガルー(Kaigelu)ブランドでは Kaigelu 316 というセルロイド風の美軸万
-
【ふるさと納税】とちおとめ 280g×8パック 栃木県壬生町
栃木県壬生町 (みぶまち) に 10000円寄付するともらえます。 残念ながら今シー
-
セブンイレブン冷凍食品 担々麺
いつもはファミマで汁なし担々麺を買うのですが、今日はセブンイレブンで普通の担々麺を買ってみま
- PREV
- 究極のテクニカル分析 / 黒岩 泰
- NEXT
- スローな TII にしてくれ