커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
4474
글번호 230811
답변완료
수식문의드립니다
1분봉기준입니다.
1.
시간을 입력하면
예를들어
input : 시간(093000);
입력한 분봉의 저점에서 30개봉동안 입력한 시간의저점*0.005 을 더한 값을 출력하려고 합니다
1. 093000 의 저점
2. 093000 의 저점 + (093000의 저점 * 0.005)
3. 2번값에 + (093000의 저점 * 0.005)
....
부탁드립니다
행복한 성탄 보내세요~
2018-12-24
262
글번호 124705
답변완료
문의
전일 항생오전 10시15분부터 오후1시 까지 시간의 거래량의 40%,60%지점을 다음날 오전10시 15분부터 1시사이에 나타나게 부탁드립니다
2018-12-24
280
글번호 124704
답변완료
수식요청 드립이다.
안녕하세요.
항생 분봉 틱봉 당일청산 아래 시스템에서
매수 "dbp" 당일목표수익 청산 완료된 경우 -> 매도 당일 1회 추가진입,
매도 "dsp" 당일목표수익 청산 완료된 경우 -> 매수 당일 1회 추가진입,
추가진입은 추가진입수식(예제)적용 당일 1회 추가진입, 추가익절, 추가손절 청산수식
추가요청 드립니다.
1. 당일 매매 시간 - 기존 매매 시간과 동일함.
2. 1회 추가진입 추가손절청산 - 진입가에서 20틱이상 손실발생시 추가손절청산 당일 매매종료.
3. 1회 추가진입 추가익절청산 - 진입가에서 25틱이상 수익발생하고, 매수기준 현제봉이 5일평을
하향돌파시 추가익절청산 당일 매매종료.
수식 추가요청 드립이다.
감사합니다
//----------------------------------------------------------------------------------
# 추가진입수식(예제)
Input : Period(9),추가익절(25),추가손절(20);
If CrossUp(CCI(Period), 0) Then{
Buy("추가매수");
}
If CrossDown(CCI(Period), 0) Then{
Sell(추가매도");
}
//----------------------------------------------------------------------------------
# 시스템수식
Input : 익절(15),손절(10),당일목표수익(90),당일목표손실(50);
input : 시작시간1(101500),종료시간1(125500),시작시간2(140000),종료시간2(151500);
Input : Period(12), sigPeriod(9);
var : Tcond(false);
Var : N1(0),dayPl(0),당일수익(0),당일손실(0),Xcond(false);
당일수익 = PriceScale*당일목표수익;
당일손실 = PriceScale*당일목표손실;
daypl = NetProfit-N1;
if (sdate != sdate[1] and stime >= 시작시간1) or
(sdate == sdate[1] and stime >= 시작시간1 and stime[1] < 시작시간1) Then
{
Tcond = true;
Xcond = false;
N1 = NetProfit;
}
if (sdate != sdate[1] and stime >= 종료시간1) or
(sdate == sdate[1] and stime >= 종료시간1 and stime[1] < 종료시간1) Then
{
Tcond = false;
if MarketPosition == 1 Then
ExitLong("bx1");
if MarketPosition == -1 Then
ExitShort("sx1");
}
if (sdate != sdate[1] and stime >= 시작시간2) or
(sdate == sdate[1] and stime >= 시작시간2 and stime[1] < 시작시간2) Then
{
Tcond = true;
}
if (sdate != sdate[1] and stime >= 종료시간2) or
(sdate == sdate[1] and stime >= 종료시간2 and stime[1] < 종료시간2) Then
{
Tcond = false;
if MarketPosition == 1 Then
ExitLong("bx2");
if MarketPosition == -1 Then
ExitShort("sx2");
}
if TotalTrades > TotalTrades[1] then
{
if (IsExitName("dbp",1) == true or IsExitName("dbl",1) == true or
IsExitName("dsp",1) == true or IsExitName("dsl",1) == true) then
Xcond = true;
if daypl >= 당일수익 or daypl <= -당일손실 Then
Xcond = true;
}
value1 = TRIX(Period);
value2 = ema(value1, sigPeriod);
if Tcond == true and Xcond == false then
{
If CrossUP(value1, value2) Then
Buy("b");
If CrossDown(value1, value2) Then
Sell("s");
}
if MarketPosition == 1 then
{
ExitLong("dbp",atlimit,EntryPrice+((당일수익-daypl)/CurrentContracts));
ExitLong("dbl",AtStop,EntryPrice-((당일손실+daypl)/CurrentContracts));
ExitLong("bp",Atlimit,EntryPrice+PriceScale*익절);
ExitLong("bl",AtStop,EntryPrice-PriceScale*손절);
}
if MarketPosition == -1 then
{
ExitShort("dsp",atlimit,EntryPrice-((당일수익-daypl)/CurrentContracts));
ExitShort("dsl",AtStop,EntryPrice+((당일손실+daypl)/CurrentContracts));
ExitShort("sp",Atlimit,EntryPrice-PriceScale*익절);
ExitShort("sl",AtStop,EntryPrice+PriceScale*손절);
}
2018-12-24
277
글번호 124703
답변완료
endtime 좀 봐주십시요.
* 좋은 하루 되십시요^^
* 아래 식에서 endtime 시간 적용좀 수정 해주십시요.
즉 전일 9시30분에 매매시작 하여 다음날 새벽 5시에 청산할려고 하는데 안되네요.
수정좀 부탁 드립니다.
### 아래 식
input : 시스템적용일(20181221), 시스템적용시간(093000) , endtime(050000);
var : cnt(0),Xcnt(0),Ecnt(0) ;
Ecnt = 0;
for cnt = 0 to 20
{ if sdate == EntryDate(cnt) Then
Ecnt = Ecnt+1;
}
if date != date[1] Then
Xcnt = 0 ;
var1 =ma(c,3) ;
var2 =ma(c,9) ;
if sdate >= 시스템적용일 and stime >= 시스템적용시간 Then
{
Condition1 = true;
}
if Condition1 == true then
{
if CrossUp(c,var1) Then buy();
if CrossDown(var1,var2) Then Sell();
}
SetStopEndofday(endtime);
* 고맙습니다.
2018-12-23
293
글번호 124702
답변완료
부탁드립니다.
안녕하세요?
아래 수식에서 다음을 수정해 주셨으면 합니다.
1.수치표시(1) 같이 파동선과 수평선의 표시를 선택할 수 있도록 부탁드립니다.
2.소숫점 앞부분 갯수와 소숫점 아래 갯수를 조절할 수 있도록 부탁드립니다.
3.틱수를 고점의 경우는 고점수치 표시 위에, 저점의 경우 저점수치 표시 아래에 표시되게 부탁드립니다.
좋은 날 되십시요.
input:length(4),종가사용여부(0),파동선두께(5),수평선두께(2),수치표시(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,1],2)+"/ +"+NumToStr(abs(고[1,1]-저[1,1])/PriceScale,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,1],2)+"/ +"+NumToStr(abs(고[1,1]-저[1,1])/PriceScale,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,1],2)+"/ -"+NumToStr(abs(고[1,1]-저[1,1])/PriceScale,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,1],2)+"/ -"+NumToStr(abs(고[1,1]-저[1,1])/PriceScale,0)+"틱");
}
}
최종꼭지점 = "저점";
}
#상단수평
if T == -1 and T[1] != -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(TL2,파동선두께);
TL_SetColor(TL2,red);
TL_SetSize(TL3,파동선두께);
TL_SetColor(TL3,red);
}
#하단수평
if T == 1 and T[1] != 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(TL4,파동선두께);
TL_SetColor(TL4,blue);
TL_SetSize(TL5,파동선두께);
TL_SetColor(TL5,blue);
}
2018-12-23
274
글번호 124701
답변완료
문의드립니다.
1. 아래의 기본적인 Heiken Ashi 지표의 수식적용이 안되는데 확인후 수정좀 부탁드립니다.
haClose = (Open+High+Low+Close)/4;
haOpen = (haOpen[1] + haClose[1])/2 ;
haHigh = Max(High, haOpen, haClose);
haLow = Min(Low, haOpen, haClose) ;
2. 하나투자금융의 Heiken Ashi 차트를 지표수식으로 작성할수 있을까요?
가능하다면 이것도 수식작성좀 부탁드립니다.
(아래는 참조사항 입니다.)
가. 하나투자금융의 Heiken Ashi 차트 지표식 작성방법
(1)양봉은 흰색 혹은 빨강색으로 표시하고 음봉은 검은색 혹은 파랑색으로 표시
(2)사각형은 끝 부분은 각각 시가와 종가를 표시(양봉/음봉 위치가 반대방향)
(3)사각형 위, 아래에 연결되어 있는 선은 각각 고가와 저가를 표시
(4)가격차트 설정에 색상 적용의 상승/하락은 전일종가 보다 당일시가가 상승하면
상승, 하락이면 하락이고 양봉/음봉은 당일시가를 기준으로 당일종가가 상승하면
양봉, 하락하면 음봉으로 표현 합니다.
<색상적용>
* 상승/양봉:전일종가 기준 당일시가가 상승, 당일종가가 당일시가 보다 상승.
* 상승/음봉:전일종가 기준 당일시가가 상승, 당일종가가 당일시가 보다 하락.
* 하락/양봉:전일종가 기준 당일시가가 하락, 당일종가가 당일시가 보다 상승.
* 하락/음봉:전일종가 기준 당일시가가 하락, 당일종가가 당일시가 보다 하락.
나. 하나투자금융의 Heiken Ashi차트 해석 및 활용
캔들의 색깔을 보고 상승과 하락을 구분할 수 있으며 사각형이 길수록 시가와 종가의
차이가 많았음을 의미하고 shadow가 길수록 고가와 저가의 차이가 많았음을 의미함.
2018-12-23
300
글번호 124700
답변완료
문의드립니다
타주기 trix지표를 참조 해서 스톡캐스틱 으로 신호를 내고 싶습니다.
예를 들어 1분봉 차트로 거래를 할때...
참조차트 5분봉 에서 trix선이 시그널 선 위에 있을땐 매수신호만,
반대로 trix선이 시그널 아래 있을땐 매도 신호만 발생했으면 합니다.
위 조건일때만
매수신호:스톡캐스틱 %k 선이 %d 골든크로스하면 매수
매도신호:스톡캐스틱 %k 선이 %d 데드크로스 하면 매도
2018-12-23
283
글번호 124699
답변완료
문위드립니다
macd 오실레타 지표에서 시그널을 막대로 바꾸엇습니다
0선 기준선 위에서는 빨강색 막대,,기준선 아래서는 파란색 막대로
가능한지요
막대모양도 아래에 문위한 60596번 모양으로 만들어주시면 감사하겟습니다
2018-12-23
337
글번호 124698
답변완료
지표 의뢰드려요
안녕하세요!
키움의 수식을 예스로 변환 부탁드립니다!
항상 감사드립니다!
-------------------------------------------------------------------------------
수식명: 이격도
지표조건설정
P1(120)
TICV(1)
DIF(20)
[ 수식 1] 이격도
ln1=( c-ma(c,p1) ) / ticv;
ln1
[ 수식 2] 이격도*
if(Ln1<(DIF*-1),LN1,0)
[ 수식 3] 이격도+
if(Ln1>DIF,LN1,0)
[ 수식 4]
[ 수식 5]
----------------------------------------------------------------------------
수식명: 고저이평선크로스1
지표조건설정
P1 (5)
P2 (20)
[ 수식 1 ]
EAVG(H,P1)
[ 수식 2 ]
EAVG(L,P1)
[ 수식 3 ]
EAVG(C,P2)
---------------------------------------------------------------------
수식명: 고저이평선크로스2
지표조건설정
P1 (5)
P2 (20)
[ 수식 1]
VAR1=EAVG(H,P1);
VAR2=EAVG(L,P1);
VAR3=AVG(C,P2);
IF(VAR2>VAR3, 1 , IF(VAR1<VAR3, -1 , 0 ) )
[ 수식 2]
[ 수식 3]
[ 수식 4]
[ 수식 5]
2018-12-24
339
글번호 124697