커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
1648
글번호 230811
답변완료
선행스팬1.2 위치조정을 하고 싶습니다
선행스팬 26봉 앞에 있는걸
5봉 앞으로 위치조정 해보고 싶습니다.알려주세욧
부탁 드립니다...
2021-08-11
904
글번호 151439
답변완료
국내 주식 시스템 식 부탁드림니다.
국내 주식
1. data1 5분봉
매수 진행
매일
9시 10분에 5만원어치 매수
12시 10분에 5만원어치 매수
3시 10분에 5만원어치 매수
매수 청산
매수후 매수 평균이 5% 일때 전체 수량이 50% 청산
50% 청산후 평균매수가가 마이너스가 안될경우 나머지 50%는 10% 에서 전량 청산
50% 청산후 평균 매수가가 마이너스가 될경우 나머지50%도 5%에서 전량 청산
예를들면
매수는 매일 하루에 3회 일정 금액 매수
매수평균가에서 5% 수익달성시 매수수량의 50% 5%에 청산
나머지는 매수평균 수익률이 0%이하로 떨어지지 않는한 10% 수익에 나머지 전량 청산
만약 50% 청산후 매수평균 수익률이 0%이하로 떨어질경우는 평균 수익률이 5% 될때 전량 청산 입니다.
PS
분할매도가 100회가 되지 않고 50회정도 된다음에도 매수 조건 발생시
누적 매수가 되는 수식이 가능할까요?
2021-08-11
849
글번호 151438
동동이아빠 님에 의해서 삭제되었습니다.
2021-08-11
7
글번호 151437
답변완료
부탁 드립니다.
도움에 감사 드립니다.
지정된 일자
예를 들어 2021월 1월 1일에 지정하면 공휴일이고
1월2일(토요일), 1월3일(일요일)이라 지표가 나타 나지 않습니다.
1/1일을 지정하더라도 1/4(월요일)부터
지표가 나타 나게 할수 있는지요 ?
input:일자(20210101);
var:sum3(0),v3(0);
v3=v;
if Condition1 == false and sdate == 일자 Then
Condition1 = true;
if Condition1 == true and Condition1[1] == false Then
{
sum3 = 0;
}
if Condition1 == true then
{
sum3 = sum3 + v3;
}
plot2(sum3);
PlotBaseLine1(0);
2021-08-11
644
글번호 151436
좋운날 님에 의해서 삭제되었습니다.
2021-08-11
54
글번호 151435
답변완료
지표 부탁드립니다.
늘 감사합니다.
다름이 아니오라
1. 선물 20일간의 고점평균과 저점평균을 4등분해서 선으로 표기하였으면 합니다.
그리고 텍스트 표시로 "20일 430.25" 모양으로 나왔으면 좋겠습니다.
선색깔은 색상표에 나와있는 색으로 조합하여 만들었으면 합니다.
2. 전일 종가와 금일 시가 사이를 장시작과 동시에 4등분선으로 하였으면 합니다.
이상입니다.
감사합니다.
2021-08-11
888
글번호 151432
답변완료
수식 문의 드립니다ㅠ
코스피 200 선물 분봉 거래에서
예를 들어 15분봉을 사용
4번째 Bar(DayIndex == 3)의, High, Low, DayIndex를 별개의 변수로 저장하고
5번째 이후의 Bar에서
만약 High를 돌파하면 그 지점에서 AtStop으로 "Long" 진입
만약 Low를 돌파하면 그 지점에서 AtStop으로 "Short" 진입
진입하였다면 그 봉 번호와 가격정보(OHLC)를 뒤에 봉이 진행되더라도 변하지 않게끔
변수에 저장하고 싶습니다
High도 돌파하고, Low도 돌파하면, 보유하고 있었던 포지션을 청산(어떻게 작성해야 할지 모르겠음..)
이런 수식을 아래와 같이 작성해보았는데요
========================================================
시스템 수식
Var : Bar_4_High(0), Bar_4_Low(0), Bar_4_Index(0), Buy_Target(0), Sell_Target(0);
Var : Entry_Bar_High(0), Entry_Bar_Low(0), Entry_Bar_Index(0);
If bdate != bdate[1] Then {
Bar_4_High = 0;
Bar_4_Low = 0;
Bar_4_Index = 0;
Buy_Target = 0;
Sell_Target = 0;
Entry_Bar_Index = 0;
Entry_Bar_High = 0;
Entry_Bar_Low = 0;
}
If DayIndex + 1 == 4 Then {
Bar_4_High = H;
Bar_4_Low = L;
Bar_4_Index = DayIndex + 1;
Buy_Target = Bar_4_High + PriceScale;
Sell_Target = Bar_4_Low - PriceScale;
}
If (DayIndex + 1 >= 5) and (Bar_4_High != 0) and (Close >= Bar_4_High) and !(Close <= Bar_4_Low) then {
Buy("Buy", AtStop, Buy_Target);
Entry_Bar_Index = DayIndex + 1;
}
If (DayIndex + 1 >= 5) and (Bar_4_High != 0) and !(Close >= Bar_4_High) and (Close <= Bar_4_Low) then {
Sell("Sell", AtStop, Sell_Target);
Entry_Bar_Index = DayIndex + 1;
}
If DayIndex + 1 == Entry_Bar_Index Then {
Entry_Bar_High = H;
Entry_Bar_Low = L;
}
SetStopEndofday(1510);
===================================================
지표 수식
Var : Bar_4_High(0), Bar_4_Low(0), Bar_4_Index(0), Buy_Target(0), Sell_Target(0);
Var : Entry_Bar_High(0), Entry_Bar_Low(0), Entry_Bar_Index(0);
If bdate != bdate[1] Then {
Bar_4_High = 0;
Bar_4_Low = 0;
Bar_4_Index = 0;
Buy_Target = 0;
Sell_Target = 0;
Entry_Bar_Index = 0;
Entry_Bar_High = 0;
Entry_Bar_Low = 0;
}
If DayIndex + 1 == 4 Then {
Bar_4_High = H;
Bar_4_Low = L;
Bar_4_Index = DayIndex + 1;
Buy_Target = Bar_4_High + PriceScale;
Sell_Target = Bar_4_Low - PriceScale;
}
If (DayIndex + 1 >= 5) and (Bar_4_High != 0) and (Close >= Bar_4_High) and !(Close <= Bar_4_Low) then {
//Buy("Buy", AtStop, Buy_Target);
Entry_Bar_Index = DayIndex + 1;
}
If (DayIndex + 1 >= 5) and (Bar_4_High != 0) and !(Close >= Bar_4_High) and (Close <= Bar_4_Low) then {
//Sell("Sell", AtStop, Sell_Target);
Entry_Bar_Index = DayIndex + 1;
}
If DayIndex + 1 == Entry_Bar_Index Then {
Entry_Bar_High = H;
Entry_Bar_Low = L;
}
Plot1(Bar_4_High);
Plot2(Bar_4_Low);
Plot3(Bar_4_Index);
plot4(Buy_Target);
plot5(Sell_Target);
plot6(Entry_Bar_Index);
plot7(Entry_Bar_High);
plot8(Entry_Bar_Low);
=====================================================
이렇게 작성을 한다면 이르면 바로 다음 봉에서라도 진입이 일어나야 할 것 같은데
진입이 늦어지고 또한 첫 번째 봉에서도 진입이 일어나는 현상을 보고 있습니다
제가 무언가를 잘못 파악하고 있는데 도움좀 주시면 감사하겠습니다
예를 들어 위의 산식 복사해서 KP200 선물 15분봉에 적용해보면
8월 10일자 기준
첫 번째 봉에서 BUY 진입이 일어나는 것도 이상하고..
4번봉의 Low지점을 뚫었으니까 6번봉에서 바로 AtStop으로 주문이 나가야 할 것 같은데
7번봉에서 주문이 나가는 것으로 되어있더라고요..
지표를 출력해보면 Entry_Bar_Index가 계속 DayIndex가 증가함에 따라 따라서 증가하고 있어서 High, Low도 계속 바귀네요..
Buy, Sell 주문을 넣는 If 문이 딱 한 번만 실행되게 해야 하는데..
For 문 안에 If문을 넣어야 하나요..?
해결책좀 주시기 바랍니다ㅠ
2021-08-11
992
글번호 151431
답변완료
거래량 없는 구간 지표 출력
항상 빠르고 상세한 답변을 주셔서
많은 도움을 받고 있습니다. 감사합니다.
첨부한 이미지는 설명을 드리기 위해
콜 9월물 425 와 8월물 425의 양합선을 예시로 그려 본 것입니다.
그림에서 핑크색 사각 표시 부분이
data1의 거래가 없는 구간입니다.
이때 하단의 지표도 출력(사각 표시)되지 않고 있습니다.
이렇게 거래가 없는 구간에도 지표가 나오게 할수 있는 방법이 있을까요?
예를들면 마지막 거래가격인 8.33을
양합 산출에서 최종 종가로(또는 다른 방법) 인식하게 할 수 있는지요?
----- 지표식(예시) -----
//양합선
var : 양합(0);
양합 = Data1(c) + Data2(c);
Plot11(양합, "양합");
2021-08-11
940
글번호 151430
답변완료
수고하십니다
수고하십니다
아래 수식을 파동중 마지막현재파동에만
적용되는 수식 요청 합니다
var : LRLv(0),LRSv(0),cnt(0),maxR(0),Mid(0);
var : TL1(0),TL2(0),TL3(0),idx(0),idx1(0);
if Bdate != Bdate[1] Then
{
idx = Index;
idx1 = idx[1];
}
if idx1 > 0 Then
{
LRLv = LRL(C,index-idx1);
LRSv = LRS(C,Index-idx1);
maxR = 0;
For cnt = 0 to Index-idx1
{
Mid = LRLV-LRSv*cnt;
if abs(L[cnt]-Mid) > maxR Then
maxR = abs(L[cnt]-Mid);
if abs(H[cnt]-Mid) > maxR Then
maxR = abs(H[cnt]-Mid);
}
TL_Delete(TL1);
TL1 = TL_New(sDate[Index-idx1],sTime[Index-idx1],Mid,sDate,sTime,LRLv);
TL_SetExtRight(TL1,true);
2021-08-11
861
글번호 151429