커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
4441
글번호 230811
답변완료
수식문의
안녕하세요
하기 수식 문의 드립니다.
기본적으로 볼린져 밴드 기준으로 합니다.
1. 가격이 볼린져 밴드 하단을 닿거나 통과하고 다시 올라가면, 매수 진입합니다.
마찬가지로, 가격이 볼린져 밴드 상단을 닿거나 통과하고 다시 내려오면, 매도 진입합니다.
2. ADX가 상승중일때는
매수의 경우 볼린져 밴드 상단에 닿더라도 매도 신호를 내지 않습니다.
매도의 경우 볼린져 밴드 하단에 닿더라도 매수 신호를 내지 않습니다.
ADX 지수가 낮아지기 시작할 때 신호 발생을 합니다.
3. 손절매 없이 상기 두가지가 쭉 이어가는 형태가 나오도록 부탁드립니다.
감사합니다.
2017-02-13
111
글번호 106737
답변완료
3가지 경우로 묶어서 시스템식 부탁드립니다.
안녕하세요.
다음의 시스템식에서 추가로 부탁드립니다.
감사합니다.
다음 1/2번(주/야간시장 포함), 3/4번(최대수익 대비 하락시점 and 최소 1P 수익시점, 주간시장), 5/6(최대수익 대비 하락시점 and 최소 1P 수익시점,주/야간시장 포함) 묶어서 3가지의 경우로 시스템식 부탁드립니다.
* 1/2번의 경우는 주간과 야간선물 시장 포함하여 청산 조건에 도달하면 청산이 되도록 부탁합니다.
1. 국내선물 개장(09:00) 첫봉이 시초가 위에서 시작하면 매수하여 1.0 P 청산시스템
2. 국내선물 개장(09:00) 첫봉이 시초가 아래에서 시작하면 매도하여 1.0 P 청산시스템
* 3/4번의 경우는 진입후 1P 수익이 난 상태에서 추가수익을 내기 위하여 최대 수익 대비 -0.5P 하락가 되는 점 또는 최소한 1P 수익 보장 시점에서 자동청산 되도록 수식 부탁합니다.(주간선물시장)
3. 국내선물 개장(09:00) 첫봉이 시초가 위에서 시작하면 매수하여 1.0 P 청산시스템
4. 국내선물 개장(09:00) 첫봉이 시초가 아래에서 시작하면 매도하여 1.0 P 청산시스템
* 5/6번의 경우는 진입후 1P 수익이 난 상태에서 추가수익을 내기 위하여 최대 수익 대비 -0.5P 하락가 되는 점 또는 최소한 1P 수익 보장 시점에서 자동청산 되도록 수식 부탁합니다.(주간/야간선물시장 포함)
5. 국내선물 개장(09:00) 첫봉이 시초가 위에서 시작하면 매수하여 1.0 P 청산시스템
6. 국내선물 개장(09:00) 첫봉이 시초가 아래에서 시작하면 매도하여 1.0 P 청산시스템
===============
안녕하세요
예스스탁입니다.
시스템은 동시호가 매수/매도는 가능하지 않습니다.
아래는 당일 첫봉 시가에 신호발생하는 식입니다.
모두 분봉에 적용하시고 당일청산은 정규장 내 시간으로 지정하셔야 합니다.
1
if NextBarSdate > sdate Then
buy("b",AtMarket);
SetStopProfittarget(1,PointStop);
2
if NextBarSdate > sdate Then
sell("s",AtMarket);
SetStopProfittarget(1,PointStop);
3
if NextBarSdate > sdate Then
buy("b",AtMarket);
SetStopEndofday(152900);
4
if NextBarSdate > sdate Then
sell("s",AtMarket);
SetStopEndofday(152900);
2017-02-13
135
글번호 106736
대가들의매매 님에 의해서 삭제되었습니다.
2017-02-10
0
글번호 106706
답변완료
수식문의드립니다
1. 현재종목의일주일동안의 평균주가/종합지수의일주일동안의평균주가
2. 현재종목의 일주일동안의 등락률/종합지수의 일주일동안의의등락률
지표식부탁드립니다.
2017-02-10
135
글번호 106705
답변완료
수식문의드립니다
1주동안의 최고 거래량이 지난4주동안의 평균거래량보다 2배이상이고
그리고 최근 4주간의 전체거래량이 지난 4주간의 거래량보다 2배이상인 종목
그리고 20선이 상승하고 있는 종목
2017-02-10
120
글번호 106704
답변완료
부탁드립니다
안녕하세요!
plot1(dayopen,"당일시가");
plot2((dayhigh+daylow)/2,"당일중심가");
Text_Delete(var1);
Text_Delete(var2);
var1 = Text_New(sdate,stime,dayopen,"당일시가:"+ NumToStr(dayopen,2));
var2 = Text_New(sdate,stime,(dayhigh+daylow)/2,"당일중심:"+ NumToStr((dayhigh+daylow)/2,2));
Text_SetStyle(var1,1,1);
Text_SetStyle(var2,1,1);
당일 중심선 그리고 당일 시가선은 처럼
당일 고점 또는 당일고점 다음봉을 기준으로 중심선처럼 그려졌으면 합니다
그림을 첨부합니다 참조해서 만들어 주시면 감사하겟습니다.
비슷하게라도 나오면 됩니다.
안되면
고점봉을 기준으로 저점에서 피보나치수열로 그려져도 될겠습니다.
두서없는 글을 늦게까지 공부하여 올립니다.
2017-03-11
179
글번호 106703
답변완료
51749관련입니다
아래와 같이 산식을 작성해 주셨는데
Hv를 양봉일때의 거래량으로 제한하고
금일의 봉도 양봉이며
최근50일간 금일거래량합계의 50%이상의 거래량은 없을것을 구현하고 싶습니다
이리저리 만져봐도 잘 않되서 질문합니다
=========아래============
15시 이후 거래량이라면 60분봉에서 가능하지만
15시~15시20분 사이 거래량이면 10분봉이나 20분봉에서만 가능합니다.
15시 이후 거래량이면 아래식을
var : Hv(0),cnt(0);
if date != date[1] Then
var1 = 0;
if stime >= 130000 Then
var1 = var1+V;
Hv = DayVolume(1);
for cnt = 1 to 40{
if DayVolume(cnt) > Hv Then
Hv = DayVolume(cnt);
}
if var1 > Hv Then
find(1);
2017-02-09
146
글번호 106702
답변완료
부탁 드립니다.
도움 주심에 감사 드립니다.
다음 수식을 실행한것과
이것을 함수화 하여 실행 한것이 차이가 있습니다.
그림처럼 함수화 한것의 수평선을 없애고 싶습니다.
미리 감사 드립니다.
input:시작년월일(20170208),시작시각(080000);
input:종료년월일(20170208),종료시각(153000);
input: Period1(12),Period2(26),Period3(9);
variables: VolumeValue( 0 ), MedPrice( 0 ), PV( 0 ),StartCalcDate(0),StartTime(0),
CumulativeVolume( 0 ), CumulativePV( 0 ), Started( false ), Denom( 0 ),
KeyCumVol( 0 ), KeyCumPV( 0 ), MidasValue( 0 ),endCalcDate(0),endTime(0) ;
Var : Ep1(0), JISU1(0),Ep2(0), JISU2(0),Ep3(0),Jisu3(0);
var : MACDVal(0),MACDSig(0),ii(0),SD(false),ED(false);
Ep1 = 2/(Period1+1);
Ep2 = 2/(Period2+1);
Ep3 = 2/(Period3+1);
StartCalcDate = 시작년월일;
StartTime = 시작시각;
endCalcDate = 종료년월일;
endTime = 종료시각;
if sdate == StartCalcDate and
(stime == StartTime or (stime > StartTime and stime[1] < StartTime)) Then
Started = true;
if Started == true and sdate == endCalcDate and
(stime >= endTime or (stime > endTime and stime[1]< endTime)) Then
Started = false;
if Started == true then
{
VolumeValue = iff( DataCompress < 1, Ticks, Volume ) ;
MedPrice = (H + L)/2 ;
PV = MedPrice * VolumeValue ;
CumulativeVolume = VolumeValue + CumulativeVolume ;
CumulativePV = PV + CumulativePV ;
}
if Started == true and Started[1] == false then
{
Started = true ;
Denom = 1 ;
KeyCumVol = CumulativeVolume ;
KeyCumPV = CumulativePV ;
}
else if Denom >= 1 then
Denom = CumulativeVolume - KeyCumVol ;
if Started then
{
if Denom > 1 then
MidasValue = ( CumulativePV - KeyCumPV ) / Denom ;
else if Denom == 1 then
MidasValue = MedPrice ;
ii = ii+1;
if ii <= 1 then {
JISU1 = MidasValue;
JISU2 = MidasValue;
MACDVal = JiSu1-Jisu2;
MACDsig = MACDVal;
}
else{
JISU1 = MidasValue * EP1 + JISU1[1] * (1-EP1);
JISU2 = MidasValue * EP2 + JISU2[1] * (1-EP2);
MACDVal = JiSu1-Jisu2;
MACDsig = MACDVal * EP3 + MACDsig[1] * (1-EP3);
}
plot1(MACDVal);
// plot2(MACDsig);
//PlotBaseLine1(0);
}
함수 실행파일:
input: 시작년월일(20170208),시작시각(080000);
input:종료년월일(20170208),종료시각(153000);
input: Period1(12),Period2(26),Period3(9);
var1=function_macd(시작년월일,시작시각,종료년월일,종료시각,Period1,Period2,Period3);
plot1(var1);
함수명:function_macd
input:시작년월일(numeric),시작시각(numeric);
input:종료년월일(numeric),종료시각(numeric);
input: Period1(numeric),Period2(numeric),Period3(numeric);
variables: VolumeValue( 0 ), MedPrice( 0 ), PV( 0 ),StartCalcDate(0),StartTime(0),
CumulativeVolume( 0 ), CumulativePV( 0 ), Started( false ), Denom( 0 ),
KeyCumVol( 0 ), KeyCumPV( 0 ), MidasValue( 0 ),endCalcDate(0),endTime(0) ;
Var : Ep1(0), JISU1(0),Ep2(0), JISU2(0),Ep3(0),Jisu3(0);
var : MACDVal(0),MACDSig(0),ii(0),SD(false),ED(false);
Ep1 = 2/(Period1+1);
Ep2 = 2/(Period2+1);
Ep3 = 2/(Period3+1);
StartCalcDate = 시작년월일;
StartTime = 시작시각;
endCalcDate = 종료년월일;
endTime = 종료시각;
if sdate == StartCalcDate and
(stime == StartTime or (stime > StartTime and stime[1] < StartTime)) Then
Started = true;
if Started == true and sdate == endCalcDate and
(stime >= endTime or (stime > endTime and stime[1]< endTime)) Then
Started = false;
if Started == true then
{
VolumeValue = iff( DataCompress < 1, Ticks, Volume ) ;
MedPrice = (H + L)/2 ;
PV = MedPrice * VolumeValue ;
CumulativeVolume = VolumeValue + CumulativeVolume ;
CumulativePV = PV + CumulativePV ;
}
if Started == true and Started[1] == false then
{
Started = true ;
Denom = 1 ;
KeyCumVol = CumulativeVolume ;
KeyCumPV = CumulativePV ;
}
else if Denom >= 1 then
Denom = CumulativeVolume - KeyCumVol ;
if Started then
{
if Denom > 1 then
MidasValue = ( CumulativePV - KeyCumPV ) / Denom ;
else if Denom == 1 then
MidasValue = MedPrice ;
ii = ii+1;
if ii <= 1 then {
JISU1 = MidasValue;
JISU2 = MidasValue;
MACDVal = JiSu1-Jisu2;
MACDsig = MACDVal;
}
else{
JISU1 = MidasValue * EP1 + JISU1[1] * (1-EP1);
JISU2 = MidasValue * EP2 + JISU2[1] * (1-EP2);
MACDVal = JiSu1-Jisu2;
MACDsig = MACDVal * EP3 + MACDsig[1] * (1-EP3);
}
function_macd=MACDVal;
// plot2(MACDsig);
// PlotBaseLine1(0);
}
2017-02-09
204
글번호 106701
답변완료
지표문의드림니다
1,이동평균 크로스업 가격(위치) 다음봉종가
2,이동평균 크로스다운 가격(위치) 다음봉종가
3,아침 9시부터 크로스 한자리를 계산하여 다음날 아침 6시까지 누적한다
4 그림첨부합니다
나타낼지표 :
1d 보다2u가높을경우 (1d-2u)
1d 보다2u가낮을경우 (1d+2u)
2u 보다3d가높을경우 (2u+3d)
2u 보다3d가낮을경우 (2u-3d)
위값을 만족할경우
누적 합산해주세요
2017-02-10
209
글번호 106700