커뮤니티

예스랭귀지 Q&A

글쓰기

좋아요 님에 의해서 삭제되었습니다.

프로필 이미지
좋아요
2019-12-13
0
글번호 134345
시스템
답변완료

수식손좀봐주세요

현재값이 wma 돌파를 찾고 그 후 새로운 돌파까지 계단식 선을 그으려고 하는데 잘 나오지가 않아요. 돌파시 wma값과 계단식 선의 값이 틀려요. wma 선을 돌파할때의 가격이 아니고 그 다음날 의 가격이 표시가 되어요. 수정좀 부탁드려요 input : Period(30),d1(1.8),기간(5),k(2); var : wma(0),NL(0),BarsSince(-1); wma = wma((money/v+c+o)/3,period)+D1*std((money/v+c+o)/3,period); if wma < c Then { NL = wma; BarsSince = 0; } Else { if BarsSince >= 0 Then BarsSince = BarsSince+1; } if BarsSince == 기간-k Then var1 = NL; plot1(var1);
프로필 이미지
아무다
2019-12-13
133
글번호 134343
지표
답변완료

시스템식 부탁드립니다.

항상 도움 주셔서 감사합니다. 국내선물 10분봉 RSI 값 구하는 식 a = c-c(1) ; rsi값 : sum(if(a-a(1)>0,a-a(1),0),3)/sum(if(a-a(1)>0,a-a(1),a(1)-a),3)*100 매수조건 : 1. 최근 3일의 RSI 값을 계산하여 전일 RSI값이 30 이하이며 2. 금일 개장 후 첫 1시간 고가(9시~10시)를 돌파시 매수 매수청산 : 익일 시가 청산 매수손절 : 금일 9시 ~ 10시 사이 저가 이탈시 도움 부타드립니다. 감사합니다.
프로필 이미지
양치기
2019-12-13
135
글번호 134342
시스템
답변완료

문의 드립니다.

항상 노고에 감사드립니다. 두가지 질문이 있습니다. 답변 부탁드립니다. print 함수 사용법 관련 질문드립니다. 예를들어 print 함수로 call 270 과 call 272.5 종목을 csv 파일로 저장을 하려고 할때 발생하는 문제에 대한 질문들입니다. 1. 각 종목명을 파일명으로 자동 저장하게 할 수는 없는지요 종목 코드를 반환하는 var : Code(""); Code = SymbolCode; 를 이용해서 가능할 줄 알고 print("c:₩ %s .csv","%.2f, %.2f, %.2f, %.2f", code , data1(open), data1(high), data1(low), data1(close) ); 이런 식으로 했는데 안되네요 ㅠㅠ 2. 그리고 주 종목으로 call 270을 놓고 타주기 참조종목으로 call 272.5 종목을 불러와서 1초 데이타를 저장한다고 할 때 data1(close)와 data2(close)를 print 하면 주종목이 거래가 있던 시간봉(여기서는1초봉) 에 대해서만 data2의 print 값이 이상하게 print 되는 것을 확인 할 수 있었습니다. 혹시 이 문제를 해결할 수 없는지요? 감사합니다. 답변 부탁드립니다.
프로필 이미지
afflatus
2019-12-12
151
글번호 134341
지표
답변완료

문의드립니다

안녕하세요~ 다시 문의드립니다 var : T3(0); var12 = ma(C,50); var13 = ma(C,80); var14 = var12-var13; var15 = -var14; input : short2(12),long2(26),sig2(9); var : MACDV01(0),MACDS01(0); MACDV01 = MACD(short2,long2); MACDS01 = WMA(MACDV01,sig2); if crossup(var14,var15) or CrossDown(var14,var15) Then { value18 = value17[1]; } if var14 > 0 and var14 > var14[1] Then value17 = var14; if var14 < var15 and var15 > var15[1] Then value17 = var15; if crossup(var14,0) Then T3 = 1; if CrossDown(var14,0) Then T3 = -1; if (T3 == 1 and var14 >= value18) and MACDV01 > MACDS01 then { T3 = 2; buy(); } if CrossDown(var12,var13) Then ExitLong(); if (T3 == -1 and var15 >= value18) and MACDV01 < MACDS01 Then { T3 = -2; sell(); } if CrossUp(var12,var13) Then ExitShort(); 1. 첨부파일 그림처럼 밀려서 신호가 나옵니다ㅠ 전제조건인 앞 고점보다 클때, 딱 그시점에서만 다른조건이랑 맞으면 진입하고 다른조건이 안맞으면 신호가 없도록 수정해 주시면 좋겠습니다. 크로스업 크로스다운처럼 특정 시점으로 딱 지정할수는 없을까요? 2. 재상승해서 앞 고점보다 클때도 여전히 신호가 나오는데(첫상승에 다른조건 안맞아서 신호 없다가 재상승때 신호) 처음 상승일때만 신호가 나오도록 같이 부탁드릴게요. 첨부파일에서 뒤에 신호가 그렇네요. 1번 내용에 추가해서 따로 부탁드릴게요. 혹시 이부분은 설명 달아주시면 제가 다른 조건 추가해서 수정해보겠습니다 2번이 힘들다면 처음 1번 내용만큼은 꼭 부탁드리겠습니다 즐거운 주말 보내세요~
프로필 이미지
국산3
2019-12-12
165
글번호 134340
시스템
답변완료

