아래는 일전에 도움을 주신,
RSI의 과매도,과매수권을 캔들위에 표현하는 수식입니다.
이를 수정하여,
RSI signal 의 과매도 과매수권을 캔들위에 표현하고 싶습니다.
RSI signal = ma((RSI(RSI_Period)),시그널);
아래 수식의 rsi를 RSI signal로 수정하면 되지 않을까 싶은데
실력이 천박하여 이렇게 문의드립니다.
부탁 드립니다. 감사합니다.
Input : Length(9);
Var : Counter(0), DownAmt(0), UpAmt(0), UpSum(0), DownSum(0), UpAvg(0), DownAvg(0),RSIV(0),Current(0);
var : cnt1(0),current1(0),UpAmt1(0),DownAmt1(0),UpAvg1(0),DownAvg1(0),RSIv1(0);
var : cnt2(0),current2(0),UpAmt2(0),DownAmt2(0),UpAvg2(0),DownAvg2(0),RSIv2(0);
var : upPrice(0),dnPrice(0);
If CurrentBar == 1 AND Length > 0 Then
Begin
UpSum = 0;
DownSum = 0;
For Counter = 0 To Length - 1
Begin
UpAmt = C[Counter] - C[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 = C[0] - C[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
RSIv = 100 * UpAvg / (UpAvg + DownAvg);
Else
RSIv = 0;
IF rsiv[1] >= 30 AND rsiv[1] <= 70 Then
{
for cnt1 = 0 to 100
{
Current1 = C+PriceScale*cnt1;
UpAmt1 = current1 - C[1];
If UpAmt1 >= 0 Then
DownAmt1 = 0;
Else
Begin
DownAmt1 = -UpAmt1;
UpAmt1 = 0;
End;
UpAvg1 = (UpAvg[1] * (Length - 1) + UpAmt1) / Length;
DownAvg1 = (DownAvg[1] * (Length - 1) + DownAmt1) / Length;
If UpAvg1 + DownAvg1 <> 0 Then
RSIv1 = 100 * UpAvg1 / (UpAvg1 + DownAvg1);
Else
RSIv1 = 0;
IF rsiv1 >= 70 Then
{
upPrice = CURRENT1;
cnt1 = 101;
}
}
for cnt2 = 0 to 100
{
Current2 = C-PriceScale*cnt2;
UpAmt2 = current2 - C[1];
If UpAmt2 >= 0 Then
DownAmt2 = 0;
Else
Begin
DownAmt2 = -UpAmt2;
UpAmt2 = 0;
End;
UpAvg2 = (UpAvg[1] * (Length - 1) + UpAmt2) / Length;
DownAvg2 = (DownAvg[1] * (Length - 1) + DownAmt2) / Length;
If UpAvg2 + DownAvg2 <> 0 Then
RSIv2 = 100 * UpAvg2 / (UpAvg2 + DownAvg2);
Else
RSIv2 = 0;
IF rsiv2 <= 30 Then
{
dnPrice = CURRENT2;
cnt2 = 101;
}
}
plot1(upPrice);
plot2(dnPrice);
}
답변 1
예스스탁
예스스탁 답변
2022-07-06 17:36:20
안녕하세요
예스스탁입니다.
문의하신 내용은 답변이 어렵습니다.
작성해 보는데 시간이 많이 소모되는 내용입니다.
올려주신 수식도 저희가 작성해서 드린 수식은 아닙니다.
사용자분이 작성해서 일부 오류된 부분만 찾아서 수정해 드린 내용입니다.
업무상 일정이상 시간이 요구되는 내용은 저희가 답변드리기 어렵습니다.
도움을 드리지 못해 죄송합니다.
즐거운 하루되세요
> 부똘이 님이 쓴 글입니다.
> 제목 : 수식 문의
> 아래는 일전에 도움을 주신,
RSI의 과매도,과매수권을 캔들위에 표현하는 수식입니다.
이를 수정하여,
RSI signal 의 과매도 과매수권을 캔들위에 표현하고 싶습니다.
RSI signal = ma((RSI(RSI_Period)),시그널);
아래 수식의 rsi를 RSI signal로 수정하면 되지 않을까 싶은데
실력이 천박하여 이렇게 문의드립니다.
부탁 드립니다. 감사합니다.
Input : Length(9);
Var : Counter(0), DownAmt(0), UpAmt(0), UpSum(0), DownSum(0), UpAvg(0), DownAvg(0),RSIV(0),Current(0);
var : cnt1(0),current1(0),UpAmt1(0),DownAmt1(0),UpAvg1(0),DownAvg1(0),RSIv1(0);
var : cnt2(0),current2(0),UpAmt2(0),DownAmt2(0),UpAvg2(0),DownAvg2(0),RSIv2(0);
var : upPrice(0),dnPrice(0);
If CurrentBar == 1 AND Length > 0 Then
Begin
UpSum = 0;
DownSum = 0;
For Counter = 0 To Length - 1
Begin
UpAmt = C[Counter] - C[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 = C[0] - C[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
RSIv = 100 * UpAvg / (UpAvg + DownAvg);
Else
RSIv = 0;
IF rsiv[1] >= 30 AND rsiv[1] <= 70 Then
{
for cnt1 = 0 to 100
{
Current1 = C+PriceScale*cnt1;
UpAmt1 = current1 - C[1];
If UpAmt1 >= 0 Then
DownAmt1 = 0;
Else
Begin
DownAmt1 = -UpAmt1;
UpAmt1 = 0;
End;
UpAvg1 = (UpAvg[1] * (Length - 1) + UpAmt1) / Length;
DownAvg1 = (DownAvg[1] * (Length - 1) + DownAmt1) / Length;
If UpAvg1 + DownAvg1 <> 0 Then
RSIv1 = 100 * UpAvg1 / (UpAvg1 + DownAvg1);
Else
RSIv1 = 0;
IF rsiv1 >= 70 Then
{
upPrice = CURRENT1;
cnt1 = 101;
}
}
for cnt2 = 0 to 100
{
Current2 = C-PriceScale*cnt2;
UpAmt2 = current2 - C[1];
If UpAmt2 >= 0 Then
DownAmt2 = 0;
Else
Begin
DownAmt2 = -UpAmt2;
UpAmt2 = 0;
End;
UpAvg2 = (UpAvg[1] * (Length - 1) + UpAmt2) / Length;
DownAvg2 = (DownAvg[1] * (Length - 1) + DownAmt2) / Length;
If UpAvg2 + DownAvg2 <> 0 Then
RSIv2 = 100 * UpAvg2 / (UpAvg2 + DownAvg2);
Else
RSIv2 = 0;
IF rsiv2 <= 30 Then
{
dnPrice = CURRENT2;
cnt2 = 101;
}
}
plot1(upPrice);
plot2(dnPrice);
}