커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
2546
글번호 230811
답변완료
중간선 쌍바닥 쓰리바닥 세로선
input : P(10),상(2),하(1);
var : T(0),ll(0),TL(0);
var1 = highest(H,P);
var2 = Lowest(L,P);
var3 = (var1+var2)/2;
if Var3 > Var3[1] Then
T = 1;
if Var3 < Var3 [1] Then
T = -1;
Plot1(Var3,"var3",IFF(T == 1,Red,Blue));
#상승구간
if T == 1 Then
{
#상승구간 첫봉
if T != T[1] Then
{
#직전 하락구간 최저가 저장
value1 = ll[1];
#전전 하락구간 최저가
value2 = value1[1];
#전전전 하락구간 최저가
value3 = value2[1];
if value1 <= value2+PriceScale*상 and value1 >= value2-PriceScale*하 and value2 > 0 Then
{
TL = TL_New_self(sDate,sTime,0,sDate,sTime,99999999);
TL_SetColor(TL,Red);
TL_SetSize(TL,0.5);
}
}
}
#하락구간
if T == -1 Then
{
#최저가 계산
if T != T[1] Then
{
ll = l;
}
Else
{
if ll > 0 and l < ll Then
ll = l;
}
}
#상승구간
if T == 1 Then
{
#상승구간 첫봉
if T != T[1] Then
{
#직전 하락구간 최저가 저장
value1 = ll[1];
#전전 하락구간 최저가
value2 = value1[1];
#전전전 하락구간 최저가
value3 = value2[1];
if value1 <= value2+PriceScale*상 and value1 >= value2-PriceScale*하 and
value2 <= value3+PriceScale*상 and value2 >= value3-PriceScale*하 and
value3 > 0 Then
{
TL = TL_New_Self(sDate,sTime,0,sDate,sTime,99999999);
TL_SetColor(TL,blue);
TL_SetSize(TL,1);
}
}
}
#하락구간
if T == -1 Then
{
#최저가 계산
if T != T[1] Then
{
ll = l;
}
Else
{
if ll > 0 and l < ll Then
ll = l;
}
}
한 지표에 세로선을 두가지 구현하다보니, 쌍바닥이 연속될때 쓰리바닥이라서, 쓰리바닥은 쌍바닥과 겹치게되어 세로선 색상이 이상합니다. 겹치는 부분에서는 쌍바닥 세로선은 안 나타나고 쓰리바닥 세로선만 표시되게 부탁합니다.
2022-10-13
1270
글번호 162954
답변완료
시스템 부탁드려요
1.매수진입 후
2. 2봉 전 저가를 하향 돌파 시 매수청산
3. 진입후 직전 10봉의 저가를 하향 돌파 시 매수청산
4. 0.5% 상승시 0.5% 상승봉의 직전 2봉전의 저가를 하향 돌파시 매수 청산
4. 1% 상승시 1% 상승봉의 직전 2봉전의 저가를 하향 돌파시 매수 청산
////////////////////////////////////////////////////////////////
1. 매도 진입 후
2. 매수와 똑같은 방식으로 작성 부탁드립니다.
고맙습니다.
2022-10-13
1007
글번호 162953
답변완료
그뮬망지표부탁드립니다
수식1
AA=eavg(C, period);
valuewhen(1, AA>=AA(1), AA)
수식2
AA=eavg(C, period+5);
valuewhen(1, AA>=AA(1), AA)
수식3
AA=eavg(C, period+10);
valuewhen(1, AA>=AA(1), AA)
수식4
AA=eavg(C, period+15);
valuewhen(1, AA>=AA(1), AA)
수식5
AA=eavg(C, period+20);
valuewhen(1, AA>=AA(1), AA)
지표조건
period 5 1일 이평 부터 60 일 이평 까지 부탁드립니다
2022-10-13
909
글번호 162952
답변완료
시스탬식과 종목 검색부탁드립니다
ap = (High+Low+Close)/3;
esa = eavg(ap, ch_length);
d = eavg(abs(ap - esa), ch_length);
ci = (ap - esa) / (0.015 * d);
wt1 = eavg(ci, Avg_length);
wt2 = avg(wt1,4);
crossup(wt1, wt2)
지표변수 ch_length 10
Avg_length 21
###시스템부탁드리니다
### 당일발생하는 매수신호만 종목 검색두 부탁 드립니다
2022-10-13
1122
글번호 162951
답변완료
시스탬식과 종목 검색부탁드립니다
이격도압축돌파 시스템
수식
A5=disparity(5);
A10=disparity(10);
A15=disparity(15);
A20=disparity(20);
A25=disparity(25);
A30=disparity(30);
A35=disparity(35);
A40=disparity(40);
A45=disparity(45);
A50=disparity(50);
A55=disparity(55);
A60=disparity(60);
A65=disparity(65);
A70=disparity(70);
A75=disparity(75);
A80=disparity(80);
A85=disparity(85);
A90=disparity(90);
A95=disparity(95);
A100=disparity(100);
MAXA=max(A5, A10, A15, A20, A25, A30, A35, A40, A45, A50, A55, A60, A65, A70, A75, A80, A85, A90, A95, A100);
MINA=min(A5, A10, A15, A20, A25, A30, A35, A40, A45, A50, A55, A60, A65, A70, A75, A80, A85, A90, A95, A100);
AA=valuewhen(1, MAXA/MINA*100 <ratio, eavg(C, 50)*MAXA/100);
if(crossup(C, AA) and V>=eavg(V, 20)*Vratio, 1, 0)
지표변수
ratio 105
Vratio 3
2022-10-13
1297
글번호 162950
답변완료
박스 지표 부탁드립니다
이격도압축_박스
수식4
A5=disparity(5);
A10=disparity(10);
A15=disparity(15);
A20=disparity(20);
A25=disparity(25);
A30=disparity(30);
A35=disparity(35);
A40=disparity(40);
A45=disparity(45);
A50=disparity(50);
A55=disparity(55);
A60=disparity(60);
A65=disparity(65);
A70=disparity(70);
A75=disparity(75);
A80=disparity(80);
A85=disparity(85);
A90=disparity(90);
A95=disparity(95);
A100=disparity(100);
MAXA=max(A5, A10, A15, A20, A25, A30, A35, A40, A45, A50, A55, A60, A65, A70, A75, A80, A85, A90, A95, A100);
MINA=min(A5, A10, A15, A20, A25, A30, A35, A40, A45, A50, A55, A60, A65, A70, A75, A80, A85, A90, A95, A100);
valuewhen(1, MAXA/MINA*100 <ratio, eavg(C, 50)*MAXA/100)
수식5
A5=disparity(5);
A10=disparity(10);
A15=disparity(15);
A20=disparity(20);
A25=disparity(25);
A30=disparity(30);
A35=disparity(35);
A40=disparity(40);
A45=disparity(45);
A50=disparity(50);
A55=disparity(55);
A60=disparity(60);
A65=disparity(65);
A70=disparity(70);
A75=disparity(75);
A80=disparity(80);
A85=disparity(85);
A90=disparity(90);
A95=disparity(95);
A100=disparity(100);
MAXA=max(A5, A10, A15, A20, A25, A30, A35, A40, A45, A50, A55, A60, A65, A70, A75, A80, A85, A90, A95, A100);
MINA=min(A5, A10, A15, A20, A25, A30, A35, A40, A45, A50, A55, A60, A65, A70, A75, A80, A85, A90, A95, A100);
valuewhen(1, MAXA/MINA*100 <ratio, eavg(C, 50)*MINA/100)
지표조건
ratio 105
2022-10-13
1293
글번호 162949
답변완료
수식 수정 부탁드립니다
작성해주신 아래 두 수식을 종가 파바볼릭으로 수정 부탁합니다. 감사합니다
--------------------------------------------------------------------
1.
Input : af(0.02), maxAF(0.2);
var : sarv(0);
sarv = SAR(af,maxAF);
if l == DayLow Then
var1 = 0;
if h == DayHigh Then
var2 = 0;
if CrossUp(C,sarv) Then
{
var1 = var1+1;
if Var2 >= 3 Then
Buy();
}
if CrossDown(C,sarv) Then
{
var2 = var2+1;
if var1 >= 3 Then
Sell();
}
--------------------------------------------------------------------------
2.
Input : AF(0.02), AFMAX(0.2);
Var : Direction(0), SAR_Value(Close), AF_Value(.02), HighValue(High), LowValue(Low), EP(0),Sarv(0);
var : T(0),hh(0),hh1(0),hh2(0),ll(0),ll1(0),ll2(0);
var : upv(0),dnv(0);
if Bdate != bdate[1] Then
{
Direction = 0;
SAR_Value = c;
AF_Value = 0.02;
HighValue = h;
LowValue = l;
EP = 0;
}
if EP != 0 Then
{
if Direction == 1 then
{
EP = HighValue;
SAR_Value = SAR_Value + AF_Value * (EP - SAR_Value);
if High > HighValue then
{
HighValue = High;
AF_Value = AF_Value + AF;
if AF_Value >= AFMAX then AF_Value = AFMAX;
}
if Low < SAR_Value then
{
Direction = -1;
SAR_Value = EP;
AF_Value = 0;
EP = 0;
LowValue = low;
}
}
else
{
EP = LowValue;
SAR_Value = SAR_Value + AF_Value * (EP - SAR_Value);
if Low < LowValue then
{
LowValue = Low;
AF_Value = AF_Value + Af;
if AF_Value >= AFMAX then AF_Value = AFMAX;
}
if High > SAR_Value then
{
Direction = 1;
SAR_Value = EP;
AF_Value = 0;
EP = 0;
HighValue = High;
}
}
Sarv = SAR_Value;
}
else
{
if SAR_Value != 0 && EP == 0 then
{
if Direction == 1 then
{
EP = HighValue;
AF_Value = AF;
SAR_Value = SAR_Value + AF_Value * (EP - SAR_Value);
if High > HighValue then
{
HighValue = High;
AF_Value = AF_Value + AF;
if AF_Value >= AFMAX then AF_Value = AFMAX;
}
}
else
{
EP = LowValue;
AF_Value = Af;
SAR_Value = SAR_Value + AF_Value * (EP - SAR_Value);
if Low < LowValue then
{
LowValue = Low;
AF_Value = AF_Value + AF;
if AF_Value >= AFMAX then AF_Value = AFMAX;
}
}
Sarv = SAR_Value;
}
else
{
if Direction == 0 then
{
if Close > Close[1] then Direction = 1;
else
if Close < Close[1] then Direction = -1;
}
else
{
if Direction == 1 then
{
if Close < Close[1] then
{
Direction = -1;
SAR_Value = HighValue;
Sarv = SAR_Value;
}
}
if Direction == -1 then
{
if Close > Close[1] then
{
Direction = 1;
SAR_Value = LowValue;
Sarv = SAR_Value;
}
}
}
LowValue = min(Low, LowValue);
HighValue = max(High, HighValue);
}
}
if l == DayLow Then
var1 = 0;
if h == DayHigh Then
var2 = 0;
if CrossUp(C,sarv) Then
{
var1 = var1+1;
if Var2 >= 3 Then
Buy();
}
if CrossDown(C,sarv) Then
{
var2 = var2+1;
if var1 >= 3 Then
Sell();
}
2022-10-13
1083
글번호 162948
답변완료
하나로 부탁드립니다
1번
input : Period(60);
var : HT(0),NewH(0);
HT = highest(V,Period);
if V > HT[1] Then
NewH = (O+C+L+H+C)/5;
if newH > 0 Then
{
Plot1(NewH*1.03);
Plot2(NewH*0.98);
}
2번
input : Period(120);
var : HT(0),NewH(0);
HT = highest(V,Period);
if V > HT[1] Then
NewH = (O+C+L+H+C)/5;
if newH > 0 Then
{
Plot1(NewH*1.03);
Plot2(NewH*0.98);
}
3번
input : Period(224);
var : HT(0),NewH(0);
HT = highest(V,Period);
if V > HT[1] Then
NewH = (O+C+L+H+C)/5;
if newH > 0 Then
{
Plot1(NewH*1.03);
Plot2(NewH*0.98);
}
%%%%% 하나로 만들어주세요 채우기 부탁드립니다
###### 박스 하단라인끝에 60 120 224 수치표현 부탁드립니다 꾸뻑 감사
2022-10-13
1463
글번호 162946
답변완료
수식작성 부탁드립니다.
안녕하십니까
수식부탁드립니다.
ㅇ 매수
1. 월봉 macd 오실레이터 상승
2. 주봉 macd 오실레이터 상승
3. 일봉 macd 오실레이터 상승
위 조건 모두 만족 시 매수
ㅇ 매도
1. 주봉 macd 오실레이터 하락 전환
일봉챠트에 수식을 적용하면 다음날 매수 주문이 나가는거 같은데
매수조건이 만족 될 경우 만족된 날 오후 3시 18분에 여전히 조건이 만족되면 매수 주문이
나갈수 있게 부탁드립니다.
항상 수고해 주셔서 감사합니다.
2022-10-13
1222
글번호 162945