커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
6040
글번호 230811
답변완료
확인 의뢰드립니다!
안녕하세요!
보내주신 수식 적용해 보니 아무것도 보이질 않는군요!
콜277.5를 data1으로 해서 data6까지 콜로 적용했어요!
제가 뭘 잘못 한건가요?
var : nday1(0,data1),week1(0,data1),Exdate1(false,data1);
var : H1(0,data1),L1(0,data1),D1(0,data1),B1(0,data1),H11(0,data1),L11(0,data1);
nday1 = data1(date - int(date/100)*100);
week1 = data1(DayOfWeek(date));
if nday1 >= 8 and nday1 <= 14 and week1 == 4 then
Exdate1 = true;
Else
Exdate1 = false;
if data1(bdate != bdate[1] and Exdate1 == false and Exdate1[1] == true) Then
{
d1 = data1(sdate);
H1 = data1(H);
L1 = data1(L);
H11 = H1[1];
L11 = L1[1];
}
if data1(sdate == d1) Then
{
B1 = data1(daylow);
}
if data1(H) > H1 Then
H1 = data1(H);
if data1(L) < L1 Then
L1 = data1(L);
if H1 > 0 and L1 > 0 then
{
plot1(H1,"월고1");
plot2(L1,"월저1");
}
if H11 > 0 and L11 > 0 then
{
plot3(H11,"전고1");
plot4(L11,"전저1");
}
if B1 > 0 then
plot5(B1,"월물첫날저가1");
var : nday2(0,data2),week2(0,data2),Exdate2(false,data2);
var : H2(0,data2),L2(0,data2),D2(0,data2),B2(0,data2),H22(0,data2),L22(0,data2);
nday2 = data2(date - int(date/100)*100);
week2 = data2(DayOfWeek(date));
if nday2 >= 8 and nday2 <= 14 and week2 == 4 then
Exdate2 = true;
Else
Exdate2 = false;
if data2(bdate != bdate[1] and Exdate2 == false and Exdate2[1] == true) Then
{
d2 = data2(sdate);
H2 = data2(H);
L2 = data2(L);
H22 = H2[1];
L22 = L2[1];
}
if data2(sdate == d2) Then
{
B2 = data2(LowD(0));
}
if data2(H) > H2 Then
H2 = data2(H);
if data2(L) < L2 Then
L2 = data2(L);
if H2 > 0 and L2 > 0 then
{
plot6(H2,"월고2");
plot7(L2,"월저2");
}
if H22 > 0 and L22 > 0 then
{
plot8(H22,"전고2");
plot9(L22,"전저2");
}
if B2 > 0 then
plot10(B2,"월물첫날저가2");
var : nday3(0,data3),week3(0,data3),Exdate3(false,data3);
var : H3(0,data3),L3(0,data3),D3(0,data3),B3(0,data3),H33(0,data3),L33(0,data3);
nday3 = data3(date - int(date/100)*100);
week3 = data3(DayOfWeek(date));
if nday3 >= 8 and nday3 <= 14 and week3 == 4 then
Exdate3 = true;
Else
Exdate3 = false;
if data3(bdate != bdate[1] and Exdate3 == false and Exdate3[1] == true) Then
{
d3 = data3(sdate);
H3 = data3(H);
L3 = data3(L);
H33 = H3[1];
L33 = L3[1];
}
if data3(sdate == d3) Then
{
B3 = data3(LowD(0));
}
if data3(H) > H3 Then
H3 = data3(H);
if data3(L) < L3 Then
L3 = data3(L);
if H3 > 0 and L3 > 0 then
{
plot11(H3,"월고3");
plot12(L3,"월저3");
}
if H33 > 0 and L33 > 0 then
{
plot13(H33,"전고3");
plot14(L33,"전저3");
}
if B3 > 0 then
plot15(B3,"월물첫날저가3");
var : nday4(0,data4),week4(0,data4),Exdate4(false,data4);
var : H4(0,data4),L4(0,data4),D4(0,data4),B4(0,data4),H44(0,data4),L44(0,data4);
nday4 = data4(date - int(date/100)*100);
week4 = data4(DayOfWeek(date));
if nday4 >= 8 and nday4 <= 14 and week4 == 4 then
Exdate4 = true;
Else
Exdate4 = false;
if data4(bdate != bdate[1] and Exdate4 == false and Exdate4[1] == true) Then
{
d4 = data4(sdate);
H4 = data4(H);
L4 = data4(L);
H44 = H4[1];
L44 = L4[1];
}
if data4(sdate == d4) Then
{
B4 = data4(LowD(0));
}
if data4(H) > H4 Then
H4 = data4(H);
if data4(L) < L4 Then
L4 = data4(L);
if H4 > 0 and L4 > 0 then
{
plot16(H4,"월고4");
plot17(L4,"월저4");
}
if H44 > 0 and L44 > 0 then
{
plot18(H44,"전고4");
plot19(L44,"전저4");
}
if B4 > 0 then
plot20(B4,"월물첫날저가4");
var : nday5(0,data5),week5(0,data5),Exdate5(false,data5);
var : H5(0,data5),L5(0,data5),D5(0,data5),B5(0,data5),H55(0,data5),L55(0,data5);
nday5 = data5(date - int(date/100)*100);
week5 = data5(DayOfWeek(date));
if nday5 >= 8 and nday5 <= 14 and week5 == 4 then
Exdate5 = true;
Else
Exdate5 = false;
if data5(bdate != bdate[1] and Exdate5 == false and Exdate5[1] == true) Then
{
d5 = data5(sdate);
H5 = data5(H);
L5 = data5(L);
H55 = H5[1];
L55 = L5[1];
}
if data5(sdate == d5) Then
{
B5 = data5(LowD(0));
}
if data5(H) > H5 Then
H5 = data5(H);
if data5(L) < L5 Then
L5 = data5(L);
if H5 > 0 and L5 > 0 then
{
plot21(H5,"월고5");
plot22(L5,"월저5");
}
if H55 > 0 and L55 > 0 then
{
plot23(H55,"전고5");
plot24(L55,"전저5");
}
if B5 > 0 then
plot25(B5,"월물첫날저가5");
var : nday6(0,data6),week6(0,data6),Exdate6(false,data6);
var : H6(0,data6),L6(0,data6),D6(0,data6),B6(0,data6),H66(0,data6),L66(0,data6);
nday6 = data6(date - int(date/100)*100);
week6 = data6(DayOfWeek(date));
if nday6 >= 8 and nday6 <= 14 and week6 == 4 then
Exdate6 = true;
Else
Exdate6 = false;
if data6(bdate != bdate[1] and Exdate6 == false and Exdate6[1] == true) Then
{
d6 = data6(sdate);
H6 = data6(H);
L6 = data6(L);
H66 = H6[1];
L66 = L6[1];
}
if data6(sdate == d6) Then
{
B6 = data6(LowD(0));
}
if data6(H) > H6 Then
H6 = data6(H);
if data6(L) < L6 Then
L6 = data6(L);
if H6 > 0 and L6 > 0 then
{
plot26(H6,"월고6");
plot27(L6,"월저6");
}
if H66 > 0 and L66 > 0 then
{
plot28(H66,"전고6");
plot29(L66,"전저6");
}
if B6 > 0 then
plot30(B6,"월물첫날저가6");
2019-01-24
199
글번호 125567
답변완료
수식 부탁 드립니다
시뮬레이션 차트에 적용하는 비용/수량 설정창에 누적자산 기준 진입과 똑같은 결과값이 나오는 주문수식을 부탁드립니다.
자세히 설명을 드리면, 초기 투자자금은 2천만원이고 저의 진입식은 네가지 종류이고
어느 것이 먼저 진입될지, 하루에 네가지 중에 몇개의 매수신호가 나올지 모르는 상황에서
시장에 따라 계좌가 손해보면 손해 보는대로 이익이 나면 이익이 나는대로 누적자산에 4등분
되어 각각 주문이 들어가고, 수익에 복리효과가 발생할 수 있도록 매수 주문처리를 하고
싶습니다.
30분봉에서
매수주문1. 시가대비 0.5% 상승시 매수
매수주문2. 시가대비 1% 상승시 매수
매수주문3. 전일고가를 넘는 갭상승 출발후 시가대비 0.5% 상승시 매수
매수주문4. 전일고가를 넘는 갭상승 출발 후 시가대비 0.7% 상승시 매수
이렇게 네가지 주문에 매번 누적자산의 4등분 된 금액이 들어갈 수 있는 매수식 부탁합니다.
2019-01-24
165
글번호 125565
답변완료
수식 부탁드립니다.
수식 부탁드립니다.
아래에 해당하는 선 6개를 차트에 넣고 명칭이 차트에 표시될 수 있도록 수식 부탁드립니다.
1. "전일저가"(daylow(1))
2. "전일종가"(dayclose(1))
3. "전일고가"(dayhigh(1))
4. "상대전일고가"(외부입력)
5. "상대전일저가"(외부입력)
6. "상대전일종가"(외부입력)
외부입력을 미리 넣어야한다면 대충 숫자 1.0 ,2.0 ,3.0 넣어주십시오.
감사합니다.
2019-01-24
148
글번호 125559
haha1122 님에 의해서 삭제되었습니다.
2019-01-24
17
글번호 125556
답변완료
함수식
안녕하세요 미리 감사인사올립니다
질문 1 아래식에서 현재가가 중심선을 돌파후 5거래량 이평이 20일 거래량이평을 돌파한후
매수 신호발생시 10틱 아래에서 매수대기
매도는 반대입니다
Input : Period(20), MultiD(2);
var : BBmd(0),BBup(0),BBdn(0);
BBmd1 = ma(C,Period);
BBup1 = BollBandUp(Period,MultiD);
BBdn1 = BollBandDown(Period,MultiD);
질문2
당일의 싯가가 전일의 중심선 위에서 시작하면 A 로직
당일의 싯가가 전일의 중심선 아래에서 시작하면 B 로직
질문3 지표식
전일의 중심선을 수평선으로 표시되게 부탁드려요
항상 감사합니다
2019-01-25
159
글번호 125553
답변완료
수식 수정부탁드립니다.
아래 수식으로 진입 시간이나 종료 시간을 함수로 조정하려하는데
예를 들어 진입 시간이나 종료 시간을 변경하여 시스템 매매를 하여도
0~24시로 인식하여 매매되는 현상이 일어나는데 수식중 어디가 잘못된건지
찾지를 못하겠습니다. 수정 부탁드립니다.
그리고 함수식으로 정해진 매매시간동안 하루 지정 횟수만 매매가 되도록
수식도 포함 부탁드립니다.
input: b_time1(000000),e_time1(240000);
input: 상단(95),하단(5),익절틱수(10);
input : 당일수익틱수(160);
input : 당일목표손실(100);
Input : short(16), long(26), signal(25);
Var : MACDv(0), MACDs(0),macdo(0) ;
MACDv = MACD(short, long);
MACDs = ema(MACDv,signal);
macdo = MACDv-MACDs;
Var : stoK(0),stoD(0),T1(0),T2(0);
var : Tcond(false);
Var : N1(0),dayPl(0),당일수익(0),당일손실(0),Xcond(false);
당일수익 = PriceScale*당일수익틱수;
당일손실 = PriceScale*당일목표손실;
if (sdate != sdate[1] and stime >= b_time1) or
(sdate == sdate[1] and stime >= b_time1 and stime[1] < b_time1) Then
{
Tcond = true;
Xcond = false;
N1 = NetProfit;
}
daypl = NetProfit-N1;
if TotalTrades > TotalTrades[1] Then
{
if (IsExitName("금일종료",1) == true or IsExitName("금일종료1",1) == true or
IsExitName("금일종료2",1) == true or IsExitName("금일종료3",1) == true) then
Xcond = true;
if daypl >= 당일수익 or daypl <= -당일손실 Then
Xcond = true;
}
If b_time1<=sTime and sTime<= e_time1 Then
{
stoK = StochasticsK(stoK_p11,stoK_p12);
stoD = StochasticsD(stoK_p11,stoK_p12,stoK_p13);
}
if Xcond == false and
MarketPosition == 0 and
MarketPosition >= 0 and
CrossDown(MACDo,0) then
sell("매도",AtMarket);
if MarketPosition == -1 Then
{
ExitShort("금일종료",atlimit,EntryPrice-((당일수익-daypl)/CurrentContracts));
ExitShort("금일종료1",AtStop,EntryPrice+((당일손실+daypl)/CurrentContracts));
if Crossup(stok,상단) then
ExitShort("매도청산",AtMarket);
}
if Xcond == false and
MarketPosition == 0 and
MarketPosition <= 0 and
crossup(MACDo,0) then
buy("매수",AtMarket);
if MarketPosition == 1 Then
{
ExitShort("금일종료2",atlimit,EntryPrice-((당일수익-daypl)/CurrentContracts));
ExitShort("금일종료3",AtStop,EntryPrice+((당일손실+daypl)/CurrentContracts));
if Crossdown(stok,하단) then
Exitlong("매수청산",AtMarket);
}
SetStopProfittarget(PriceScale*익절틱수,PointStop);
2019-01-24
157
글번호 125539
답변완료
문의합니다.
매수진입
C < C[1] < C[2] 인
즉 종가가 3연속으로 하락하는
가장 최근의 3연속 음봉을 찾아서 최초음봉 2번째음봉 3번째음봉중에서
최초음봉의 시가 O[2] 를 매수기준가로 저장합니다.
무포지션이나 매도포지션에서
현재봉 종가가 위의 매수기준가를 위로 돌파하면 매수진입합니다.
매도진입
C > C[1] >C[2] 인
즉 종가가 3연속으로 상승하는
가장 최근의 3연속 양봉을 찾아서 최초양봉 2번째양봉 3번째양봉중에서
최초양봉의 시가 O[2]를 매도기준가로 저장합니다.
무포지션이나 매수포지션에서
현재봉 종가가 위의 매도기준가를 하방으로 돌파하면 매도진입합니다.
청산
매수이던지 매도이던지 수익이 10틱나면 수익청산합니다.
2019-01-24
153
글번호 125536
답변완료
질문입니다.
아래의 수식을 사용자 함수로 변환 부탁드립니다.(분봉에서 사용)
var : HL0(0),HL1(0),HL2(0),HL3(0);
#당일 HL0
if H[1] == dayhigh Then
HL0 = L;
if L < HL0 Then
HL0 = L;
if date != date[1] Then{
HL1 = HL0[1];#전일 HL
HL2 = HL1[1];#전전일 HL
HL3 = HL2[1];#전전전일 HL
}
2019-01-24
157
글번호 125530
답변완료
부탁드립니다 !
항상 수고하심에 감사드립니다 ^^
1, 아래 수식에서 선이 발생되어 봉과 만날때(몸통으로 만나든 꼬리로 만나든 상관없이)
음성신호가 발생되도록 수정 부탁드립니다
2, 또 이때 이 만남봉과 이전의 기준이된 봉과의 거리(그동안 발생된 봉의 수)를 수치로
봉 근처에 표시할수있을까요?
예를들어 쌍바닥선이 완성된 경우라면 이전 저점자리의 봉과 현재 만남봉 사이에서 발생된
봉의 갯수가 총 몇개인지 알고자함입니다
가능하다면 수치는 좀 두껍게 부탁드리고요 색상도 수정가능했으면 좋겠습니다
감사합니다!!!
input : af(0.02), maxAF(0.2);
input : 텍스트출력(1),선굵기(2);
var : T(0),cnt(0),count(0);
var : HH1(0),LL1(0),HD1(0),HT1(0),LD1(0),LT1(0),day1(0),day0(0),TL3(0);
var : TL1(0),TL2(0),tx1(0),tx2(0),tx11(0),tx22(0);
Array : HD[20](0),HT[20](0),HH[20](0),LD[20](0),LT[20](0),LL[20](0);
var1 = CSar(af,maxAF);
if bdate != bdate[1] Then
{
day0 = sdate;
day1 = day0[1];
}
if crossup(c,var1) Then
{
T = 1;
HH[0] = H;
HD[0] = sdate;
HT[0] = stime;
for cnt = 1 to 19
{
HD[cnt] = HD[cnt-1][1];
HT[cnt] = HT[cnt-1][1];
HH[cnt] = HH[cnt-1][1];
}
if LL[0] > 0 Then
{
if 텍스트출력 == 1 then
{
Tx11 = Text_New(HD[1],HT[1],HH[1],NumToStr((HH[1]-LL[1])/PriceScale,0)+NewLine+NumToStr(HH[1],2));
Text_SetStyle(tx11,2,1);
Text_SetColor(tx11,BLACK);
Text_Delete(tx1);
Tx1 = Text_New(HD[0],HT[0],HH[0],NumToStr((HH[0]-LL[0])/PriceScale,0)+NewLine+NumToStr(HH[0],2));
Text_SetStyle(tx1,2,1);
Text_SetColor(tx1,GRAY);
Condition1 = false;
for cnt = 1 to 19
{
if Condition1 == false and abs(LL[0]-LL[cnt]) <= PriceScale*1 and LD[cnt] >= day1 Then
{
Condition1 = true;
TL1 = TL_New(LD[cnt],LT[cnt],LL[cnt],LD[0],LT[0],LL[0]);
TL_SetSize(TL1,선굵기);
TL_SetColor(TL1,yellow);
}
}
}
}
}
if CrossDown(c,var1) Then
{
T = -1;
LL[0] = L;
LD[0] = sdate;
LT[0] = stime;
for cnt = 1 to 19
{
LD[cnt] = LD[cnt-1][1];
LT[cnt] = LT[cnt-1][1];
LL[cnt] = LL[cnt-1][1];
}
if HH[0] > 0 Then
{
if 텍스트출력 == 1 then
{
Tx22 = Text_New(LD[1],LT[1],LL[1],NumToStr((HH[1]-LL[1])/PriceScale,0)+NewLine+NumToStr(LL[1],2));
Text_SetStyle(tx22,2,0);
Text_SetColor(tx22,RED);
Text_Delete(tx2);
Tx2 = Text_New(LD[0],LT[0],LL[0],NumToStr((HH[0]-LL[0])/PriceScale,0)+NewLine+NumToStr(LL[0],2));
Text_SetStyle(tx2,2,0);
Text_SetColor(tx2,MAGENTA);
Condition2 = false;
for cnt = 1 to 19
{
if Condition2 == false and abs(HH[0]-HH[cnt]) <= PriceScale*1 and HD[cnt] >= day1 Then
{
Condition2 = true;
TL2 = TL_New(HD[cnt],HT[cnt],HH[cnt],HD[0],HT[0],HH[0]);
TL_SetSize(TL2,선굵기);
TL_SetColor(TL2,yellow);
}
}
}
}
}
if T == 1 then
{
if H > HH[0] Then
{
HH[0] = H;
HD[0] = sdate;
HT[0] = stime;
if 텍스트출력 == 1 then
{
Text_Delete(tx1);
Tx1 = Text_New(HD[0],HT[0],HH[0],NumToStr((HH[0]-LL[0])/PriceScale,0)+NewLine+NumToStr(HH[0],2));
Text_SetStyle(tx1,2,1);
Text_SetColor(tx1,black);
TL_Delete(TL3);
Condition3 = false;
for cnt = 1 to 19
{
if Condition3 == false and abs(HH[0]-HH[cnt]) <= PriceScale*1 and HD[cnt] >= day1 Then
{
Condition3 = true;
TL3 = TL_New(HD[cnt],HT[cnt],HH[cnt],HD[0],HT[0],HH[0]);
TL_SetSize(TL3,선굵기);
TL_SetColor(TL3,yellow);
}
}
}
}
}
if T == -1 then
{
if L < LL[0] Then
{
LL[0] = L;
LD[0] = sdate;
LT[0] = stime;
if 텍스트출력 == 1 then
{
Text_Delete(tx2);
Tx2 = Text_New(LD[0],LT[0],LL[0],NumToStr((HH[0]-LL[0])/PriceScale,0)+NewLine+NumToStr(LL[0],2));
Text_SetStyle(tx2,2,0);
Text_SetColor(tx2,red);
TL_Delete(TL3);
Condition3 = false;
for cnt = 1 to 19
{
if Condition3 == false and abs(LL[0]-LL[cnt]) <= PriceScale*1 and LD[cnt] >= day1 Then
{
Condition3 = true;
TL3 = TL_New(LD[cnt],LT[cnt],LL[cnt],LD[0],LT[0],LL[0]);
TL_SetSize(TL3,선굵기);
TL_SetColor(TL3,yellow);
}
}
}
}
}
2019-01-24
180
글번호 125524