커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
5556
글번호 230811
답변완료
수식부탁드립니다
안녕하세요..
아래수식에서
1) Reverse1및 Reverse2 가 상승하면 각각 Pink 표시하고
Reverse1 > Reverse2 상태에서 -- Reverse1및 Reverse2 상승하면 Cyan,하락하면 Lcyan
2) Reverse1및 Reverse2 가 하락하면 각각 Lcyan 표시하고
Reverse1 < Reverse2 상태에서 -- Reverse1및 Reverse2가 하락하면 Red,하락하면 Lcyan
3) Reverse1 > RSI 이면 RSI 색을 BLUE ,
Reverse1 < RSI 이면 RSI 색을 Red 표시 ..
답변해주신 수식으로는 색은 제대로 표시되나 챠트가 다르게 구현되어 다시부탁드립니다
Input : Short(12), Long(24);
Input : Period1(9);
var : RSI1(0);
value1 = accumN(C-C[1],Short);
value2 = accumN(C-C[1],Long);
value3 = iff(C>C[1],C-C[1],0);
value4 = iff(C<C[1],C-C[1],0);
RSI1 = RSI(Period1);
PlotBaseLine1(0, "기준");
PlotBaseLine2(75, "기준2");
PlotBaseLine3(-75, "기준3");
if RSI1 >=RSI1[1] Then
plot3(RSI1-50,"RSI1",YELLOW);
if RSI1 <=RSI1[1] Then
plot3(RSI1-50,"RSI1",BLUE);
If value1 > 0 Then
plot2 (value1*(-100)/accumN(value3,Short), "reverse1");
Else
plot2 (value1*100/accumN(value4,Short), "reverse1");
If value2 > 0 then
plot1(value2*(-100)/accumN(value3,Long),"reverse2");
Else
plot1(value2*100/accumN(value4,Long),"reverse2");
2021-05-12
1313
글번호 148958
푸른 님에 의해서 삭제되었습니다.
2021-05-12
0
글번호 148947
답변완료
수정부탁드립니다.
안녕하세요...글번호72393 에 수정해주신것이 제가 의도한것과 달라서요.
글번호 63245 에서 수정부탁드립니다.
plot 7 0값라인 추가해 주세요.
잔량라인은 당일것만 그려지게요.
수고하세요...꾸벅
2021-05-12
1390
글번호 148946
답변완료
주가비교로 종목검색(월봉, 일봉)
아래와 같은 2가지로 종목을 검색하고 싶습니다.
첫번째, 주가비교(다른주기)로 검색하는 경우.
1. 주가비교(다른주기) : 0봉전 종가(일봉) >= 1봉전 종가(월봉)
2. 월봉기준 : 0봉전 종가 >= 20기간 단순이동평균(고가기준)
두번째, 조건주기가 월봉, 일봉이 같이 있는 경우
1. 월봉기준 : 0봉전 종가 >= 1봉전 종가
2. 월봉기준 : 0봉전 종가 >= 20기간 단순이동평균(고가기준)
3. 월봉기준 : 1봉전 종가 < 20기간 단순이동평균(고가기준)
4. 월봉기준 : 3봉 동안 최저종가 대비 종가 등략률이 10%이상 30%이하
5. 월봉기준 : 1봉전 종가 대비 0봉전 종가 등략률이 10%이상 15%이하
6. 월봉기준 : 0봉전 종가 >= 0봉전 Pivot Line 2차 저항선
7. 일봉기준 : 0봉전 종가 >= 0봉전 Pivot Line 2차 저항선
8. 일봉기준 : 3봉 이내 2회 연속으로 0봉전 종가 >= 0봉전 시가
2021-05-12
1296
글번호 148945
답변완료
수식검증 부탁드려요
다른 수식과 조합해서 쓰려는데
계속 오류 뜨네요,, ㅜㅜ
input : N(20);
Input : Period(12), Period1(5);sto3(5);
var : HH(0),fk(0),fd(0),t(0);
var : hi(0),l1(0),l2(0),i1(0),i2(0);
var : stok(0),stod(0);
HH = Highest(H,N);
fk = fastK(Period);
fd = fastD(Period,Period1);
stok = StochasticsK(sto1,sto2);
stod = StochasticsD(sto1,sto2,sto3);
#신고가 봉번호
if H > HH[1] Then
hi = Index;
if stok > stok[1] Then
T = 1;
if stok < stok[1] Then
T = -1;
#상승전환
if T == 1 and T != T[1] Then
{
L1 = stok[1];
L2 = L1[1];
}
#스토 골드
if T == 1 and L1 > L2 and L2 <= 20 and L2 > 0 and CrossUp(stok,stod) Then
{
T = 2;
Find(1);
}
#현재봉 스토 골드
#최고가 발생 후 스토 데드 2번발생
}
#sto데드
If CrossDown(fk, fd) Then
{
T = -1;
L1 = fk;
L2 = L1[1];
i1 = Index;
i2 = i1[1];
}
#스토 데드이후의 최저가
if T == -1 Then
{
if fk < L1 Then
{
L1 = fk;
i1 = Index;
}
}
2021-05-12
1181
글번호 148944
따라고나 님에 의해서 삭제되었습니다.
2021-05-12
0
글번호 148943
답변완료
질문좀 할께요~
안녕하세요.
현재종가가 가중 5이평선위에 위치해 있거나, 돌파하는걸 검색하고 싶은데요..
참고로 기관.외인 양매수된 종목검색은 안되는 건가요?
부탁드려요~~
2021-05-12
1125
글번호 148942
답변완료
수정부탁드립니다
#,보내주신 수식적용할때 첨부파일처럼 상단파동 파란색라인은 비율이 맞는데
하단파동 빨간색 라인은 비율이 틀리게 출력됩니다,수식확인요청드립니다
input : af(0.02), maxAF(0.2),텍스트출력(1),크기(0);;
var : T(0),HH(0),LL(0),HD(0),HT(0),LD(0),LT(0);
var : HH1(0),LL1(0),HD1(0),HT1(0),LD1(0),LT1(0);
var : TL1(0),TL2(0),TL3(0),TL4(0),TL5(0);
var : TL6(0),tl7(0),TL8(0),TL9(0),TL10(0);
var : tx1(0),tx2(0),tx11(0),tx22(0);
var : x1(0),x2(0),x3(0),x4(0),x5(0);
var : x6(0),x7(0),x8(0),x9(0),x10(0);
var1 = CSar(af,maxAF);
if crossup(c,var1) Then
{
T = 1;
HH = H;
HD = sdate;
HT = stime;
HH1 = HH[1];
HD1 = HD[1];
HT1 = HT[1];
if LL > 0 Then
{
if 텍스트출력 == 1 then
{
Tx11 = Text_New(HD1,HT1,HH1,NumToStr((HH1-LL1),2)+NewLine+NumToStr(HH1,2));
Text_SetStyle(tx11,2,1);
Text_SetColor(tx11,BLUE);
Text_SetSize(tx11,크기);
Text_Delete(tx1);
Tx1 = Text_New(HD,HT,HH,NumToStr((HH-LL[1]),2)+NewLine+NumToStr(HH,2));
Text_SetStyle(tx1,2,1);
Text_SetColor(tx1,BLUE);
Text_SetSize(tx1,크기);
}
}
}
if CrossDown(c,var1) Then
{
T = -1;
LL = L;
LD = sdate;
LT = stime;
LL1 = LL[1];
LD1 = LD[1];
LT1 = LT[1];
if HH > 0 Then
{
if 텍스트출력 == 1 then
{
Tx22 = Text_New(LD1,LT1,LL1,NumToStr((HH1-LL1),2)+NewLine+NumToStr(LL1,2));
Text_SetStyle(tx22,2,0);
Text_SetColor(tx22,RED);
Text_Delete(tx2);
Text_SetSize(tx22,크기);
Tx2 = Text_New(LD,LT,LL,NumToStr((HH[1]-LL),2)+NewLine+NumToStr(LL,2));
Text_SetStyle(tx2,2,0);
Text_SetColor(tx2,RED);
Text_SetSize(tx2,크기);
}
}
}
if T == 1 then
{
if H > HH Then
{
HH = H;
HD = sdate;
HT = stime;
if 텍스트출력 == 1 then
{
Text_Delete(tx1);
Tx1 = Text_New(HD,HT,HH,NumToStr((HH-LL[1]),2)+NewLine+NumToStr(HH,2));
Text_SetStyle(tx1,2,1);
Text_SetColor(tx1,BLUE);
Text_SetSize(tx1,크기);
}
}
}
if T == -1 then
{
if L < LL Then
{
LL = L;
LD = sdate;
LT = stime;
if 텍스트출력 == 1 then
{
Text_Delete(tx2);
Tx2 = Text_New(LD,LT,LL,NumToStr((HH[1]-LL),2)+NewLine+NumToStr(LL,2));
Text_SetStyle(tx2,2,0);
Text_SetColor(tx2,RED);
Text_SetSize(tx2,크기);
}
}
}
if nextbarsdate != sdate Then
{
if T == 1 Then
{
TL_Delete(TL1);
TL_Delete(TL2);
TL_Delete(TL3);
TL_Delete(TL4);
TL_Delete(TL5);
#TL1 = TL_New(LD,LT,HH,sDate,sTime,HH);
TL2 = TL_New(LD,LT,HH+1.0,sDate,sTime,HH+1.0);
TL3 = TL_New(LD,LT,HH+1.617,sDate,sTime,HH+1.618);
TL4 = TL_New(LD,LT,HH-1.0,sDate,sTime,HH-1.0);
TL5 = TL_New(LD,LT,HH-1.618,sDate,sTime,HH-1.618);
TL_SetColor(TL1,BLUE);
TL_SetColor(TL2,BLUE);
TL_SetColor(TL3,BLUE);
TL_SetColor(TL4,BLUE);
TL_SetColor(TL5,BLUE);
TL_Delete(TL6);
TL_Delete(TL7);
TL_Delete(TL8);
TL_Delete(TL9);
TL_Delete(TL10);
#TL6 = TL_New(LD,LT,LL,sDate,sTime,LL);
TL7 = TL_New(LD,LT,LL+1.0,sDate,sTime,LL+1.0);
TL8 = TL_New(LD,LT,LL+1.618,sDate,sTime,LL+1.618);
TL9 = TL_New(LD,LT,LL-1.0,sDate,sTime,LL-1.0);
TL10 = TL_New(LD,LT,LL-1.618,sDate,sTime,LL-1.618);
TL_SetColor(TL6,RED);
TL_SetColor(TL7,RED);
TL_SetColor(TL8,RED);
TL_SetColor(TL9,RED);
TL_SetColor(TL10,RED);
Text_Delete(x1);
Text_Delete(x2);
Text_Delete(x3);
Text_Delete(x4);
Text_Delete(x5);
#x1 = Text_New(sDate,sTime,HH,NumToStr(HH,2));
x2 = Text_New(sDate,sTime,HH+1.0,NumToStr(HH+1.0,2));
x3 = Text_New(sDate,sTime,HH+1.618,NumToStr(HH+1.618,2));
x4 = Text_New(sDate,sTime,HH-1.0,NumToStr(HH-1.0,2));
x5 = Text_New(sDate,sTime,HH-1.618,NumToStr(HH-1.618,2));
Text_SetColor(x1,BLUE);
Text_SetColor(x2,BLUE);
Text_SetColor(x3,BLUE);
Text_SetColor(x4,BLUE);
Text_SetColor(x5,BLUE);
Text_SetStyle(x1,0,2);
Text_SetStyle(x2,0,2);
Text_SetStyle(x3,0,2);
Text_SetStyle(x4,0,2);
Text_SetStyle(x5,0,2);
Text_Delete(x6);
Text_Delete(x7);
Text_Delete(x8);
Text_Delete(x9);
Text_Delete(x10);
#x6 = Text_New(sDate,sTime,LL,NumToStr(LL,2));
x7 = Text_New(sDate,sTime,LL+1.0,NumToStr(LL+1.0,2));
x8 = Text_New(sDate,sTime,LL+1.618,NumToStr(LL+1.618,2));
x9 = Text_New(sDate,sTime,LL-1.0,NumToStr(LL-1.0,2));
x10 = Text_New(sDate,sTime,LL-1.618,NumToStr(LL-1.618,2));
Text_SetColor(x6,RED);
Text_SetColor(x7,RED);
Text_SetColor(x8,RED);
Text_SetColor(x9,RED);
Text_SetColor(x10,RED);
Text_SetStyle(x6,0,2);
Text_SetStyle(x7,0,2);
Text_SetStyle(x8,0,2);
Text_SetStyle(x9,0,2);
Text_SetStyle(x10,0,2);
}
Else
{
TL_Delete(TL1);
TL_Delete(TL2);
TL_Delete(TL3);
TL_Delete(TL4);
TL_Delete(TL5);
#TL1 = TL_New(HD,HT,HH,sDate,sTime,HH);
TL2 = TL_New(HD,HT,HH+1.0,sDate,sTime,HH+1.0);
TL3 = TL_New(HD,HT,HH+1.617,sDate,sTime,HH+1.618);
TL4 = TL_New(HD,HT,HH-1.0,sDate,sTime,HH-1.0);
TL5 = TL_New(HD,HT,HH-1.618,sDate,sTime,HH-1.618);
TL_SetColor(TL1,BLUE);
TL_SetColor(TL2,BLUE);
TL_SetColor(TL3,BLUE);
TL_SetColor(TL4,BLUE);
TL_SetColor(TL5,BLUE);
TL_Delete(TL6);
TL_Delete(TL7);
TL_Delete(TL8);
TL_Delete(TL9);
TL_Delete(TL10);
#TL6 = TL_New(HD,HT,LL,sDate,sTime,LL);
TL7 = TL_New(HD,HT,LL+1.0,sDate,sTime,LL+1.0);
TL8 = TL_New(HD,HT,LL+1.618,sDate,sTime,LL+1.618);
TL9 = TL_New(HD,HT,LL-1.0,sDate,sTime,LL-1.0);
TL10 = TL_New(HD,HT,LL-1.618,sDate,sTime,LL-1.618);
TL_SetColor(TL6,RED);
TL_SetColor(TL7,RED);
TL_SetColor(TL8,RED);
TL_SetColor(TL9,RED);
TL_SetColor(TL10,RED);
Text_Delete(x1);
Text_Delete(x2);
Text_Delete(x3);
Text_Delete(x4);
Text_Delete(x5);
#x1 = Text_New(sDate,sTime,HH,NumToStr(HH,2));
x2 = Text_New(sDate,sTime,HH+1.0,NumToStr(HH+1.0,2));
x3 = Text_New(sDate,sTime,HH+1.618,NumToStr(HH+1.618,2));
x4 = Text_New(sDate,sTime,HH-1.0,NumToStr(HH-1.0,2));
x5 = Text_New(sDate,sTime,HH-1.618,NumToStr(HH-1.618,2));
Text_SetColor(x1,BLUE);
Text_SetColor(x2,BLUE);
Text_SetColor(x3,BLUE);
Text_SetColor(x4,BLUE);
Text_SetColor(x5,BLUE);
Text_SetStyle(x1,0,2);
Text_SetStyle(x2,0,2);
Text_SetStyle(x3,0,2);
Text_SetStyle(x4,0,2);
Text_SetStyle(x5,0,2);
Text_Delete(x6);
Text_Delete(x7);
Text_Delete(x8);
Text_Delete(x9);
Text_Delete(x10);
#x6 = Text_New(sDate,sTime,LL,NumToStr(LL,2));
x7 = Text_New(sDate,sTime,LL+1.0,NumToStr(LL+1.0,2));
x8 = Text_New(sDate,sTime,LL+1.618,NumToStr(LL+1.618,2));
x9 = Text_New(sDate,sTime,LL-1.0,NumToStr(LL-1.0,2));
x10 = Text_New(sDate,sTime,LL-1.618,NumToStr(LL-1.618,2));
Text_SetColor(x6,RED);
Text_SetColor(x7,RED);
Text_SetColor(x8,RED);
Text_SetColor(x9,RED);
Text_SetColor(x10,RED);
Text_SetStyle(x6,0,2);
Text_SetStyle(x7,0,2);
Text_SetStyle(x8,0,2);
Text_SetStyle(x9,0,2);
Text_SetStyle(x10,0,2);
}
}
감사합니다.
2021-05-12
1375
글번호 148939
러블리 님에 의해서 삭제되었습니다.
2021-05-12
60
글번호 148936