커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
4510
글번호 230811
답변완료
문의
아래수식과 반대인 exitshort 수식 부탁드립니다.
***********************************************************************************
안녕하세요
예스스탁입니다.
식을 수정해 드립니다.
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 hh == 0 or (hh > 0 and h > hh) Then
hh = h;
if ll == 0 or (ll > 0 and l < ll) Then
ll = l;
if ii >= 봉갯수 and hh-ll >= HLRANGE Then
ExitLong();
}
2019-03-22
380
글번호 127323
답변완료
차트 참조에서
차트 참조에서
코스피하락종목수/(코스피상승종목수+코스피하락종목수)*100
지표 부탁드립니다
2019-03-22
356
글번호 127321
답변완료
수식 검토
아래 buy 청산수식을 역으로 참조하여
sell 청산수식을 작성해보았는데 시뮬레이션이 되지 않습니다.
살펴주세요
input: 특정시간(130000);
input : X1(20),CR(8),CF(0);
var : EL(0),E1(0),H1(0),i1(0),S1(0);
if stime >= 특정시간 Then
{
if stime[1] < 특정시간 Then
{
EL = L;
E1 = 0;
}
if L < EL Then{
EL = L;
E1 = 0;
}
if E1 == 0 and C >= EL+PriceScale*X1 Then{
E1 = 1;
H1 = H;
i1 = index;
}
if E1 == 1 and index > i1 Then{
if H > H1 Then
H1 = H;
if L <= H1-PriceScale*CR Then{
E1 = 2;
I1 = index;
S1 = H1;
}
}
if E1 == 2 and index > i1 and C >= S1+PriceScale*CF Then{
ExitShort("sx");
E1 = 0;
}
}
***************************************************************************************
안녕하세요
예스스탁입니다.
input: 특정시간(130000);
input : X1(20),CR(8),CF(0) ;
var : EH(0),E1(0),i1(0),S1(0),L1(0);
if stime >= 특정시간 Then
{
if stime[1] < 특정시간 Then
{
EH = H;
E1 = 0;
}
if H > EH Then
{
EH = H;
E1 = 0;
}
if E1 == 0 and C <= EH-PriceScale*X1 Then
{
E1 = 1;
L1 = L;
i1 = index;
}
if E1 == 1 and index > i1 Then
{
if L < L1 Then
L1 = L;
if H >= L1+PriceScale*CR Then
{
E1 = 2;
I1 = index;
S1 = L1;
}
}
if E1 == 2 and index > i1 and C <= S1-PriceScale*CF Then
{
exitlong("bx");
E1 = 0;
}
}
즐거운 하루되세요
2019-03-22
356
글번호 127315
답변완료
변수값
아래 수식 (가) 는 정상적으로 작동 됩니다.
그런데 수식(나) 로 변경 하였는데 변수 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
356
글번호 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
396
글번호 127310
답변완료
수식 문의 드립니다....^^
수고가 많으시죠....
1. 고가가 볼린저밴드 상단에 20일 이내에 있고 Macd 데드크로스에 매도
2. 저가가 볼린저밴드 하단에 20일 이내에 있고 Macd 골든크로스에 매수
B Bands (80, 2) MACD( 24, 52, 9)
입니다...수고하세요....^^
2019-03-22
372
글번호 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
378
글번호 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
364
글번호 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
345
글번호 127302