커뮤니티

VI관련 질문입니다.

프로필 이미지
jch2303
2017-11-30 04:23:14
180
글번호 114584
답변완료

첨부 이미지

var : up1(0), up2(0), up3(0), up4(0), up5(0),up6(0),Up7(0); var : dn1(0), dn2(0), dn3(0), dn4(0), dn5(0),dn6(0),dn7(0); var : a1(0),a2(0),b1(0),b2(0); if o[1]==h[1]&&o[1]==l[1]&&(v[1]==0||v[1]>=1)&&v>=1 Then{ a1 = o*1.1; b1 = o*0.9; } if date >= 19981207 then { if CodeCategory() == 2 then { if date >= 20030721 then { up1 = int(a1/100+0.00001)*100; up2 = int(a1/100+0.00001)*100; up3 = int(a1/100+0.00001)*100; up4 = int(a1/50+0.00001)*50; up5 = int(a1/10+0.00001)*10; up6 = int(a1/5+0.00001)*5; up7 = int(a1/1+0.00001)*1; } else { up1 = int(a1/1000+0.00001)*1000; up2 = int(a1/500+0.00001)*500; up3 = int(a1/100+0.00001)*100; up4 = int(a1/50+0.00001)*50; up5 = int(a1/10+0.00001)*10; up6 = int(a1/10+0.00001)*10; up7 = int(a1/1+0.00001)*1; } } Else { up1 = int(a1/1000+0.00001)*1000; up2 = int(a1/500+0.00001)*500; up3 = int(a1/100+0.00001)*100; up4 = int(a1/50+0.00001)*50; up5 = int(a1/10+0.00001)*10; up6 = int(a1/5+0.00001)*5; up7 = int(a1/1+0.00001)*1; } if CodeCategory() == 1 || CodeCategory() == 2 then { if sdate < 20101004 Then { If a1 >= 500000 Then a2 = up1; Else If a1 >= 100000 Then a2 = iff(up2>=500000, up1, up2); Else If a1 >= 50000 Then a2 = iff(up3>=100000, up2, up3); Else If a1 >= 10000 Then a2 = iff(up4>=50000, up3, up4); Else If a1 >= 5000 Then a2 = iff(up5>=10000, up4, up5); Else If a1 >= 1000 Then a2 = iff(up5>=5000, up5, up6); Else a2 = iff(up6>=1000, up6, up6); } Else { If a1 >= 500000 Then a2 = up1; Else If a1 >= 100000 Then a2 = iff(up2>=500000, up1, up2); Else If a1 >= 50000 Then a2 = iff(up3>=100000, up2, up3); Else If a1 >= 10000 Then a2 = iff(up4>=50000, up3, up4); Else If a1 >= 5000 Then a2 = iff(up5>=10000, up4, up5); Else If a1 >= 1000 Then a2 = iff(up5>=5000, up5, up6); Else a2 = iff(up6>=1000, up6, up7); } } else if CodeCategory() == 8 || CodeCategory() == 9 then { // ETF a2 = up6; } } if date >= 19981207 then { if CodeCategory() == 2 then { if date >= 20030721 then { dn1 = int(b1/100+0.00001)*100; dn2 = int(b1/100+0.00001)*100; dn3 = int(b1/100+0.00001)*100; dn4 = int(b1/50+0.00001)*50; dn5 = int(b1/10+0.00001)*10; dn6 = int(b1/5+0.00001)*5; dn7 = int(b1/1+0.00001)*1; } else { dn1 = int(b1/1000+0.00001)*1000; dn2 = int(b1/500+0.00001)*500; dn3 = int(b1/100+0.00001)*100; dn4 = int(b1/50+0.00001)*50; dn5 = int(b1/10+0.00001)*10; dn6 = int(b1/10+0.00001)*10; dn7 = int(b1/1+0.00001)*1; } } Else { dn1 = int(b1/1000+0.00001)*1000; dn2 = int(b1/500+0.00001)*500; dn3 = int(b1/100+0.00001)*100; dn4 = int(b1/50+0.00001)*50; dn5 = int(b1/10+0.00001)*10; dn6 = int(b1/5+0.00001)*5; dn7 = int(b1/1+0.00001)*1; } if CodeCategory() == 1 || CodeCategory() == 2 then { if sdate < 20101004 Then { If b1 >= 500000 Then b2 = dn1; Else If b1 >= 100000 Then b2 = iff(dn2>=500000, dn1, dn2); Else If b1 >= 50000 Then b2 = iff(dn3>=100000, dn2, dn3); Else If b1 >= 10000 Then b2 = iff(dn4>=50000, dn3, dn4); Else If b1 >= 5000 Then b2 = iff(dn5>=10000, dn4, dn5); Else If b1 >= 1000 Then b2 = iff(dn5>=5000, dn5, dn6); Else b2 = iff(dn6>=1000, dn6, dn6); } Else { If b1 >= 500000 Then b2 = dn1; Else If b1 >= 100000 Then b2 = iff(dn2>=500000, dn1, dn2); Else If b1 >= 50000 Then b2 = iff(dn3>=100000, dn2, dn3); Else If b1 >= 10000 Then b2 = iff(dn4>=50000, dn3, dn4); Else If b1 >= 5000 Then b2 = iff(dn5>=10000, dn4, dn5); Else If b1 >= 1000 Then b2 = iff(dn5>=5000, dn5, dn6); Else b2 = iff(dn6>=1000, dn6, dn7); } } else if CodeCategory() == 8 || CodeCategory() == 9 then { // ETF b2 = dn6; } } plot1(floor(a2)); plot2(Ceiling(b2)); 위 수식이 게시판에서 본 vi수식인데 적용하고나니 첨부한 그림처럼 엔벨로프처럼 나옵니다. vi가격에 맞게 표시하는 방법없나요? 그리고 상승이나 하락 vi해제후 1분동안 매수금지 시스템식을 만드는 방법을 가르쳐주세요 그리고 시초가가찍히고 10봉뒤부터 매수하는 시스템식도 함께 만들어주세요.
시스템
답변 1
프로필 이미지

예스스탁 예스스탁 답변

2017-11-30 14:17:25

안녕하세요 예스스탁입니다. 1.2 해당식 이전에 키움수식을 저희랭귀지로 변경 요청으로 변경해 드린수식입니다. vi가격에 맞게 표시하는 방법이 어떤 내용인지 잘 모르겠습니다 vi지표에 대해서는 아는부분이 없습니다. 상승이나 하락 vi해제가 어떤 내용인지 좀더 자세한 내용을 올려주셔야 수식 답변이 가능할것 같습니다. 3 "시초가가찍히고 10봉뒤"는 당일 10번째 봉 이후부터 매매라는 의미이시면 진입식에 아래 조건 추가하시면 됩니다. dayindex >= 10 즐거운 하루되세요 > jch2303 님이 쓴 글입니다. > 제목 : VI관련 질문입니다. > var : up1(0), up2(0), up3(0), up4(0), up5(0),up6(0),Up7(0); var : dn1(0), dn2(0), dn3(0), dn4(0), dn5(0),dn6(0),dn7(0); var : a1(0),a2(0),b1(0),b2(0); if o[1]==h[1]&&o[1]==l[1]&&(v[1]==0||v[1]>=1)&&v>=1 Then{ a1 = o*1.1; b1 = o*0.9; } if date >= 19981207 then { if CodeCategory() == 2 then { if date >= 20030721 then { up1 = int(a1/100+0.00001)*100; up2 = int(a1/100+0.00001)*100; up3 = int(a1/100+0.00001)*100; up4 = int(a1/50+0.00001)*50; up5 = int(a1/10+0.00001)*10; up6 = int(a1/5+0.00001)*5; up7 = int(a1/1+0.00001)*1; } else { up1 = int(a1/1000+0.00001)*1000; up2 = int(a1/500+0.00001)*500; up3 = int(a1/100+0.00001)*100; up4 = int(a1/50+0.00001)*50; up5 = int(a1/10+0.00001)*10; up6 = int(a1/10+0.00001)*10; up7 = int(a1/1+0.00001)*1; } } Else { up1 = int(a1/1000+0.00001)*1000; up2 = int(a1/500+0.00001)*500; up3 = int(a1/100+0.00001)*100; up4 = int(a1/50+0.00001)*50; up5 = int(a1/10+0.00001)*10; up6 = int(a1/5+0.00001)*5; up7 = int(a1/1+0.00001)*1; } if CodeCategory() == 1 || CodeCategory() == 2 then { if sdate < 20101004 Then { If a1 >= 500000 Then a2 = up1; Else If a1 >= 100000 Then a2 = iff(up2>=500000, up1, up2); Else If a1 >= 50000 Then a2 = iff(up3>=100000, up2, up3); Else If a1 >= 10000 Then a2 = iff(up4>=50000, up3, up4); Else If a1 >= 5000 Then a2 = iff(up5>=10000, up4, up5); Else If a1 >= 1000 Then a2 = iff(up5>=5000, up5, up6); Else a2 = iff(up6>=1000, up6, up6); } Else { If a1 >= 500000 Then a2 = up1; Else If a1 >= 100000 Then a2 = iff(up2>=500000, up1, up2); Else If a1 >= 50000 Then a2 = iff(up3>=100000, up2, up3); Else If a1 >= 10000 Then a2 = iff(up4>=50000, up3, up4); Else If a1 >= 5000 Then a2 = iff(up5>=10000, up4, up5); Else If a1 >= 1000 Then a2 = iff(up5>=5000, up5, up6); Else a2 = iff(up6>=1000, up6, up7); } } else if CodeCategory() == 8 || CodeCategory() == 9 then { // ETF a2 = up6; } } if date >= 19981207 then { if CodeCategory() == 2 then { if date >= 20030721 then { dn1 = int(b1/100+0.00001)*100; dn2 = int(b1/100+0.00001)*100; dn3 = int(b1/100+0.00001)*100; dn4 = int(b1/50+0.00001)*50; dn5 = int(b1/10+0.00001)*10; dn6 = int(b1/5+0.00001)*5; dn7 = int(b1/1+0.00001)*1; } else { dn1 = int(b1/1000+0.00001)*1000; dn2 = int(b1/500+0.00001)*500; dn3 = int(b1/100+0.00001)*100; dn4 = int(b1/50+0.00001)*50; dn5 = int(b1/10+0.00001)*10; dn6 = int(b1/10+0.00001)*10; dn7 = int(b1/1+0.00001)*1; } } Else { dn1 = int(b1/1000+0.00001)*1000; dn2 = int(b1/500+0.00001)*500; dn3 = int(b1/100+0.00001)*100; dn4 = int(b1/50+0.00001)*50; dn5 = int(b1/10+0.00001)*10; dn6 = int(b1/5+0.00001)*5; dn7 = int(b1/1+0.00001)*1; } if CodeCategory() == 1 || CodeCategory() == 2 then { if sdate < 20101004 Then { If b1 >= 500000 Then b2 = dn1; Else If b1 >= 100000 Then b2 = iff(dn2>=500000, dn1, dn2); Else If b1 >= 50000 Then b2 = iff(dn3>=100000, dn2, dn3); Else If b1 >= 10000 Then b2 = iff(dn4>=50000, dn3, dn4); Else If b1 >= 5000 Then b2 = iff(dn5>=10000, dn4, dn5); Else If b1 >= 1000 Then b2 = iff(dn5>=5000, dn5, dn6); Else b2 = iff(dn6>=1000, dn6, dn6); } Else { If b1 >= 500000 Then b2 = dn1; Else If b1 >= 100000 Then b2 = iff(dn2>=500000, dn1, dn2); Else If b1 >= 50000 Then b2 = iff(dn3>=100000, dn2, dn3); Else If b1 >= 10000 Then b2 = iff(dn4>=50000, dn3, dn4); Else If b1 >= 5000 Then b2 = iff(dn5>=10000, dn4, dn5); Else If b1 >= 1000 Then b2 = iff(dn5>=5000, dn5, dn6); Else b2 = iff(dn6>=1000, dn6, dn7); } } else if CodeCategory() == 8 || CodeCategory() == 9 then { // ETF b2 = dn6; } } plot1(floor(a2)); plot2(Ceiling(b2)); 위 수식이 게시판에서 본 vi수식인데 적용하고나니 첨부한 그림처럼 엔벨로프처럼 나옵니다. vi가격에 맞게 표시하는 방법없나요? 그리고 상승이나 하락 vi해제후 1분동안 매수금지 시스템식을 만드는 방법을 가르쳐주세요 그리고 시초가가찍히고 10봉뒤부터 매수하는 시스템식도 함께 만들어주세요.