커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
5562
글번호 230811
답변완료
변수값
아래 수식 (가) 는 정상적으로 작동 됩니다.
그런데 수식(나) 로 변경 하였는데 변수 L 값에 관계없이 수식(가)의 진입신호와 동일하게 발생합니다
수식(나) 의 수식이 변수 L 값에 따라 진입신호가 바르게 작동 되도록 (나)의 수식을 수정하여 주십시요.
수식(가)
If c > (LRLs[1] + K) Then Buy();
If c < (LRLs[1] - K) Then Sell();
수식(나)
If abs(LRLs[1] - LRLs1[2]) < L Then
{
If c > (LRLs[1] + K) Then Buy();
If c < (LRLs[1] - K) Then Sell();
}
2019-03-22
370
글번호 127312
답변완료
수식문의요
수식1
sc=Stochasticsslow(sto1,sto2);
valuewhen(1,crossdown(sc,hp),low)
수식2
sc=Stochasticsslow(sto1,sto2);
valuewhen(1,crossup(sc,lp),high)
sto1 12
sto2 5
hp 60
lp 40
키움변환 부탁드립니다 항상 감사합니다
2019-03-22
417
글번호 127310
답변완료
수식 문의 드립니다....^^
수고가 많으시죠....
1. 고가가 볼린저밴드 상단에 20일 이내에 있고 Macd 데드크로스에 매도
2. 저가가 볼린저밴드 하단에 20일 이내에 있고 Macd 골든크로스에 매수
B Bands (80, 2) MACD( 24, 52, 9)
입니다...수고하세요....^^
2019-03-22
386
글번호 127307
답변완료
함수요청
안녕하세요?
유렉스 거래소 상품 거래시간을 표현하고 싶습니다.
(유럽의 일광 절약 시간제는 3월 마지막 일요일에 시작하여 10월 마지막 일요일에 해제됩니다.)
아래는 작성주신 시카고거래소 상품 거래시간입니다.
(미국의 일광 절약 시간제는 3월의 두 번째 일요일에 시작하여 11월 첫 일요일해제됩니다.)
Var : st(0), et(0),year(0);
var : V1(0),V2(0),v99(0);
Year = Floor(sDate / 10000)*10000;
V1 = Dayofweek((10000 * Year) + (100 * 3) + 1);
If V1 == 0 Then
Value2 = 8;
Else
Value2 = 15 - V1; // 3월 두번째 일요일 날짜
V2 = Dayofweek((10000 * Year) + (100 * 11) + 1);
If V2 == 0 Then
Value4 = 1;
Else
value4 = 8 - V2; // 11월 첫번째 일요일 날짜
If sdate > (10000 * Year) + (100 * 3) + value2
And sdate < (10000 * Year) + (100 * 11) + value4 Then
Begin
st = 070000; // 써머타임 적용 시, 장시작 시간
et = 060000; // 써머타임 적용 시, 장종료 시간
End
Else
Begin
st = 080000; // 장 시작 시간
et = 070000; // 장 종료 시간
End;
condition1 = (IntPortion(stime/10000) > IntPortion(et/10000)
And IntPortion(stime[1]/10000) <= IntPortion(et/10000)) Or st <> st[1];
2019-03-22
436
글번호 127306
답변완료
문의
시뮬레이션을 통해
시간 변화값, 봉갯수 변화값, HL RANGE 변화값이 모두 나와야하는데
HL RANGE 값만 나오지 않습니다.
시간,봉갯수,HL RANGE 3개가 연동될 수 있도록 부탁드립니다.
***************************************************************************
안녕하세요
예스스탁입니다.
input : 시간(130000),봉갯수(100),HLRANGE(0.50);
var : hh(0),ll(0),ii(0);
if bdate != bdate[1] Then
{
hh = 0;
ll = 0;
ii = 0;
}
if stime >= 시간 then
{
ii = ii +1;
if h > hh Then
hh = h;
if l < ll Then
ll = l;
if ii >= 봉갯수 and hh-ll >= HLRANGE Then
ExitLong();
}
즐거운 하루되세요
> 목마와숙녀 님이 쓴 글입니다.
> 제목 : 수식 문의
> 청산수식을 문의드립니다.
입력한 시간부터 봉갯수를 카운트하고 고가저가를 파악합니다.
13시부터 봉개수 100개 되고 고가저가의 RANGE가 0.5이하면 청산합니다.
input : 시간(130000),봉갯수(100),HL RANGE(0.50)
항상 고맙습니다.
2019-03-22
387
글번호 127305
답변완료
문의드립니다
아래 전략 3가지 에서 손절 30 익절 30 외부 변수로 추가 부탁드립니다
1
input : P1(9),P2(13);
Var : cnt(0),Nth(0),tempmax(0), tempindex(0), X1(0),RCI1(0),X2(0),RCI2(0);
Array : VALUE1[50](0),VALUE2[50](0),NTHVALUE[50](0);
for cnt = 0 to 49{
VALUE1[cnt] = C[cnt];
VALUE2[cnt] = C[cnt];
}
###############################################
For Nth = 0 to P1-1 {
tempmax = -99999999;
For cnt = 0 to P1-1{
if VALUE1[cnt] > tempmax then{
tempmax = VALUE1[cnt];
tempIndex = cnt;
NTHVALUE[cnt] = Nth+1;
}
}
VALUE1[tempIndex] = -99999999;
}
X1 = 0;
for cnt = 0 to P1-1{
X1 = X1+ABS((cnt+1)-NTHVALUE[cnt])^2;
}
RCI1 = (1-(6*X1)/(P1*(P1^2-1)))*100;
###############################################
For Nth = 0 to P2-1 {
tempmax = -99999999;
For cnt = 0 to P2-1{
if value2[cnt] > tempmax then{
tempmax = value2[cnt];
tempIndex = cnt;
NTHVALUE[cnt] = Nth+1;
}
}
VALUE2[tempIndex] = -99999999;
}
X2 = 0;
for cnt = 0 to P2-1{
X2 = X2+ABS((cnt+1)-NTHVALUE[cnt])^2;
}
RCI2 = (1-(6*X2)/(P2*(P2^2-1)))*100;
if RCI1 > 80 and RCI2 > 80 and CrossDown(RCI1,RCI2) Then
sell();
if RCI1 < -80 and RCI2 < -80 and CrossUp(RCI1,RCI2) Then
buy();
2
input : P1(9),P2(13),P3(18);
Var : cnt(0),Nth(0),tempmax(0), tempindex(0), X1(0),RCI1(0),X2(0),RCI2(0),X3(0),RCI3(0);
Array : VALUE1[50](0),VALUE2[50](0),VALUE3[50](0),NTHVALUE[50](0);
for cnt = 0 to 49{
VALUE1[cnt] = C[cnt];
VALUE2[cnt] = C[cnt];
VALUE3[cnt] = C[cnt];
}
###############################################
For Nth = 0 to P1-1 {
tempmax = -99999999;
For cnt = 0 to P1-1{
if VALUE1[cnt] > tempmax then{
tempmax = VALUE1[cnt];
tempIndex = cnt;
NTHVALUE[cnt] = Nth+1;
}
}
VALUE1[tempIndex] = -99999999;
}
X1 = 0;
for cnt = 0 to P1-1{
X1 = X1+ABS((cnt+1)-NTHVALUE[cnt])^2;
}
RCI1 = (1-(6*X1)/(P1*(P1^2-1)))*100;
###############################################
For Nth = 0 to P2-1 {
tempmax = -99999999;
For cnt = 0 to P2-1{
if value2[cnt] > tempmax then{
tempmax = value2[cnt];
tempIndex = cnt;
NTHVALUE[cnt] = Nth+1;
}
}
VALUE2[tempIndex] = -99999999;
}
X2 = 0;
for cnt = 0 to P2-1{
X2 = X2+ABS((cnt+1)-NTHVALUE[cnt])^2;
}
RCI2 = (1-(6*X2)/(P2*(P2^2-1)))*100;
###############################################
For Nth = 0 to P3-1 {
tempmax = -99999999;
For cnt = 0 to P3-1{
if value3[cnt] > tempmax then{
tempmax = value3[cnt];
tempIndex = cnt;
NTHVALUE[cnt] = Nth+1;
}
}
VALUE3[tempIndex] = -99999999;
}
X3 = 0;
for cnt = 0 to P3-1{
X3 = X3+ABS((cnt+1)-NTHVALUE[cnt])^2;
}
RCI3 = (1-(6*X3)/(P3*(P3^2-1)))*100;
if RCI1 > 80 and RCI2 > 80 and RCI3 > 80 and CrossDown(RCI1,RCI3) Then
sell();
if RCI1 < -80 and RCI2 < -80 and RCI2 < -80 and CrossUp(RCI1,RCI3) Then
buy();
3
input : P1(9),P2(13),P3(18);
Var : cnt(0),Nth(0),tempmax(0), tempindex(0), X1(0),RCI1(0),X2(0),RCI2(0),X3(0),RCI3(0);
Array : VALUE1[50](0),VALUE2[50](0),VALUE3[50](0),NTHVALUE[50](0);
for cnt = 0 to 49{
VALUE1[cnt] = C[cnt];
VALUE2[cnt] = C[cnt];
VALUE3[cnt] = C[cnt];
}
###############################################
For Nth = 0 to P1-1 {
tempmax = -99999999;
For cnt = 0 to P1-1{
if VALUE1[cnt] > tempmax then{
tempmax = VALUE1[cnt];
tempIndex = cnt;
NTHVALUE[cnt] = Nth+1;
}
}
VALUE1[tempIndex] = -99999999;
}
X1 = 0;
for cnt = 0 to P1-1{
X1 = X1+ABS((cnt+1)-NTHVALUE[cnt])^2;
}
RCI1 = (1-(6*X1)/(P1*(P1^2-1)))*100;
###############################################
For Nth = 0 to P2-1 {
tempmax = -99999999;
For cnt = 0 to P2-1{
if value2[cnt] > tempmax then{
tempmax = value2[cnt];
tempIndex = cnt;
NTHVALUE[cnt] = Nth+1;
}
}
VALUE2[tempIndex] = -99999999;
}
X2 = 0;
for cnt = 0 to P2-1{
X2 = X2+ABS((cnt+1)-NTHVALUE[cnt])^2;
}
RCI2 = (1-(6*X2)/(P2*(P2^2-1)))*100;
###############################################
For Nth = 0 to P3-1 {
tempmax = -99999999;
For cnt = 0 to P3-1{
if value3[cnt] > tempmax then{
tempmax = value3[cnt];
tempIndex = cnt;
NTHVALUE[cnt] = Nth+1;
}
}
VALUE3[tempIndex] = -99999999;
}
X3 = 0;
for cnt = 0 to P3-1{
X3 = X3+ABS((cnt+1)-NTHVALUE[cnt])^2;
}
RCI3 = (1-(6*X3)/(P3*(P3^2-1)))*100;
if RCI1 > 80 and RCI2 > 80 and CrossDown(RCI1,RCI2) Then
sell();
if RCI1 < -80 and RCI2 < -80 and CrossUp(RCI1,RCI2) Then
buy();
if RCI1 > 80 and RCI2 > 80 and RCI3 > 80 and CrossDown(RCI1,RCI3) Then
sell();
if RCI1 < -80 and RCI2 < -80 and RCI2 < -80 and CrossUp(RCI1,RCI3) Then
buy();
2019-03-22
358
글번호 127302
답변완료
시스템문의합니다
당일 시가대비 20틱위에서 매도2계약들어가서 진입가 대비 10틱 20틱에서 1계약씩청산하고 청산이 안됐을시 50틱에서 추가로 가지고 있는 수량대비 2배로 추가매도하고 평단가 대비 10틱 20틱에서 반 반 청산하고 또 청산이 안됐을 경우 80틱에서 추가로 가지고있는 수량대비 2배로 추가매도해서 평단가 대비 10틱 20틱에서 반 반씩청산 하는시스템식을 만들고 싶습니다 그렇게 각 30틱마다 진입이 되겠끔해서 500틱까지 반복이 되겠끔 하고 싶습니다
매수도 마찬가지로요
만약 20틱에서 진입해서 다 청산이 되면 다시 20틱에 오면 매도가 되겠끔 50틱에서 추가로 들어가서 청산이 되면 다시 50틱에서도 진입이 됬으면 좋겠습니다 단 진입이 되어있으면 추가 진입은 금지이고 각 진입이된 다음 30틱에서 진입이 되겠끔 부탁드립니다
만약 1계약이 청산된 상태라면 1계약은 추가로 진입가능하고요
2019-03-22
382
글번호 127300
답변완료
분할 청산 수식 부탁해요~~(국내 주식)
매수진입은 100회에 걸쳐 진입하였고
청산은 첫 신호에 전량 청산으로 요청한 식이 아래 식입니다.
여기에 추가 부탁드릴께요~~~
청산도 해당 조건에 달성시 보유 주식에 10%씩 10회에 걸쳐 청산하는 식을 요청합니다.
====================================================================================
안녕하세요
예스스탁입니다.
Input: Period(14),LPercent(5),SPercent(80),금액(1000000),최대누적횟수(100);
var : MoneyFlow(0);
MoneyFlow = MFI(Period);
if MoneyFlow < 5 and MaxEntries < 최대누적횟수 Then
buy("b",OnClose,def,Floor(금액/c));
if MarketPosition == 1 and MoneyFlow >= SPercent Then
ExitLong("bx");
즐거운 하루되세요
> 이형지 님이 쓴 글입니다.
> 제목 : MFI 매수-청산 수식 부탁해요~~
> 국내 주식 매매
30분봉 기준
MFI 저점(LPercent(5))이하에서는 신호 발생시마다 분할매수로 1회에 100만원씩
최대 100회(1억)까지
청산은 MFI 고점(SPercent)에서 일괄 청산하는 식을 만들어 주시면 감사하겠습니다.
2019-03-22
369
글번호 127298
답변완료
신규 진입 수식 부탁합니다.
해당 조건을 모두 만족할때 신규 진입 뜨는 수식 부탁해요..
일봉 차트 - 국내 주식
CCI 일봉 > 0 &&
CCI 주봉 > 0 &&
주봉 20일 이동평균 라인이 우상향 &&
일봉이 5일이동평균(일봉)보다 아래 있을 때
2019-03-22
366
글번호 127296