커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
4317
글번호 230811
답변완료
수식 작성 요청드립니다.
안녕하세요.
요청드릴 지표는
매수영역 : 20, 12 두 이동평균선 상승, MACD > 0, 전환선(5) > 전환선(9) 정배열 일때
바탕색을 노란색
매도영역 : 20, 12 두 이동평균선 하락, MACD < 0, 전환선(5) < 전환선(9) 역배열 일때
바탕색을 하늘색
감사합니다.
2017-11-05
173
글번호 113901
답변완료
문의 드립니다.
변수 var1, var2, var3, var4, var5 중에서 0보다 큰 것의 갯수를 식으로 표현하고 싶습니다.
CountIF(condition,Period) 함수로는 할 수 없는 것같아서 ..... 도움을 부탁드립니다.
2017-11-04
172
글번호 113900
답변완료
수식작성 부탁드려요
프로그램언어가 미숙해 도움이 필요합니다 ㅠㅠ
'변동성'을 간단하게 지표로 만들어 print함수로 엑셀출력가능하도록 하고싶습니다.
우선 월봉기준으로, (지금으로부터 n번째 전 월봉의 종가)/(지금으로부터 n+1번째 전 월봉의 종가)를 '수익률'로 정의할때, 최근 12개월 수익률들의 표준편차의 역수를 매달 지수로 출력되도록 하고싶습니다.
예를들어 10월 31일날 이 지수를 확인한다면 (10월종가/9월종가), (9월종가/8월종가).... 해서 12개 값의 표준편차의 역수를 구하고 싶습니다.
도움 부탁드립니다. 감사합니다.
2017-11-04
178
글번호 113899
답변완료
예스수식으로 변환이 안되어 문의드립니다.
EL식으로 새로작성 택하여 아래의 EL식을 넣으면 문제가 몇개 나옵니다.
제가 EL식과 예스 수식을 잘 이해하지 못해서 그런 것을 수도 있고
예스에서 지원되는 EL모드의 범위를 잘 몰라서 그런 것일 수도 있는데 도움 부탁드립니다.
EL(EasyLanguage)의 함수에 대한 YesLang 변환표라도 있으면 좋겠습니다.^^
함수 변환표라도 있으면 이메일로 받고 싶습니다.
Inputs: Price(Close), LRLen(20), AvgLen(15), MomLen(10), Pcnt(.5);
Vars: XLinReg(0), Mom(0), SetBarH(0), SetBarL(0), SetBarS(0), CountL(0), CountS(0);
{Assignment of Exponential Linear Regression and Momentum}
XLinReg = XAverage(LinearRegValue(Price, LRLen, 0), AvgLen);
Mom = Momentum(Price, MomLen);
{Accumulates to count the bars after the SetUps below}
CountL = CountL + 1;
CountS = CountS + 1;
{Assignment of System Entry/Exit criteria}
Condition1 = XLinReg > XLinReg[1];
Condition2 = Mom < 0 AND Mom > Mom[1];
Condition3 = XLinReg < XLinReg[1];
Condition4 = Mom > 0 AND Mom < Mom[1];
{Check criteria and generate Buy order if criteria have been met within 4 bars}
IF Condition1 AND Condition2 Then Begin
IF CountL = 1 OR CountL > 4 Then Begin
SetBarL = High;
CountL = 1;
End;
IF CountL <= 4 Then Begin
value1 = Pcnt * (SetBarL - XLinReg);
Buy ("Long") Next Bar at SetBarL + value1 Stop;
End;
End;
{Check criteria and generate Sell order if criteria have been met within 4 bars}
IF Condition3 AND Condition4 Then Begin
IF CountS = 1 OR CountS > 4 Then Begin
SetBarS = Low;
CountS = 1;
End;
IF CountS <= 4 Then Begin
value1 = Pcnt * (SetBarS - XLinReg);
Sell ("Short") Next Bar at SetBarS - value1 Stop;
End;
End;
{Initial Stops}
ExitLong ("X")Next Bar from entry ("Long") AT$ Low - (Pcnt * AvgTrueRange(10)) Stop;
ExitShort ("Y")Next Bar from entry ("Short") AT$ High + (Pcnt * AvgTrueRange(10)) Stop;
{Trailing Stops}
IF Condition3 AND Low < Lowest(Low, 4)[1] Then
ExitLong Next Bar at Market;
IF Condition1 AND High > Highest(High, 4)[1] Then
ExitShort Next Bar at Market;
2017-11-06
300
글번호 113898
답변완료
문의드립니다..
if Condition1 == false and dayopen+PriceScale < 50 and crossup(c,r2) Then
buy("buy",Atlimit,R2);
이진입식을 30분차트에서 사용중인데 10분봉기준으로 조건만족시 진입되게하려면
어떻게 하는지 알려주시면 감사하겠습니다..
2017-11-04
157
글번호 113897
답변완료
문의드립니다
일봉이나 분봉에서 전봉에 고가나저가에(고가선저가선)2개 나오게, 항상현재봉말고전봉에수평선이2개나오게합니다 . 현재봉이,전봉을고가를돌파하면저가선만 나오고 전봉의고가선은사라지게하고~~
반대로현재봉이전봉을 저가를돌파하면고가선은나오고전봉의 저가선은 사라지게 2개선색상은 지정하게끔부탁드립니다~~~미리감사드립니다
2017-11-04
182
글번호 113896
답변완료
문의 드립니다.
안녕하세요
Input : shortPeriod(12), longPeriod(26), Period(9);
value1 = MACD(shortPeriod, longPeriod);
value2 = ema(value1, Period);
if C <= BBup-PriceScale*5 and C >= BBdn+PriceScale*5 Then{
If CrossUP(value1, value2) Then
{
buy("bMACD");
}
If CrossDown(value1, value2) Then
{
sell("sMACD");
}
}
상기 수식에서 하기와 같이 추가하고 싶은 것이 있어서 문의 드립니다.
1.
가끔가다 보면 MACD가 양에서 음으로 바뀐다음에 다시 양으로 바로 바뀌는 경우가 발생합니다.
즉 매수 진입 후 다음봉에서 바로 매도로 진입되는데...반대경우도 마찬가지구요...
일단 진입후 2번째 봉까지는 진입한 포지션이 바뀌지 않도록 할 수 있는지 수식 부탁드립니다.
세번째 부터 바뀌는 것에는 적용되도록 부탁드립니다.
2.
저는 상기 수식을 10분봉에 사용하는데, 20분봉을 같이 data 2로 연계해서 사용하면서
20분봉의 상기 수식도 같이 적용되는 방법이 없는지요,
즉 10분봉이나 20분봉이나 매수나 매도 신호가 발생되면, 약간의 진입가격의 차이는 있겠지만, 두가지 봉 모두 진입하게되는 방법이 없는지요?
상기 두가지 검토 부탁드립니다.
2017-11-03
163
글번호 113895
답변완료
지표에 이런것들 있는지 이게 뭔지 정확히 의미 좀 부탁드립니다..
On= <ㅡ 뭘 뜻하는지요?
Height= <ㅡ뭘뜻하는지..
Index= <ㅡ 뭘뜻하는지..
option <ㅡ 뭘뜻하는지...
term <ㅡ이것도 뭘 뜻하는지..
loStan <이건 어디에 지표에 잇고 뭘뜻하는지..?
hiStan <이건 어디에 지표에 잇고 뭘뜻하는지..?
2017-11-03
198
글번호 113894
답변완료
Array boundary out reached ?
안녕하세요.
주간장 일봉과 야간장 일봉을 각각 하나의 일봉으로 보고 볼린저 밴드를 그려 실시간으로 1분봉에 표현하려고 다음과 같은 식을 만들었습니다.
식을 실행하면 'Array boundary out reached' 라는 에러와 함께 프로그램이 종료됩니다.
array[100]이 너무 크다는 얘기 같아 array[10] 으로 줄여서 해 봤지만 동일한 결과를 만났습니다.
어떻게 수정해야 할지 가르침 부탁드립니다.
감사합니다.
----------------------------------------------------------------------------------------
Variables : cnt(0);
Array : 주간일봉_시가[100](0), 주간일봉_고가[100](0), 주간일봉_저가[100](0), 주간일봉_종가[100](0);
Array : 야간일봉_시가[100](0), 야간일봉_고가[100](0), 야간일봉_저가[100](0), 야간일봉_종가[100](0);
Array : 복합일봉_시가[100](0), 복합일봉_고가[100](0), 복합일봉_저가[100](0), 복합일봉_종가[100](0);
Array : 환산일봉_시가[100](0), 환산일봉_고가[100](0), 환산일봉_저가[100](0), 환산일봉_종가[100](0);
# ---<<< 주간장 >>>----------------------------------------------------------------------------
If (sDate[1] != sDate And 090000 <= sTime) Or
(sDate[1] == sDate And sTime[1] < 090000 And 090000 <= sTime) Then Begin # 주간일봉 첫봉
복합일봉_시가[0] = Open;
복합일봉_고가[0] = High;
복합일봉_저가[0] = Low;
복합일봉_종가[0] = Close;
주간일봉_시가[0] = Open;
주간일봉_고가[0] = High;
주간일봉_저가[0] = Low;
주간일봉_종가[0] = Close;
For cnt = 1 To 99 Begin
복합일봉_시가[cnt] = 복합일봉_시가[cnt-1][1];
복합일봉_고가[cnt] = 복합일봉_고가[cnt-1][1];
복합일봉_저가[cnt] = 복합일봉_저가[cnt-1][1];
복합일봉_종가[cnt] = 복합일봉_종가[cnt-1][1];
End;
End;
If 090000 <= sTime And sTime < 180000 then Begin # 주간장
If 주간일봉_고가[0] < High Then 주간일봉_고가[0] = High;
If 주간일봉_저가[0] > Low Then 주간일봉_저가[0] = Low;
주간일봉_종가[0] = Close;
복합일봉_고가[0] = 주간일봉_고가[0];
복합일봉_저가[0] = 주간일봉_저가[0];
복합일봉_종가[0] = 주간일봉_종가[0];
End;
# ---<<< 야간장 >>>----------------------------------------------------------------------------
If (sDate[1] != sDate And 180000 <= sTime) Or
(sDate[1] == sDate And sTime[1] < 180000 And 180000 <= sTime) Then Begin # 야간일봉 첫봉
복합일봉_시가[0] = Open;
복합일봉_고가[0] = High;
복합일봉_저가[0] = Low;
복합일봉_종가[0] = Close;
야간일봉_시가[0] = Open;
야간일봉_고가[0] = High;
야간일봉_저가[0] = Low;
야간일봉_종가[0] = Close;
For cnt = 1 To 99 Begin
복합일봉_시가[cnt] = 복합일봉_시가[cnt-1][1];
복합일봉_고가[cnt] = 복합일봉_고가[cnt-1][1];
복합일봉_저가[cnt] = 복합일봉_저가[cnt-1][1];
복합일봉_종가[cnt] = 복합일봉_종가[cnt-1][1];
End;
End;
If 180000 <= sTime Or sTime < 090000 Then Begin # 야간장
If 야간일봉_고가[0] < High Then 야간일봉_고가[0] = High;
If 야간일봉_저가[0] > Low Then 야간일봉_저가[0] = Low;
야간일봉_종가[0] = Close;
복합일봉_고가[0] = 야간일봉_고가[0];
복합일봉_저가[0] = 야간일봉_저가[0];
복합일봉_종가[0] = 야간일봉_종가[0];
End;
# ---<<< 환산일봉 계산 >>>--------------------------------------------------------------------
If (sDate[1] != sDate And 090000 <= sTime) Or
(sDate[1] == sDate And sTime[1] < 090000 And 090000 <= sTime) Then Begin # 주간일봉 첫봉
환산일봉_시가[0] = 복합일봉_시가[0];
환산일봉_고가[0] = 복합일봉_고가[0];
환산일봉_저가[0] = 복합일봉_저가[0];
환산일봉_종가[0] = 복합일봉_종가[0];
For cnt = 1 To 99 Begin
환산일봉_시가[cnt] = 환산일봉_시가[cnt-1][1];
환산일봉_고가[cnt] = 환산일봉_고가[cnt-1][1];
환산일봉_저가[cnt] = 환산일봉_저가[cnt-1][1];
환산일봉_종가[cnt] = 환산일봉_종가[cnt-1][1];
End;
End;
If (sDate[1] != sDate And 180000 <= sTime) Or
(sDate[1] == sDate And sTime[1] < 180000 And 180000 <= sTime) Then Begin # 야간일봉 첫봉
환산일봉_시가[0] = 복합일봉_시가[0];
환산일봉_고가[0] = 복합일봉_고가[0];
환산일봉_저가[0] = 복합일봉_저가[0];
환산일봉_종가[0] = 복합일봉_종가[0];
For cnt = 1 To 99 Begin
환산일봉_시가[cnt] = 환산일봉_시가[cnt-1][1];
환산일봉_고가[cnt] = 환산일봉_고가[cnt-1][1];
환산일봉_저가[cnt] = 환산일봉_저가[cnt-1][1];
환산일봉_종가[cnt] = 환산일봉_종가[cnt-1][1];
End;
End;
# === <<< Bolinger Band >>>===========================================================================
Input : Period(20), MultiD(2);
var : MAv(0),BBup(0),BBdn(0);
MAv = ma(환산일봉_종가,Period);
BBup = BollBandUp(Period,MultiD);
BBdn = BollBandDown(Period,MultiD);
Plot1(MAv, "이평");
Plot2(BBup, "상단밴드");
Plot3(BBdn, "하단밴드");
2017-11-03
165
글번호 113893