커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
4472
글번호 230811
관리자에 의해 자유게시판으로 이동되었습니다
2018-12-20
18
글번호 124621
답변완료
수식부탁드립니다
#,보내주신 수식 잘 사용하고 있습니다 진심으로 감사드립니다.
ㅡ,추가질문입니다,*60543 답변수식에서 동일호가 추세선 연결시점을 텍스트호가 출력시점
으로 하고 싶습니다 수식에는 저점동일호가(쌍바닥) 연결추세선이 고점파동이 완성될때
추세선이 그려지는것 같습니다,이렇게 되면 장중에 저점 쌍바닥패턴이나 고점 쌍봉패턴에
진입하려는 타이밍을 놓치는 경향이 있어서 그럽니다,
파동의 완성과 상관없이 호가 텍스트출력과 동시에 동일호가를 추세선으로 연결하고 싶은데
자꾸 에러가 뜨네요~ㅠ
도움 부탁 드립니다.
2018-12-20
323
글번호 124620
답변완료
질문입니다.
예스렝귀지로 코스피선물에서 시스템을 작성하고,
예스스팟으로 예스렝귀지 시스템을 어디까지 컨트롤 할 수 있는지 질문입니다.
예를들어,
예스렝귀지에서 매수시그널을 매도시그널로 전환하고,
매도시그널을 매수시그널로 바꾸어서 진입하도록 하는 것도 가능한가요?
그외에 시그널 발생 가격보다 시기를 일정기간 늦추어 진입하거나,
발생가격보다 일정가격 위나 아래에 도달했을때 진입하게 하는것이 가능한지 궁금합니다.
또, atstop을 atlimit 등 다른 타입으로 바꿀수도 있는지 궁금하네요.
답변 언제나 감사합니다.
2018-12-20
268
글번호 124619
답변완료
문의 드립니다.
항상 고맙습니다.
예를 들어
수식1)
60분전(변수로 입력)에서 부터 현재까지의 최고가 최저가의 차이값(진폭)을 지표로
수식2)
1일전 2일전 3일전 n일전(변수)의
60분전(변수)에서 부터 현재까지의 최고가 최저가의 차이값의 평균값(평균진폭)을
당일에 지표로 나타 나도록 부탁 드립니다.
2018-12-20
276
글번호 124618
답변완료
지표부탁합니다.
input : HP(2.5),LP(1.9) ;
var : HH(0),LL(0),cnt(0);
HH = dayhigh(HP);
LL = daylow(LP);
for cnt = 1 to (HP,LP) {
if dayhigh(cnt) > HH Then
HH = dayhigh(cnt);
if DayLow(cnt) < LL Then
LL = DayLow(cnt);
}
Plot1(HH+0.0, "고가");
Plot2(LL-0.0, "저가");
plot3((HH+LL)/2,"중심선");
plot4(dayopen(HP,LP),"n일전시가");
2.5일전고가와1.9일전저가 표시선만들기입니다.
위지표 수정부탁합니다.
2018-12-20
288
글번호 124617
답변완료
수식1
차트상우축가격대을 100틱간격으로수평선4개선
50틱간격으로수평선3개선 잘부탁드립니다
2018-12-20
281
글번호 124616
답변완료
문의드립니다.
해외선물을 틱봉으로 매매시( 장종료시간 : 07:00 ) 봉 완성과 관계없이
065000에 진입포지션을 청산하려면 어떻게 해야 하나요?
2018-12-20
276
글번호 124615
답변완료
문의드립니다
1)60534번다시한번문의드립니다 ,지그재그상승과하락을찍는선을 현재봉보다(-1)전봉에 선을찍게하고싶습니다 그림과같이고점다음봉에저점다음봉에 찍히는데(스마일표시한부분)고점과저점에찍히도록 (화살표로표시한부분에) 하고십습니다 다시부탁드립니다~~항상감사드립니다
2)Input:barCnt(5);
Var:j(0),turnPntBit(""),TL1(0),TL33(0),TL44(0),HD(0),HT(0),LD(0),LT(0),HH(0),LL(0);
var : TL121(0),TL122(0),tx121(0),tx122(0);
Array:valArr[10](0),barArr[10](0),turnPntArr[10]("");
// 봉이 새로 생겼으므로 봉개수 관리하는 변수들의 봉개수 값 1씩 증가
For j = 0 To 9 {
barArr[j] = barArr[j] + 1;
}
// 고점조건 = 5-1-5에서 가운데 고가가 좌측 5봉과 우측 5봉 고가보다 높다
// 저점조건 = 5-1-5에서 가운데 저가가 좌측 5봉과 우측 5봉 저가보다 낮다
Condition1 = Highest(H,barCnt)[barCnt+1] <= H[barCnt] and H[barCnt] > Highest(H,barCnt);
Condition2 = Lowest(L,barCnt)[barCnt+1] >= L[barCnt] and L[barCnt] < Lowest(L,barCnt);
// 전환점구분 null값으로 초기화;
// if 고점조건, 저점조건 동시 만족시 then
// if 이전 고점,저점 범위를 모두 벗어났을 때
// 전환점구분 = 고저점;
// else if 이전 고점을 갱신했다면 전환점구분 = 고점;
// else if 이전 저점을 갱신했다면 전환점구분 = 저점;
// else if 전환점배열의 현재(배열상 1번째)값이 고점이면 전환점구분 = 저점;
// else if 전환점배열의 현재 값이 저점이면 전환점구분 = 고점;
// else if 고점조건 만족하면 전환점구분 = 고점;
// else if 저점조건 만족하면 전환전구분 = 저점;
turnPntBit = "";
If Condition1 and Condition2 Then {
If Max(valArr[1],valArr[2]) < H[barCnt] and Min(valArr[1],valArr[2]) > L[barCnt] Then
turnPntBit = "HiLo";
Else If Max(valArr[1],valArr[2]) < H[barCnt] Then turnPntBit = "Hi";
Else If Min(valArr[1],valArr[2]) > L[barCnt] Then turnPntBit = "Lo";
Else If turnPntArr[1] == "Hi" Then turnPntBit = "Lo";
Else If turnPntArr[1] == "Lo" Then turnPntBit = "Hi";
}
Else If Condition1 Then turnPntBit = "Hi";
Else If Condition2 Then turnPntBit = "Lo";
// if 전환점구분에 값이 있을 때만 아래 실행, 없으면 통과
If turnPntBit <> "" Then
{
// if 전환점구분이 고저점이면 then
// 이전 파동은 연장시키고 아래에서 새로이 파동선을 추가토록 한다.
If turnPntBit == "HiLo" Then
{
valArr[1] = IFF(turnPntArr[1] == "Hi",H[barCnt],L[barCnt]);
barArr[1] = barCnt;
TL_SetEnd(TL1,sDate[barArr[1]],sTime[barArr[1]],valArr[1]);
If turnPntArr[1] == "Hi" Then
turnPntBit = "Lo";
Else
turnPntBit = "Hi";
}
// if 신규 전환점구분이 현재(전환점배열 1번째)와 다르면 then
// 배열값들을 이전값으로 Move;
If turnPntBit <> turnPntArr[1] Then
{
for j = 8 downto 1
{
valArr[j+1] = valArr[j];
barArr[j+1] = barArr[j];
turnPntArr[j+1] = turnPntArr[j];
}
}
// if 전환점구분이 바뀌었거나 또는
// (전환점구분은 안바뀌었는데
// (이전 고점보다 높은 고점이 발생했거나 또는
// 이전 저점보다 낮은 저점이 발생했으면)) then
If turnPntBit <> turnPntArr[1] or
(turnPntBit == turnPntArr[1] and
((turnPntBit == "Hi" and valArr[1] < H[barCnt]) or
(turnPntBit == "Lo" and valArr[1] > L[barCnt]))) Then {
// 값 배열에는 고점 또는 저점을 대입;
// 봉개수 배열에는 입력변수의 봉개수 대입;
// 전환점 배열에 전환점구분값을 대입;
valArr[1] = IFF(turnPntBit == "Hi",H[barCnt],L[barCnt]);
barArr[1] = barCnt;
turnPntArr[1] = turnPntBit;
// if 이전봉대비 전환점구분이 바뀌었다면 추세선 새로 그리고;
// else 전환점구분이 안바뀌었으면 값만 바뀐거므로 추세선 연장;
If turnPntArr[1][1] <> turnPntArr[1][0] Then
TL1 = TL_New(sDate[barArr[2]],sTime[barArr[2]],valArr[2],
sDate[barArr[1]],sTime[barArr[1]],valArr[1]);
Else
TL_SetEnd(TL1,sDate[barArr[1]],sTime[barArr[1]],valArr[1]);
}
}
TL_SetSize(TL1,0);
TL_SetColor(TL1,GREEN);
var : TL11(0),TL12(0);
if turnPntArr[1][0] == "Hi" Then{
TL_Delete(TL11);
TL11 = TL_New(sDate[barArr[2]],sTime[barArr[2]],valArr[1],sDate[barArr[1]],sTime[barArr[1]],valArr[1]);
TL_SetExtRight(TL11,true);
TL_SetColor(TL11,BLUE);
TL_SetSize(TL11,3);
TL_Delete(TL121);
var1 = valArr[1]-abs(valArr[1]-valArr[2])*0.382;
var2 = valArr[1]-abs(valArr[1]-valArr[2])*0.618;
TL_SetExtRight(TL121,true);
TL_SetColor(TL121,GREEN);
TL_SetSize(TL121,1);
TL_Delete(TL122);
TL_SetExtRight(TL122,true);
TL_SetColor(TL122,GREEN);
TL_SetSize(TL122,1);
Text_Delete(tx121);
Text_Delete(tx122);
tx121 = Text_New(sdate,stime,var1,NumToStr(var1,2));
tx122 = Text_New(sdate,stime,var2,NumToStr(var2,2));
}
if turnPntArr[1][0] == "Lo" Then{
TL_Delete(TL12);
TL12 = TL_New(sDate[barArr[2]],sTime[barArr[2]],valArr[1],sDate[barArr[1]],sTime[barArr[1]],valArr[1]);
TL_SetExtRight(TL12,true);
TL_SetColor(TL12,RED);
TL_SetSize(TL12,3);
TL_Delete(TL121);
var1 = valArr[1]+abs(valArr[1]-valArr[2])*0.382;
var2 = valArr[1]+abs(valArr[1]-valArr[2])*0.618;
TL_SetExtRight(TL121,true);
TL_SetColor(TL121,GREEN);
TL_SetSize(TL121,1);
TL_Delete(TL122);
TL_SetExtRight(TL122,true);
TL_SetColor(TL122,GREEN);
TL_SetSize(TL122,1);
Text_Delete(tx121);
Text_Delete(tx122);
tx121 = Text_New(sdate,stime,var1,NumToStr(var1,2));
tx122 = Text_New(sdate,stime,var2,NumToStr(var2,2));
}
if bdate != BDate[1] Then{
HD = sdate;
HT = stime;
LD = sdate;
LT = stime;
HH = H;
LL = L;
}
if H > HH Then{
HH = H;
HD = sdate;
HT = stime;
}
TL_Delete(TL33);
if turnPntArr[1][0] == "Hi" Then{
TL33 = TL_New(sDate[barArr[1]],sTime[barArr[1]],valArr[1],HD,HT,dayhigh);
}
if turnPntArr[1][0] == "Lo" Then{
TL33 = TL_New(sDate[barArr[2]],sTime[barArr[2]],valArr[2],HD,HT,dayhigh);
}
TL_SetExtRight(TL33,true);
if L < LL Then{
LL = L;
LD = sdate;
LT = stime;
}
TL_Delete(TL44);
if turnPntArr[1][0] == "Hi" Then{
TL44 = TL_New(sDate[barArr[2]],sTime[barArr[2]],valArr[2],LD,LT,daylow);
}
if turnPntArr[1][0] == "Lo" Then{
TL44 = TL_New(sDate[barArr[1]],sTime[barArr[1]],valArr[1],LD,LT,daylow);
}
TL_SetExtRight(TL44,true);
Text_SetLocation(Tx121,sdate,stime,Text_GetValue(Tx121));
Text_SetLocation(Tx122,sdate,stime,Text_GetValue(Tx122));
Text_SetStyle(tx121,0,1);
Text_SetStyle(tx122,0,1);
고점과저점두선을나오게 하였는데 고점을찍으면청색으로 나오면 밑에빨강저점은사라지게,
반대로 저점빨강이나오면 고점청색은 사라지게 즉 하나만 나오게부탁드립니다~~
2018-12-20
432
글번호 124614
답변완료
문의드립니다.
도움주시는 덕분에 도전하고 있습니다. 매번 감사합니다.
1. 지표
어제 지표와 비슷한 방식인데요. ||은 절대값기호입니다. 해당 수학기호 수식으로 부탁드립니다.
*참조
http://etfhq.com/blog/2011/02/07/kaufmans-efficiency-ratio/
2. 지표
저보다 잘 아실테지만 ln은 자연로그입니다. 수학기호 수식으로 변환부탁드립니다.
3. 지표
외부변수 nday <- 평균기간값
산술평균 > 기하평균 > 조화평균 이면
true
2018-12-20
426
글번호 124613