답변완료
지표식 검토 부탁 드립니다.
안녕하십니까!!!
지표식 검토 부탁 드립니다.
_그물망_추세_갯수n색_yin <지표>
이평선 그물망(상승,하락,횡보 구간별 색상표시)
지표식 조건
1. 이평선의 전봉 대비 변동율이 제한변동폭율(+0.5 %) 초과이면 상승(RED), 제한변동폭율(-0.5 %) 미만이면 하락(BLUE) 으로 표시한다. OK
이평선의 전봉 대비 변동율이 -제한변동폭율(+0.5 %) <= 전봉 대비 변동율 <= +제한변동폭율(-0.5 %) 이면 횡보(CYAN)으로 표시한다.
2. 그물망 전체 갯수를 지정할 수 있도록 한다. OK
3. 그물망 전체 각 이평선의 상승, 하락, 횡보의 갯수를 구하여 전체 갯수 대비 각각의 추세 백분율 지표를 만든다. OK
4. 추세 백분율 지표로 EMA, DEMA, TEMA, QEMA 를 구한다. OK
5. QEMA 수식을 구하지 못하여 TEMA를 EMA처리함. <확인 필요>
개발 히스토리
1. plot(n)함수 및 plot 이름을 변수처리 못하므로 나열(열거) 형으로 plot1~plot30으로 나열하여 자주 쓸 만한 5개의 그물망case 를 처리 OK
2. 반목문 처리 재시도 why?? 사용불편, case가 부족하고 속도가 늦는 듯 하다 OK
- 이평선 갯수, 주기의 case 한계를 줄인다 OK
- plot문이 변수처리가 안되므로 반복문은 30개 이내로 제한 OK
3. 개발지표식명 : _그물망_추세_갯수n색_yin <지표>
지표식내에서 반복처리와 나열처리 2가지 소스 주석처리 OK
반목문과 나열(열거)문으로 나온 결과를 보니 서로 값이 상이하다.
- 그래프 모양은 엇비슷하게 나오나 이평선 위치도 틀리고 추세색도 틀리게 나온다.
4. 3번의 결과가 의아해서 지수이동평균(그물망) <지표> 식과 반복처리/나열처리 결과를 각각 비교하여 보니
반복처리는 값이 안 맞고 나열처리는 맞았다.
5. 4.번의 지수이동평균(그물망) <지표> 식으로 지표식 조건 1번을 구현하여도 일부 구간에서 색상표시를 못한다.
이평선의 전봉 대비 변동율이 제한변동폭율(+0.5 %) 초과이면 상승(RED), 제한변동폭율(-0.5 %) 미만이면 하락(BLUE) 으로 표시한다.
이평선의 전봉 대비 변동율이 -제한변동폭율(+0.5 %) <= 전봉 대비 변동율 <= +제한변동폭율(-0.5 %) 이면 횡보(CYAN)으로 표시한다.
6. 여러가지 시도를 하여도 일부 구간에서 색상표시를 제대로 못하는 원인을 찾지 못하여 작업 중지.
수식 에러 및 체크 대상 <2, 3번 중요>
1. 반복문 처리시 이평선 위치가 틀리다 (반복문 처리시 이평선 위치가 왜 틀리는가)
2. 반복문/열거문 모두 추세반전 변곡점 에서 상승(하락)시에 파란색(빨강)으로 반대로 표시가 되는 구간이 나타난다.
3. 일부 구간(변곡점 부근)에서 상승, 횡보, 하락이 다른 색으로 나오는 원인이 무엇인가
4. QEMA 수식을 확인치 못하여 TEMA를 EMA처리함.
5. 다음 수식과정이 맞는지 체크
상승비율 = 상승추세갯수 / 전체추세갯수 * 100 ;
EMA_v = EMA(상승비율, P_지수);
Re_EMA_v = EMA(EMA_v, P_지수);
DEMA_v = EMA_v * 2 - Re_EMA_v;
TEMA_v = (3 * EMA_v) - (3 * Re_EMA_v) + ( EMA(Re_EMA_v, P_지수) ) ;
QEMA_v = EMA(TEMA_v, P_지수) ;
6. QEMA 공식 확인 필요
QEMA = TEMA + DEMA(Close - TEMA) ;
QEMA = 5*EMA1 - 10*EMA2 + 10*EMA3 - 5*EMA4 + EMA5 ;
2022-02-28
1280
글번호 156788
지표
답변완료
수식완성 요청
안녕하세요. 콜옵션 3개, 풋옵션 3개로 옵션 양합선 3개를 한차트에 구현하고 싶은데…초보라서 쉽지가 않네요.
다른 사람의 식에다 내가 옵션을 4개 추가하려고 하는데 오류가 생기네요.
수식을 완성시켜주시면 감사하겠습니다.
=================================================
Input : 시가대비이면1(1);
Input : 당일분이면1(1);
var : 양합1(0, data1), 콜현재가1(0, data1), 풋현재가1(0, Data2);
var : 양합2(0, data3), 콜현재가2(0, data3), 풋현재가2(0, Data4);
var : 양합3(0, data5), 콜현재가3(0, data5), 풋현재가3(0, Data6);
var : 콜시가1(0), 풋시가1(0), 콜전종1(0), 풋전종1(0);
var : 콜시가2(0), 풋시가2(0), 콜전종2(0), 풋전종2(0);
var : 콜시가3(0), 풋시가3(0), 콜전종3(0), 풋전종3(0);
var : 양합선색1(0), 양합선색2(0), 양합선색3(0);
콜시가1 = Data1(OpenD(0));
콜시가2 = Data3(OpenD(0));
콜시가3 = Data5(OpenD(0));
풋시가1 = Data2(OpenD(0));
풋시가2 = Data4(OpenD(0));
풋시가3 = Data6(OpenD(0));
콜전종1 = data1(closeD(1));
콜전종2 = data3(closeD(1));
콜전종3 = data5(closeD(1));
풋전종1 = data2(closeD(1));
풋전종2 = data4(closeD(1));
풋전종3 = data6(closeD(1));
콜현재가1 = Data1(c);
콜현재가2 = Data3(c);
콜현재가3 = Data5(c);
풋현재가1 = Data2(c);
풋현재가2 = Data4(c);
풋현재가3 = Data6(c);
If 당일분이면1 == 1 then {
If 시가대비이면1 == 1 then
양합1 = (콜현재가1+풋현재가1) - (콜시가1+풋시가1);양합2== (콜현재가2+풋현재가2) - (콜시가2+풋시가2); 양합3= (콜현재가3+풋현재가3) - (콜시가3+풋시가3);
else 양합1 = (콜현재가1+풋현재가1) - (콜전종1+풋전종1); 양합2= (콜현재가2+풋현재가2) - (콜전종2+풋전종2); 양합3 = (콜현재가3+풋현재가3) - (콜전종3+풋전종3) ;
}
else 양합1 = 콜현재가1+풋현재가1; 양합2 = 콜현재가2+풋현재가2; 양합3 = 콜현재가3+풋현재가3 ;
양합선색1 = IFF(양합1[1] <= 양합1, RED, BLUE);
양합선색2 = IFF(양합2[1] <= 양합2, RED, BLUE);
양합선색3 = IFF(양합3[1] <= 양합3, RED, BLUE);
if 당일분이면1 == 1 Then {
if CurrentDate == bdate Then
plot11(양합1, "양합선", 양합선색1);
Plot12(양합2, "양합선", 양합선색2);
Plot13(양합3, "양합선", 양합선색3); }
Else
plot11(양합1, "양합선", 양합선색1);
Plot12(양합2, "양합선", 양합선색2);
Plot13(양합3, "양합선", 양합선색3);
plot51(0, "0선", GRAY);
2022-02-27
972
글번호 156786
지표
답변완료
수식 질문드립니다.
monthly
만기일까지 남은날짜
뽑아내는 함수 혹시있나요?
만기일 포함해서 만기주 만기전주 10거래일만 매매하려면 어떻게하면 될까요??
들쑥날쑥 구현하기 쉽지않네요 감사합니다.
var : month(0),nday(0),week(0),TL(0);
var : condiw(0);
month = int(date/100)-int(date/10000)*100;
nday = date - int(date/100)*100;
Week = DayOfWeek(date);
if sDate != sDate[1] Then
{
condiw = 0;
}
#if nday >= 8 and nday <= 14 and week == 4 Then condiw=1;
if nday >= 7 and nday <= 13 and week == 3 Then condiw=1;
else if nday >= 6 and nday <= 12 and week == 2 Then condiw=1;
else if nday >= 5 and nday <= 11 and week == 1 Then condiw=1;
else if nday >= 2 and nday <= 8 and week == 5 Then condiw=1;
else if nday >= 1 and nday <= 7 and week == 4 Then condiw=1;
else if nday >= 1 and nday <= 6 and week == 3 Then condiw=1;
else if nday >= 1 and nday <= 5 and week == 2 Then condiw=1;
else if nday >= 1 and nday <= 4 and week == 1 Then condiw=1;
else if nday >= 1 and nday <= 1 and week == 5 Then condiw=1;
else if nday >= 23 and nday <= 29 and week == 5 Then condiw=1;
else if nday >= 24 and nday <= 30 and week == 1 Then condiw=1;
else if nday >= 25 and nday <= 31 and week == 2 Then condiw=1;
else if nday >= 26 and nday <= 31 and week == 3 Then condiw=1;
else if nday >= 27 and nday <= 31 and week == 4 Then condiw=1;
else if nday >= 28 and nday <= 31 and week == 5 Then condiw=1;
else if nday >= 31 and nday <= 31 and week == 1 Then condiw=1;
Else condiw ==0;
#옵션만기
if nday >= 8 and nday <= 14 and week == 4 and sTime >= 150000 and sTime[1] < 150000 then
{
TL = TL_New(sDate,sTime,0,sDate,sTime,9999999);
TL_SetColor(TL,RED);
}
#선물만기
if Month%3 == 0 and nday >= 8 and nday <= 14 and week == 4 and sTime >= 150000 and sTime[1] < 150000 then
{
TL = TL_New(sDate,sTime,0,sDate,sTime,9999999);
TL_SetColor(TL,BLUE);
}
Plot1(condiw);
2022-02-27
862
글번호 156784
지표
답변완료
문의드립니다
수고많으십니다
채널에 가격과%를넣을려하는데 45줄에 에러 뜨고 맞는지도 모르겠습니다
챠트에 가격과%를 출력하고싶습니다 환절기 감기 조심하시고 수고하십시오
input : P1(1), Mult1(0.5), mult2(0.9), mult3(1.5), mult4(2.5), mult5(3.1), mult6(4.2),mult7(6.8) ;
var : sumV(0), DailyVol(0),text(0), count(0), ChUp1(0), ChDn1(0), ChUp2(0), ChDn2(0), ChUp3(0), ChDn3(0), ChUp4(0), ChDn4(0), ChUp5(0), ChDn5(0), ChUp6(0), ChDn6(0), ChUp7(0), ChDn7(0) ;
sumV = 0;
for count = 1 to P1 {
sumV = sumV+(DayHigh(count)-DayLow(count));
}
DailyVol = sumV / P1;
ChUp1 = dayOpen + DailyVol*Mult1;
ChUp2 = dayOpen + DailyVol*Mult2;
ChUp3 = dayOpen + DailyVol*Mult3;
ChUp4 = dayOpen + DailyVol*Mult4;
ChUp5 = dayOpen + DailyVol*Mult5;
ChUp6 = dayOpen + DailyVol*Mult6;
ChUp7 = dayOpen + DailyVol*Mult7;
ChDn1 = dayOpen - DailyVol*Mult1;
ChDn2 = dayOpen - DailyVol*Mult2;
ChDn3 = dayOpen - DailyVol*Mult3;
ChDn4 = dayOpen - DailyVol*Mult4;
ChDn5 = dayOpen - DailyVol*Mult5;
ChDn6 = dayOpen - DailyVol*Mult6;
ChDn7 = dayOpen - DailyVol*Mult7;
plot1(ChUp1);
plot2(ChUp2);
plot3(ChUp3);
plot4(ChUp4);
plot5(ChUp5);
plot6(ChUp6);
plot7(ChUp7);
plot8(ChDn1);
plot9(ChDn2);
Plot10(ChDn3);
plot11(ChDn4);
plot12(ChDn5);
plot13(ChDn6);
plot14(ChDn7);
For count = 1 to 14
{
Text_Delete(sumv[count]);
Text [count] = Text_New(sDate,sTime,p1[count],"("+NumToStr(P1[count],2)+"%)"+NumToStr(p1[count],2));
Text_Delete(p1[count]);
}
2022-02-27
953
글번호 156779
지표