커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
1551
글번호 230811
답변완료
수식 문의드립니다
안녕하세요. 분할청산 관련해서 문의드립니다.
다음과 같은 식으로 4분할 청산을 하고 있습니다.
분할청산이 잘 되긴 하는데(PN풍년),
매수 후 익일에 청산이 나오면 분할매도가 안됩니다.(NICE)
어떻게 수정하면 되는지 문의드립니다.
감사합니다.
if MarketPosition == 1 Then {
if MaxEntries == 1 Then
{
ExitLong("ex1-1",AtLimit,AvgEntryPrice*1.1,"",floor(MaxContracts/4),1);
ExitLong("ex1-2",AtLimit,AvgEntryPrice*1.12,"",floor(MaxContracts/4),1);
ExitLong("ex1-3",AtLimit,AvgEntryPrice*1.14,"",floor(MaxContracts/4),1);
if H>=AvgEntryPrice*1.1 Then {ExitLong("당일청산1");}
}
}
2023-03-15
686
글번호 167167
고박사122 님에 의해서 삭제되었습니다.
2023-03-15
9
글번호 167166
답변완료
시스템 작성의뢰
수고하십니다 !
1, 이평선이 정배열 되고 960 이평선과 1920 이평선의 간격이 13 틱이상 벌어지고 pvi지표가 100.90 이상 상승 하고
on balance price 지표가 40.30 이상상승 하고 obv지표가 670 이상 상승 하고 120 이평선이
240 이평선을 다운 크로스 할때 매도를 하고 960 이평선이 7680 이평선을 다운크로스 하고 240 이평선이 480 이평선을 업크로스 할때
청산을 한다
2, 이평선이 역배열 되고 960 이평선과 1920 이평선의 간격이 13 틱이상 벌어지고 pvi지표가 99.90 이상 하락 하고 on
balance price 지표가 -24,10 이상 하락 하고 obv지표가 -160.50 이상 하락 하고 120 이평선이 240 이평선을 업
크로스 할때 매수를 하고 960 이평선이 7680 이평선을 업크로스 하고 240 이평선이 480 이평선을 다운 크로스 할때 청산을 한다
2023-03-14
1159
글번호 167165
답변완료
지표 수식변환부탁드립니다
Re : 지표 수식변환부탁드립니다
아래지표 코멘트드립니다
예스트레이더 수식으로 전환 부탁드립니다
Avgif(C-A,-1,0.0) // (종가 - 224일지수이평) 값이 0보다 작은값들에 대해서만 평균을구한다
Stdevif(C-A,-1,0.0) // (종가 - 224일지수이평) 값이 0보다 작은값들에 대해서만 표준편차 구한다
기간은 moving 224일동안의 해당되는 평균,표준편차를 구하는것으로 하면 되겠읍니다
> seayun1 님이 쓴 글입니다.
> 제목 : 지표 수식변환부탁드립니다
> 영웅문 수식 변환 부탁드립니다
A=MA(C,가격1,지수);
A+Avgif(C-A,-1,0.0)-2*Stdevif(C-A,-1,0.0)
2023-03-14
1405
글번호 167164
답변완료
수식 문의드립니다
input : Periods(10),Multiplier(3.0),changeATR(true),showsignals(true),highlighting(true);
input : short(12),long(26);
var : src(0),ATr2(0),ATrv(0),upv(0),up1(0),dnv(0),dn1(0);
var : trend(0),macdv(0);
src = (h+l)/2;
atr2 = ma(TrueRange, Periods);
atrv = iff(changeATR , atr(Periods) , atr2);
upv = src-(Multiplier*atrv);
up1 = iff(IsNaN(upv[1]) == False,upv[1],upv);
upv = iff(close[1] > up1 , max(upv,up1) , upv);
dnv =src+(Multiplier*atrv);
dn1 = iff(isnan(dnv[1]) == False,dnv[1], dnv);
dnv = iff(close[1] < dn1 , min(dnv, dn1) , dnv);
trend = 1;
trend = iff(IsNaN(trend[1]) == False,trend[1], trend);
trend = iff(trend == -1 and close > dn1 , 1 , IFf( trend == 1 and close < up1 , -1 , trend));
macdv = macd(short,long);
if trend == 1 and trend[1] == -1 and macdv > 0 Then
{
Buy();
}
if trend == -1 and trend[1] == 1 and macdv < 0 Then
{
exitlong();
}
논라값(참/거짓)이나 논리표현식이 와야 한다고 나옵니다ㅜㅜ
어디가 잘못된것일까요?
2023-03-14
783
글번호 167163
답변완료
표시 삭제
input : Period(120);
Var:j(0),T(0),count(0),l1(0),l2(0),l3(0);
Var: date11(0),date12(0),time11(0),time12(0),
date21(0),date22(0),time21(0),time22(0),txx(0),
date31(0),date32(0),time31(0),time32(0),tx(0),tx1(0);
Array:HiVal[20](0),LoVal[20](0),HiBar[20](0),LoBar[20](0);
Plot1(value12);
For j = 0 To 19
{
HiBar[j] = HiBar[j] + 1;
LoBar[j] = LoBar[j] + 1;
}
if crossup(c,highest(H,Period)[1]) Then
T = 1;
if CrossDown(c,Lowest(L,Period)[1]) Then
T = -1;
If T == -1 Then
{
If T[1] != -1 Then
{
For j = 18 DownTo 0
{
LoVal[j+1] = LoVal[j];
LoBar[j+1] = LoBar[j];
}
LoVal[0] = L;
LoBar[0] = 0;
date11 = date[HiBar[0]];
time11 = stime[HiBar[0]];
Value11 = HiVal[0];
date12 = date[LoBar[0]];
time12 = stime[LoBar[0]];
Value12 = LoVal[0];
date21 = date[HiBar[0]];
time21 = stime[HiBar[0]];
date22 = date[0];
time22 = stime[0];
Condition1 = False;
Condition11 = False;
count = 0;
}
Else
{
If LoVal[0] >= L Then
{
LoVal[0] = L;
LoBar[0] = 0;
date12 = date[LoBar[0]];
time12 = stime[LoBar[0]];
Value12 = LoVal[0];
date22 = date[0];
time22 = stime[0];
if Condition11 == true and value12 < l2-PriceScale*5 Then
Text_Delete(txx);
Condition1 = False;
}
Else
{
if Condition1 == False and Value12 <= value11-0.5 and H >= value12+PriceScale*3 Then
{
Condition1 = true;
count = count+1;
l1 = value12;
l2 = l1[1];
l3 = l2[1];
if count >= 2 and l1 >= l2-PriceScale*5 Then
{
Condition11 = true;
txx = Text_New(sdate,sTime,H+PriceScale*5,"●");
Text_SetStyle(txx,2,2);
Text_SetColor(txx,Red);
Text_SetSize(txx,25);
}
}
if Condition11 == true and value12 < l2-PriceScale*5 Then
{
Condition11 = False;
Text_Delete(txx);
}
}
}
}
If T == 1 Then
{
If T[1] != 1 Then
{
Text_Delete(txx);
For j = 18 DownTo 0
{
HiVal[j+1] = HiVal[j];
HiBar[j+1] = HiBar[j];
}
HiVal[0] = H;
HiBar[0] = 0;
date11 = date[LoBar[0]];
time11 = stime[LoBar[0]];
Value11 = LoVal[0];
date12 = date[HiBar[0]];
time12 = stime[HiBar[0]];
Value12 = HiVal[0];
date31 = date[LoBar[0]];
time31 = stime[LoBar[0]];
date32 = date[0];
time32 = stime[0];
}
If HiVal[0] < H Then
{
HiVal[0] = H;
HiBar[0] = 0;
date12 = date[HiBar[0]];
time12 = stime[HiBar[0]];
Value12 = HiVal[0];
date32 = date[0];
time32 = stime[0];
}
}
양전환되거나 첫 반등 저점에서 -6틱 도달시, 동그라미 삭제 부분에서,
동그라미가 하나일 때는 잘 되는데, 반등 많은 횡보 구간에서 동그라미가 여러개 생길 경우 마지막 동그라미만 삭제가 되고 이전 것은 저장이 됩니다. 전부 삭제하고 싶습니다.
1방안:다음 동그라미 생기면 동시에 앞 동그라미 삭제.(항상 하나만 존재) (1방안 우선)
2방안:삭제 조건이 되면 일괄 삭제. 등 등. 수정 부탁드립니다.
2023-03-14
926
글번호 167162
고박사122 님에 의해서 삭제되었습니다.
2023-03-14
10
글번호 167161
답변완료
시스템식 부탁드립니다.
항상 도움 주셔서 감사합니다.
1.
아래 두 함수를 특정 조건이 만족했을 경우만 사용하고 싶습니다.
제가 알기로는 아래 함수는 조건문을 사용해서
제어가 안되는 것으로 알고 있는데 맞게 알고 있는지 모르겠습니다.
가령 예를 들면
if 함수를 써서 조건이 만족했을때문 작용하도록 하고 싶습니다.
if marketposition == 0 and crossup(C,dayopen) then
buy("b) ;
if marketposition == 1 and maxentry >= 5 then
SetStopLoss(PriceScale*100,PointStop);
SetStopProfittarget(PriceScale*100,PointStop);
else
exitlong("bx",avgentryprice+PriceScale*100,1) ;
exitshort("sx",avgentryprice-PriceScale*100,1) ;
위와 같이 코딩해봤는데 잘 안됩니다.
제가 놓치고 있는게 있나요?
도움 부탁드립니다.
2. 매수 진입 후 가격이 하락하여 피라미딩으로 추가 계약 진입시
마지막 진입과 이전 진입과의 합이 10틱이상 수익시 2계약만 청산하고 싶습니다.
가령 매수 진입 이후 가격이 계속 하락하여 1계약씩 추가로 진입하여
총 10번 진입해서 총 계약수가 10계약이 있을 경우
가격이 다시 상승하는 경우 마지막 진입포지션 손익과 이전 진입포지션
수익의 합이 플러스 10틱인 경우 10번째랑 9번째 포지션만 청산하고 싶습니다.
그리고 가격이 계속 상승하는 경우 8번째랑 7번번째 포지션 수익의 합이 다시
10틱이 되었을 경우 8번째랑 7번째 포지션만 청산하고 싶습니다.
그러다가 가격이 다시 하락하면 또 10틱 단위로 추가 매수하다가
가격이 재차 상승하는 경우 마지막 진입과 그 이전 진입의 포지션 수익의
합이 10틱이 되면 최근 진입한 2계약만 청산하고 싶습니다.
위 조건에 맞는 시스템식 부탁드립니다.
감사합니다.
2023-03-14
1143
글번호 167150
답변완료
잔고함수 예수금
안녕하세요.
GetUnclearedDeposits(AccoundNum) 함수는 주식계좌의 (대용+현금)에서 현금값만 알려주나요?
선물계좌에서는 (대용+현금)한 값을 알려주는거 같은데.. 확인부탁드립니다~
2023-03-14
832
글번호 167148