커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
5488
글번호 230811
답변완료
디마크고가를 이동평균할수있게 도와 주세요 .
새해에도 고생하시는 운영자님들 항상 복 받으시고 건강하세요.
아이디와 계좌를 약 10년전에 만들어 두고 수식에 어려움이 너무 많아서
여태 사용하지 않았던 사용자 입니다.
다름이 아니라 디마크고가의 일주기 이평값을 분봉에 사용하기 위해서 입니다 .
게시판에서 일봉의 지수이평을 분봉에 사용하는것과 결합해 보려고 하니
실력이 모자라 도저히 안돼네요.
아래수식에서 디마크고가의 일봉값을 지수이동 평균한것과
dema이동평균한것을 분봉에 불러 와서 검색하기 위함입니다.
수식에 능통한 분들의 도움을 구하고자 합니다 .
디마크고가의 지수200 이평과 , 디마크고가의 데마40 이평을 분봉에 사용하기 위함입니다.
~~~~~ 아래 수식 ~~~~~~~~~~~~~
Input : Period(200);
Var :dh(0),dh200(0),Ep(0), JISU(0), DINDEX(0), PreJISU(0);
Ep = 2/(Period+1);
if bdate != bdate[1] then{
DINDEX = DINDEX + 1;
PreJISU = JISU[1];
}
if DINDEX <= 1 then
JISU = C;
else
JISU = C * EP + PreJISU * (1-EP);
If DayClose(1) > DayOpen(1) Then
{
value1 = (DayHigh(1)+DayLow(1)+DayClose(1)+DayHigh(1))/2-DayLow(1);
value2 = (DayHigh(1)+DayLow(1)+DayClose(1)+DayHigh(1))/2-DayHigh(1);
}
Else If DayClose(1) < DayOpen(1) Then
{
value1 = (DayHigh(1)+DayLow(1)+DayClose(1)+DayLow(1))/2-DayLow(1);
value2 = (DayHigh(1)+DayLow(1)+DayClose(1)+DayLow(1))/2-DayHigh(1);
}
Else
{
value1 = (DayHigh(1)+DayLow(1)+DayClose(1)+DayClose(1))/2-DayLow(1);
value2 = (DayHigh(1)+DayLow(1)+DayClose(1)+DayClose(1))/2-DayHigh(1);
}
dh=value1;
dh200= JISU(dh,period);
위와 같이 하면 "함수만이 입력값을 가질수 있읍니다"
라고 나옵니다 .
데마이평은 ema(ema(dh,40),40)
으로 사용해도 됩니다 . 감사합니다 .
2020-01-03
474
글번호 134886
답변완료
참조챠트의 가격
거래하려는 챠트의 가격은 C인데
참조챠트의 가격은 무엇인가요?
2020-01-03
341
글번호 134885
답변완료
질문 올립니다.
안녕하세요. 늘 감사드립니다.
진입 횟수를 줄이는 의미도 있을 거 같아서,
청산봉에서는 새로 진입하지 않고,
최소한 청산봉 다음 봉에서부터라야 진입이 가능하게 하려면 어떻게 해야 하는지요?
감사합니다.
2020-01-03
332
글번호 134884
답변완료
구현 가능한지 궁금합니다.
예를 들면,
삼성전자 하이닉스 lg 전자의 data 평균값을 1초 단위로 구해서,
1초틱 data 1000개의 평균값을 구합니다.
이 값을
함수(if 구분) 에 대입해서 최종값을 산출하여
0. 평균값을 차트에 뿌리는게 가능한지..
1. 함수값을 차트에 뿌리는게 가능한지..
2. 0,1 두개를 매매조건으로 사용 가능한지..
일단 간단하게 질문 올리긴했는데요, 이게 구현 가능한지 답변 부탁드립니다.
감사합니다.
2020-01-03
425
글번호 134882
답변완료
수식부탁입니다
#65486 도움부탁드립니다.
2020-01-03
354
글번호 134881
답변완료
분봉데이터 엑셀로 받는법
종목의 원하는 날짜~날짜까지 날짜,시,고,저,종,거래량 같은 기본적인 데이터를 엑셀로 복사하고싶은데 어떻게 해야하나요?
2020-01-03
412
글번호 134877
상중하 님에 의해서 삭제되었습니다.
2020-01-03
0
글번호 134875
답변완료
부탁드립니다
수고하십니다
아래 수식에서 2선으로 plot1,plot2 청섹선과 적색선 두선으로 부탁드립니다
Input : shortPeriod(10), longPeriod(20);
var : PriceOsc(0),Direction(0);
PriceOsc = OSCP(shortPeriod, longPeriod);
if PriceOsc > PriceOsc[1] Then
Direction = 1;
if PriceOsc < PriceOsc[1] Then
Direction = -1;
if Direction == 1 and Direction != Direction[1] Then
var1 = PriceOsc[1];
if Direction == -1 and Direction != Direction[1] Then
var1 = PriceOsc[1];
plot1(var1,"선",iff(Direction==1,BLUE,RED));
2020-01-03
342
글번호 134872
답변완료
부탁드립니다.
아래수식을 65467번의 수식추가 부탁드립니다.
아래1번수식의 이부분을
Value1 = HiLoLineZigZag(length,종가사용여부,고,저,TL_NewBit);
2번수식에서 사용할수 있게 변환 부탁드립니다.
번거롭게 해서 죄송합니다.
한번더 부탁드립니다.
----------------------------------------------
1. (65467번의 수식)
Input:length(20),익청(20),손절(20);
Var:종가사용여부(0),TL_NewBit(0);
Array:고[10,4](0),저[10,4](0);
Value1 = HiLoLineZigZag(length,종가사용여부,고,저,TL_NewBit);
if value1 == 1 and value1 != value1[1] Then
{
Condition1 = true;
Condition2 = true;
}
if value1 == -1 and value1 != value1[1] Then
{
Condition3 = true;
Condition4 = true;
}
If MarketPosition <= 0 and value1 == 1 and Condition1 == true Then
Buy("B1",AtStop,고[2,1]);
If MarketPosition <= 0 and value1 == -1 and Condition4 == true Then
Buy("B2",AtStop,고[1,1]);
if MarketPosition == 1 Then
{
ExitLong("Bp",AtLimit,EntryPrice+PriceScale*익청,"",1,1);
}
If MarketPosition >= 0 and value1 == -1 and Condition3 == true Then
Sell("S1",AtStop,저[2,1]);
If MarketPosition >= 0 and value1 == 1 and Condition2 == true Then
Sell("S2",AtStop,저[1,1]);
if MarketPosition == -1 Then
{
ExitShort("Sp",AtLimit,EntryPrice-PriceScale*익청,"",1,1);
}
SetStoploss(PriceScale*손절,PointStop);
if MarketPosition == 1 Then
{
Condition1 = false;
Condition4 = false;
}
if MarketPosition == -1 Then
{
Condition2 = false;
Condition3 = false;
}
---------------------------------------------------------
2.
Input: length(20);
Var : j(0),jj(0),T(0);
var : 최종고가(0),최종저가(0),최종꼭지점(""),처리구분(""),TL1(0);
Array:HH[10,4](0),LL[10,4](0); // 1:가격,2:Index,3:sDate,4:sTime
If Index == 0 Then
{
HH[1,1] = H;
LL[1,1] = L;
}
Condition1 = Highest(H,length) == H and 최종고가 <> H;
Condition2 = Lowest (L,length) == L and 최종저가 <> L;
처리구분 = "";
If Condition1 and Condition2 Then // 기간고점과 기간저점 동시 발생
{
If 최종꼭지점 == "저점" Then
{
If LL[1,1] > L Then 처리구분 = "저점처리";
Else 처리구분 = "고점처리";
}
Else If 최종꼭지점 == "고점" Then
{
If HH[1,1] < H Then 처리구분 = "고점처리";
Else 처리구분 = "저점처리";
}
}
Else If Condition1 Then 처리구분 = "고점처리";
Else If Condition2 Then 처리구분 = "저점처리";
#==========================================#
If 처리구분 == "고점처리" Then
{
T = 1;
최종고가 = H; // 신규고점을 체크하기 위해 저장
If 최종꼭지점 == "저점" Then
{
For j = 10 DownTo 2
{
For jj = 1 To 4
{
HH[j,jj] = HH[j-1,jj];
}
}
HH[1,1] = H;
HH[1,2] = Index;
HH[1,3] = sDate;
HH[1,4] = sTime;
TL1 = TL_New(LL[1,3],LL[1,4],LL[1,1],HH[1,3],HH[1,4],HH[1,1]);
TL_SetSize(TL1,1);
TL_SetColor(TL1,RED);
}
Else If HH[1,1] < H Then // 1번 고점보다 높은 고가 출현
{
HH[1,1] = H;
HH[1,2] = Index;
HH[1,3] = sDate;
HH[1,4] = sTime;
TL_SetEnd(TL1,HH[1,3],HH[1,4],HH[1,1]);
// 시작점은 변동없고 끝점의 위치가 현재 봉으로 연장된 것임
}
최종꼭지점 = "고점";
}
#==========================================#
If 처리구분 == "저점처리" Then
{
T = -1;
최종저가 = L;
If 최종꼭지점 == "고점" then
{
For j = 10 DownTo 2
{
For jj = 1 To 4
{
LL[j,jj] = LL[j-1,jj];
}
}
LL[1,1] = L;
LL[1,2] = Index;
LL[1,3] = sDate;
LL[1,4] = sTime;
TL1 = TL_New(HH[1,3],HH[1,4],HH[1,1],LL[1,3],LL[1,4],LL[1,1]);
TL_SetSize(TL1,1);
TL_SetColor(TL1,BLUE);
}
Else If LL[1,1] > L then
{
LL[1,1] = L;
LL[1,2] = Index;
LL[1,3] = sDate;
LL[1,4] = sTime;
TL_SetEnd(TL1,LL[1,3],LL[1,4],LL[1,1]);
}
최종꼭지점 = "저점";
}
-----------------------------------------------------------------------------
2020-01-03
338
글번호 134868