커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
1710
글번호 230811
답변완료
부탁드립니다
안녕하세요
아래지표에 꼭지점과 같이 시스템에 화살표를 표시하고 싶습니다
가능하시면 부탁드리겠습니다 수고하세요
Input:length(10),종가사용여부(0),파동선두께(2),수치표시(1);
Input:가로라인두께(2),고점라인색상(RED),저점라인색상(BLUE);
Var:j(0),jj(0),HH(0),LL(0),최종고가(0),최종저가(0),최종꼭지점(""),처리구분(""),
TL1(0),Text1(0),text2(0),TL2(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
{
최종고가 = 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]);
var1 = 고[2,1]-저[1,1];
TL2 = TL_New(저[1,3],저[1,4],저[1,1],sDate,sTime,저[1,1]);
If 수치표시 == 1 Then
{
Text1 = Text_New(고[1,3],고[1,4],고[1,1],NumToStr(고[1,1],2));
Text_SetStyle(Text1, 2, 1);
Text2 = Text_New(고[1,3],고[1,4],고[1,1],NumToStr(고[1,1]-저[1,1],2)+NewLine);
Text_SetStyle(Text2, 2, 1);
Text_SetColor(text2,RED);
}
TL_SetSize(TL1,파동선두께);
TL_SetColor(TL1,BLUe);
TL_SetSize(TL2,가로라인두께);
TL_SetColor(TL2,저점라인색상);
}
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]);
TL_SetEnd(TL2,고[1,3],고[1,4],저[1,1]);
// 시작점은 변동없고 끝점의 위치가 현재 봉으로 연장된 것임
If 수치표시 == 1 Then
{
Text_SetLocation(Text1,고[1,3],고[1,4],고[1,1]);
Text_SetString(Text1,NumToStr(고[1,1],2));
Text_SetLocation(Text2,고[1,3],고[1,4],고[1,1]);
Text_SetString(Text2,NumToStr(고[1,1]-저[1,1],2)+NewLine);
}
}
최종꼭지점 = "고점";
}
#==========================================#
If 처리구분 == "저점처리" Then
{
최종저가 = 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]);
var1 = 고[1,1]-저[2,1];
TL2 = TL_New(고[1,3],고[1,4],고[1,1],sDate,sTime,고[1,1]);
If 수치표시 == 1 Then
{
Text1 = Text_New(저[1,3],저[1,4],저[1,1],NumToStr(저[1,1],2));
Text_SetStyle(Text1, 2, 0);
Text2 = Text_New(저[1,3],저[1,4],저[1,1],NewLine+NumToStr(저[1,1]-고[1,1],2));
Text_SetStyle(Text2, 2, 0);
Text_SetColor(text2,RED);
}
TL_SetSize(TL1,파동선두께);
TL_SetColor(TL1,BLUe);
TL_SetSize(TL2,가로라인두께);
TL_SetColor(TL2,고점라인색상);
}
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]);
TL_SetEnd(TL2,저[1,3],저[1,4],고[1,1]);
If 수치표시 == 1 Then
{
Text_SetLocation(Text1,저[1,3],저[1,4],저[1,1]);
Text_SetString(Text1,NumToStr(저[1,1],2));
Text_SetLocation(Text2,저[1,3],저[1,4],저[1,1]);
Text_SetString(Text2,NewLine+NumToStr(저[1,1]-고[1,1],2));
}
}
최종꼭지점 = "저점";
}
2021-12-12
852
글번호 154393
답변완료
늘 고맙습니다
늘 고맙습니다
시스템을 사용하려 그러는데
예스트레이더에 기본 탑재되어있는 (수익차트 누적수익(기간별)) 에서
누적수익 최고값에서 80% 에 선을 하나더 나타내어 시장과 시스템과의 적합 여부를 알고 싶습니다 혼자 해 보려고 낑낑거렸는데 안 되네요..
되신다면 누적수익(기간별)에서 80& 에 선 하나 부탁드립니다
같이 나타나고 되고 안되면 지표로라도 괜찮습니다
수고하심에 늘 감사드립니다
2021-12-12
891
글번호 154392
팍스 님에 의해서 삭제되었습니다.
2021-12-12
0
글번호 154391
답변완료
강조수식 부탁드려요
아래 수식을 강조수식으로 전환부탁요
a=H>Highest(H(1), period1);
b=H>Highest(H(1), period2);
aa=H>Highest(H(1), period3);
bb=H>Highest(H(1), period4);
a && b
period1 3 period2 5 period3 10 period4 15
2021-12-11
903
글번호 154390
답변완료
지표전환부탁드립니다
아래 키움수식을 예스수식으로 전환부탁드립니다.
<1>
수식1
a=highest(H,period1);
b=lowest(L,period1);
x=b+(a-b)*상승/100;
y=b+(a-b)*하락/100;
조건=if(close>=x,x,0);
zu=highestsince(1,(조건 && !조건(1))==1,x);
k=if(close>=x,zu,0)
수식2
a=highest(H,period1);
b=lowest(L,period1);
x=b+(a-b)*상승/100;
y=b+(a-b)*하락/100;
조건=if(close<=y,y,0);
zd=lowestsince(1,(조건 && !조건(1))==1,y);
if(close<=y,zd,0)
수식3
shift(k,10)
지표조건설정 period1/20 상승/60 하락/40
<2>
수식1
m5=avg(C,기간1);
m10=avg(C,기간2);
VALUEWHEN(1,Crossup(m5,m10) or Crossdown(m5,m10),m10)
수식2
m5=avg(C,기간1);
m10=avg(C,기간2);
VALUEWHEN(1,Crossup(m5,m10) or Crossdown(m5,m10),m5)
수식3
a=(highest(high,shortPeriod)+lowest(low,shortPeriod))/2;
b=(highest(high,midPeriod)+lowest(low,midPeriod))/2;
Valuewhen(1,Crossup(a,b) or Crossdown(a,b),b)
수식4
a=(highest(high,shortPeriod)+lowest(low,shortPeriod))/2;
b=(highest(high,midPeriod)+lowest(low,midPeriod))/2;
Valuewhen(1,Crossup(a,b) or Crossdown(a,b),a)
지표조건설정
기간1/5 기간2/10 shortPeriod/5 midPeriod/10
<3>
수식1
ValueWhen(1, H>Highest(H(1), p1), H);
수식2
ValueWhen(1, H>Highest(H(1), p2), H);
수식3
ValueWhen(1, L<Lowest(L(1), p1), L)
수식4
ValueWhen(1, L<Lowest(L(1), p2), L)
지표조건설정
p1/5 p2/10
2021-12-11
1242
글번호 154389
크라켄 님에 의해서 삭제되었습니다.
2021-12-11
9
글번호 154388
답변완료
일목균형표 관련 문의사항
+ 안녕하세요? 일목균형표를 사용하는 데 문의 사항이 있습니다.
1)후행스팬을 사용하려고 기간을 26에서 52로 변경하려고 하면 어떻게 해야 되는 지요?
지표속성 변수(26)을 52로 변경하여도 기존 26일과 동일하게 수치선이 나옵니다.
영웅문에서는 변경이 가능한데 좀 다른 것 같습니다.
2) 그리고 구름대를 일수를 셀 수 있도록 일별로 칸칸이 줄무늬로 나타낼 수 있는 지요?
2021-12-11
1233
글번호 154387
답변완료
수식 부탁드립니다.
제가 간단한 ATR을 이용한 지표를 좀 만들었습니다.
샹들리에 전략이랑 비슷한 지표인데 오류가 납니다.
근데 제가 잘 모르겠습니다. ㅠㅠ 도와주세요.
Input : Period(14), Multi(2);
Var : ATRx(0), ATRts(0), ATRnew(0);
ATRx = ATR(Period)*Multi;
// 추세 반전 확인
if close crossup ATRts then
ATRts = close - ATRx;
else close crossdown ATRts then
ATRts = close + ATRx;
end
//추세 동안의 ATRts의 계산공식
if close > ATRts then
ATRnew = close - ATRx;
if ATRnew > ATRts then
ATRts = ATRnew;
end
else close < ATRts then
ATRnew = close + ATRx;
if ATRnew < ATRts then
ATRts = ATRnew;
end
end
위에 같이 만들었는데 맞는 것 같은데 잘 모르겠습니다.
부디 도와주세요.
2021-12-11
759
글번호 154386
helpme 님에 의해서 삭제되었습니다.
2021-12-11
1
글번호 154385