만기일 강제청산 안된 신호상 잔고

[상황] -15분봉이고, 봉은 봉시작 시간으로 표시되게 사용 중입니다. -선물에서 강제청산 탭으로 15:35에 당일청산을 사용해오던 중, 선물옵션만기일은 실제 거래시간종료가 15:20이라서 할 수 없이 강제청산탭에 15:19분으로 설정하여 실제 강제 청산되서 실잔고는 없는 상황입니다. [질문] -만기일 다음날 원래 사용해오던 강제청산탭 15:35분으로 원위치 설정하니, 신호상 미청산 잔고가 남게 되네요.(매수잔고; 수익 상태이고 손절라인에 걸리지 않아서~) -이럴 경우 신호상 미청산 매수잔고로 인해 만기일 다음날은 엇박자가 나게 생겼는데, 시스템수식적으로 처리할 방법은 없나요? - if bdate != bdate[1] Then { "기존 사용 수식" } 으로 넣어봤더니 안되는데 biz date 이해를 잘못했나 봅니다. ㅠ.ㅠ 항상 도움에 감사드리며~~
프로필 이미지
theogo66
2019-12-12
300
글번호 134339
시스템
답변완료

특정가격 n봉동안 모니터링

수식에 의해 도출된 진입희망가격이 나온다음에, 진입희망가격이 나온 뒤, n봉간 모니터링 하면서 그 가격에 도달하는경우 매수 혹은 매도 주문을 내는 로직을 구현하고 싶습니다. 예를들어 크루드오일 매수 진입희망가격이 50.00 이 나온 뒤, n봉 내에서 50.00에 도달하는 경우 atstop 매수 주문 n봉 내에서 50.00에 도달하지 못하는 경우 매수주문 하지 않고 다음진입희망 가격을 찾는 로직으로 돌아감. 크루드오일 매도 진입희망가격이 45.00 이 나온 뒤, n봉 내에서 45.00에 도달하는 경우 atstop 매도 주문 n봉 내에서 45.00에 도달하지 못하는 경우 매도주문 하지 않고 다음진입희망 가격을 찾는 로직으로 돌아감. 구현이 가능하다면 도움 부탁드립니다.
프로필 이미지
노인
2019-12-12
158
글번호 134338
시스템
답변완료

부탁드립니다

수고하십니다 65249번 재질문 입니다 분홍색점 주홍색점 걸리는점 이외에 점들은 백색점 으로부탁드립니다
프로필 이미지
파생돌이
2019-12-12
146
글번호 134337
지표
답변완료

키움 수식 변환점요

eavg(eavg(amount(1)/v(1)*1000000)) ma 로 바꾸면 숫자를 넣으라고 하네요 키움에서는 그냥 이렇게 해도 그래프가 나오는데
프로필 이미지
아무다
2019-12-12
259
글번호 134336
지표
답변완료

호가잔량 표시 고저파동식

