함수설명
DMI(Directional Movement Index) 지표함수
작성방법
DMI(기간)
C
복사
매개변수 설명
•
"기간": Numeric, 최근 N개봉 기간값을 입력
계산
DMPlus = (당일고가-전일고가) > 0 이고
(당일고가-전일고가 > 전일저가-당일저가) 이면
(당일고가-전일고가)이고 아니면 0.
DMMinus = (전일저가-당일저가) > 0 이고
(당일고가-전일고가 < 전일저가-당일저가) 이면
(전일저가-당일저가)이고 아니면 0.
TR = TrueRange값
TRn = TR의 Period 기간 이동평균값
DMnPlus = (+DM)의 Period 기간 이동평균값
DMnMinus = (-DM)의 Period 기간 이동평균값
DIPlus = DMnPlus/TRn
DIMinus = DMnMinus/TRn
DMI = (DiPlus-DIMinus)의 절대값/(DiPlus+DIMinus)*100
활용예시
//인라인함수(수식안에서 만들어 사용하는 함수)
//DIPlus 함수식
Function Infx_DIPlus Numeric
{
Input : Length(NumericSimple) ;
Var : Counter(0), TRange(0), MyRange(Length);
var : PlusDM14(0), PlusDM(0), MinusDM(0);
If CurrentBar == 1 Then
{
MyRange = Length;
Infx_DIPlus = 0;
PlusDM14 = 0;
TRange = 0;
For Counter = 0 To MyRange - 1
{
If High[Counter] - High[Counter+1] < 0 Then
PlusDM = 0;
Else
PlusDM = High[Counter] - High[Counter+1];
If Low[Counter+1] - Low[Counter] < 0 Then
MinusDM = 0;
Else
MinusDM = Low[Counter+1] - Low[Counter];
If MinusDM >= PlusDM Then
PlusDM = 0;
TRange = TRange + TrueRange[Counter];
PlusDM14 = PlusDM14 + PlusDM;
}
If TRange <> 0 Then
Infx_DIPlus = 100 * PlusDM14 / TRange;
Else
Infx_DIPlus = 0 ;
}
Else If CurrentBar > 1 Then
{
If High[0] - High[1] < 0 Then
PlusDM = 0;
Else
PlusDM = High[0] - High[1];
If Low [1] - Low [0] < 0 Then
MinusDM = 0;
Else
MinusDM = Low[1] - Low[0];
If MinusDM >= PlusDM Then
PlusDM = 0;
If MyRange > 0 Then Begin
TRange = TRange[1] - (TRange[1] / MyRange) + TrueRange;
PlusDM14 = PlusDM14[1] - (PlusDM14[1] / MyRange) + PlusDM;
End;
If TRange <> 0 Then
Infx_DIPlus = 100 * PlusDM14 / TRange;
Else
Infx_DIPlus = 0 ;
}
}
EndFunction
//DIMinus 함수식
Function Infx_DIMinus Numeric
{
Input : Length(NumericSimple);
Var : Counter(0), TRange(0), MyRange(Length);
var : MinusDM14(0), MinusDM(0), PlusDM(0);
If CurrentBar == 1 Then
{
MyRange = Length;
Infx_DIMinus = 0;
MinusDM14 = 0;
TRange = 0;
For Counter = 0 To MyRange-1
{
If High[Counter] - High[Counter+1] < 0 Then
PlusDM = 0 ;
Else
PlusDM = High[Counter] - High[Counter + 1];
If Low[Counter + 1] - Low[Counter] < 0 Then
MinusDM = 0;
Else
MinusDM = Low[Counter + 1] - Low[Counter];
If PlusDM >= MinusDM Then
MinusDM = 0;
TRange = TRange + TrueRange[Counter];
MinusDM14 = MinusDM14 + MinusDM;
}
If TRange <> 0 Then
Infx_DIMinus = 100 * MinusDM14 / TRange;
Else
Infx_DIMinus = 0;
}
Else If CurrentBar > 1 Then
{
If High[0] - High[1] < 0 Then
PlusDM = 0;
Else
PlusDM = High[0] - High[1];
If Low[1] - Low [0] < 0 Then
MinusDM = 0 ;
Else
MinusDM = Low[1] - Low[0] ;
If PlusDM >= MinusDM Then
MinusDM = 0 ;
If MyRange > 0 Then
{
TRange = TRange[1] - (TRange[1] / MyRange) + TrueRange;
MinusDM14 = MinusDM14[1] - (MinusDM14[1] / MyRange) + MinusDM;
}
If TRange <> 0 Then
Infx_DIMinus = 100 * MinusDM14 / TRange;
Else
Infx_DIMinus = 0;
}
}
EndFunction
//DMI 함수식
Function Infx_DMI Numeric
{
Inputs: Length(NumericSimple);
Variables: DP(0), DM(0);
DP = Infx_DIPlus(Length);
DM = InFx_DIMinus(Length);
If DP + DM == 0 Then
Infx_DMI = 0;
Else
Infx_DMI = 100 * AbsValue(DP - DM) / (DP + DM);
}
EndFunction
input : Period(20);
var : DMIv(0);
DMIv = Infx_DMI(Period);
Plot1(DMIv);
C
복사
뒤로가기는 좌측상단의 목차 버튼을 눌러주세요.