제가 임의로 만든 A지표가 있는데요.
data1과 data2의 값을 참조해서 만든 지표입니다.
당연히 data1과 data2의 차트는 그대로 둔 상태에서,
A지표값를 Rsi로 만들어서 표시하고 싶습니다.
Rsi 함수에서 "c"값을 "지표값"으로 바꾸면 될 것 같은데, 안되고 있습니다.
도와주시면 감사하겠습니다.
Rsi함수식은 아래와 같이 작성했습니다.
“KKK “ 가 제가 만든 지표이구요,,,
함수는 “KKKK”로 했는데,
검증은 문제 없다고 되는데,
지표를 출력해 보면, 0으로 나옵니다..(ㅜㅠ,,,)
사용자 함수식(KKKK)
Inputs: Length(NumericSimple);
Variables: Counter(0), DownAmt(0), UpAmt(0), UpSum(0), DownSum(0), UpAvg(0), DownAvg(0), KKK(0) ;
KKK = ( Data1(@#$%) + Data2(*&^%$%) );
If CurrentBar == 1 AND Length > 0 Then Begin
UpSum = 0;
DownSum = 0;
For Counter = 0 To Length - 1 Begin
UpAmt = KKK[Counter] - KKK[Counter+1];
If UpAmt >= 0 Then
DownAmt = 0;
Else Begin
DownAmt = -UpAmt;
UpAmt = 0;
End;
UpSum = UpSum + UpAmt;
DownSum = DownSum + DownAmt;
End;
UpAvg = UpSum / Length;
DownAvg = DownSum / Length;
End
Else
If CurrentBar > 1 AND Length > 0 Then Begin
UpAmt = KKK[0] - KKK[1];
If UpAmt >= 0 Then
DownAmt = 0;
Else Begin
DownAmt = -UpAmt;
UpAmt = 0;
End;
UpAvg = (UpAvg[1] * (Length - 1) + UpAmt) / Length;
DownAvg = (DownAvg[1] * (Length - 1) + DownAmt) / Length;
End;
If UpAvg + DownAvg <> 0 Then
KKKK = 100 * UpAvg / (UpAvg + DownAvg);
Else
KKKK = 0;
답변 1
예스스탁
예스스탁 답변
2022-06-21 11:05:41
안녕하세요
예스스탁입니다.
1
차트 제일 앞쪽을 보시면 2개의 데이타의 시작점이 다른것을 보실 수 있습니다.
2개 데이타를 사용하면 2개 데이타가 모두 차트에 있는 시점부터 계산되게 하셔야 합니다.
최초 n/a가 계산되면 이전값을 사용하는 내용이 있으므로 계속 n/a가 되게 됩니다.
2
Inputs: Length(NumericSimple);
Variables: Counter(0), DownAmt(0), UpAmt(0), UpSum(0), DownSum(0), UpAvg(0), DownAvg(0),kkk(0);
var : ii(0);
kkk = data1(c)+Data2(c);
if IsNaN(kkk) == False Then
ii = ii +1;
If ii == length+1 Then Begin
UpSum = 0;
DownSum = 0;
For Counter = 0 To Length - 1 Begin
UpAmt = KKK[Counter] - KKK[Counter+1];
If UpAmt >= 0 Then
DownAmt = 0;
Else Begin
DownAmt = -UpAmt;
UpAmt = 0;
End;
UpSum = UpSum + UpAmt;
DownSum = DownSum + DownAmt;
End;
UpAvg = UpSum / Length;
DownAvg = DownSum / Length;
End
Else
If ii > length+1 Then Begin
UpAmt = KKK[0] - KKK[1];
If UpAmt >= 0 Then
DownAmt = 0;
Else Begin
DownAmt = -UpAmt;
UpAmt = 0;
End;
UpAvg = (UpAvg[1] * (Length - 1) + UpAmt) / Length;
DownAvg = (DownAvg[1] * (Length - 1) + DownAmt) / Length;
End;
If UpAvg + DownAvg <> 0 Then
KKKK = 100 * UpAvg / (UpAvg + DownAvg);
Else
KKKK = 0;
즐거운 하루되세요
> 클레멘타인 님이 쓴 글입니다.
> 제목 : 제가 만든 지표값을 Rsi 지표로 나타내고 싶은데요,,,
>
제가 임의로 만든 A지표가 있는데요.
data1과 data2의 값을 참조해서 만든 지표입니다.
당연히 data1과 data2의 차트는 그대로 둔 상태에서,
A지표값를 Rsi로 만들어서 표시하고 싶습니다.
Rsi 함수에서 "c"값을 "지표값"으로 바꾸면 될 것 같은데, 안되고 있습니다.
도와주시면 감사하겠습니다.
Rsi함수식은 아래와 같이 작성했습니다.
“KKK “ 가 제가 만든 지표이구요,,,
함수는 “KKKK”로 했는데,
검증은 문제 없다고 되는데,
지표를 출력해 보면, 0으로 나옵니다..(ㅜㅠ,,,)
사용자 함수식(KKKK)
Inputs: Length(NumericSimple);
Variables: Counter(0), DownAmt(0), UpAmt(0), UpSum(0), DownSum(0), UpAvg(0), DownAvg(0), KKK(0) ;
KKK = ( Data1(@#$%) + Data2(*&^%$%) );
If CurrentBar == 1 AND Length > 0 Then Begin
UpSum = 0;
DownSum = 0;
For Counter = 0 To Length - 1 Begin
UpAmt = KKK[Counter] - KKK[Counter+1];
If UpAmt >= 0 Then
DownAmt = 0;
Else Begin
DownAmt = -UpAmt;
UpAmt = 0;
End;
UpSum = UpSum + UpAmt;
DownSum = DownSum + DownAmt;
End;
UpAvg = UpSum / Length;
DownAvg = DownSum / Length;
End
Else
If CurrentBar > 1 AND Length > 0 Then Begin
UpAmt = KKK[0] - KKK[1];
If UpAmt >= 0 Then
DownAmt = 0;
Else Begin
DownAmt = -UpAmt;
UpAmt = 0;
End;
UpAvg = (UpAvg[1] * (Length - 1) + UpAmt) / Length;
DownAvg = (DownAvg[1] * (Length - 1) + DownAmt) / Length;
End;
If UpAvg + DownAvg <> 0 Then
KKKK = 100 * UpAvg / (UpAvg + DownAvg);
Else
KKKK = 0;