커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
6040
글번호 230811
답변완료
문의드립니다
Input:length(5);
Var:j(0),lastHiVal(0),lastLoVal(0),sBar(0),eBar(0),TL1(0),TL2(0),TL3(0),Text1(0),처리구분(""),
TL_Val1(0),TL_Val2(0);
Var:TL11(0),TL12(0),TL13(0),TL14(0),TL15(0),TL16(0),TL17(0),TL18(0),TL19(0),TL20(0);
Var:TL21(0),TL22(0),TL23(0),TL24(0),TL25(0),TL26(0),TL27(0),TL28(0),TL29(0),TL30(0),mav(0),T(0);
Array:고점[10,2](0),저점[10,2](0);
처리구분 = "";
If Highest(H,length) == H and lastHiVal <> H and Lowest(L,length) == L and lastLoVal <> L Then
{ If 저점[1,1] > L Then 처리구분 = "저점처리";
If 고점[1,1] < H Then 처리구분 = "고점처리";
}
Else If Highest(H,length) == H and lastHiVal <> H Then 처리구분 = "고점처리";
Else If Lowest(L,length) == L and lastLoVal <> L Then 처리구분 = "저점처리";
If 처리구분 == "고점처리" Then
{
lastHiVal = H;
If 고점[1,2] < 저점[1,2] Then
{
For j = 10 DownTo 2
{
고점[j,1] = 고점[j-1,1];
고점[j,2] = 고점[j-1,2];
}
}
If 고점[1,2] < 저점[1,2] or 고점[1,1] < H Then
{
고점[1,1] = H;
고점[1,2] = Index;
sBar = Index - 저점[1,2];
eBar = 0;
TL_Delete(TL1);
TL_Delete(TL2);
If TL_GetBeginDate(TL1) == sDate[sBar] and TL_GetBeginTime(TL1) == sTime[sBar] Then
{
Text_Delete(Text1);
If 고점[3,1][1] < 고점[2,1][1] and 고점[2,1][1] > 고점[1,1][1]and 저점[2,1][1] < 저점[1,1][1] Then
TL_Delete(TL2);
}
TL1 = TL_New(sDate[sBar],sTime[sBar],저점[1,1],sDate[eBar],sTime[eBar],고점[1,1]);
TL2 = TL_New(sDate[eBar+1],sTime[eBar+1],고점[1,1]-PriceScale*15,sDate[eBar],sTime[eBar],고점[1,1]-PriceScale*15);
TL_SetExtRight(Tl2,true);
TL_SetColor(Tl2,BLUE);
TL_SetSize(TL2,2);
TL_SetColor(TL1,BLACK);
TL_SetSize(TL1,0);
If 고점[3,1] < 고점[2,1] and 고점[2,1] > 고점[1,1] and 저점[2,1] < 저점[1,1] Then
{
sBar = Index - 저점[2,2];
eBar = Index - 저점[1,2];
}
}
}
If 처리구분 == "저점처리" Then
{
lastLoVal = L;
If 저점[1,2] < 고점[1,2] Then
{
For j = 10 DownTo 2
{
저점[j,1] = 저점[j-1,1];
저점[j,2] = 저점[j-1,2];
}
}
If 저점[1,2] < 고점[1,2] or 저점[1,1] > L Then
{
저점[1,1] = L;
저점[1,2] = Index;
sBar = Index - 고점[1,2];
eBar = 0;
TL_Delete(TL1);
TL_Delete(TL2);
If TL_GetBeginDate(TL1) == sDate[sBar] and TL_GetBeginTime(TL1) == sTime[sBar] Then
{
Text_Delete(Text1);
If 저점[2,1][1] < 저점[1,1][1] and 저점[2,1][1] < 저점[3,1][1] and 고점[2,1][1] > 고점[1,1][1] Then
TL_Delete(TL3);
}
TL1 = TL_New(sDate[sBar],sTime[sBar],고점[1,1],sDate[eBar],sTime[eBar],저점[1,1]);
TL2 = TL_New(sDate[eBar+1],sTime[eBar+1],저점[1,1]+PriceScale*15,sDate[eBar],sTime[eBar],저점[1,1]+PriceScale*15);
TL_SetExtRight(Tl2,true);
TL_SetColor(Tl2,MAGENTA);
TL_SetSize(TL2,2);
TL_SetColor(TL1,BLACK);
TL_SetSize(TL1,0);
If 저점[2,1] < 저점[1,1] and 저점[2,1] < 저점[3,1] and 고점[2,1] > 고점[1,1] Then
{
sBar = Index - 고점[2,2];
eBar = Index - 고점[1,2];
}
}
}
mav = ma(C,20);
수평선을 전봉종가에 나오게 부탁드립니다~~매번감사드립니다
2019-01-28
236
글번호 125654
답변완료
수식 부탁드립니다.
TRIX에서 0선 돌파 이후
첫번째 시그널선과의 교차 신호 말고
그 다음인 두번째 교차하는 반대 신호에서 청산식 좀 부탁드립니다.
아래에서 어떻게 추가 하면 될까요?
Input : Period(5), sigPeriod(3);
value1 = TRIX(Period);
value2 = ema(value1, sigPeriod);
If MarketPosition == 0 and CrossUP(value1, 0) Then
{
Buy();
}
If MarketPosition == 1 and CrossDown(value1, value2) Then
{
ExitLong();
}
If MarketPosition == 0 and CrossDown(value1, 0) Then
{
Sell();
}
If MarketPosition == -1 and CrossUP(value1, value2) Then
{
ExitShort();
}
2019-01-28
212
글번호 125649
답변완료
문의드립니다
문의드립니다
이전 5분봉 고가가280.15 이고 저가가 280.00 이라면
그봉에서 거래된 거래량을 누적하는것입니다
예로 5분봉산 1봉전에 거래된 거래량들
280.00에서 거래된 거래량은 30개이고
280.05에서 거래된 거래량은 30 이고
280.10에서 거래된 거래량은 200 이고
280.15에서 거래된 거래량은 100 이고
2봉전 고가 280.25는 저가 280.10 는 5분봉산 2봉전에 거래된 거래량들
280.10에서 거래된 거래량은 50개 이고
280.15에서 거래된 거래량은25개 이고
280.20에서 거래된 거래량은 20개 이고
280.25에서 거래된 거래량은 10개 입니다
5분봉상 1봉전과 2봉전 두봉에서 겸치는 부분은 280.10 과 280.15 입니다
1봉전 280.10에 거래량은200 더하기
2봉전 280.10에 거래량은50 이니 누적된거래량은250개입니다
그리고
1봉전 280.15에거래량은 100개 더하기
2봉전 280.15에 거랴량은25개 이니 더하면 125개입니다
표시방법은 1봉전 과 2봉전 중 겹친 가격에서 거래량 누적된 값이 제일큰값을 표시하고십니다
280.10에 누적된거래량 큰값이니 250개을 여기에 Plot1();
280.10 여기세 표시하고요 Plot2();
이전 봉들을 적용하는 값들을
설정하수있도록 부탁드립니다 예로 var(2): 조절할수있도록요
부탁드립니다 감사합니다
2019-01-28
220
글번호 125648
답변완료
문의 드립니다.
도움 주셔셔 감사 드립니다.
1)변환 부탁 드립니다.
2)변환후 data2용으로도 부탁 드립니다.
sg=(c-avg(c,p1))/stdev(c,p1);
양봉=c>=o;
음봉=c<=o;
aa=countsince(crossup(sg,2),음봉);
bb=sum(aa);
cc=bb-valuewhen(1,aa(1)==0 && aa==1,bb(1));
dd=valuewhen(1,cc==1,high);
dd !=dd
2019-01-28
231
글번호 125641
회원 님에 의해서 삭제되었습니다.
2019-01-28
35
글번호 125635
답변완료
안녕하세요...
*참조데이터
D1~D15까지 열 다섯개의 참조데이터의 당일 고저폭을 구하서
D1~D5까지의 고저폭의 평균
D6~D10까지의 고저폭의 평균
D11~D15까지의 고저폭의 평균 을
plot1
plot2
plot3
지표로 나타내고자 합니다......
*항상 감사드립니다....수고하세요....
2019-01-28
188
글번호 125633
답변완료
시스템 수식 문의입니다
아래와 같이 답변 주셔서 해봤는데요...아무 신호도 안나오네요...ㅜㅜ
수정 부탁드립니다.
안녕하세요
예스스탁입니다.
if H > H[1] Then
var1 = Highest(H,2);
Else
var1 = highest(H,3);
if L > L[1] Then
var2 = lowest(L,2);
Else
var2 = Lowest(L,3);
if crossup(c,var1) Then
buy("b");
if CrossDown(c,var2) Then
sell("s");
즐거운 하루되세요
> 흑형 님이 쓴 글입니다.
> 제목 : 수식작성 부탁드립니다.
> 안녕하세요~
첨부 파일과 같이....
-. 기본적으로 두개의캔들의 고점과 저점을 기준으로 상향 돌파시 매수 신호, 하향 돌파시 매도 신호
-. 신호가 나왔을 시 반대 신호가 나올때까지 같은방향은 안나옴
-. ex)고점봉의 고점, -1봉의 저점을 박스권으로 이후 캔들의 종가가 저점 이탈시 매도신호발생
-. 단, -1봉의 저점이 고점봉보다 높을시에는 -2봉의 저점을 취함
꼭 필요합니다~~부탁드릴께요~~~^^
2019-01-27
238
글번호 125632
답변완료
수식 문의 드립니다.
안녕하십니까
매번 고생이 많으십니다.
질문은 아래 고저라인 파동식을 그리는 지표인데,
고저라인이 바뀔때... 즉, 고점처리 → 저점처리 혹은 저점처리 → 고점처리로 바뀌는
** 꼭지점 최근 10개 중 가장 높은 값의 (고점처리 부분)
꼭지점에서 보조지표 RSI 값(기간은 임의)을 "꼭지RSI" 로 할당하고 Text3으로 그 봉(꼭지점) 위에 RSI 값 표시,
꼭지점 이전 봉에서 RSI값을 "꼭지첫번째RSI" 로 할당하고 Text4로 그 봉(꼭지점 이전) 위에 RSI 값 표시,
** 꼭지점 최근 10개 중 두번째 높은 값의 (고점처리 부분)
꼭지점에서 보조지표 RSI 값(기간은 임의)을 "꼭지RSI" 로 할당하고 Text5으로 그 봉(꼭지점) 위에 RSI 값 표시,
꼭지점 이전 봉에서 RSI값을 "꼭지첫번째RSI" 로 할당하고 Text6으로 그 봉(꼭지점 이전) 위에 RSI 값 표시,
** 가장 높은 꼭지점 의 RSI값과 두번째 꼭지점의 RSI값을 비교하는 수식
(자세한 것은 첨부된 그림 참조)
식 어디 부분에 작성해야 하고, 어떻게 작성해야 할지 몰라 문의드립니다.
※ 식이 복잡해진다면 어느 부분에 대충 이런 수식을 넣으면 될것 같다는 힌트(주석)이라도 부탁드리겠습니다.
항상 도움 주시는 것 감사드립니다....^^
항상 도움 주시는 것 다시 감사드립니다....^^
Input:length(12);
Var:j(0),lastHiVal(0),lastLoVal(0),sBar(0),eBar(0),TL1(0), Text1(0),처리구분("");
Array:고점[10,2](0),저점[10,2](0); //가격,위치
처리구분 = "";
If Highest(H,length) == H and lastHiVal <> H and
Lowest(L,length) == L and lastLoVal <> L Then
{
If 저점[1,1] > L Then 처리구분 = "저점처리";
If 고점[1,1] < H Then 처리구분 = "고점처리";
}
Else If Highest(H,length) == H and lastHiVal <> H Then 처리구분 = "고점처리";
Else If Lowest(L,length) == L and lastLoVal <> L Then 처리구분 = "저점처리";
#====================고점처리========
If 처리구분 == "고점처리" Then
{
lastHiVal = H;
If 고점[1,2] < 저점[1,2] Then
{
For j = 10 DownTo 2
{
고점[j,1] = 고점[j-1,1];
고점[j,2] = 고점[j-1,2];
}
}
If 고점[1,2] < 저점[1,2] or 고점[1,1] < H Then
{
고점[1,1] = H;
고점[1,2] = Index;
sBar = Index - 저점[1,2];
eBar = 0;
If TL_GetBeginDate(TL1) == sDate[sBar] and
TL_GetBeginTime(TL1) == sTime[sBar] Then
{
TL_Delete(TL1);
Text_Delete(Text1);
}
TL1 = TL_New(sDate[sBar],sTime[sBar],저점[1,1], sDate[eBar],sTime[eBar],고점[1,1]);
Text1 = Text_New(sDate[eBar],sTime[eBar],고점[1,1], NumToStr(고점[1,1],2));
Text_SetStyle(Text1, 2, 1);
}
}
If 처리구분 == "저점처리" Then
{
lastLoVal = L;
If 저점[1,2] < 고점[1,2] then
{
For j = 10 DownTo 2
{
저점[j,1] = 저점[j-1,1];
저점[j,2] = 저점[j-1,2];
}
}
If 저점[1,2] < 고점[1,2] or 저점[1,1] > L then
{
저점[1,1] = L;
저점[1,2] = Index;
sBar = Index - 고점[1,2];
eBar = 0;
If TL_GetBeginDate(TL1) == sDate[sBar] and
TL_GetBeginTime(TL1) == sTime[sBar] Then
{
TL_Delete(TL1);
Text_Delete(Text1);
}
TL1 = TL_New(sDate[sBar],sTime[sBar],고점[1,1], sDate[eBar],sTime[eBar],저점[1,1]);
Text1 = Text_New(sDate[eBar],sTime[eBar],저점[1,1], NumToStr(저점[1,1],2));
Text_SetStyle(Text1, 2, 0);
}
}
TL_SetSize(TL1,3);
TL_SetColor(TL1,CYAN);
2019-01-28
278
글번호 125631
답변완료
수식부탁드립니다
항상 수고에 감사를 드립니다
아래의 2종류의 수식을 5분봉 타주기로 변환 부탁드립니다.
감사합니다.
<<1번 지표>>
Input : Period(20), MultiD(2),signal(10);
var : BBmd(0),BBup(0),BBdn(0);
BBmd = ma(C,Period);
BBup = BollBandUp(Period,MultiD);
BBdn = BollBandDown(Period,MultiD);
#1 = (상단BB -하단BB) ÷ 중간BB
var1 = (BBup-BBdn)/BBmd;
var2 = ma(var1,signal);
plot1(var1);
plot2(var2);
<<2번지표>>
input : N(10),period2(20);
var1 = (C-O)/(H-L)*V;
var2 = AccumN(var1,N);
var3 = AccumN(V,N);
var4 = var2/var3;
Var5 = ema(Var4,Period2);
plot1(var4);
plot2(var5);
PlotBaseLine1(0);
2019-01-27
203
글번호 125630