커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
1686
글번호 230811
에구머니 님에 의해서 삭제되었습니다.
2021-05-20
2
글번호 149171
답변완료
문의
1.보조data2를 이용한 수식으로 변환바랍니다.
2.보조data2를 이용한 수식으로 변환되었다면, 그 수식에 피라미딩 수식을 추가해주세요.
- 피라미딩은 max 10개까지 허용
- buy 진입시 진입과 동일한 진입조건이 발생할 때 마다 누적합니다.
- sell 진입시 진입과 동일한 진입조건이 발생할 때 마다 누적합니다.
* 별첨파일은 피라미딩의 이해를 돕기 위해 첨부하였습니다.
-아래 수식과 동일한 내용으로 지표를 작성하였습니다.
-진입시점이 지표에서 뾰족한 부분입니다.
-진입(1) 후 뾰족한 부분(2)...(3) 발생하는 때마다 피라미딩을
하는 게 바램입니다.
항상 고맙습니다.
--------------------------------------------------------------------
Input : Period(12), Period1(5), Period2(5),이평(200);
value1 = StochasticsK(Period,Period1);
value2 = StochasticsD(Period,Period1,Period2);
# 매수/매도청산
If CrossUP(value1, value2) and c > ma(c,이평) Then
{
buy();
}
# 매도/매수청산
If CrossDown(value1, value2) and c < ma(c,이평) Then
{
sell();
}
2021-05-20
1960
글번호 149170
답변완료
전일시가,고가,저가,종가
안녕하세요~~매번 고맙습니다
-1분봉에서 전일시가,전일고가,저일저가,전일종가를 표현 할수 있는지요?
-특정날자 특정시간의 (해당일 장시작 후 해당시간까지의 고가 + 해당일 장시작 후 해당시간까지의 저가 /2) 값을 구하고 싶습니다.
2021-05-20
2011
글번호 149169
답변완료
wr(윌리암스알)지표식에서
wr지표식에서
종가를 기준으로 식을 구하는 것이 아닌
-20 상향돌파시에는 고가를 기준으로 지표식을 구하고(종가가 -20을 상향돌파여부와 관계없이)
-80을 하락 추락시에는 저가를 기준으로 지표식을 구하고자합니다.
감사합니다
2021-05-20
2172
글번호 149161
답변완료
수식작성
input : P1(5),P2(20),p3(3),P4(50),P5(120);
input : sto1(12),sto2(26),sto3(5);
Input : trixp(12), sigPeriod(9);
INPUTS: LENGTH(5);
input : short(12),long(26),sig(9);
input : StartTime(133500),EndTime(055000);
Input : 당일수익틱수(1000);
var : Tcond(false),mav3(0),mav4(0),dis(0);
var : mav1(0),mav2(0),stok(0),stod(0);
var : trixv(0),trixs(0),TEMA(0),macdo(0);
Var : N1(0),dayPl(0),당일수익(0),Xcond(false);
if sDate != sDate[1] Then
SetStopEndofday(Endtime);
if (sdate != sdate[1] and stime >= EndTime) or
(sdate == sdate[1] and stime >= EndTime and stime[1] < EndTime) Then
Tcond = False;
if (sdate != sdate[1] and stime >= StartTime) or
(sdate == sdate[1] and stime >= StartTime and stime[1] < StartTime) Then
{
Tcond = true;
SetStopEndofday(0);
Xcond = false;
N1 = NetProfit;
}
당일수익 = PriceScale*당일수익틱수;
daypl = NetProfit-N1;
if TotalTrades > TotalTrades[1] then
{
if daypl >= 당일수익 Then
Xcond = true;
if IsExitName("dbp",1) == true or IsExitName("dsp",1) == true then
Xcond = true;
}
mav1 = ma(C,P1);
mav2 = ma(C,P2);
mav3 = ma(c,p3);
mav4 = ma(c,p4);
dis = Disparity(p5);
stok = StochasticsK(sto1,sto2);
stod = StochasticsD(sto1,sto2,sto3);
trixv = trix(trixp);
trixs = ema(trixv,sigPeriod);
TEMA = (3 * Ema(c,LENGTH)) - (3 * Ema(Ema(c,LENGTH),LENGTH)) +
(Ema(Ema(Ema(c,LENGTH),LENGTH),LENGTH));
macdo = macd_osc(short,long,sig);
var1 = 0;
var2 = 0;
if stok > stod Then
var1 = var1+1;
if trixv > trixs Then
var1 = var1+1;
if c > tema Then
var1 = var1+1;
if macdo > 0 Then
var1 = var1+1;
if stok < stod Then
var2 = var2+1;
if trixv < trixs Then
var2 = var2+1;
if c < tema Then
var2 = var2+1;
if macdo < 0 Then
var2 = var2+1;
if Tcond == true and Xcond == False Then
{
if crossup(mav1,mav2) and var1 >= 3 Then
{
if C < mav4 and dis < 100 Then
Sell();
Else
buy();
}
if CrossDown(mav1,mav2) and var2 >= 3 Then
{
if C > mav4 and dis > 100 Then
Buy();
Else
sell();
}
}
if MarketPosition == 1 then
{
ExitLong("dbp",atlimit,EntryPrice+((당일수익-daypl)/CurrentContracts));
if CrossDown(mav3,mav4) Then
ExitLong();
}
if MarketPosition == -1 then
{
ExitShort("dsp",atlimit,EntryPrice-((당일수익-daypl)/CurrentContracts));
if CrossUp(mav3,mav4) Then
ExitShort();
}
===================
buy 50선 아래 , sell 50선위 청산시 반대포지션 진입신호의 수식어 부탁드립니다
2021-05-20
1953
글번호 149151
답변완료
틱차트에서 주봉상 이평선
주봉상 5일, 10일, 20일, 60일, 120일 이동평균, 일목균형표 전환선, 일목균형표 기준선을
틱차트에서 선이 자동으로 그어지는 수식좀 부탁드리겠습니다.
2021-05-20
1794
글번호 149150
답변완료
문의드립니다
청산 전략에 관해 발췌한 내용인데 의도가 제대로 전달이 안된것 같아 다시 질문 드립니다.
1. "이 청산 전략의 첫번째 단계는 최고가 일을 확인하는 것이다. 물론 새로운 고점이 만들어지면 최고가일은 변하게 된다.............."
>>>이 전략은 일봉 기준입니다. 롱 진입 이후 최고가를 찍는 날을 말하는 것 같습니다.
'최고가일'이 만들어졌다는것이 조건 1번. 롱 진입당일은 당연히 '최고가일'이어야 맞을거 같습니다.
2. "셋업일은 종가가 최고가일의 저가 아래로 떨어질때를 말한다............."
>>>'최고가일'이 만들어진 후로 일봉종가가 '최고가일'의 저가 아래에서 형성되었을때
'셋업일'이 형성되며 조건2번이 만들어집니다.
3. 그리고 나서 셋업일의 저가가 침범당했을때를 트리거 데이라고 하며 이 때 청산을 해야한다........."
>>>조건 1번 2번이 다 충족된경우 즉 '셋업일'이 만들어진 다음날 후로는 셋업일의 저가에서 청산해야한다
최고가일 셋업일 다 일봉기준입니다.
질문에 답해주셔서 언제나 감사드립니다.
2021-05-19
1736
글번호 149149
답변완료
주문을 수행할 때,,,
기본 진입을 매수,매도로만 만들면, 리버설 시스템이 되잖아요,,,
여기에 청산식을 추가해서 청산한 후에
같은 방향의 재진입 조건이 되더라도 진입를 안하도록 해서,
원래의 리버설 시스템에서 발생했던 거래횟수가 변하지 않게 하고 싶습니다.
그렇게 하려면, 매수후 매수청산후에는 매도신호가 나오기 전에는,
매수신호는 다시 안나오게 하면 될 것 같은데,
어떻게 해야 하는지 잘 모르겠어요..
당연히 매도신호도 마찬가지로 매도 후에 매도청산이 된 후에는 ,
매도신호는 나오지 말고, 매수 신호만 나오게 하면 될 것 같은데요,,
알려주시면 감사하겠습니다..
~~
2021-05-19
1558
글번호 149148
답변완료
수정 부탁드립니다!
안녕하세요!
지난번에 만들어주신 수식을 일부 수정하고 싶어서 이렇게 이해를 돕고자 첨부자료를 올립니다!
수정을 부탁드립니다!
감사합니다!
Input:length(6),종가사용여부(0),파동선두께(1),수치표시(1);
Var:j(0),jj(0),HH(0),LL(0),최종고가(0),최종저가(0),최종꼭지점(""),처리구분(""),
TL1(0),Text1(0),tl2(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
{
최종고가 = 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));
Text_SetStyle(Text1, 2, 1);
Text_SetColor(Text1,BLACK);
}
TL_SetSize(TL1,파동선두께);
TL_SetColor(TL1,GREEN);
}
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]);
TL_SetEnd(TL2,고[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));
}
}
최종꼭지점 = "고점";
}
#==========================================#
If 처리구분 == "저점처리" Then
{
최종저가 = LL;
If 최종꼭지점 == "고점" then
{
For j = 10 DownTo 2A
{
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));
Text_SetStyle(Text1, 2, 0);
Text_SetColor(Text1,BLACK);
}
TL_SetSize(TL1,파동선두께);
TL_SetColor(TL1,GREEN);
}
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]);
TL_SetEnd(TL2,저[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));
}
}
최종꼭지점 = "저점";
}
#===============피보나치 되돌림=======================#
Array: fr[31,4](0); // 1:비율, 2:값, 3:라인번호, 4:텍스트번호 <= 2차원 배열입니다.
If Index == 0 Then // 첫번째 칼럼에는 피보나치 비율을
{
fr[1,1] = 0;
fr[2,1] = 0.236;
fr[3,1] = 0.382;
fr[4,1] = 0.50;
fr[5,1] = 0.618;
fr[6,1] = 0.764;
fr[7,1] = 1;
fr[8,1] = 1.236;
fr[9,1] = 1.382;
fr[10,1] = 1.50;
fr[11,1] = 1.618;
fr[12,1] = 2;
fr[13,1] = 2.236;
fr[14,1] = 2.382;
fr[15,1] = 2.50;
fr[16,1] = 2.618;
fr[17,1] = 3;
fr[18,1] = 3.236;
fr[19,1] = 3.382;
fr[20,1] = 3.50;
fr[21,1] = 3.618;
fr[22,1] = 4;
fr[23,1] = 4.236;
fr[24,1] = 4.382;
fr[25,1] = 4.50;
fr[26,1] = 4.618;
fr[27,1] = 5.382;
fr[28,1] = 5.618;
fr[29,1] = 6.382;
fr[30,1] = 6.618;
fr[31,1] = 6.845;
}
If 최종꼭지점[1] == "고점" and 최종꼭지점 == "저점" Then // 추세가 바뀔 때 피보나치 라인을 계산
{
for j = 1 to 31
{
If fr[j,3] > 0 Then TL_Delete(fr[j,3]); // 기존의 라인은 지우고
fr[j,2] = 고[1,1] - ((고[1,1] - 저[2,1]) * fr[j,1]); // 피보나치 비율을 곱해서 계산
fr[j,3] = TL_New(고[1,3],고[1,4],fr[j,2],sDate,sTime,fr[j,2]); // 라인을 생성
TL_SetExtRight(fr[j,3],true);
TL_SetColor(fr[j,3],blue);
}
}
Else If 최종꼭지점[1] == "저점" and 최종꼭지점 == "고점" Then
{
for j = 1 to 31
{
If fr[j,3] > 0 Then TL_Delete(fr[j,3]);
fr[j,2] = 저[1,1] + ((고[2,1] - 저[1,1]) * fr[j,1]);
fr[j,3] = TL_New(저[1,3],저[1,4],fr[j,2],sDate,sTime,fr[j,2]);
TL_SetExtRight(fr[j,3],true);
TL_SetColor(fr[j,3],BLUE);
}
}
Else // 추세변동이 없으면 기존 피보나치 라인을 연장한다.
{
for j = 1 to 31
{
TL_SetEnd(fr[j,3],sDate,sTime,fr[j,2]);
}
}
for j = 1 to 31 {
If 수치표시 == 1 Then
{
If fr[j,4] > 0 Then Text_Delete(fr[j,4]);
fr[j,4] = Text_New(고[1,3],고[1,4],fr[j,2],"(" + NumToStr(fr[j,1]*100,1) + "%) " + NumToStr(fr[j,2],2));
Text_SetStyle(fr[j,4], 0, 1);
Text_SetColor(fr[j,4], BLUE);
Text_SetLocation(fr[j,4], sdate, stime, fr[j,2]);
}
If 수치표시 == 1 Then
{
If fr[j,4] > 0 Then Text_Delete(fr[j,4]);
fr[j,4] = Text_New(저[1,3],저[1,4],fr[j,2],"(" + NumToStr(fr[j,1]*100,1) + "%) " + NumToStr(fr[j,2],2));
Text_SetStyle(fr[j,4], 0, 1);
Text_SetColor(fr[j,4], BLUE);
Text_SetLocation(fr[j,4], sdate, stime, fr[j,2]);
}
}
2021-05-20
1463
글번호 149147