커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
1665
글번호 230811
답변완료
시스템에서 지표함수 활용 가능여부?
시스템에서 지표함수 활용 가능여부?
수식작성은 지표함수에서만 작성 가능한데
만약 신호를 강조함수에서 당겨와서 적용하고 싶다고 하면 가능한지 궁금합니다.
예를 들면,
강조창에 모멘텀을 가져와서 모멘텀이 크면 사고 작으면 팔고 이런식으로 상호 지표간에
교차하여 활용할 수 있는지 궁금합니다.
2021-06-02
1679
글번호 149526
답변완료
잔고금액 확인 후 발주수량 산출방법
잔고금액 확인 후 발주수량 산출방법
현금잔고가 10,000원이라고 확인이 되면 이중 50%에 해당하는 수량만큼
발주를 하고 청산 후 금액이 변동이 발생하면 신규 발주시에는
다시 변경된 금액기준으로 50%를 적용하여 발주하라는 수식을 만들고 싶습니다.
2021-06-02
1610
글번호 149525
답변완료
시스템 검증 작업 시 과거 특정 기간 데이터 적용 가능여부
시스템 검증 작업 시 과거 특정 기간 데이터 적용 가능여부
백테스팅을 진행할 때 항상 현재부터 과거 100개봉, 1000개봉 이렇게
일괄 적용이 되는데 특정기간에 전략을 검토하려면 특정 구간만 잘라서
테스트를 할 수 있으면 좋을텐데 그런 기능 또는 방법이 있는지 궁금합니다.
2021-06-02
1498
글번호 149524
답변완료
수식 수정 의뢰드립니다
안녕하세요!
부족한 실력이지만 직접 만들어 본건데 전일중간값 과 당일중간값의 지표가 이상하게 출력이 되네요!
확인 좀 부탁드립니다!
제가 원하는건 콜과 풋옵션 교차챠트의 전일 중간값 과 당일 중간값의 가격선이 나타나도록 하는 겁니다!
그리고 중간값 가격선에 가격이 텍스트로 표시 될 수 있도록 부탁드립니다!
항상 노고에 감사드립니다!
//=========== 지표 출력 ==============
//---- 전일가격 ----
plot1(Data1(HighD(1)), "자기전고");
plot2(Data1(LowD(1)), "자기전저");
plot3(Data2(HighD(1)), "상대전고");
plot4(Data2(LowD(1)), "상대전저");
plot5(((Data1(HighD(1))-(Data1(lowD(1))+(Data2(HighD(1))-(Data2(lowD(1))))/2))), "전일중간값");
//---- 당일가격 ----
plot6(Data1(HighD(0)), "자기당고");
plot7(Data1(LowD(0)), "자기당저");
plot8(Data2(HighD(0)), "상대당고");
plot9(Data2(LowD(0)), "상대당저");
plot10((Data1(HighD(0))+ Data1(lowD(0))/2), "당일중간값");
plot11((Data2(lowD(0))+ Data2(highD(0))/2), "당일중간값1");
--------------------------------------------------------------------
다음은 국내선물에서 사용하는 피보나치 수식입니다!
해외선물에서도 사용할 수 있도록 적용시간 기준을 수정해 주세요!
1. 전일 9시 ~ 익일 0시 까지의 진폭을 당일 9시부터 적용
2. 전일 9시 ~ 익일 5시 까지의 진폭을 당일 9시부터 적용
(항생용은 별도로 만들어주세요)
input : n1(23.6),n2(38.2),n3(50.0),n4(61.8),n5(76.4),n6(100),n7(123.6),n8(138.2),n9(150),n10(161.8),n11(176.4),n12(200),n13(223.6),n14(261.8);
var1 = dayhigh(1)-daylow(1);
plot1(DayOpen+var1*(n1/100));
plot2(DayOpen+var1*(n1/100)+0.05);
plot3(DayOpen+var1*(n2/100));
plot4(DayOpen+var1*(n2/100)+0.05);
plot5(DayOpen+var1*(n3/100));
plot6(DayOpen+var1*(n3/100)+0.05);
plot7(DayOpen+var1*(n4/100));
plot8(DayOpen+var1*(n4/100)+0.05);
plot9(DayOpen+var1*(n5/100));
plot10(DayOpen+var1*(n5/100)+0.05);
plot11(DayOpen+var1*(n6/100));
plot12(DayOpen+var1*(n6/100)+0.05);
plot13(DayOpen+var1*(n7/100));
plot14(DayOpen+var1*(n7/100)+0.05);
plot15(DayOpen+var1*(n8/100));
plot16(DayOpen+var1*(n8/100)+0.05);
plot17(DayOpen+var1*(n9/100));
plot18(DayOpen+var1*(n9/100)+0.05);
plot19(DayOpen+var1*(n10/100));
plot20(DayOpen+var1*(n10/100)+0.05);
plot21(DayOpen+var1*(n11/100));
plot22(DayOpen+var1*(n11/100)+0.05);
plot23(DayOpen+var1*(n12/100));
plot24(DayOpen+var1*(n12/100)+0.05);
plot25(DayOpen+var1*(n13/100));
plot26(DayOpen+var1*(n13/100)+0.05);
plot27(DayOpen+var1*(n14/100));
plot28(DayOpen+var1*(n14/100)+0.05);
plot29(DayOpen-var1*(n1/100));
plot30(DayOpen-var1*(n1/100)-0.05);
plot31(DayOpen-var1*(n2/100));
plot32(DayOpen-var1*(n2/100)-0.05);
plot33(DayOpen-var1*(n3/100));
plot34(DayOpen-var1*(n3/100)-0.05);
plot35(DayOpen-var1*(n4/100));
plot36(DayOpen-var1*(n4/100)-0.05);
plot37(DayOpen-var1*(n5/100));
plot38(DayOpen-var1*(n5/100)-0.05);
plot39(DayOpen-var1*(n6/100));
plot40(DayOpen-var1*(n6/100)-0.05);
plot41(DayOpen-var1*(n7/100));
plot42(DayOpen-var1*(n7/100)-0.05);
plot43(DayOpen-var1*(n8/100));
plot44(DayOpen-var1*(n8/100)-0.05);
plot45(DayOpen-var1*(n9/100));
plot46(DayOpen-var1*(n9/100)-0.05);
plot47(DayOpen-var1*(n10/100));
plot48(DayOpen-var1*(n10/100)-0.05);
plot49(DayOpen-var1*(n11/100));
plot50(DayOpen-var1*(n11/100)-0.05);
plot51(DayOpen-var1*(n12/100));
plot52(DayOpen-var1*(n12/100)-0.05);
plot53(DayOpen-var1*(n13/100));
plot54(DayOpen-var1*(n13/100)-0.05);
plot55(DayOpen-var1*(n14/100));
plot56(DayOpen-var1*(n14/100)-0.05);
plot57(DayOpen);
plot58(DayOpen(1));
2021-06-02
1584
글번호 149523
답변완료
수식 문의
항상 수식 작성에 도움 주셔서 감사합니다.
- 볼린저밴드는 종가로 적용이 되기 때문에 현재봉이 아직 확정되지 않은 상태에서는
현재봉의 움직임에 따라 상하단 밴드도 같이 움직이는 경우가 많이 있습니다.
그래서 현재봉의 움직임과 상관없이 상하단 밴드가 움직이지 않도록 하기 위하여
현재봉의 시가로 적용하는 볼린저밴드 수식을 부탁 드립니다.
* 볼밴(20.2)의 경우
1. 현재봉만 시가를 적용하고, 1일전~19일전까지는 종가를 적용하는 수식
2. 현재봉~19일전까지 모두 시가를 적용하는 수식
2021-06-02
1329
글번호 149522
답변완료
산식검토
아래와 같이 범위를 구분하는 산식을 짜는것이 논리적 흐름에 적당한가요?
각단계별 시스템은 일정한 값을 보이는데
이 4단계를 합쳐서 하나의 시스템으로 만드니 엉뚱한 값을 보입니다
1. Var10<0.3
2. Var10>=0.3 and var11<=16
3. Var10>=0.3 and var11>16 and var11<=26
4. Var10>=0.3 and var11>26
2021-06-02
1369
글번호 149521
답변완료
수식문의
키움증권의 수식인데요.. 대충 특정 기간동안의 고점과 저점을 N등분 하는 선을 나타내게 하려는건데..
첨부파일 차트 처럼 나오게요..
키움증권에서의 수식은 (수식이름을 CL이라고 하였습니다. period는 임의로 설정할수 있게해놨습니다. 이 기간은 416 수치로 고정해도 됩니다.)
1. highest(high, period)
2. CL=valuewhen(1,(highest(h(1),period)<highest(h,period)),((highest(high,Period)+lowest(low,Period))/2));
highest(H, period)-(((highest(H, period)-CL)/5)*2)
(수식은 반복되고.. 끝에 숫자만 늘어납니다)
3. CL=valuewhen(1,(highest(h(1),period)<highest(h,period)),((highest(high,Period)+lowest(low,Period))/2));
highest(H, period)-(((highest(H, period)-CL)/5)*3)
4. CL=valuewhen(1,(highest(h(1),period)<highest(h,period)),((highest(high,Period)+lowest(low,Period))/2));
highest(H, period)-(((highest(H, period)-CL)/5)*4)
5. CL=valuewhen(1,(highest(h(1),period)<highest(h,period)),((highest(high,Period)+lowest(low,Period))/2));
highest(H, period)-(((highest(H, period)-CL)/5)*5)
첨부파일처럼 가능할런가요?
2021-06-01
1652
글번호 149520
답변완료
청산식 좀 봐주십시요.
* 많은 도움에 고맙습니다.
* 아래 수식이 안되는데 어느부분이 잘못되었나요?
## 5개봉합이 20틱 넘으면 청산
value1 = max(h[1],h[2],h[3],h[4],h[5]);
value2 = min(l[1],l[2],l[3],l[4],l[5]);
value3 = value1 - value2 ;
if MarketPosition == 1 and value3 >= c + PriceScale*20 Then ExitLong("SS1CUT3");
if MarketPosition == -1 and value3 <= c - PriceScale*20 Then ExitShort("DD1CUT3");
* 좋은 하루 되십시요.
2021-06-01
1367
글번호 149519
크라켄 님에 의해서 삭제되었습니다.
2021-06-01
35
글번호 149518