커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
1804
글번호 230811
답변완료
재문의드립니다
69862번 1번항재문의 드립니다 현재파동고점과저점에 수치가 나오는데 제가원하는것이 아닙니다~~상승추세선 시작점수치와 끈나는 부분수치값이 나오게
하락추세선 시작점수치와 끈나는 부분수치값이 나오게현재가처럼마지막값이나오게 다시한번수정부탁드립니다~~`
2020-11-11
647
글번호 143805
답변완료
문의
buy식은 아래처럼 하면 되는지요?
var : sum(0,Data2),do(0,Data2),dh(0,Data2),dh1(0,Data2);
sum = Data2(c)+data3(c);
if data2(bdate != Bdate[1]) Then
{
do = sum;
dh = sum;
dh1 = dh[1];
}
if sum > dh Then
dh = sum;
if stime >= 100000 and sum <= do+2.00 and sum >= do+1.00 then
buy("b1");
if stime >= 100000 and sum <= dh1+2.00 and sum >= dh1+1.00 then
buy("b2");
***********************************************************************************
안녕하세요
예스스탁입니다.
var : sum(0,Data2),do(0,Data2),dl(0,Data2),dl1(0,Data2);
sum = Data2(c)+data3(c);
if data2(bdate != Bdate[1]) Then
{
do = sum;
dl = sum;
dl1 = dl[1];
}
if sum < dl Then
dl = sum;
if stime >= 100000 and sum <= do-1.00 and sum >= do-2.00 then
sell("s1");
if stime >= 100000 and sum <= dl1-1.00 and sum >= dl1-2.00 then
sell("s2");
즐거운 하루되세요
> 목마와숙녀 님이 쓴 글입니다.
> 제목 : 문의
> data1 선물
data2 콜연결atm0
data3 풋연결atm0
양합(data2+data3)
생성된 양합으로 진입합니다.
데이트레이딩
1)
if stime >= 100000 and 금일 양합 open - 금일 양합(1.00 ~ 2.00) then
sell();
10시 부터
금일 양합이 090000기준 양합 시가 - (1.00 ~ 2.00)이면 sell
2)
if stime >= 100000 and 전일 양합 저점 - 금일 양합(1.00 ~ 2.00) then
sell();
10시 부터
금일 양합이 전일 양합 저점 - (1.00 ~ 2.00) 이면 sell
수식 부탁드립니다.
2020-11-11
555
글번호 143801
새론시작 님에 의해서 삭제되었습니다.
2020-11-11
11
글번호 143799
답변완료
아래 수식의 잘못 표기된곳은요?
Input : Period(1);
var1 = Plot1(ma((h+l)/2,Period), "이동평균");
if var1 > var1[1] Then
Plot1(var1,"지표",red);
Else
Plot1(var1,"지표",blue);
2020-11-11
355
글번호 143798
답변완료
수식의뢰드립니다.
업무에 노고가 많으십니다.
과거 20일부터 그 이전 과거10일까지의 고가중 최고가를 구하고 싶습니다.(일봉기준)
ex) 오늘이 11월 11일/10월 10일 ~ 10월 20일의 고가 중 최고가
현재부터 과거 10일까지의 고가를 구하는 수식은 highest(H, 10)으로 가능한걸로 알고 있는데 위의 수식은 어떻게 되는지 궁금합니다.
2020-11-11
434
글번호 143797
답변완료
수식의뢰 드립니다!
안녕하세요!
일목의 파동 목표가를 구하는 수식을 만들어 보다가 너무 어려워 도움을 부탁드립니다!
이해를 돕고져 첨부해 드리는 이미지와 수식을 기준으로 목표가를 나타내고 싶습니다.
(조건)
A = 이전 파동 최고점
B = 이전 파동 최저점
C = 현재 파동 최고점
D = 현재 파동 최고점 이후 눌림이 최저점
(산출식)
E = 2*C-B
V = 2*C-D
N = C-B+D
NT = 2*D-B
VT = 2*A-B
--------------------------------
위의 산출식이 안되면 아래식으로도 해주셔도 됩니다
A = 파동전 최저점(파동의 시작점)
B = 파동후 최고점
C = B이후의 눌림 목 최저점
V = 2B - C
N = C+B-A
E = 2B-A
NT = 2C-A
부탁드려요!
----------------------------------------
항상 노고에 감사드립니다!
input:length(4),종가사용여부(0),파동선두께(1),수치표시(1);
Var:j(0),jj(0),HH(0),LL(0),최종고가(0),최종저가(0),최종꼭지점(""),처리구분(""),
TL1(0),Text1(0),tl2(0),tl3(0),tl4(0),tl5(0),T(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
{
T = 1;
최종고가 = 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, 0);
Text_SetColor(Text1,BLACK);
}
TL_SetSize(TL1,파동선두께);
TL_SetColor(TL1,yellow);
}
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]);
// 시작점은 변동없고 끝점의 위치가 현재 봉으로 연장된 것임
If 수치표시 == 1 Then
{
Text_SetLocation(Text1,고[1,3],고[1,4],고[1,1]);
Text_SetString(Text1,NumToStr(고[1,1],2));
}
}
최종꼭지점 = "고점";
}
#==========================================#
If 처리구분 == "저점처리" Then
{
T = -1;
최종저가 = LL;
If 최종꼭지점 == "고점" then
{
For j = 10 DownTo 2
{
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, 1);
Text_SetColor(Text1,BLACK);
}
TL_SetSize(TL1,파동선두께);
TL_SetColor(TL1,blue);
}
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]);
If 수치표시 == 1 Then
{
Text_SetLocation(Text1,저[1,3],저[1,4],저[1,1]);
Text_SetString(Text1,NumToStr(저[1,1],2));
}
}
최종꼭지점 = "저점";
}
if T == -1 and T[1] != -1 Then{
TL2 = TL_New(고[2,3],고[2,4],고[2,1],sdate,stime,고[2,1]);
TL_Delete(TL3);
TL3 = TL_New(고[1,3],고[1,4],고[1,1],sdate,stime,고[1,1]);
TL_SetExtRight(TL3,true);
TL_SetSize(TL2,파동선두께);
TL_SetColor(TL2,rgb(126,126,126));
TL_SetSize(TL3,파동선두께);
TL_SetColor(TL3,rgb(126,126,126));
}
if T == 1 and T[1] != 1 Then{
TL4= TL_New(저[2,3],저[2,4],저[2,1],sdate,stime,저[2,1]);
TL_Delete(TL5);
TL5= TL_New(저[1,3],저[1,4],저[1,1],sdate,stime,저[1,1]);
TL_SetExtRight(TL5,true);
TL_SetSize(TL4,파동선두께);
TL_SetColor(TL4,rgb(128,128,128));
TL_SetSize(TL5,파동선두께);
TL_SetColor(TL5,rgb(128,128,128));
}
2020-11-12
564
글번호 143796
답변완료
일봉상의 종가를 알고 싶어요
밑의 수식에서 LL LL1 의 일봉상 종가를 알고 싶어요. LL > LL1 일때 를 구하는 데 일봉상의 종가가 컸을때 조건이였으면 좋겠습니다 LL 의 종가가 LL1 의 종가를 구해서 LL 의 종가가 LL1의 종가보다 컸을때 조건을 구하려고 합니다
input : P(20);
var : mav(0),T(0),LL(0),LL1(0);
mav = ma(C,P);
if mav > mav[1] Then
T = 1;
if mav < mav[1] Then
T = -1;
#상승반전(전저점)
if T == 1 and T != T[1] Then
{
LL = mav[1];#전저점
LL1 = LL[1];#전전저점
}
if T == -1 and #현재 하락중
mav > LL and LL > 0 and #현재 이평값이 직전 상승반전지점보다 높음
LL > LL1 and LL1 > 0 Then #전저점이 전전저점보다 큼
Find(1);
2020-11-11
470
글번호 143795
답변완료
청산식 좀 요청 드립니다.
* 많은 도움에 고맙습니다.
* 아래 청산식 좀 부탁 드립니다.
VAR1 = MA(C,5) ;
VAR1 = MA(C,20) ;
IF CrossUp(VAR1,VAR2) Then BUY("SS1");
IF CrossDown(VAR1,VAR2) Then Sell"DD1"(); 일 경우
if MarketPosition == 1 and IsEntryName("SS1") == true Then
{ if 최대수익이 30틱 한번 발생하고 이후에 하락하여
최대 손실이 30틱 한번 발생하면 이후 다시 상승하여
수익이 10틱 되면 청산
}
if MarketPosition == -1 and IsEntryName("DD1") == true Then
{ if 최대수익이 30틱 한번 발생하고 이후에 상승하여
최대 손실이 30틱 한번 발생하면 이후 다시 하락 하여
수익이 10틱 되면 청산
}
*항상 많은 도움에 고맙습니다.
2020-11-10
518
글번호 143794
답변완료
buy를 한조건에서 한번만 나오게 하고 싶습니다
buy를 한조건에서 한번만 나오게 하고 싶습니다
for문을 사용해아하는지 궁금....예를들어서요...
If C > 파라볼릭 then
{
If crossup (씨씨아이.100) then
{
buy();
}
}
위 예문에서 파라볼릭 위에서 한번만 buy하고 C가 파라볼릭보다 작아진다음 다시 C가 파라볼릭보다 커져서 다시 C > 파라볼릭이 되면 다시 buy가 또 한번만 실행되고...
C > 파라볼릭 때마다 한번씩만 buy 되었으면 좋겠습니다...
위 예문은 씨씨아이가 100을 돌파할때마다 계속 buy가 됩니다.
가장 쉽게 작성 부탁드립니다
수고하세요
2020-11-10
492
글번호 143793