커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
4575
글번호 230811
답변완료
종목검색식 도움 바랍니다. 더위 조심하시고요. ㅎㅎ 고맙습니다
안녕하세요. 항상 도움 주셔서 감사드립니다.
종목 검색 수식 도움 요청드립니다.
대상: 주봉
조건: 다음과 같습니다.
오늘부터 2개월동안의 주봉들 중 4주전 주봉의 중간값이 가장 작은 경우.
이때 그 4주전 주봉의 중간값이 주봉5일선과 5% 내에 있고 그때 주봉5일선이 상승 중
일봉으로 구현하려고 하니 한주의 시작 등을 맞춰 하는 것들이 너무 어렵더라고요. 주봉으로 바로 하고싶은데 잘 안되어 도움 요청드립니다.
많이 더운데 건강하시고요.
2016-07-20
156
글번호 100216
답변완료
수식 작성 부탁드려요
input : 당일진입횟수(1),P(9);
var : cnt(0),count(0),RSIv(0);
count = 0;
for cnt = 0 to 20{
if sdate == EntryDate(cnt) Then
count = count+1;
}
RSIv = RSI(P);
if date != date[1] Then
Condition1 = false;
if RSIV >= 70 Then
Condition1 = true;
if stime < 145000 and
count < 당일진입횟수 and
dayopen >= DayClose(1)*1.10 and
dayopen < DayClose(1)*1.20 and
Condition1 == false
Then buy("b",AtMarket);
이 수식에 현재 RSI(9) 수치가 30 이하이면 매수한다는 조건을 추가하면 어떻게 수식을 작성하면 되나요?
2016-07-20
154
글번호 100215
답변완료
수식 문의드립니다.^^
아래 첨부파일에 보시듯이 5일선과20일선 크로스 시스템 매매신호를 적용 중입니다.
볼린져밴드상으로 볼때 수렴구간 ((박스구간)) 이때는 잦은 매매로인해 손실이 많이 발생 하는 부분입니다.
박스구간 또는 수렴구간 또는 횡보구간 에는 매매신호가 나오지 못하도록 하는 방법은 없나요?
아니면 다른 까다로운 진입 조건식을 넣어서 상,하방 추세 구간만 진입 하도록 할수 있는 방법은 없나요?
수동매매는 눈으로 보고 매매 하니 그런대로 수익이 나는데.계속 차트를 지켜 보아야 하는 거로 인해 머리가 띵~해영.
시스템 자동 매매를 돌려 볼려고 하니 수식을 몰르니 너무 힘드내요.^^
많이 가르쳐 주세영...시스템 매매한번 돌려 보고 싶어용^^
그럼 무더운 날씨에 건강 조심 하시구요.^^
2016-07-20
306
글번호 100214
답변완료
"48735 " 추가 질문드립니다.
수고많으십니다.
"48735 " 추가 질문드립니다.
답변주신 사항중 Array : mav[11](0); 에서 Array크기(공간수==>[11])를 가변적으로
Input : 에서 선언해서 계산해서 적용될 수 있는 수식 부탁드립니다.
ex) Input : 시작(5), 종료(100);
Array : mav[종료/시작](0); ===> 여기서 [종료/시작]이 계산되서 Array크기가 20이 적용되었으면 합니다.
var : ii(0);
Array : mav[11](0);
#매봉 10,20,30,..100이평을 계산해
#배열 1,2,3,...10번방에 저장
for ii = 1 to 10{
mav[ii] = ma(c,ii*10);
}
for ii = 1 to 10{
if mav[ii] > mav[ii][1] and mav[ii][1] > mav[ii][2] then
수식1;
if mav[ii] < mav[ii][1] and mav[ii][1] < mav[ii][2] then
수식2;
}
2016-07-19
158
글번호 100213
답변완료
참조 추가 부탁드립니다
안녕하세요...
Seven Binary Wave 에서 CCI 와 CO 두가지 조건을 제거하고,
외국인 선물순매수량 과 삼성전자(타종목)를 참조종목으로 추가하여
지표식을 만들고자 합니다...
아래와 같이 지표식을 만들고.. 차트에 실현시켜보면..
제대로 지표가 나오지 않고 +2 -2이하로 제한되는군요...
참조 종목이 원인인듯 한데... 이유를 모르겠습다..
지표식 수정을 부탁드립니다...
Input: shortPeriod(12), longPeriod(26), Period(9), maPeriod(20), ROCPeriod(12),
stoPeriod1(5), stoPeriod2(3), CCIPeriod(9);
var: value(0), BNW_SEVEN(0), 외국인선물수량(0, data2) ;
if ema(C,shortPeriod)-ema(C,longPeriod) >= ema(ema(C,shortPeriod)-ema(C,longPeriod),Period) then
value = 1;
else
value = -1;
if C >= ma(C, maPeriod) then
value = value + 1;
else
value = value - 1;
if (C - C[ROCPeriod]) / C[ROCPeriod] * 100 >= 0 then
value = value + 1;
else
value = value - 1;
if ema((C-lowest(L, stoPeriod1)) / (highest(H, stoPeriod1) - lowest(L, stoPeriod1)) * 100, stoPeriod2)>=50 then
value = value + 1;
else
value = value - 1;
if SAR(0.02,0.2) < C then
value = value + 1;
else
value = value - 1;
if data2(외국인선물수량) > 1000 then
value = value + 1 ;
else if data2(외국인선물수량) < -1000 then
value = value - 1 ;
else
value = 0 ;
if data3( C > ma(C, maPeriod) ) then // 삼성전자
value = value + 1 ;
else
value = value - 1 ;
BNW_SEVEN = value; // BW 가 사용자 함수로 등록되어 있어서 BNW 로 함
Plot1(BNW_SEVEN,"세븐 바이너리웨이브");
PlotBaseLine1(0,"기준선0");
PlotBaseLine2(3,"기준선3");
PlotBaseLine3(-3,"기준선-3");
무더운 여름 날씨에 건강에 유의하시기 바라며...
2016-07-19
212
글번호 100212
답변완료
부탁드립니다.
항상 도움을 받으면서 감사드리고 있습니다.
예: 5 이평, 10 이평, 20 이평, 60 이평의 음양 변화를 막대그래프로 표현하고자 합니다.
첨부파일을 첨부합니다.
예를 들어첨부파일에는
양일때
5 이평은 0 에서 1,
10 이평은 0에서 2,
20 이평은 0에서 3,
60 이평은 0에서 4까지 막대그래프로 나타나고 있습니다.
음일때
5 이평은 0 에서 -1,
10 이평은 0에서 -2,
20 이평은 0에서 -3,
60 이평은 0에서 -4까지 막대그래프로 나타나고 있습니다.
이를 각각의 칸에만 색이 표시 되도록 만들 수 있다면 부탁드립니다.
1. 5 이평이 양이면 0 에서 1까지 , 음이면 0 에서 -1까지
2. 10 이평이 양이면 1에서 2까지, 음이면 -1에서 -2까지
3. 20 이평이 양이면 2에서 3까지, 음이면 -2에서 -3까지
4. 60 이평이 양이면 3에서 4까지, 음이면 -3에서 -4까지
가능하다면 텍스트로 글자는 안 나오고 색지정도 할 수 있는지 궁금합니다.
2016-07-20
221
글번호 100211
답변완료
문의
답변 정말 감사드려요.
아래 상태에서 팝업창 기능도 있었으면 해서 부탁드립니다.
감사합니다^^
var : T1(0,data1),T2(0,data1),T3(0,data1);
var : V1(0,data1),V2(0,data1),V3(0,data1);
if crossup(data1(c),data2(c)) Then{
T1 = 1;
v1 = data1(c);
PlaySound("C:₩예스트레이더₩data₩Sound₩Stop.wav");
}
if CrossDown(data1(c),data2(c)) Then{
T1 = -1;
v1 = data1(c);
PlaySound("C:₩예스트레이더₩data₩Sound₩Stop.wav");
}
if crossup(data1(c),data3(c)) Then{
T2 = 1;
v2 = data1(c);
PlaySound("C:₩예스트레이더₩data₩Sound₩Stop.wav");
}
if CrossDown(data1(c),data3(c)) Then{
T2 = -1;
v2 = data1(c);
PlaySound("C:₩예스트레이더₩data₩Sound₩Stop.wav");
}
if crossup(data2(c),data3(c)) Then{
T3 = 1;
v3 = data2(c);
PlaySound("C:₩예스트레이더₩data₩Sound₩Stop.wav");
}
if CrossDown(data1(c),data2(c)) Then{
T3 = -1;
v3 = data2(c);
PlaySound("C:₩예스트레이더₩data₩Sound₩Stop.wav");
}
if T1 == 1 Then
plot1(v1,"교차1",RED);
if T1 == -1 Then
plot1(v1,"교차1",blue);
if T2 == 1 Then
plot2(v2,"교차2",RED);
if T2 == -1 Then
plot2(v2,"교차2",blue);
if T3 == 1 Then
plot3(v3,"교차3",RED);
if T3 == -1 Then
plot3(v3,"교차3",blue);
2016-07-19
163
글번호 100203
답변완료
지표수식 부탁드립니다
안녕하세요
감사합니다
헤외선물에 사용하려합니다
#첨부파일참조-지그제그
1 최근 3개봉중 최고점과 최저점을 직선으로잇는
지그제그수식 부탁드립니다
최고점/최저점이 갱신되면 갱신된 고점/저점에 표시되게 부탁드립니다
2 당일 최고점과 아래수식(첨부파일)에서 지그제그 꼭지점이전고점을 잇는 추세선수식부탁드립니다
당일 최저점과 아래수식(첨부파일)에서 지그제그 꼭지점이전저점을 잇는 추세선수식부탁드립니다
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
Input:length(3);
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);
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);
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]);
Text1 = Text_New(sDate[eBar],sTime[eBar],고점[1,1],NumToStr(고점[1,1],2));
Text_SetStyle(Text1, 2, 1);
If 고점[3,1] < 고점[2,1] and 고점[2,1] > 고점[1,1] and 저점[2,1] < 저점[1,1] Then
{
sBar = Index - 저점[2,2];
eBar = Index - 저점[1,2];
// TL2 = TL_New(sDate[sBar],sTime[sBar],저점[2,1],sDate[eBar],sTime[eBar],저점[1,1]);
// TL_SetColor(TL2,BLUE);
}
}
}
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);
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]);
Text1 = Text_New(sDate[eBar],sTime[eBar],저점[1,1],NumToStr(저점[1,1],2));
Text_SetStyle(Text1, 2, 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];
// TL3 = TL_New(sDate[sBar],sTime[sBar],고점[2,1],sDate[eBar],sTime[eBar],고점[1,1]);
// TL_SetColor(TL3,RED);
}
}
}
TL_SetSize(TL1,1);
TL_SetColor(TL1,WHITE);
TL_SetSize(TL2,1);
TL_SetSize(TL3,1);
TL_Val1 = 0; TL_Val2 = 0;
If 고점[2,1] > 고점[1,1] and 고점[2,1] > 고점[3,1] Then
{
If 고점[1,2] < 저점[1,2] and 저점[3,1] < 저점[2,1] Then
TL_Val1 = (저점[2,1]-저점[3,1])/(저점[2,2]-저점[3,2]) * (Index-저점[3,2])+저점[3,1];
If 저점[1,2] < 고점[1,2] and 저점[2,1] < 저점[1,1] Then
TL_Val1 = (저점[1,1]-저점[2,1])/(저점[1,2]-저점[2,2]) * (Index-저점[2,2])+저점[2,1];
}
If 저점[2,1] < 저점[1,1] and 저점[2,1] < 저점[3,1] Then
{
If 저점[1,2] < 고점[1,2] and 고점[3,1] > 고점[2,1] Then
TL_Val2 = (고점[2,1]-고점[3,1])/(고점[2,2]-고점[3,2]) * (Index-고점[3,2])+고점[3,1];
If 고점[1,2] < 저점[1,2] and 고점[2,1] > 고점[1,1] Then
TL_Val2 = (고점[1,1]-고점[2,1])/(고점[1,2]-고점[2,2]) * (Index-고점[2,2])+고점[2,1];
}
If TL_Val1 > 0 Then Plot21(TL_Val1,"추세선1",BLUE); //점그래프
If TL_Val2 > 0 Then Plot22(TL_Val2,"추세선2",RED); //점그래프
감사합니다
좋은하루 되세요
2016-07-19
274
글번호 100202
답변완료
수식 부탁드립니다.
지표식 부탁드립니다.
A(상)
B(하)
P(값)
상하 두 개의 라인이 있다고 할 때
P가 A라인을 상향 돌파되면(종가기준) 빨강라인을 가로로 계속 표시하고
P가 B라인을 하향 돌파되면(종가기준) 파랑라인을 가로로 계속 표시하고자 합니다.
이때 중요한 것은
A라인을 상향 돌파되고 나서 A라인을 이탈하더라도
B라인을 하향 돌파하기 전까지는 라인의 변화는 없어야 합니다.
반대도 마찬가지고요.
수식에 주석 부탁드립니다.
미리 감사 인사 드립니다.
2016-07-19
172
글번호 100201