커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
1544
글번호 230811
아침 님에 의해서 삭제되었습니다.
2023-03-23
137
글번호 167476
답변완료
수식 부탁 드립니다.
키움수식 예스로 변환 부탁합니다.
1.매수신호:highest(v,20) == v
2.매수신호:bb=valuewhen(1,if(aa,1,0),O);
crossup(c,bb)
&&
O<C
항상 건강하세요.
2023-03-23
1034
글번호 167475
답변완료
전환 쌍바닥
Input : 전환(0.2);
Var:j(0),jj(0),HH(0),LL(0),hiBar(0),loBar(0),최종꼭지점(""),처리구분(""), TL1(0),TX1(0);
Array:고[10,4](0),저[10,4](0);
var : box(0),BB(False);
HH = H;
LL = L;
If Index == 0 Then
{
고[1,1] = HH;
고[1,2] = 0;
고[1,3] = sDate;
고[1,4] = sTime;
저[1,1] = LL;
저[1,2] = 0;
저[1,3] = sDate;
저[1,4] = sTime;
}
If Index > 0 Then
{
hiBar = hiBar + 1;
loBar = loBar + 1;
}
If HH[hiBar] < HH Then hiBar = 0;
If LL[loBar] > LL Then loBar = 0;
Condition1 = 저[1,1]+전환 <= HH and hiBar == 0;
Condition2 = 고[1,1]-전환 >= LL and loBar == 0;
처리구분 = "";
If Condition1 and Condition2 Then
{
If 최종꼭지점 == "저점" Then
{
If 저[1,1] > LL Then 처리구분 = "저점처리";
Else 처리구분 = "고점처리";
}
Else If 최종꼭지점 == "고점" Then
{
If 고[1,1] < HH Then 처리구분 = "고점처리";
Else 처리구분 = "저점처리";
}
}
Else If Condition1 Then 처리구분 = "고점처리";
Else If Condition2 Then 처리구분 = "저점처리";
If 처리구분 == "고점처리" Then
{
If 최종꼭지점 == "저점" Then
{
For j = 10 DownTo 2
{
For jj = 1 To 4
{
고[j,jj] = 고[j-1,jj];
}
}
고[1,1] = HH[hiBar];
고[1,2] = Index - hiBar;
고[1,3] = sDate[hiBar];
고[1,4] = sTime[hiBar];
hiBar = -1;
loBar = -1;
TL1 = TL_New_Self(저[1,3],저[1,4],저[1,1],고[1,3],고[1,4],고[1,1]);
TL_SetSize(TL1,2);
TL_SetColor(TL1,RED);
Text_Delete(tx1-1);
TX1 = Text_New_Self(고[1,3],고[1,4],고[1,1],NumToStr(고[1,1]-저[1,1],2));
Text_SetSize(tx1,30);
Text_SetColor(Tx1,Red);
Text_SetStyle(tx1,1,1);
Text_SetBold(tx1,1);
}
Else If 고[1,1] < HH[hiBar] Then
{
고[1,1] = HH[hiBar];
고[1,2] = Index - hiBar;
고[1,3] = sDate[hiBar];
고[1,4] = sTime[hiBar];
hiBar = -1;
loBar = -1;
TL_SetEnd(TL1,고[1,3],고[1,4],고[1,1]);
Text_SetString(TX1,NumToStr(고[1,1]-저[1,1],2));
Text_SetLocation(TX1,고[1,3],고[1,4],고[1,1]);
}
최종꼭지점 = "고점";
Plot1(고[1,1]);
NoPlot(2);
}
If 처리구분 == "저점처리" Then
{
If 최종꼭지점 == "고점" Then
{
For j = 10 DownTo 2
{
For jj = 1 To 4
{
저[j,jj] = 저[j-1,jj];
}
}
저[1,1] = LL[loBar];
저[1,2] = Index - loBar;
저[1,3] = sDate[loBar];
저[1,4] = sTime[loBar];
hiBar = -1;
loBar = -1;
TL1 = TL_New_Self(고[1,3],고[1,4],고[1,1],저[1,3],저[1,4],저[1,1]);
TL_SetSize(TL1,2);
TL_SetColor(TL1,BLUE);
Text_Delete(tx1-1);
TX1 = Text_New_Self(저[1,3],저[1,4],저[1,1],NumToStr(저[1,1]-고[1,1],2));
Text_SetSize(tx1,30);
Text_SetColor(Tx1,Blue);
Text_SetStyle(tx1,1,0);
Text_SetBold(tx1,1);
bb = False;
if bb == False and 저[1,1] <= 고[1,1]-0.5 and 고[1,1] > 0 Then
{
bb= true;
box = Box_New_Self(고[1,3],고[1,4],고[1,1],저[1,3],저[1,4],저[1,1]);
Box_SetColor(box,Lime);
Box_SetFill(box,true,70);
}
}
Else If 저[1,1] > LL[loBar] Then
{
저[1,1] = LL[loBar];
저[1,2] = Index - loBar;
저[1,3] = sDate[loBar];
저[1,4] = sTime[loBar];
hiBar = -1;
loBar = -1;
TL_SetEnd(TL1,저[1,3],저[1,4],저[1,1]);
Text_SetString(TX1,NumToStr(저[1,1]-고[1,1],2));
Text_SetLocation(TX1,저[1,3],저[1,4],저[1,1]);
if bb == true Then
Box_SetEnd(box,저[1,3],저[1,4],저[1,1]);
Else
{
if bb == False and 저[1,1] <= 고[1,1]-0.5 and 고[1,1] > 0 Then
{
bb= true;
box = Box_New_Self(고[1,3],고[1,4],고[1,1],저[1,3],저[1,4],저[1,1]);
Box_SetColor(box,Lime);
Box_SetFill(box,true,70);
}
}
}
최종꼭지점 = "저점";
Plot2(저[1,1]);
NoPlot(1);
}
a.추세선이 음전환되면 동그라미 표시.
(가) 양전환되거나, (나) 직저 깨진 후 직전저점으로부터 -3틱 도달시 삭제.
b.쌍바닥 : 당일 고점 -0.7p 아래에서
추세선 직저와 상1틱 ~ 하2틱 사이에 쌍바닥이면 동그라미 표시.
c.쌍봉 : 직고와 상0틱 ~ 하1틱 사이에 쌍봉이면 동그라미 표시.
상하 변수 따로 따로 설정. 감사합니다.
2023-03-24
1424
글번호 167472
답변완료
수식 문의드립니다.
매수된 종목이
5% 이상 상승시, 30분봉상 주가가 10일선을 이탈할때 매도하는 수식을 만들고 싶습니다.
2023-03-23
1508
글번호 167471
답변완료
수식문의드립니다
수고하십니다
첨부한 그림을 응용하여
매수(매도)신호 발생시 stoploss, targetpoint 를 TL 선으로 진입가-목표가/진입가-손절가 사이를 그림처럼 바탕색을 넣을 수 있는 수식을 부탁드립니다.
포지션이 청산되면 TL 선이 없어지도록하는 수식을 부탁드립니다.
예)
이동평균선(20) 을 상향돌파시 매수
손절선=최근5개봉저가
목표가= 진입가 + ( (진입가-손절가)*1.5)
2023-03-23
1867
글번호 167470
답변완료
제1조건과 제2조건을 동시에 만족하는 식
안녕하세요?
추세도 있으면서 변동성도 좋을때에 수직선을 긋는 식을 만들고 싶은데 잘 안됩니다.
수정 좀 부탁드립니다.
=======================================================================
//============== TDI(추세지표) ===============//
input : len1(20),len2(40);
var : mt(0),sum1(0),sum2(0),TDI(0),T(0);
mt = Abs(C-C[len1-1]);
sum1 = AccumN(mt,len1);
sum2 = AccumN(mt,len2);
TDI = sum1-(sum2-sum1);
If TDI[0] > TDI[1] Then {
T = 1;
}
//============== ATR(변동성지표) ===============//
Input : Period(14),SigPeriod(9);
var : AvgTrueRange(0,Data1),ATRsig(0,Data1);
Var : TL1(0),TL2(0),TL3(0),TL4(0),TL5(0),TL6(0),TL7(0),TL8(0),TL9(0),TL10(0);
AvgTrueRange = Data1(ATR(Period));
ATRsig = ema(Data1(ATR(Period)),SigPeriod);
//=========================================//
If T==1 and cRossUp(AvgTrueRange, ATRsig) Then {
TL1 = TL_New(sdate,stime,99999999,sdate,stime,0);
TL_SetColor(TL1,ReD);
TL_SetSize(TL1,0);
PlaySound("C:₩EugeneYesTrader₩Bin10₩data₩Sound₩@거래량증가시작변동성확때시작");
}
2023-03-23
1340
글번호 167468
답변완료
수식 문의드립니다.
1. 일봉 저가가 5일선을 데드크로스 후, 30분봉상 5선이 10선을 골든크로스할 때 매수
2. 일봉 저가가 5일선 데드크로스 후, 30분봉상 20선을 골든크로스 할때 매수
1번 조건일때 1차매수, 2번 조건일 때 2차매수하고
익절 5%, 손절 5%
수식을 만들고 싶습니다. 항상 감사합니다.
2023-03-23
2124
글번호 167460
답변완료
피라미딩별청산2
피라미딩 적용했을 때
a,b 진입 후
a는 xb1
b는 xb2로 청산하는 수식을 작성했는데
a,b 모두 xb1으로 청산됩니다.
b는 xb2로 청산되게 수식 수정 부탁드립니다.
******************************************************************************
input:st1(101000),butd21(100),butd31(10000);
input:st2(103000),butd22(2000),butd32(12500);
input : exst(103000),ex하락1(99999),ex하락2(99999);
var : T1(0),entry(0);
if Bdate != Bdate[1] Then
T1 = TotalTrades;
if MarketPosition == 0 Then
entry = TotalTrades-T1;
Else
entry = (TotalTrades-T1)+1;
if MarketPosition == 0 and sTime>=st1 and entry==0 and
!(data2(c<Highd(0)-butd21)) and !(data3(c>Lowd(0)+butd31)) Then
Buy("a");
if MarketPosition == 1 then
{
if MaxEntries==1 and sTime>=st2 and entry==1 and
!(data2(c<Highd(0)-butd22)) and !(data3(c>Lowd(0)+butd32)) Then
Buy("b");
}
var : Tcond(false,Data2),h2(0,Data2),L2(0,Data2);
if Data2(Bdate != Bdate[1]) Then
Tcond = False;
if Data2((sdate != sdate[1] and stime >= exst) or
(sdate == sdate[1] and stime >= exst and stime[1] < exst)) Then
{
Tcond = true;
h2 = Data2(h);
l2 = Data2(l);
}
if Tcond == true Then
{
if Data2(H) > h2 Then
h2 = Data2(h);
if Data2(L) < l2 Then
l2 = Data2(l);
if MarketPosition == 1 and IsEntryName("a") and data2(c<h2-ex하락1) then
exitlong("xb1");
if MarketPosition == 1 and IsEntryName("b") and data2(c<h2-ex하락2) then
exitlong("xb2");
}
2023-04-24
1419
글번호 167458
답변완료
문의 드립니다.
안녕하세요.
당일 포함한 10 ATR 를 구하고 W 값에 저장
당일 최저가 에서 하락하면 하락한 값만큼 W 값 에서 마이너스 시키고 W1에 저장 (저장값에 0.3을 더하거나 뺄수 있음)
당일 최고가 에서 상승한 가격을 W 에 더한값이 W2(저장값에 0.3을 더하거나 뺄수 있음)
W가격 화면에 플릇으로 표시
당일최저가 -W1 값 플릇 으로 표시
당일최고가 +W2 값 플릇 으로 표시
2023-03-23
1471
글번호 167457