커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
1685
글번호 230811
답변완료
수식 질문드립니다.
function C1_OnRiseSignal(Signal)
{
Main.MessageLog("신호완성/"+Signal.signalKind);
var n;
if (ChartEx1.GetClose(1, 0) > 0) n = Math.ceil(ChartEx1.GetClose(1, 0)*6/2.5);
Main.MessageLog("n=" ???????? );
if (Signal.signalKind == 1 )
{
위에서 n 값을 로그로 나오게 표현하고 싶습니다.
감사합니다.
2022-03-12
1312
글번호 157110
답변완료
halfTrend 지표수식 문의
아래 수식에 의미를 설명 부탁드립니다.
maxLowPrice = max(lowPrice, maxLowPrice);
if highma < maxLowPrice and close < maxLowPrice Then
{
trend = 1;
nextTrend = 0;
minHighPrice = highPrice;
2022-03-12
1316
글번호 157109
답변완료
수식 문의 드립니다
늘 감사합니다..
1.다름이 아니오라 아래 그림과 같이 고점과 저점을 연결하고 싶습니다..
그림은 3분봉이지만 분봉 일봉 상관없이 자동으로 이어지게 했으면 합니다..
2. 이렇게 이어진 고점과 저점에 가격을 자동으로 표기되도록 하고싶습니다..
감사합니다..
2022-03-12
1070
글번호 157108
답변완료
문의드립니다.
안녕하세요.
Input : 진입계약(3), 청산계약1(20), 청산계약2(50), 청산계약3(300), PriceChannel Length(20)
1. 매수진입 : 5이평, 20이평, 100이평 정배열시 and Price Channel 상한,하한 모두 상승시 진입계약(3)
** Price Channel 상한,하한 모두 상승시 : 상승이후 수평유지시에도 상승으로 판단
매수청산 계약1 : 진입계약1(20틱)
매수청산 계약2 : 진입계약2(50틱)
매수청산 계약3 : 청산계약3이상(300틱) and (20이평하락으로변경 or Price Channel 하한 Touch시)
** "Price Channel 하한 Touch시"는 종가기준이 아닌 봉중에 Touch시 청산
손절 : 50틱 ==> 이경우 미청산계약 모두 손절
2. 매도진입 : 5이평, 20이평, 100이평 역배열시 and Price Channel 상한,하한 모두 하락시 진입계약(3)
** Price Channel 상한,하한 모두 하락시 : 하락이후 수평유지시에도 하락으로 판단
매도청산 계약1 : 진입계약1(20틱)
매도청산 계약2 : 진입계약2(50틱)
매도청산 계약3 : 청산계약3이상(300틱) and (20이평상승으로변경 or Price Channel 상한 Touch시)
** "Price Channel 상한 Touch시"는 종가기준이 아닌 봉중에 Touch시
손절 : 50틱 ==> 이경우 미청산계약 모두 손절
미리 감사드립니다.
2022-03-12
1045
글번호 157107
답변완료
시스템식 문의 드립니다.
asdf
2022-03-12
974
글번호 157106
답변완료
간단한 수식 작성 질문드립니다.
대단히 수고 많으십니다.
프로그램에 미숙하여 간단한 수식 요청 드립니다.
예제로 삼아 공부하고자 합니다.
주식에 적용할 예정입니다.
1. 당일 시가 대비 5% 하락시 매수, 매수가에서 1.5% 수익시 매도
2. (1번에서 매수 이후 추가하락) 당일 시가 대비 8% 하락시 추가매수
매수평단에서 1.5% 수익시 매도
3. (1, 2번 매수 이후 추가하락) 당일 시가 대비 10% 하락시 전량 손절
혹은 1번 매수 이후 3시간 경과시 매도
조건값 만족시 반복해서 매수되지 않고 한번만 매수되도록 설정하는 법 역시 질문드립니다.
바쁘시겠지만 답변 부탁드리겠습니다.
감사합니다^^
2022-03-11
967
글번호 157105
답변완료
수식 질문드립니다.
if (Signal.signalKind == 1 )
여기에다가
GetRemainDays(nCallPut, nATMLevel) 를써서
남은 날짜가 15거래일 미만일때만 매매들어가게 하고 싶습니다.
if (Signal.signalKind == 1 && GetRemainDays(0,1)<15 )
요렇게 바꾸면 문제없겠죠?
감사합니다.
2022-03-11
1180
글번호 157104
답변완료
수식문의 드립니다.
매수 : 090000시 매수
매도 : 151900시 청산
2022-03-11
991
글번호 157103
답변완료
76319번에 대하여 재질문 드립니다.
담당자님, 안녕하세요.
Q&A 76319번에서 제가 질의하면서 설명을 제대로 못드린거 같습니다.
처음에 잘 설명드려야 하는데 번거롭게 해드려 거듭 죄송합니다.
다시 설명드린 내용으로 검토와 조건 변경(수정)한 수식의 작성을 부탁드립니다.
당초 Q&A 76306번의 조건을 수정하여 지표를 변경하고자 했습니다.
(76306번의 기존 조건)
40일간 각 일봉 시가, 종가의 80개 가격(value) 중에서 (시가, 종가 구분 없이)
가격(value)이 '(당일 시가 - 5.0)~(당일 시가 + 5.0)'의 범위 내에 있으면서
and 그 가격(value)이 당일 시가와 가장 가까운 것을 5개 선정
=> if diff[cnt] < tempmin and diff[cnt] < y
(변경하는 조건)
40일간 각 일봉 시가, 종가의 80개 가격(value) 중에서 (시가, 종가 구분 없이)
가격(value)이 '(당일 시가 - 5.0)~(당일 시가 + 5.0)'의 범위 내에 있으면서
and 그 가격(value)이 산출된 일봉의 날짜가 당일(D) 부터 가까운 순서로 최근 일자의 5개 가격(value) 선정
=> 따라서, 제 생각에 'diff[cnt] < tempmin' 조건은 제외되는 대신에 'diff[cnt] < y'의 조건과 함께
'각 가격(value)의 일봉 날짜가 당일(D) 부터 가까운 순서로 선택'하는 조건이 필요하지 않을까 추측해봅니다.
하지만 확실히는 잘 모르겠습니다.
cf. 수식에서 'diff[cnt] < tempmin' 조건과 tempmin 관련 변수를 제외하고 실행하면
'diff[cnt] < y' 조건을 충족하고 당일로 부터 먼 순서로 가격 5개가 선택됩니다.
예시를 통해 부연 설명드리면,
----------------------------------------------------------------------
N(10), nth(5), y(5)로 설정하고, 당일(D)의 시가 361.0인 경우
날짜 시가 종가 diff[cnt] 기존조건으로 변경조건으로
(D-1) 364.0 358.0 3.0 5개 선택시 가격 5개 선택시 가격
(D-2) 400.0 322.0 39.0 362.0 364.0
(D-3) 363.0 359.0 2.0 360.0 358.0
(D-4) 362.5 359.5 1.5 362.5 363.0
(D-5) 362.0 360.0 1.0 359.5 359.0
(D-6) 401.0 321.0 40.0 363.0 또는 359.0 362.0 또는 359.5
.............
(D-10) 402.0 320.0 41.0
--------------------------------------------------------------------------
위와 같이 기존 조건을 변경한 조건의 지표 수정을 부탁드립니다.
하단에는 76319번 Q&A 내용과 기존에 담당자님께서 작성해주신 수식을 기재했습니다.
계속 요청드리는 점 양해 바라며
수식 작성해 주신것에 미리 감사드립니다.
===================================================================
<Q&A 76319번 질의 및 담당자님 답변 내용>
===================================================================
===================================================================
===================================================================
안녕하세요
예스스탁입니다.
기존의 답변드린 수식이 당일로 부터 가까운 것을 기준으로 계산을 합니다.
1번방 : 1일전 시가, 2번방 : 1일전 종가
3번방 : 2일전 시가, 4번방 : 2일전 종가
5번방 : 3일전 시가, 6번방 : 3일전 종가
...
79번방 : 40일전 시가, 80번방 : 40일전 종가
value에 1일전~40일전의 시가와 종가 값이 1번방~80번까지 저장이 되고
최소차이값을 계산할때도 1번방~80번 순서로 찾게 되어 있습니다.
For cnt = 1 to N*2
{
if diff[cnt] < tempmin and diff[cnt] < y then
{
tempmin = diff[cnt];
tempIndex = cnt;
}
}
즐거운 하루되세요
> 원칙투자자 님이 쓴 글입니다.
> 제목 : 지표 수식 작성 부탁드립니다.
> 담당자님, 안녕하세요.
담당자님께서 지표를 잘 작성해주셨는데,
적용조건을 변경한 수식으로 수정하고자
담당자님께 부탁드립니다.
잘 작성해주신 지표로
계속 번거롭게 해드려 정말 죄송합니다.
수식작성 Q&A 76306번 지표(하단에 기재된 기존 수식)의 조건 수정입니다.
==========================================================
40일간 각 일봉 시가, 종가의 80개 가격(value) 중에서
가격(value)이 '(당일 시가 - 5.0)~(당일 시가 + 5.0)'의 범위 내에 있으면서 (-> 기존과 동일한 조건)
and 그 가격(value)이 산출된 일봉의 날짜가 당일로 부터 가까운 순서대로 (-> 수정된 조건)
최근 일자의 5개 가격(value)을 선정
===========================================================
위와 같이 기존 수식의 조건을 변경한 지표의 수정을 부탁드립니다.
조건을 수정하여 요청드린 점 죄송하게 생각합니다.
이제 가급적 지표 수정을 마무리 하겠습니다.
다시 한번 지표 작성에 대해 미리 감사드립니다.
일교차가 심한데 건강 챙기시기 바랍니다
<기존의 지표 수식>
( Q&A 76306번에 대한 답변에서담당자님께서 작성해주신 수식)
==========================================================
==========================================================
input : N(40),nth(5),y(5);
var : cnt(0),nthi(0);
Var : tempmin(0), tempindex(0),NTHindex(0),ii(0);
Array : value[200](0),diff[200](0), NTHVALUE[10](0);
if Bdate != Bdate[1] Then
{
ii = 0;
For cnt = 1 to N
{
ii = ii+1;
value[ii] = DayOpen(cnt);
diff[ii] = abs(value[ii]-DayOpen(0));
ii = ii+1;
value[ii] = DayClose(cnt);
diff[ii] = abs(value[ii]-DayOpen(0));
}
For nthi = 1 to nth
{
tempMin = 99999999;
tempIndex = -1;
For cnt = 1 to N*2
{
if diff[cnt] < tempmin and diff[cnt] < y then
{
tempmin = diff[cnt];
tempIndex = cnt;
}
}
if tempIndex != -1 Then
{
NTHVALUE[nthi] = value[tempIndex];
diff[tempIndex] = 99999999;
}
Else
{
NTHVALUE[nthi] = Nan;
}
}
}
plot1(NTHVALUE[1]);
plot2(NTHVALUE[2]);
plot3(NTHVALUE[3]);
plot4(NTHVALUE[4]);
plot5(NTHVALUE[5]);
============================================================
2022-03-14
1048
글번호 157102