커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
1753
글번호 230811
대한이 님에 의해서 삭제되었습니다.
2022-05-13
0
글번호 158828
답변완료
시스템식 문의 드립니다.
안녕하세요 질문이 있어 글을 올려봅니다.
아래의 지표식을 살펴보면 저가대비 5%상승할때마다.
var1, var2 값이 변경되는데
혹시 저가대비 5%상승해서 var1, var2 값이 바뀌었을때
그전의 변수값 (var1, var2)로 매매를 하려면
var1(1), var(2) 이거나 var1[1], var2[1]
로 사용해야 하나요?? 사실 둘다 적용해봤는데 작동이 안됩니다.
방법이 있으시면 알려주세요!!ㅜ.ㅜ
1
var1 = L*1.05;
var2 = H*0.90;
if Index == 0 or (value1 > 0 and H >= value1) Then
{
value1 = var1;
value2 = Var2;
}
Else
{
if var1 < value1 Then
value1 = value1;
if var2 > Value2 Then
value2 = Var2;
}
Plot1(Value1);
plot2(value2);
2
var1 = L*1.05;
var2 = H*0.90;
if Index == 0 Then
{
value1 = var1;
value2 = Var2;
}
Else
{
if var1 < value1 Then
value1 = value1;
if var2 > Value2 Then
value2 = Var2;
if H >= value1 Then
{
value1 = var1;
Value2 = Var2;
}
}
Plot1(Value1);
plot2(value2);
즐거운 하루되세요
2022-05-13
1333
글번호 158824
2wnwn 님에 의해서 삭제되었습니다.
2022-05-13
16
글번호 158823
답변완료
수식 질문드립니다.
data1은 선물1분봉입니다.
data2는 참조차트 10틱입니다.
여기서 var1 = data2(C)-data2(C[1])
average(var1,2000) 값을
1분봉의 OHLC 값 나오도록 봉차트 구현가능한지 궁금합니다.
즉, 10틱을 다시 1분봉으로 변환해서 지표로 표기하고싶습니다.
감사합니다.
2022-05-13
1273
글번호 158822
답변완료
좋은 주말 되십시요
* 좋은날 좋은 주말 되십시요.
<요청 사항>
아래 수식으로 진입후 손실 40틱 나면 추가 매수 시스탬좀 요청 드립니다.
var1 = ma(c,5) ;
Var2 = ma(c,20)
if CrossUp(var1, Var2) Then Buy() ;
if CrossDown(var1,Var2) Then Sell(); 일경우
진입후 손실이 40틱 나면 추가 매수 로직 과 싸운드 좀 부탁 드립니다.
ex)
if MarketPosition == 1 and 진입후 10봉 경과 and 손실 40틱 Then Buy("매수추가") ;
if MarketPosition == -1 and 진입후 10봉 경과 and 손실 40틱 Then Buy("매도추가") ;
if 매수추가 진입 PlaySound("C:₩예스트레이더₩data₩Sound₩alert.wav");
if 매도추가 진입 PlaySound("C:₩예스트레이더₩data₩Sound₩alert.wav");
고맙습니다. 좋은 주말 되십시요.
2022-05-13
1375
글번호 158821
답변완료
문의드립니다
안녕하세요 도움구하고자 문의드립니다
이평선이 10 20 30 40 50 5개있을때
이평선 순서 상관없이 어느거 하나라도
우상향일때 1로 표시
2개 우상향일때 2로 표시
3개 우상향일때 3으로 표시
이런식으로 표시 할려면 어떻게 해야도나요?
감사합니다
2022-05-13
1212
글번호 158820
알리섬 님에 의해서 삭제되었습니다.
2022-05-13
12
글번호 158819
답변완료
AB-ratio 시스템 변수값 고정
항상 감사드립니다
아래 ab-ratio 시스템엣 변수값을 고정하고 싶습니다
t77=1 또는 t77=-1 일때만 t80이 1 또는 -1값을 갖게 하고싶습니다
t77=1 또는 t77=-1 조건에서 t77=0 조건으로 변해서 장시간(며칠간) 지속될때는 신호가 나오질 않습니다
t77= 1 또는 t77= -1 조건일때 t80= 1 또는 t80= -1 로확정되고 t80값은 조건이 없어지더라도 그대로 며칠간 유지하고 싶습니다
t80 값은 한번 변경되면 다음변경시까지 챠트내 지표가 없어지더라도 며칠동안 그대로 유지 하고 싶습니다
Inputs: Length(5200);
Variables : ABull(0), ABear(0), BBull(0), BBear(0),ARatio(0), BRatio(0);
var:t66(0),t70(0),t71(0),t77(0),t80(0);
ABull = accumn(High - Open, Length);
ABear = Accumn(Open - Low, Length);
BBull = Accumn(High - Close[1], Length);
BBear = Accumn(Close[1] - Low, Length);
ARatio = ABull / ABear * 100;
BRatio = BBull / BBear * 100;
if aRatio>100 Then
t66 = 1 ;
if BRatio>100 Then
t70 = 1 ;
if aRatio>100 and BRatio>100 Then
t71 = 1 ;
if t71=1 Then
t77 = 1 ;
if ARatio<100 Then
t66 = -1 ;
if BRatio<100 Then
t70 = -1 ;
if BRatio<100 Then
t70 = -1 ;
if aRatio<100 and BRatio<100 Then
t71 = -1 ;
if t71=-1 Then
t77 = -1 ;
if aRatio>100 and BRatio<100 Then
t77 = 0 ;
if aRatio<100 and BRatio>100 Then
t77 = 0 ;
2022-05-13
1324
글번호 158818
답변완료
문의 드립니다.
안녕하세요.
저번에 도와주셔서 감사드립니다.
아래 수식에
시간만 나오게 해주셨는데
시간에 시분초 나오게 되어있는데 너무 햇갈려서
이것을 시:분:초 이렇게 수정할 수 있을까요?
또
고가에서 저가까지 몇틱이고
저가에서 고가까지 몇틱인지 표시 나오게 해줄 수 없을까요?
그러니까 고가에서 저가까지 시간 나오고 그 시간 아래에 +몇틱인지 표시 나왔으면 좋겠습니다.
또 저가에서 고가까지 시간 나오고 그 시간 위에 +몇틱인지 표시 나오게 하고 싶습니다.
감사합니다.
주말 잘 보내세요~~!!
input:length(4),종가사용여부(0),파동선두께(5),수치표시(1),수평선표시(1);
Var:j(0),jj(0),HH(0),LL(0),최종고가(0),최종저가(0),최종꼭지점(""),처리구분(""),
TL1(0),Text1(0),tl2(0),tl3(0),tl4(0),tl5(0),T(0);
Array:고[10,4](0),저[10,4](0); // 1:가격,2:Index,3:sDate,4:sTime
#==========================================#
HH = IFF(종가사용여부==1,C,H);
LL = IFF(종가사용여부==1,C,L);
If Index == 0 Then
{
고[1,1] = HH;
저[1,1] = LL;
}
Condition1 = Highest(HH,length) == HH and 최종고가 <> HH;
Condition2 = Lowest (LL,length) == LL and 최종저가 <> LL;
처리구분 = "";
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
{
T = 1;
최종고가 = HH; // 신규고점을 체크하기 위해 저장
If 최종꼭지점 == "저점" Then
{
For j = 10 DownTo 2
{
For jj = 1 To 4
{
고[j,jj] = 고[j-1,jj];
}
}
고[1,1] = HH;
고[1,2] = Index;
고[1,3] = sDate;
고[1,4] = sTime;
TL1 = TL_New(저[1,3],저[1,4],저[1,1],고[1,3],고[1,4],고[1,1]);
If 수치표시 == 1 Then
{
Text1 = Text_New(고[1,3],고[1,4],고[1,1],NumToStr(고[1,4],0));
Text_SetStyle(Text1, 2, 1);
Text_SetColor(Text1,BLACK);
}
TL_SetSize(TL1,파동선두께);
TL_SetColor(TL1,red);
}
Else If 고[1,1] < HH Then // 1번 고점보다 높은 고가 출현
{
고[1,1] = HH;
고[1,2] = Index;
고[1,3] = sDate;
고[1,4] = sTime;
TL_SetEnd(TL1,고[1,3],고[1,4],고[1,1]);
// 시작점은 변동없고 끝점의 위치가 현재 봉으로 연장된 것임
If 수치표시 == 1 Then
{
Text_SetLocation(Text1,고[1,3],고[1,4],고[1,1]);
Text_SetString(Text1,NumToStr(고[1,4],0));
}
}
최종꼭지점 = "고점";
}
#==========================================#
If 처리구분 == "저점처리" Then
{
T = -1;
최종저가 = LL;
If 최종꼭지점 == "고점" then
{
For j = 10 DownTo 2
{
For jj = 1 To 4
{
저[j,jj] = 저[j-1,jj];
}
}
저[1,1] = LL;
저[1,2] = Index;
저[1,3] = sDate;
저[1,4] = sTime;
TL1 = TL_New(고[1,3],고[1,4],고[1,1],저[1,3],저[1,4],저[1,1]);
If 수치표시 == 1 Then
{
Text1 = Text_New(저[1,3],저[1,4],저[1,1],NumToStr(저[1,4],0));
Text_SetStyle(Text1, 2, 0);
Text_SetColor(Text1,BLACK);
}
TL_SetSize(TL1,파동선두께);
TL_SetColor(TL1,blue);
}
Else If 저[1,1] > LL then
{
저[1,1] = LL;
저[1,2] = Index;
저[1,3] = sDate;
저[1,4] = sTime;
TL_SetEnd(TL1,저[1,3],저[1,4],저[1,1]);
If 수치표시 == 1 Then
{
Text_SetLocation(Text1,저[1,3],저[1,4],저[1,1]);
Text_SetString(Text1,NumToStr(저[1,4],0));
}
}
최종꼭지점 = "저점";
}
if T == -1 and T[1] != -1 Then
{
if 수평선표시 == 1 Then
{
TL2 = TL_New(고[2,3],고[2,4],고[2,1],sdate,stime,고[2,1]);
TL_Delete(TL3);
TL3 = TL_New(고[1,3],고[1,4],고[1,1],sdate,stime,고[1,1]);
TL_SetExtRight(TL3,true);
}
TL_SetSize(TL1,파동선두께);
TL_SetColor(TL1,BLUE);
TL_SetSize(TL1,파동선두께);
TL_SetColor(TL1,BLUE);
}
if T == 1 and T[1] != 1 Then
{
if 수평선표시 == 1 Then
{
TL4= TL_New(저[2,3],저[2,4],저[2,1],sdate,stime,저[2,1]);
TL_Delete(TL5);
TL5= TL_New(저[1,3],저[1,4],저[1,1],sdate,stime,저[1,1]);
TL_SetExtRight(TL5,true);
}
TL_SetSize(TL1,파동선두께);
TL_SetColor(TL1,RED);
TL_SetSize(TL1,파동선두께);
TL_SetColor(TL1,RED);
}
2022-05-13
1602
글번호 158817