커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
4476
글번호 230811
답변완료
문의드립니다.
늘 감사합니다.
일봉에서 몸통의길이(시가과 종가의 범위)가 3%이상이이고, 아래꼬리가 몸통보다 2배 이상 큰 봉발생시 매수진입
손절 : 매수진입봉의 저가를 이탈하하는 봉완성시 손절
익절1 : 5% 이상 상승후 4% 하락시
익절2 : 5% 수익보존
2019-01-05
155
글번호 124992
답변완료
부탁 드립니다.
도움주심에 감사 드립니다.
첨부 그림과 같이 부탁 드립니다.
input:수평기준_상(0.002),수평기준_하(-0.002),sig(5);
var1=ma(trix(10),sig);
var2=ma(trix(15),sig);
var3=ma(trix(20),sig);
var4=ma(trix(25),sig);
var5=ma(trix(30),sig);
var51=수평기준_상;
var52=수평기준_하;
var53=0;
if var1>var1[1] then
plot1(var1,"p1_histo",red,def,2);
else
plot1(var1,"p1_histo",black,def,2);
if var2>var2[1] then
plot2(var2,"p2_histo",red,def,0);
else
plot2(var2,"p2_histo",black,def,0);
if var3>var3[1] then
plot3(var3,"p3_histo",red,def,0);
else
plot3(var3,"p3_histo",black,def,0);
if var4>var4[1] then
plot4(var4,"p4_histo",red,def,0);
else
plot4(var4,"p4_histo",black,def,0);
if var5>var5[1] then
plot5(var5,"p5_histo",red,def,0);
else
plot5(var5,"p5_histo",black,def,0);
PlotBaseLine1(var51);
PlotBaseLine2(var52);
PlotBaseLine3(var53);
2019-01-06
177
글번호 124991
답변완료
수식 문의드립니다
안녕하세요!
새해복 많이 받으시고,
건강하세요!!!
2019-01-06
138
글번호 124990
답변완료
수식
늘 감사합니다.
텍스트식입니다. 해외선물 기준입니다.
1. data1과 data2의 각각
당일 고가 - 저가 틱수로 환산,
당일 고가 - 시가 틱수로 환산,
당일 저가 - 시가 틱수로 환산,
위치는 상단.
2. data1과 data2의 5일전 기준 각각
당일시가 - 5일전 고가 틱수로 환산,
당일시가 - 5일전 저가 틱수로 환산,
위치는 상단.
감사합니다.
2019-01-05
172
글번호 124989
답변완료
수정 의뢰드립니다!
안녕하세요!
예스 수식을 수정하고 싶습니다!
---------------------------------------------------------------------------------
피보나치에 녹색 파동선을 빼주시고 피보나치선에 피보나치 비율과 가격이 나타나도록
수정해 주세요!
Input:length(10),기준일(20110101),파동선두께(2);
Var:j(0),jj(0),jjj(0),최종고가(0),최종저가(0),최종변곡점(""),처리구분(""),
TL1(0);
Array:고[5,4](0),저[5,4](0), // 1:가격, 2:Index, 3:sDate, 4:sTime
역사적고점[5](0),역사적저점[5](0); // 1:가격, 2:Index, 3:sDate, 4:sTime
#==========================================#
If Index == 0 Then
{
고[1,1] = H;
저[1,1] = L;
}
Condition1 = Highest(H,length) == H and 최종고가 <> H;
Condition2 = Lowest (L,length) == L and 최종저가 <> L;
처리구분 = "";
If Condition1 and Condition2 Then // 기간고점과 기간저점 동시 발생
{
If 최종변곡점 == "저점" Then 처리구분 = "고점처리"; // 저 - 고 순으로 처리
Else 처리구분 = "저점처리"; // 고 - 저 순으로 처리
}
Else If Condition1 Then 처리구분 = "고점처리";
Else If Condition2 Then 처리구분 = "저점처리";
#==========================================#
If 처리구분 == "고점처리" Then
{
최종고가 = H; // 신규고점을 체크하기 위해 저장
If 최종변곡점 == "저점" Then
{
For j = 5 DownTo 2
{
For jj = 1 To 4
{
고[j,jj] = 고[j-1,jj];
}
}
고[1,1] = H;
고[1,2] = Index;
고[1,3] = sDate;
고[1,4] = sTime;
TL1 = TL_New(저[1,3],저[1,4],저[1,1],고[1,3],고[1,4],고[1,1]);
TL_SetSize(TL1,파동선두께);
TL_SetColor(TL1,GREEN);
}
Else If 고[1,1] < H Then // 1번 고점보다 높은 고가 출현
{
고[1,1] = H;
고[1,2] = Index;
고[1,3] = sDate;
고[1,4] = sTime;
TL_SetEnd(TL1,고[1,3],고[1,4],고[1,1]);
}
If 기준일 <= Date and 역사적고점[1] < 고[1,1] Then
{
For jjj = 1 To 4 // 1:가격, 2:Index, 3:sDate, 4:sTime
{
역사적고점[jjj] = 고[1,jjj];
}
}
최종변곡점 = "고점";
}
#==========================================#
If 처리구분 == "저점처리" Then
{
최종저가 = L;
If 최종변곡점 == "고점" then
{
For j = 5 DownTo 2
{
For jj = 1 To 4
{
저[j,jj] = 저[j-1,jj];
}
}
저[1,1] = L;
저[1,2] = Index;
저[1,3] = sDate;
저[1,4] = sTime;
TL1 = TL_New(고[1,3],고[1,4],고[1,1],저[1,3],저[1,4],저[1,1]);
TL_SetSize(TL1,파동선두께);
TL_SetColor(TL1,GREEN);
}
Else If 저[1,1] > L then
{
저[1,1] = L;
저[1,3] = sDate;
저[1,4] = sTime;
저[1,2] = Index;
TL_SetEnd(TL1,저[1,3],저[1,4],저[1,1]);
}
If 기준일 <= Date and ( 역사적저점[1] > 저[1,1] or 역사적저점[1] == 0 ) Then
{
For jjj = 1 To 4
{
역사적저점[jjj] = 저[1,jjj];
역사적고점[jjj] = 0; // 역사적 고점 초기화
}
}
최종변곡점 = "저점";
}
#==========================================#
Var:기울기(0);
Array:fr[7,4](0); // 1:비율, 2:값, 3:라인번호, 4:텍스트번호
If Index == 0 Then
{
fr[1,1] = 0;
fr[2,1] = 0.236;
fr[3,1] = 0.382;
fr[4,1] = 0.50;
fr[5,1] = 0.618;
fr[6,1] = 0.764;
fr[7,1] = 1;
}
If 역사적고점[1] > 0 and 역사적저점[1] > 0 Then
{
If 역사적고점[1][1] != 역사적고점[1] or 역사적저점[1][1] != 역사적저점[1] Then
{
기울기 = (역사적고점[1] - 역사적저점[1]) / (역사적고점[2] - 역사적저점[2]);
for j = 1 to 7
{
If fr[j,3] > 0 Then TL_Delete(fr[j,3]); // 기존의 라인은 지우고
fr[j,2] = 기울기 * fr[j,1] * (index - 역사적저점[2]) + 역사적저점[1]; // 피보나치 비율을 곱해서 계산
fr[j,3] = TL_New(역사적저점[3],역사적저점[4],역사적저점[1],sDate,sTime,fr[j,2]); // 라인을 생성
}
}
Else
{
for j = 1 to 7
{
fr[j,2] = 기울기 * fr[j,1] * (index - 역사적저점[2]) + 역사적저점[1];
TL_SetEnd(fr[j,3],sDate,sTime,fr[j,2]);
}
}
}
----------------------------------------------------------------------------
<수정요청>
아래 수식은 항생에 적용하던 양방향 대칭 피보나치 입니다!
몇가지 내용을 수정보강하고 싶습니다.
1. 국선 장시작시 시가기준 반대편 고점이나 저점에 맞게 반대편도 대칭피보나치 비율숫자와
가격이 선에 표시되게 만들어 주세요!
(즉, 시가 기준 장이 위로 상승하면 시가0% ~ 최고가100% 까지 피보나치 비율선이 반대편 시가 아래에도 동일하게 나타나게 해주세요! )
2. 볼린저밴드 표시는 필요하지 않습니다.
3. 해외선물도 적용할 수 있도록 수정해 주세요!
감사합니다!
Input : Period(20), Dv(2);
var : BBup(0),BBdn(0);
BBup = BollBandUp(Period,Dv);
BBdn = BollBandDown(Period,Dv);
if (sdate != sdate[1] and stime >= 101500) or
(sdate == sdate[1] and stime >= 101500 and stime[1] < 101500) Then
{
var1 = O;
var2 = BBup[1]-BBdn[1];
value1 = var1+var2;
value2 = var1-var2;
}
plot1(value1);
plot2(value1-var2*0.236);
plot3(value1-var2*0.382);
plot4(value1-var2*0.500);
plot5(value1-var2*0.618);
plot6(var1);
plot7(value2+var2*0.618);
plot8(value2+var2*0.500);
plot9(value2+var2*0.382);
plot10(value2+var2*0.236);
plot11(value2);
--------------------------------------------------------------------------------
아래 피보나치 수식에 가격과 비율이 나타나게 수정하고 싶습니다.
var1 = dayhigh(1);
var2 = daylow(1);
var3 = var1-var2;
Var4 = Var2-Var1;
Plot1(var1,"전일고점");
Plot2(var2,"전일저점");
Plot3(var1-var3*0.236);
Plot4(var1-var3*0.382);
plot5(var1-var3*0.5);
Plot6(var1-var3*0.618);
Plot7(var1-var3*0.736);
plot8(var1-var3*1.236);
Plot9(var1-var3*1.382);
plot10(var1-var3*1.5);
Plot11(var1-var3*1.618);
Plot12(var1-var3*1.736);
Plot13(var1-var3*2.0);
plot14(var1-var3*2.236);
Plot15(var1-var3*2.382);
plot16(var1-var3*2.5);
Plot17(var1-var3*2.618);
Plot18(var1-var3*2.736);
Plot19(var1-var3*3.0);
plot20(var1-var3*3.236);
Plot21(var1-var3*3.382);
plot22(var1-var3*3.5);
Plot23(var1-var3*3.618);
Plot24(var1-var3*3.736);
Plot25(var1-var3*4.0);
Plot26(Var1+var3*0.236);
Plot27(Var1+var3*0.382);
plot28(Var1+var3*0.5);
Plot29(Var1+var3*0.618);
Plot30(Var1+var3*0.736);
Plot31(var1+var3*1.0);
plot32(Var1+var3*1.236);
Plot33(Var1+var3*1.382);
plot34(Var1+var3*1.5);
Plot35(Var1+var3*1.618);
Plot36(Var1+var3*1.736);
Plot37(Var1+var3*2.0);
plot38(Var1+var3*2.236);
Plot39(Var1+var3*2.382);
plot40(Var1+var3*2.5);
Plot41(Var1+var3*2.618);
Plot42(Var1+var3*2.736);
Plot43(Var1+var3*3.0);
plot44(Var1+var3*3.236);
Plot45(Var1+var3*3.382);
plot46(Var1+var3*3.5);
Plot47(Var1+var3*3.618);
Plot48(Var1+var3*3.736);
Plot49(Var1+var3*3.0);
2019-01-05
230
글번호 124987
답변완료
분할 매도 주문 부탁합니다
매수는 수동으로 한 후에 여러 종목을 한번에 일괄 매도 주문을 내고 싶습니다
수익률 1.5%가격으로 매도수량 33%(33/100) 매도주문
3%가격으로 매도수량 33%(33/100) 매도주문
4.5%가격으로 매도수량 33%(33/100)매도주문
고맙습니다
2019-01-04
169
글번호 124986
답변완료
시스탬
늘 감사합니다.
아래지표를 가지고
시스탬으로 변환 부탁드립니다..
9시에시작 5시30분에 청산후 정지
plot2 ~ Plot11 선까지 모든선를 현재가가 위로가면 매수 아래면 매도..이렇게요
var1 = (DayHigh+DayLow)/2;
plot1(c);
plot2(var1);
plot3(var1*1.005,"당일중심+0.5%");
plot4(var1*1.010,"당일중심+1.0%");
plot5(var1*1.015,"당일중심+1.5%");
plot6(var1*1.020,"당일중심+2.0");
plot7(var1*0.995,"당일중심-0.5%");
plot8(var1*0.990,"당일중심-1.0%");
plot9(var1*0.985,"당일중심-1.5%");
plot10(var1*0.980,"당일중심-2.0");
Plot11(dayOpen(0), "시가");
Plot12(dayopen+(1.50), "고가");
Plot13(dayopen-(1.50),"저가");
2019-01-04
178
글번호 124981
답변완료
한가지만 더 부탁드릴께요~~
익절 청산 수식인데요...
봉완성후 익절틱수1가 넘으면 청산되는 수식인데요...
거기에다 봉완성이 되지 않더라도 가격 도달시 즉시 청산 하는 수식을 넎고 싶어요..
변수이름: 바로즉시익절틱수1 , 바로즉시익절틱수2
이변수이름으로 아래수식에 추가로 넣어주세요~~
if T == 1 then
SetStopProfittarget(PriceScale*익절틱수1, PointStop);
SetStopLoss(PriceScale*손절틱수1, PointStop);
if T == -1 then
SetStopProfittarget(PriceScale*익절틱수2, PointStop);
SetStopLoss(PriceScale*손절틱수2, PointStop);
2019-01-04
159
글번호 124980
답변완료
수식 부탁해요~~ 분할진입
총 5회까지 진입가능하게요
매수 진입시
최초 신호떳을때 진입
최초 진입 가격 -5tick 도달시 즉시 현재가 진입
최초 진입 가격 -10tick 도달시 즉시 현재가 진입
최초 진입 가격 -15tick 도달시 즉시 현재가 진입
최초 진입 가격 -20tick 도달시 즉시 현재가 진입
하는 수식 부탁합니다 ( 매도는 반대방향으로 )
1회만 진입하는 식은 다음과 같습니다.
input : p1(3),p2(1),af(0.02), maxAF(0.2);
input : 익절틱수1(55),익절틱수2(49),손절틱수1(70),손절틱수2(30);
input : 매수후수익날랑말랑한틱수(35),매도후수익날랑말랑한틱수(37),매수진입후아예빠져서손절날틱수(80),매도진입한후아예빠져서손절날틱수(74);
input : N1(1),N2(10);
Input :N(25),매수제한(0.02),매도제한(0.18);
var : cnt(0),sum1(0),sum2(0),avg1(0),avg2(0),avg3(0),T(0),mav2(0),mav3(0),value(0);
var : sum3(0),Tcond(false);
var1 = CSar(af,maxAF);
Var4 = highest(H,N);
Var5 = lowest(L,N);
if DayClose(N2) > 0 Then
{
sum1 = 0;
sum2 = 0;
for cnt = 0 to N2-1
{
if cnt < N1 Then
sum1 = sum1 + DayClose(cnt);
if cnt < N2 Then
sum2 = sum2 + DayClose(cnt+1);
}
avg1 = sum1/N1;
avg2 = sum2/N2;
T = 0;
if avg1 >= avg2 Then
T = 1;
if avg1 < avg2 Then
T = -1;
#골드가 발생하면
if var1 > C Then
{
#value1에 봉번호 저장
value1 = index;
#value2에 종가 저장
value2 = C;
}
#데드가 발생하면
If var1 < C Then
{
#value3에 봉번호 저장
value3 = index;
#value4에 종가 저장
value4 = C;
}
#무포지션이고
#골드이후 10개봉이상 경과했고
#종가가 직전 10봉의 최고가보다 크고
#종가가 골드봉의 종가보다 크면
#매수
if MarketPosition == 0 and
T == 1 and
index >= value1+P1 and
C > highest(H,P1)[1] and
C <= Var4-(Var4-Var5)*매수제한 and
C > value2 then
buy("매수",OnClose,def,1);
#무포지션이고
#데드이후 10개봉이상 경과했고
#종가가 직전 10봉의 최저가보다 작고
#종가가 데드봉의 종가보다 작으면
#매도
if MarketPosition == 0 and
T == -1 and
index >= value3+P2 and
C < Lowest(L,P2)[1] and
C >= Var5+(Var4-Var5)*매도제한 and
C < value4 then
Sell("매도",OnClose,def,1);
====================================================================================
청산 수식도 부탁해요~~
이식은 분할진입하지 않고 단발 진입할때의 청산 수식이구요...
분할진입할때의 청산시 수식은 다음과 같이 부탁드려요...
모든 기준 금액은 최초 진입했던 가격을 기준으로 하고요.. 청산시는 분할진입한것 일괄 청산
if T == 1 then
SetStopProfittarget(PriceScale*익절틱수1, PointStop);
SetStopLoss(PriceScale*손절틱수1, PointStop);
if T == -1 then
SetStopProfittarget(PriceScale*익절틱수2, PointStop);
SetStopLoss(PriceScale*손절틱수2, PointStop);
if MarketPosition == 1 Then
{
if highest(H,BarsSinceEntry) >= EntryPrice+PriceScale*매수후수익날랑말랑한틱수 Then
ExitLong("본전탈출1",AtStop,EntryPrice+PriceScale*2);
Else
ExitLong("가슴아픈손절1",AtStop,EntryPrice-PriceScale*매수진입후아예빠져서손절날틱수);
}
if MarketPosition == -1 Then
{
if Lowest(L,BarsSinceEntry) <= EntryPrice-PriceScale*매도후수익날랑말랑한틱수 Then
ExitShort("본전탈출2",AtStop,EntryPrice-PriceScale*2);
Else
ExitShort("가슴찢어지는손절",AtStop,EntryPrice+PriceScale*매도진입한후아예빠져서손절날틱수);
}
}
2019-01-04
179
글번호 124979