커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
6138
글번호 230811
답변완료
수식 검토
답변 수식으로 시뮬레이션을 해보았는데 8틱 이하만 결과가 나옵니다
첨부사진 1은 1차거래 선택(7틱봉) : 2틱 이상부터는 결과가 같습니다.
첨부사진 2는 1차거래 선택(1분봉) : 5틱 이상부터는 결과가 같습니다.
아래 3가지 경우에도 결과가 나올 수 있도록 부탁드립니다.
1차 거래선택 & 20틱~30틱
2차 거래선택 & 20틱~30틱
3차 거래선택 & 20틱~30틱
****************************************************************
안녕하세요
예스스탁입니다.
문의하신 내용은 내용상 수식에서 가능하지 않은 부분이 있습니다.
하나의 봉에서 고가와 저가의 시간순서를 수식에서 알수 없습니다
봉완성시 시가대비 종가의 위치로 식을 작성한다면 아래와 같이
작성할수는 있습니다.
이용에 참고하시기 바랍니다
input : 틱(7),차수(2);
var : T(0),cnt(0);
if Bdate != Bdate[1] Then{
T = 0;
cnt = 0;
}
if T <= 0 and C >= O+PriceScale*틱 Then{
T = 1;
cnt = cnt+1;
if cnt == 차수 Then
buy();
}
if T >= 0 and C <= O+PriceScale*틱 Then{
T = -1;
cnt = cnt+1;
if cnt == 차수 Then
sell();
}
즐거운 하루되세요
> 목마와숙녀 님이 쓴 글입니다.
> 제목 : 차수 선택
> 선택한 차수만 거래하고 싶습니다.
1.리버스 거래 base
2.거래횟수 1회
3.신호는 고가와 저가 차이 7틱
-저가에서 고가도달이면 buy
-고가에서 저가도달이면 sell
4.차수를 선택하면 해당 차수 1회만 거래
ex)input 거래차수 "2" 입력 시 2번째 거래만 실행
***
1. 첫번째 거래
*7틱 신호
-buy : +7틱(1번째 buy) or
-sell : -7틱(1번째 sell)
2. 두번째 거래
*7틱 신호
-buy : +7틱(2번째 buy) or
-sell : -7틱(2번째 sell)
3. 세번째 거래
*7틱 신호
-buy : +7틱(3번째 buy) or
-sell : -7틱(3번째 sell)
4. 변수입력
-신호 : n틱
-거래차수:n
부탁드립니다.
2018-06-20
180
글번호 119885
답변완료
문의합니다
늘 감사합니다
수식에서 질문드릴것이 있어서요
1.
일반적인 스톡식입니다
이때
바로 직전 SToD=50일때 선물가격과 지금 SToD=50이 클때 매수해라라는 식을 만들고 싶습니다
간단하게는 SToD>SToD[1]이라는 것은 알겠는데 50이라는 정의를 어떻게 집어 넣어야 할지
잘 모르겠습니다
2.
짝을 지어서 매매가 가능한지요
예를 들어 A매수시는 B로 매도
1로 매수시는 2로 매도
이런식으로 둒을수 있는지요
묶을 수 있다면 어떻게 해야하는지 간단한 수식 예를 부탁드립니다
3.
만일 바이너리7으로 매매를 한다면
바이너리가 7을 찍고 계속 7을 찍다가 7미만으로 내려왔다가 -7을 찍지 않고 재차 7을 찍을 때
매수한하면 식을 어떻게 세워야 할까요
수식을 부탁드립니다
4.
Input : Period(0), MultiD(0), Short(0);
var : MAv(0),BBup(0),BBdn(0), stand(0), StoK(0);
MAv = ma(C,Period);
BBup = BollBandUp(Period,MultiD);
BBdn = BollBandDown(Period,MultiD);
StoK = ma(c, Short);
stand = MAv-StoK
Plot1(MAv, "이평");
Plot2(BBup, "상단밴드");
Plot3(BBdn, "하단밴드");
Plot4(stand, "기준");
에서 Plot이 오류가 났다는데 왜 그런지와 수정을 부탁드립니다
5.
매매 시작시
예를들어 바이너리7이 7 또는 -7을 처음 찍을 때는 매매를 하지 않고 그 다음 부터 매매를 시작하려면 어떻게 해야 하나요
너무 질문이 많네요
죄송합니다
바쁘신데 이렇게 부탁드려 죄송합니다
2018-06-20
160
글번호 119883
답변완료
cci 다이버전스 시스템
항상 감사드립니다
아래 식을 이용하여 CCI 다이버전스 시스템을 만들고자 합니다.
#################
### cci 지표 ####
#################
Input : Period1(40),Period2(20);
var : CCIv(0),CCIsig(0);
CCIv = CCI(Period1);
CCIsig = ema(CCIv,Period2);
################################################
### forecast oscillator_40_20(회귀분석예측) ####
################################################
input : Period31(40),signal31(20);
var : LRLv31(0),FO31(0),forecastsig31(0);
LRLv31 = LRL(c,period31);
FO31 = ((c-LRLv31)/c)*100;
forecastsig31 = ema(FO31,Signal31); #signal#
1_1.가장 최근(T1)의 crossup(ccisig,-100) 발생시 S1= 1
크로서업 발생시의 주가를 V1 에 저장
forecastsig31 의 값을 A1 에 저장
1_2.가장 최근(T1) 직전에 발생(T1[1])한 crossup(ccisig,-100) 발생시 S2= 1
크로서업 발생시의 주가를 V2 에 저장
forecastsig31 의 값을 A2 에 저장
현재봉 기준 50개봉이내에서(두번의 크로스업 발생조건 )
S1=1 and S2=1 and V1<V2 and A1>A2 조건이면 매수
2_1.가장 최근(T1)의 crossdown(ccisig,100) 발생시 S1= -1
크로서다운 발생시의 주가를 V1 에 저장
forecastsig31 의 값을 A1 에 저장
2_2.가장 최근(T1) 직전에 발생(T1[1])한 crossdown(ccisig,100) 발생시 S2= -1
크로서업 발생시의 주가를 V2 에 저장
forecastsig31 의 값을 A2 에 저장
현재봉 기준 50개봉이내에서(두번의 크로스다운 발생조건 )
S1= -1 and S2= -1 and V1>V2 and A1<A2 조건이면 매도
감사합니다
2018-06-20
229
글번호 119882
답변완료
부탁드립니다.
1. 매월 일봉 마지막 봉의 고점과 저점을 다음 달 마지막봉까지 계속 수평선으로 구현해 주세요.
그리고 매월 일봉 첫번째봉 고점과 저점도 마찬가지로 다음 달 첫번째봉까지 계속 수평선으로 구현해 주세요
고맙습니다.
2018-06-19
160
글번호 119881
답변완료
피보나치 수식 점검 부탁드립니다.
아래의 수식에서 피보나치 0.618을 하향 이탈한 3거래일 이후부터 음봉종가에 매수 시그널이 발생하지 않습니다.
예를들어서 일봉챠트를 기준으로 3월1일날 피보나치 0.618을 하향 이탈하였고 3월5일까지
반등을 못한다면 3월5일 이후에 발생하는 음봉종가(150000)에는 매수시그널이 발생되도록
만들고 싶습니다. 점검 한번 부탁드립니다.
- 아 래 -
input : n(120);
input : 지정일(20180605);
var : 매수금액(3000000);
var : hh(0),ll(0),rr(0),cnt(0),EL(0),EH(0),dd(0),d1(0);;
if bdate != bdate[1] Then
dd = dd+1;
if DayHigh(n) > 0 and DayLow(n) > 0 and sdate >= 지정일 then{
hh = dayhigh(1);
ll = daylow(1);
for cnt = 1 to n
{
if dayhigh(cnt) > hh Then
hh = DayHigh(cnt);
if daylow(cnt) < ll Then
ll = daylow(cnt);
}
rr = hh-ll;
var1 = hh;
var2 = hh - rr*0.236;
var3 = hh - rr*0.382;
var4 = hh - rr*0.500;
var5 = hh - rr*0.618;
var6 = hh - rr*0.700;
var7 = ll;
if MarketPosition == 0 and (crossup(c,var4)) and ExitDate(1) != sdate Then
Buy("매수0.5",OnClose,def,Floor(매수금액/C));
if MarketPosition == 0 and (crossup(c,var5)) and ExitDate(1) != sdate Then
Buy("매수0.618",OnClose,def,Floor(매수금액/C));
if CurrentContracts > CurrentContracts and MaxEntries == 1 Then
d1 = dd;
if dd >= d1+4 and
C < HH-RR*0.618 and
MaxEntries >= 2 and MaxEntries < 4 and
stime >= 150000 and stime[1] < 150000 and
c < dayopen Then
Buy("추매",OnClose,def,Floor(매수금액/C));
if MarketPosition == 1 Then
{
if CurrentContracts > CurrentContracts[1] Then
{
EH = H;
EL = L;
if H > EH Then
EH = H;
if L < EL Then
EL = L;
}
if MarketPosition == 1 and C > AvgEntryPrice Then
ExitLong("수익",Atlimit,EntryPrice*1.10);
}
}
2018-06-19
205
글번호 119880
답변완료
수식문의요
1.10시부터 10시59분 사이 종가선
2.11시부터 11시59분 사이 종가선
3.10시부터 10시59분 사이 1/2선
3.11시부터 11시59분 사이 1/2선
부탁드립니다
2018-06-19
172
글번호 119879
답변완료
시스탬수정
아래 시스탬에서 빨강 파랑 수평선이 그려지는데
수평선 굵기를 조절이 가능하게 수정부탁드립니다.
Input : af(0.02), maxAF(0.2);
var : T(0),HH(0),LL(0);
var1 = CSar(af,maxAF);
if crossup(c,var1) Then
{
buy();
T = 1;
HH = H;
if LL > 0 Then
{
value1 = TL_new(sdate[1],stime[1],HH,sdate,stime,HH);
TL_SetColor(value1,RED);
value2 = Text_New(sdate,stime,HH,NumToStr((HH-LL)/PriceScale,0));
Text_SetStyle(value2,2,1);
}
}
if CrossDown(c,var1) Then
{
sell();
T = -1;
LL = L;
if HH > 0 Then
{
value3 = TL_new(sdate[1],stime[1],HH,sdate,stime,HH);
TL_SetColor(value3,blue);
value4 = Text_New(sdate,stime,HH,NumToStr((HH-LL)/PriceScale,0));
Text_SetStyle(value4,2,0);
}
}
if T == 1 then
{
if H > HH Then
{
HH = H;
Text_Delete(value2);
value2 = Text_New(sdate,stime,HH,NumToStr(abs(HH-LL)/PriceScale,0));
Text_SetStyle(value2,2,1);
}
TL_SetBegin(value1,TL_GetBeginDate(value1),TL_GetBeginTime(value1),HH);
TL_SetEnd(value1,sdate,stime,HH);
}
if T == -1 then
{
if L < LL Then{
LL = L;
Text_Delete(value4);
value4 = Text_New(sdate,stime,LL,NumToStr(abs(HH-LL)/PriceScale,0));
Text_SetStyle(value4,2,0);
}
TL_SetBegin(value3,TL_GetBeginDate(value3),TL_GetBeginTime(value3),LL);
TL_SetEnd(value3,sdate,stime,LL);
}
2018-06-19
165
글번호 119878
답변완료
부탁드립니다.
도움 주심에 감사 드립니다.
그림1과 같이 나타내고자
//52행 아래의 식을
TL11 = TL_New(HD1,HT1,HH1,HD,HT,HH);에서
TL11 = TL_New(HD1,HT1,HH1+PriceScale,HD,HT,HH+PriceScale);로 고치고
//98행 의 아래의 식을
TL22 = TL_New(LD1,LT1,LL1,LD,LT,LL);를 고치니
TL22 = TL_New(LD1,LT1,LL1-PriceScale,LD,LT,LL-PriceScale);로 고치니
그림2와 같이 되었습니다.
일부 만족한지 못한 부분을 수정 부탁 드립니다.
수식)
input : af(0.02), maxAF(0.2),추세선두께(1),추세선색1(YELLOW),추세선색2(CYAN),연장선두께(2),연장선색(blue);
input : 텍스트출력(0);
var : T(0),HH(0),LL(0),HD(0),HT(0),LD(0),LT(0);
var : HH1(0),LL1(0),HD1(0),HT1(0),LD1(0),LT1(0);
var : TL1(0),TL2(0),cnt(0),count(0);
var : TL3(0),TL4(0),TL5(0),TL6(0),tx1(0),tx2(0),tx11(0),tx22(0);
Var : TL11(0),TL22(0);
var1 = CSar(af,maxAF);
if crossup(c,var1) Then
{
T = 1;
HH = H;
HD = sdate;
HT = stime;
HH1 = HH[1];
HD1 = HD[1];
HT1 = HT[1];
if LL > 0 Then
{
TL1 = TL_new(LD[1],LT[1],LL[1],HD,HT,HH);
TL_Delete(TL3);
TL_Delete(TL4);
TL_Delete(TL5);
TL_Delete(TL6);
#TL3 = TL_new(HD[1],HT[1],HH[1],sdate,stime,HH[1]);
#TL4 = TL_new(HD[1],HT[1],(HH[1]+LL)/2,sdate,stime,(HH[1]+LL)/2);
#TL5 = TL_new(HD[1],HT[1],LL,sdate,stime,LL);
#TL6 = TL_new(HD[1],HT[1],HH[1]+(HH[1]-LL[1])/2,sdate,stime,HH[1]+(HH[1]-LL)/2);
//추세선 오른쪽 연장설정
TL_SetExtRight(TL3,true);
TL_SetExtRight(TL4,true);
TL_SetExtRight(TL5,true);
TL_SetExtRight(TL6,true);
if 텍스트출력 == 1 then
{
Tx11 = Text_New(HD1,HT1,HH1,NumToStr((HH1-LL1)/PriceScale,0)+NewLine+NumToStr(HH1,2));
Text_SetStyle(tx11,2,1);
Text_Delete(tx1);
Tx1 = Text_New(HD,HT,HH,NumToStr((HH-LL[1])/PriceScale,0)+NewLine+NumToStr(HH,2));
Text_SetStyle(tx1,2,1);
}
}
#############################################
#############################################
################################################
#########################################
//52행
// TL11 = TL_New(HD1,HT1,HH1,HD,HT,HH);
TL11 = TL_New(HD1,HT1,HH1+PriceScale,HD,HT,HH+PriceScale);
}
if CrossDown(c,var1) Then
{
T = -1;
LL = L;
LD = sdate;
LT = stime;
LL1 = LL[1];
LD1 = LD[1];
LT1 = LT[1];
if HH > 0 Then
{
TL2 = TL_new(HD[1],HT[1],HH[1],LD,LT,LL);
TL_Delete(TL3);
TL_Delete(TL4);
TL_Delete(TL5);
TL_Delete(TL6);
#TL3 = TL_new(LD[1],LT[1],HH,sdate,stime,HH);
#TL4 = TL_new(LD[1],LT[1],(HH+LL[1])/2,sdate,stime,(HH+LL[1])/2);
#TL5 = TL_new(LD[1],LT[1],LL[1],sdate,stime,LL[1]);
#TL6 = TL_new(LD[1],LT[1],LL[1]-(HH-LL[1])/2,sdate,stime,LL[1]-(HH-LL[1])/2);
//추세선 오른쪽 연장설정
TL_SetExtRight(TL3,true);
TL_SetExtRight(TL4,true);
TL_SetExtRight(TL5,true);
TL_SetExtRight(TL6,true);
if 텍스트출력 == 1 then
{
Tx22 = Text_New(LD1,LT1,LL1,NumToStr((HH1-LL1)/PriceScale,0)+NewLine+NumToStr(LL1,2));
Text_SetStyle(tx22,2,0);
Text_Delete(tx2);
Tx2 = Text_New(LD,LT,LL,NumToStr((HH[1]-LL)/PriceScale,0)+NewLine+NumToStr(LL,2));
Text_SetStyle(tx2,2,0);
}
}
#############################################
#############################################
############################################
############################################
//98행
// TL22 = TL_New(LD1,LT1,LL1,LD,LT,LL);
TL22 = TL_New(LD1,LT1,LL1-PriceScale,LD,LT,LL-PriceScale);
}
if T == 1 then
{
if H > HH Then
{
HH = H;
HD = sdate;
HT = stime;
TL_SetEnd(TL1,HD,HT,HH);
TL_SetEnd(TL11,HD,HT,HH);
if 텍스트출력 == 1 then
{
Text_Delete(tx1);
Tx1 = Text_New(HD,HT,HH,NumToStr((HH-LL[1])/PriceScale,0)+NewLine+NumToStr(HH,2));
Text_SetStyle(tx1,2,1);
}
}
}
if T == -1 then
{
if L < LL Then
{
LL = L;
LD = sdate;
LT = stime;
TL_SetEnd(TL2,LD,LT,LL);
TL_SetEnd(TL22,LD,LT,LL);
if 텍스트출력 == 1 then
{
Text_Delete(tx2);
Tx2 = Text_New(LD,LT,LL,NumToStr((HH[1]-LL)/PriceScale,0)+NewLine+NumToStr(LL,2));
Text_SetStyle(tx2,2,0);
}
}
}
#추세선 두께, 색상
TL_SetSize(TL1,추세선두께);
TL_SetSize(TL11,추세선두께);
TL_SetSize(TL2,추세선두께);
TL_SetSize(TL22,추세선두께);
TL_SetColor(TL1,추세선색1);
TL_SetColor(TL11,추세선색1);
TL_SetColor(TL2,추세선색2);
TL_SetColor(TL22,추세선색2);
#연장선 두께, 색상
TL_SetSize(TL3,연장선두께);
TL_SetSize(TL4,연장선두께);
TL_SetSize(TL5,연장선두께);
TL_SetSize(TL6,연장선두께);
TL_SetColor(TL3,연장선색);
TL_SetColor(TL4,연장선색);
TL_SetColor(TL5,연장선색);
TL_SetColor(TL6,연장선색);
2018-06-20
234
글번호 119877
답변완료
일목균형표
안녕하세요
구름대를 현재가가 완전히 상승 돌파하고 3번째봉에서 매수
만약 3번째 봉나오기전에 구름대 완전돌파안되면 패스
구름대를 현재가가 완전히 하락 돌파하고 3번째봉에서 매도
만약 3번째 봉나오기전에 구름대 완전돌파안되면 패스
감사합니다^^
2018-06-19
213
글번호 119876