커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
4408
글번호 230811
답변완료
시스템 조건식
항상 감사드립니다
아래 조건식을 예스트레이드 시스템식으로 만들고 싶습니다
아래 수식은 하나대투증권 시스템식입니다..
/*************************************************/
1)매수진입
A=StochasticsslowK(FastK기간,SlowK기간,지수);
B=eavg(A,SlowK기간);
Crossup(A,B)
And
E=MACD(C,단기,장기,지수);
F=eavg(E,시그널기간);
Crossup(E,F)
2)매수청산
A=StochasticsslowK(FastK기간,SlowK기간,지수);
B=eavg(A,SlowK기간);
Crossdown(A,B)
And
E=MACD(C,단기,장기,지수);
F=eavg(E,시그널기간);
Crossdown(E,F)
3)매도진입
A=StochasticsslowK(FastK기간,SlowK기간,지수);
B=eavg(A,SlowK기간);
Crossdown(A,B)
And
E=MACD(C,단기,장기,지수);
F=eavg(E,시그널기간);
Crossdown(E,F)
4)매도청산
A=StochasticsslowK(FastK기간,SlowK기간,지수);
B=eavg(A,SlowK기간);
Crossup(A,B)
And
E=MACD(C,단기,장기,지수);
F=eavg(E,시그널기간);
Crossup(E,F)
*/
Params :
FastKPeriod(100), //FastK 기간
SlowKPeriod(28), //SlowK 기간
SlowDPeriod(13), //SlowD 기간
ShortPeriod(9), //단기
LongPeriod(23), //장기
SignalPeriod(8), //시그널기간
_MaType_(2); //2은 가중 <=========중요
Vars:
v1(0),
v2(0),
V3(0),
V4(0);
v1 = StochasticsSlowK(FastKPeriod, SlowKPeriod, _MaType_);
v2 = EAvg(v1, SlowKPeriod);
V3 = MACD(Close, ShortPeriod, LongPeriod, _MaType_) ;
V4 = Eavg(v3, SignalPeriod);
//1)매수진입
if Crossup(v1, v2) And BarNumber > FastKPeriod+SlowKPeriod+1 Then
Buy();
if Crossup(v3, v4) And BarNumber >= LongPeriod + SignalPeriod Then
Buy();
//2)매수청산
if Crossdown(v1, v2) And BarNumber > FastKPeriod+SlowKPeriod+1 Then
ExitLong();
if Crossdown(v3, v4) And BarNumber >= LongPeriod + SignalPeriod Then
ExitLong();
//3)매도진입
if Crossdown(v1, v2) And BarNumber > FastKPeriod+SlowKPeriod+1 Then
Sell();
if Crossdown(v3, v4) And BarNumber >= LongPeriod + SignalPeriod Then
Sell();
//4)매도청산
if Crossup(v1, v2) And BarNumber > FastKPeriod+SlowKPeriod+1 Then
ExitShort();
if Crossup(v3, v4) And BarNumber >= LongPeriod + SignalPeriod Then
ExitShort();
/*************************************************************************/
감사합니다
2018-07-10
161
글번호 120411
답변완료
안녕하세요
매수조건 현재가가 60이평위에있고 5이평이 20이평을골드크로스할때 매수
매도조건 현재가가 60이평위에아래에있고 5이평이 20이평을데드크로스할때 매도
매매시간 22시30분 부터 다음날05시까지 05시에 포지션 강제청산
손절50틱 익절150틱
최대수익에서 -50틱 이면 강제청산
매매중 손실이-150틱이거나 이익이+150틱이면 강제청산후 진입금지
부탁합니다
2018-07-09
120
글번호 120410
답변완료
식 좀 부탁드릴게요~
var : Hswb(0), Lswb(0), hb(0), lb(0) ,Left2(10), Right2(10) ;
Hswb = SwingHighbar(1,h,10,10,200);
Lswb = SwingLowbar(1,L,10,10,200);
hb = NthHighestBar(1,H,BarsSinceEntry);
lb = NthLowestBar(1,L,BarsSinceEntry);
if SwingLow(1,L,Left2,right2,Left2+Right2+1) != -1 Then{
value5 = L[right2];
value6 = tic20[right2];
value9 = tic5[right2];
}
if Swinghigh(1,H,Left2,right2,Left2+Right2+1) != -1 Then{
value7 = H[right2];
value8 = tic20[right2];
value10 = tic5[right2];
}
if MarketPosition == 1 and highest(H,BarsSinceEntry) > value7+PriceScale*0 then
ExitLong("항롱꼭지점스탑",atstop,Value5-PriceScale*3);
if MarketPosition == -1 and Lowest(L,BarsSinceEntry) < value5-PriceScale*0 then
ExitShort("항숏꼭지점스탑",AtStop,Value7+PriceScale*3);
////////////////////////
위 식은 제가 좀 도전해 보다가 어려워서 도움요청하는 식입니다.
구하고자 하는 내용은 20일선파동 기준으로 해서
20일선의 직전고점을 돌파했을시에 직전저점아래 3틱자리에서 청산하는 식입니다.
직전저점은 돌파된 직전고점 아래에 위치해 있는 쌍바닥저점이어야 하구요.
이런식으로 20일선파동 기준으로 또한번 직전고점을 돌파하면 높아진 직전저점아래3틱으로
다시 변경되구요.
최대한 단순하게 식을 좀 구하고 싶은데 어렵네요 도움요청합니다.
---------------------------
조금더 자세히 풀어보면 진입후에 최고값이 직전스윙하이보다 높아지면
직전스윙하이보다 작은 직전스윙로우(쌍바닥완성지점)아래3틱에서 청산
그리고 또한번 최고값이 직전스윙하이보다 높아지면
직전스윙하이보다 작은 직전스윙로우아래3틱에서 청산
여기서 중요한 점이 직전스윙로우아래3틱청산지점이 직전스윙하이보다 높아질 당시의
직전스윙로우여야 된다는 점입니다. 이후로 생성되는 스윙로우에서는 적용이 되면 안된다는 점이에요. 즉 직전고점을 돌파하지 않은 새롭게 형성된 저점에서는 적용이 되면 안된다는 점입니다.
또다시 직전스윙하이를 돌파했을시점의 스윙로우에서만 적용될 수 있도록 부탁드립니다.
스윙하이조건은 좌우10봉이고 스윙하이생성시점의 5일선이20일선보다커야하고 스윙하이가격이 20일선보다 커야 합니다.
스윙로우조건도 좌우10봉이고 스윙로우생성시점의 5일선이20일선보다작아야하고 스윙로우가격이 20일선보다 작아야 합니다.
반대방향도 마찬가지구요~
감사합니다.~
2018-07-09
166
글번호 120409
답변완료
문의드립니다
수고하십니다
1. 주가가 60 이동평균선 보다 위에 있다가 60이동평균선까지 반락하여 닿을 때
60 MA 값에서 2개 매수
매수후 0.40 손절
1.25 1개 수익청산,
1개 60MA 붕괴 청산
2. 주가가 60 이동평균선 보다 아래에 있다가 60이동평균선까지 반등하여 닿을 때
60 MA 값에서 매도
매수후 0.40 손절
1개 1.25 수익청산
1개 60 MA 돌파시 청산
시스템식문의 드립니다. 감사합니다.
2018-07-09
131
글번호 120408
답변완료
이거 어떻게 구현하나요?
주문체결과 차트에 평균단가 선이 그어지는 지표식을 구현해보려고 하는데 구현이 잘안됩니다. 어떻게 표현하나요?
2018-07-09
171
글번호 120407
답변완료
부탁 드립니다.
도움 주심에 감사 드립니다.
아래 수식이 그림과 같이 그려지도록 부탁 드립니다.
미리 감사 드립니다.
Input:length(10);
Var:TL1(0),TL2(0),TL2_exist(0),color(0),
종가사용여부(0), // 종가로 계산하려면 1로 설정한다.
TL_NewBit(0), // 1:NewLine 2:SetEndLine
slope(0),mid_idx(0),mid_val(0);
Array:고[10,4](0),저[10,4](0); // 1:가격,2:Index,3:sDate,4:sTime
#==========================================#
Value1 = HiLoLineZigZag(length,종가사용여부,고,저,TL_NewBit);
// HiLoLineZigZag는 사용자함수입니다. 링크에서 내려받으세요..
If Value1 == 1 Then { // 고점
If TL_NewBit == 1 Then { // 신규
If 고[2,1] < 고[1,1] Then { // 신규 고점이 이전 고점을 상향 돌파
// y = 기울기 * x + 절편
// x = (y - 절편) / 기울기
// y = 고[2,1]
// 절편 = 저[1,1]
slope = (고[1,1] - 저[1,1]) / (고[1,2] - 저[1,2]); // 추세선의 기울기
mid_idx = Floor((고[2,1] - 저[1,1]) / slope); // 고[2,1]과 만나는 지점
mid_val = slope * mid_idx + 저[1,1];
Var1 = Index - (저[1,2] + mid_idx); // 추세선의 중간지점 x좌표
TL1 = TL_New(저[1,3],저[1,4],저[1,1],sDate[Var1],sTime[Var1],mid_val);
TL2 = TL_New(sDate[Var1],sTime[Var1],mid_val,고[1,3],고[1,4],고[1,1]);
Var2 = Index - 저[1,2]; // 이전 색깔을 따라감
TL_SetColor(TL1,color[Var2]);
color = RED; // 상향 돌파했으므로 빨간색으로 전환
TL_SetColor(TL2,color);
TL2_exist = 1; // 추세선 2개를 연결해서 그린 것이므로 추세선이 2개임을 저장
} Else {
TL1 = TL_New(저[1,3],저[1,4],저[1,1],고[1,3],고[1,4],고[1,1]);
TL_SetColor(TL1,color);
TL2_exist = 0;
}
}
If TL_NewBit == 2 Then { // 연장
TL_Delete(TL1);
If TL2_exist == 1 Then TL_Delete(TL2); // 추세선이 2개면 두번째 추세선도 삭제
If 고[2,1] < 고[1,1] Then {
slope = (고[1,1] - 저[1,1]) / (고[1,2] - 저[1,2]);
mid_idx = Floor((고[2,1] - 저[1,1]) / slope);
mid_val = slope * mid_idx + 저[1,1];
Var1 = Index - (저[1,2] + mid_idx);
TL1 = TL_New(저[1,3],저[1,4],저[1,1],sDate[Var1],sTime[Var1],mid_val);
TL2 = TL_New(sDate[Var1],sTime[Var1],mid_val,고[1,3],고[1,4],고[1,1]);
Var2 = Index - 저[1,2];
TL_SetColor(TL1,color[Var2]);
color = RED;
TL_SetColor(TL2,color);
TL2_exist = 1;
} Else {
TL1 = TL_New(저[1,3],저[1,4],저[1,1],고[1,3],고[1,4],고[1,1]);
TL_SetColor(TL1,color);
TL2_exist = 0;
}
}
} Else If Value1 == -1 Then { // 저점
If TL_NewBit == 1 Then { // 신규
If 저[2,1] > 저[1,1] Then {
slope = (저[1,1] - 고[1,1]) / (저[1,2] - 고[1,2]);
mid_idx = Floor((저[2,1] - 고[1,1]) / slope);
mid_val = slope * mid_idx + 고[1,1];
Var1 = Index - (고[1,2] + mid_idx);
TL1 = TL_New(고[1,3],고[1,4],고[1,1],sDate[Var1],sTime[Var1],mid_val);
TL2 = TL_New(sDate[Var1],sTime[Var1],mid_val,저[1,3],저[1,4],저[1,1]);
Var2 = Index - 고[1,2];
TL_SetColor(TL1,color[Var2]);
color = BLUE;
TL_SetColor(TL2,color);
TL2_exist = 1;
} Else {
TL1 = TL_New(고[1,3],고[1,4],고[1,1],저[1,3],저[1,4],저[1,1]);
TL_SetColor(TL1,color);
TL2_exist = 0;
}
}
If TL_NewBit == 2 Then { // 연장
TL_Delete(TL1);
If TL2_exist == 1 Then TL_Delete(TL2);
If 저[2,1] > 저[1,1] Then {
slope = (저[1,1] - 고[1,1]) / (저[1,2] - 고[1,2]);
mid_idx = Floor((저[2,1] - 고[1,1]) / slope);
mid_val = slope * mid_idx + 고[1,1];
Var1 = Index - (고[1,2] + mid_idx);
TL1 = TL_New(고[1,3],고[1,4],고[1,1],sDate[Var1],sTime[Var1],mid_val);
TL2 = TL_New(sDate[Var1],sTime[Var1],mid_val,저[1,3],저[1,4],저[1,1]);
Var2 = Index - 고[1,2];
TL_SetColor(TL1,color[Var2]);
color = BLUE;
TL_SetColor(TL2,color);
TL2_exist = 1;
} Else {
TL1 = TL_New(고[1,3],고[1,4],고[1,1],저[1,3],저[1,4],저[1,1]);
TL_SetColor(TL1,color);
TL2_exist = 0;
}
}
}
TL_SetSize(TL1,2);
TL_SetSize(TL2,2);
적용된 함수식)
//함수명--->HiLoLineZigZag
Input:Length(NumericSimple),useCLprice(NumericSimple),
oHiZZ[MaxSize1,MaxSize2](NumericArrayRef), // 열번호 1:가격,2:Index,3:sDate,4:sTime
oLoZZ[MaxSize3,MaxSize4](NumericArrayRef),
oTL_NewBit(NumericRef); // 1:NewLine 2:SetEndLine
Var:j(0),jj(0),HH(0),LL(0),최종고가(0),최종저가(0),최종꼭지점(""),처리구분("");
#==========================================#
HH = IFF(useCLprice==1,C,H);
LL = IFF(useCLprice==1,C,L);
If Index == 0 Then {
oHiZZ[1,1] = HH;
oLoZZ[1,1] = LL;
}
Condition1 = Highest(HH,length) == HH and 최종고가 <> HH;
Condition2 = Lowest (LL,length) == LL and 최종저가 <> LL;
처리구분 = "";
If Condition1 and Condition2 Then { // 기간고점과 기간저점 동시 발생
If oHiZZ[1,1] < HH and oLoZZ[1,1] > LL Then { // 기존의 파동을 벗어난 경우
If HH - oHiZZ[1,1] > oLoZZ[1,1] - LL Then // 많이 벗어난 쪽으로 처리
처리구분 = "고점처리";
Else If HH - oHiZZ[1,1] < oLoZZ[1,1] - LL Then
처리구분 = "저점처리";
Else If 최종꼭지점 == "저점" Then // 벗어난 정도가 동일하면 지그재그 순서대로
처리구분 = "고점처리";
Else
처리구분 = "저점처리";
} Else If oLoZZ[1,1] > LL Then 처리구분 = "저점처리";
Else If oHiZZ[1,1] < HH Then 처리구분 = "고점처리";
Else If 최종꼭지점 == "저점" Then 처리구분 = "고점처리";
Else 처리구분 = "저점처리";
} Else If Condition1 Then 처리구분 = "고점처리";
Else If Condition2 Then 처리구분 = "저점처리";
oTL_NewBit = 0;
#==========================================#
If 처리구분 == "고점처리" Then {
최종고가 = HH; // 신규고점을 체크하기 위해 저장
If 최종꼭지점 == "저점" Then {
For j = 10 DownTo 2 {
For jj = 1 To 4 {
oHiZZ[j,jj] = oHiZZ[j-1,jj];
}
}
oHiZZ[1,1] = HH;
oHiZZ[1,2] = Index;
oHiZZ[1,3] = sDate;
oHiZZ[1,4] = sTime;
oTL_NewBit = 1;
} Else If oHiZZ[1,1] < HH Then { // 1번 고점보다 높은 고가 출현
oHiZZ[1,1] = HH;
oHiZZ[1,2] = Index;
oHiZZ[1,3] = sDate;
oHiZZ[1,4] = sTime;
oTL_NewBit = 2;
}
최종꼭지점 = "고점";
}
#==========================================#
If 처리구분 == "저점처리" Then {
최종저가 = LL;
If 최종꼭지점 == "고점" then {
For j = 10 DownTo 2 {
For jj = 1 To 4 {
oLoZZ[j,jj] = oLoZZ[j-1,jj];
}
}
oLoZZ[1,1] = LL;
oLoZZ[1,2] = Index;
oLoZZ[1,3] = sDate;
oLoZZ[1,4] = sTime;
oTL_NewBit = 1;
} Else If oLoZZ[1,1] > LL then {
oLoZZ[1,1] = LL;
oLoZZ[1,2] = Index;
oLoZZ[1,3] = sDate;
oLoZZ[1,4] = sTime;
oTL_NewBit = 2;
}
최종꼭지점 = "저점";
}
If 최종꼭지점 == "고점" Then HiLoLineZigZag = 1;
Else If 최종꼭지점 == "저점" Then HiLoLineZigZag = -1;
Else HiLoLineZigZag = 0;
2018-07-09
302
글번호 120406
답변완료
수식 부탁드립니다
5,20이평 골든크로스일때 최고가를 연결하는선
5,20이평 데드트로스일때 최저가를 연결하는선
2018-07-09
135
글번호 120405
답변완료
문의드립니다
안녕하세요.
피보나치 수식 하나 부탁드립니다.
전일 종가를 저점으로 하고, 당일 고가를 고점으로 하는 기본식인데...
전일 종가보다 당일 저가가 더 낮으면, 저점을 당일의 저가로 합니다.
지수가 하락을 하게될 경우를 생각해서
고점 역시 당일의 고가보다 전일 종가가 높으면 고점은 전일의 종가로 합니다.
이상을 바탕으로 피보나치 수식 부탁 드리겠습니다.
수고하세요^^
2018-07-09
136
글번호 120404
답변완료
시간조정
아래식을 아침9시 이후 부터 오후3시까지
범위 안에서만 신호가 나올수 있도록 만들어 주십시오.
가능하면 시간 조정을 할수 있도록 부탁 드립니다.
Input : af1(0.02), maxAF1(0.2);
Input : af2(0.02), maxAF2(0.2);
input : P(60);
var : sarv1(0),sarv2(0),mav(0);
sarv1 = sar(af1,maxAF1);
sarv2 = sar(af2,maxAF2);
mav = ma(C,P);
If C > sarv1 and C > mav Then
{
if C > sarv1 Then
Buy();
Else
ExitShort();
}
If C < sarv1 and C < mav Then
{
if C < sarv2 Then
Sell();
Else
ExitLong();
}
2018-07-09
120
글번호 120403