안녕하세요 아래 파동식 고저점에 고저점지수와 함께 호가잔량이 표시되도록 부탁드립니다 Input:전환비율(0.05),종가사용여부(0),파동선두께(2),수치표시(1),Left(5),right(5); Var:j(0),jj(0), HH(0),LL(0),hiBar(0),loBar(0),최종꼭지점(""),처리구분(""), TL1(0),Text1(0),Tx(0),순호잔(0); Array:고[10,4](0),저[10,4](0); // 1:가격,2:Index,3:sDate,4:sTime 순호잔 = bids - asks; HH = IFF(종가사용여부 == 1,C,H); LL = IFF(종가사용여부 == 1,C,L); If Index == 0 Then { 고[1,1] = HH; 고[1,2] = 0; 고[1,3] = sDate; 고[1,4] = sTime; 저[1,1] = LL; 저[1,2] = 0; 저[1,3] = sDate; 저[1,4] = sTime; } If Index > 0 Then // Index가 0일때는 이전 봉이 없으므로 Index가 1일때부터 1씩 증가 { hiBar = hiBar + 1; // 최고점을 찍은 고[저]가의 위치를 저장 해놓기 위해 봉번호를 카운트한다. loBar = loBar + 1; } If HH[hiBar] < HH Then hiBar = 0; // 현재 봉이 최고가이면 봉번호를 0으로 초기화 If LL[loBar] > LL Then loBar = 0; Condition1 = 저[1,1] * (1 + (전환비율/100)) < HH and hiBar == 0; // 전저점에서 최소변동률만큼 더한 값보다 고가가 크다면 추세가 변한 것으로 보고 신규 고점으로 인식 Condition2 = 고[1,1] * (1 - (전환비율/100)) > LL and loBar == 0; // 전고점에서 최소변동률만큼 뺀 값보다 저가가 작다면 추세가 변한 것으로 보고 신규 저점으로 인식 처리구분 = ""; If Condition1 and Condition2 Then // 고점과 저점 조건 동시 만족 { If 최종꼭지점 == "저점" Then { If 저[1,1] > LL Then 처리구분 = "저점처리"; Else 처리구분 = "고점처리"; } Else If 최종꼭지점 == "고점" Then { If 고[1,1] < HH Then 처리구분 = "고점처리"; Else 처리구분 = "저점처리"; } } Else If Condition1 Then 처리구분 = "고점처리"; Else If Condition2 Then 처리구분 = "저점처리"; #==========================================# If 처리구분 == "고점처리" Then { If 최종꼭지점 == "저점" Then { For j = 10 DownTo 2 { For jj = 1 To 4 { 고[j,jj] = 고[j-1,jj]; } } 고[1,1] = HH[hiBar]; 고[1,2] = Index - hiBar; 고[1,3] = sDate[hiBar]; 고[1,4] = sTime[hiBar]; hiBar = -1; // 다음 봉의 고가가 기준 고가로 인식되려면 hiBar 값이 0이 되어야 한다. // 봉이 바뀔 때마다 hiBar의 값을 1씩 증가시키므로 다음 봉의 hiBar 값은 0이 된다. loBar = -1; TL1 = TL_New(저[1,3],저[1,4],저[1,1],고[1,3],고[1,4],고[1,1]); If 수치표시 == 1 Then { Text1 = Text_New(고[1,3],고[1,4],고[1,1],NumToStr(고[1,1],2)); Text_SetStyle(Text1, 2, 1); Text_SetColor(Text1,YELLOW); Text_SetSize(Text1, 12); } TL_SetSize(TL1,파동선두께); TL_SetColor(TL1,BLACK); } Else If 고[1,1] < HH[hiBar] Then // 1번 고점보다 높은 고가 출현 { 고[1,1] = HH[hiBar]; 고[1,2] = Index - hiBar; 고[1,3] = sDate[hiBar]; 고[1,4] = sTime[hiBar]; hiBar = -1; loBar = -1; TL_SetEnd(TL1,고[1,3],고[1,4],고[1,1]); // 시작점은 변동없고 끝점의 위치가 현재 봉으로 연장된 것임 If 수치표시 == 1 Then { Text_SetLocation(Text1,고[1,3],고[1,4],고[1,1]); Text_SetString(Text1,NumToStr(고[1,1],2)); } } 최종꼭지점 = "고점"; } #==========================================# If 처리구분 == "저점처리" Then { If 최종꼭지점 == "고점" Then { For j = 10 DownTo 2 { For jj = 1 To 4 { 저[j,jj] = 저[j-1,jj]; } } 저[1,1] = LL[loBar]; 저[1,2] = Index - loBar; 저[1,3] = sDate[loBar]; 저[1,4] = sTime[loBar]; hiBar = -1; loBar = -1; TL1 = TL_New(고[1,3],고[1,4],고[1,1],저[1,3],저[1,4],저[1,1]); If 수치표시 == 1 Then { Text1 = Text_New(저[1,3],저[1,4],저[1,1],NumToStr(저[1,1],2)); Text_SetStyle(Text1, 2, 0); Text_SetColor(Text1,CYAN); Text_SetSize(Text1, 12); } TL_SetSize(TL1,파동선두께); TL_SetColor(TL1,BLACK); } Else If 저[1,1] > LL[loBar] Then { 저[1,1] = LL[loBar]; 저[1,2] = Index - loBar; 저[1,3] = sDate[loBar]; 저[1,4] = sTime[loBar]; hiBar = -1; loBar = -1; TL_SetEnd(TL1,저[1,3],저[1,4],저[1,1]); If 수치표시 == 1 Then { Text_SetLocation(Text1,저[1,3],저[1,4],저[1,1]); Text_SetString(Text1,NumToStr(저[1,1],2)); } } 최종꼭지점 = "저점"; } 그리고 참고로 전에 작성된 스윙고저점 호가잔량표시수식입니다 참고부탁드립니다 input : Left(5),right(5); var : Tx(0),순호잔(0); 순호잔 = bids - asks; if SwingHigh(1,H,Left,right,left+right+1) != -1 Then { tx = Text_New(sdate[right],stime[right],H[right],"순호잔 : "+NumToStr(순호잔,0)); Text_SetStyle(tx,2,1); } if SwingLow(1,L,Left,right,left+right+1) != -1 Then { tx = Text_New(sdate[right],stime[right],L[right],"순호잔 : "+NumToStr(bids,0)); Text_SetStyle(tx,2,0); }
프로필 이미지
bestkim
2019-12-12
214
글번호 134335
지표