커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
1638
글번호 230811
답변완료
부탁드립니다
신호검색 (화살표)
VV=highest(V(1), period);
accumulationVolume=valuewhen(1, V>VV*2 and C(1)<C, V);
accumulationOpen=valuewhen(1, V>VV*2 and C(1)<C, min(C, O));
AA=C<=accumulationOpen and V*multiple<accumulationVolume;
condition=AA and O<C and (disparity(250)<=110 or disparity(125)<=110)
and V > highest(V(1), period) * multiple2
지표변수
period 60
multiple 2
multiple2 1.5
변수처리 부탁드려요 감사합니다
2022-10-19
993
글번호 163128
답변완료
부탁드립니다
지표설정
수식1 거래량매집봉
VV=highest(V(1), period);
accumulationVolume=valuewhen(1, V>VV*2 and C(1)<C, V);
accumulationOpen=valuewhen(1, V>VV*2 and C(1)<C, min(C, O));
AA=C<=accumulationOpen and V*multiple<accumulationVolume;
condition=AA and O<C and (disparity(250)<=110 or disparity(125)<=110);
if(condition, O, 0)
수식2 뚝배기
VV=highest(V(1), period);
accumulationOpen=valuewhen(1, V>VV*2 and C(1)<C, min(C, O))
지표변수
period 60
multiple 2
2022-10-19
1113
글번호 163127
답변완료
부탁드립니다
부탁드립니다
2022-10-19
1091
글번호 163126
매치다2 님에 의해서 삭제되었습니다.
2022-10-19
0
글번호 163125
매치다2 님에 의해서 삭제되었습니다.
2022-10-19
0
글번호 163124
답변완료
역사적변동성
안녕하세요! 스크린샷 화면은 옵션 시뮬레이터 화면인데, 혹시 밑줄 친 역사적 변동성을 구하는 수식이 어떻게 될까요?
항상 도움주셔서 감사합니다!
2022-10-19
1279
글번호 163119
답변완료
파동의 저점과 고점 봉의 위치 재문의
안녕하십니까 ?
앞의 질문에 대한 재질문을 하고자 합니다.
파동의 최고점 최저점 봉의 위치를 타점으로 하는 데이터를 얻고자 하는 것인데
아래 로직에서 최저점 혹은 최고점은 실시간으로는 동적 메모리를 이용해서 고점과 저점의 변화에 따라서 지속적으로 갱신하는 것으로 보입니다.
하여간 아래 로직으로는 파동의 저점과 고점의 봉의 위치를 잡지 못하는것 같습니다.
(그림파일 첨부 참조)
따라서 결정되는 봉의 color값도 함께 동적메모리를 이용해서 갱신해야 하지 않는지요 ?(개인적인 생각이지만...)
yeslanguage 메모리 사용법을 몰라서 잘 안되는데 꼭 부탁드립니다.
안녕하세요
예스스탁입니다.
Input:P(0),length(10);
Var:j(0),lastHiVal(0),lastLoVal(0),sBar(0),eBar(0),TL1(0),TL2(0),
Text1(0),처리구분(""),T(0),TL3(0),TL4(0),TL5(0),color(0);
Array:고점[10,2](0),저점[10,2](0); //가격,위치
처리구분 = "";
If Highest(H,length) == H and lastHiVal <> H and
Lowest(L,length) == L and lastLoVal <> L
Then
{
If 저점[1,1] > L Then 처리구분 = "저점처리";
If 고점[1,1] < H Then 처리구분 = "고점처리";
}
Else If Highest(H,length) == H and lastHiVal <> H Then
처리구분 = "고점처리";
Else If Lowest(L,length) == L and lastLoVal <> L Then
처리구분 = "저점처리";
If 처리구분 == "고점처리" Then
{
lastHiVal = H;
If 고점[1,2] < 저점[1,2] Then
{
For j = 10 DownTo 2
{
고점[j,1] = 고점[j-1,1];
고점[j,2] = 고점[j-1,2];
}
}
If 고점[1,2] < 저점[1,2] or 고점[1,1] < H Then
{
고점[1,1] = H;
고점[1,2] = Index;
sBar = Index - 저점[1,2];
eBar = 0;
TL_Delete(TL2);
TL_Delete(TL3);
TL_Delete(TL4);
TL_Delete(TL5);
If TL_GetBeginDate(TL1) == sDate[sBar] and TL_GetBeginTime(TL1) == sTime[sBar] Then
{
TL_Delete(TL1);
Text_Delete(Text1);
}
TL1 = TL_New(sDate[sBar],sTime[sBar],저점[1,1],sDate[eBar],sTime[eBar],고점[1,1]);
TL2 = TL_New(sDate[sBar],sTime[sBar],저점[1,1],sDate[eBar],sTime[eBar],저점[1,1]);
TL3 = TL_New(sDate[sBar],sTime[sBar],저점[1,1]+(고점[1,1]-저점[1,1])*0.382,sDate[eBar],sTime[eBar],저점[1,1]+(고점[1,1]-저점[1,1])*0.382);
TL4 = TL_New(sDate[sBar],sTime[sBar],저점[1,1]+(고점[1,1]-저점[1,1])*0.500,sDate[eBar],sTime[eBar],저점[1,1]+(고점[1,1]-저점[1,1])*0.500);
TL5 = TL_New(sDate[sBar],sTime[sBar],저점[1,1]+(고점[1,1]-저점[1,1])*0.618,sDate[eBar],sTime[eBar],저점[1,1]+(고점[1,1]-저점[1,1])*0.618);
Text1 = Text_New(sDate[eBar],sTime[eBar],고점[1,1],NumToStr(고점[1,1],P));
Var1 = 고점[1,1];
Text_SetStyle(Text1, 2, 1);
Text_SetColor(Text1,Blue);
color = -1;
} # End of If 고점[1,2] < 저점[1,2] or 고점[1,1] < H
} # End of If 처리구분 == "고점처리"...
If 처리구분 == "저점처리" Then
{
lastLoVal = L;
If 저점[1,2] < 고점[1,2] then
{
For j = 10 DownTo 2
{
저점[j,1] = 저점[j-1,1];
저점[j,2] = 저점[j-1,2];
}
}
If 저점[1,2] < 고점[1,2] or 저점[1,1] > L then
{
저점[1,1] = L;
저점[1,2] = Index;
sBar = Index - 고점[1,2];
eBar = 0;
TL_Delete(TL2);
TL_Delete(TL3);
TL_Delete(TL4);
TL_Delete(TL5);
If TL_GetBeginDate(TL1) == sDate[sBar] and TL_GetBeginTime(TL1) == sTime[sBar] Then
{
TL_Delete(TL1);
Text_Delete(Text1);
} # End of If TL_GetBeginDate(TL1) ==
TL1 = TL_New(sDate[sBar],sTime[sBar],고점[1,1],sDate[eBar],sTime[eBar],저점[1,1]);
TL2 = TL_New(sDate[sBar],sTime[sBar],고점[1,1],sDate[eBar],sTime[eBar],고점[1,1]);
TL3 = TL_New(sDate[sBar],sTime[sBar],고점[1,1]-(고점[1,1]-저점[1,1])*0.382,sDate[eBar],sTime[eBar],고점[1,1]-(고점[1,1]-저점[1,1])*0.382);
TL4 = TL_New(sDate[sBar],sTime[sBar],고점[1,1]-(고점[1,1]-저점[1,1])*0.500,sDate[eBar],sTime[eBar],고점[1,1]-(고점[1,1]-저점[1,1])*0.500);
TL5 = TL_New(sDate[sBar],sTime[sBar],고점[1,1]-(고점[1,1]-저점[1,1])*0.618,sDate[eBar],sTime[eBar],고점[1,1]-(고점[1,1]-저점[1,1])*0.618);
Text1 = Text_New(sDate[eBar],sTime[eBar],저점[1,1],NumToStr(저점[1,1],P));
Var2 = 저점[1,1];
Text_SetStyle(Text1, 2, 8);
Text_SetColor(Text1,Red);
color = 1;
} # End of If 저점[1,2] < 고점[1,2] or 저점[1,1] > L
} # End of If 처리구분 == "저점처리"
TL_SetSize(TL1,0);
TL_SetColor(TL1,GRAY);
Plot1(color);
즐거운 하루되세요
> 구천룡 님이 쓴 글입니다.
> 제목 : 파동의 저점과 고점 위치
> 안녕하십니까.
아래 프로그램으로 장중 파동의 고점과 저점의 봉의 데이터 값, 즉 첨부된 그름 파일에서 붉은 색 값인 경우 +1로 출력하고 푸른색의 값인 경우 -1로 리턴하는 함수를 작성하고자 합니다. 도움 좀 부탁드립니다.
사용 목적은 파동의 고점과 저점 봉의 데이터 출력하고자 합니다.
(죄송스럽게도 제가 로직 이해가 부족해서 인지 정확히 숫자 찍히는 고점과 저점 지점을 잡을 수가 없네요)
Input:P(0),length(10);
Var:j(0),lastHiVal(0),lastLoVal(0),sBar(0),eBar(0),TL1(0),TL2(0),
Text1(0),처리구분(""),T(0),TL3(0),TL4(0),TL5(0);
Array:고점[10,2](0),저점[10,2](0); //가격,위치
처리구분 = "";
If Highest(H,length) == H and lastHiVal <> H and
Lowest(L,length) == L and lastLoVal <> L
Then
{
If 저점[1,1] > L Then 처리구분 = "저점처리";
If 고점[1,1] < H Then 처리구분 = "고점처리";
}
Else If Highest(H,length) == H and lastHiVal <> H Then
처리구분 = "고점처리";
Else If Lowest(L,length) == L and lastLoVal <> L Then
처리구분 = "저점처리";
If 처리구분 == "고점처리" Then
{
lastHiVal = H;
If 고점[1,2] < 저점[1,2] Then
{
For j = 10 DownTo 2
{
고점[j,1] = 고점[j-1,1];
고점[j,2] = 고점[j-1,2];
}
}
If 고점[1,2] < 저점[1,2] or 고점[1,1] < H Then
{
고점[1,1] = H;
고점[1,2] = Index;
sBar = Index - 저점[1,2];
eBar = 0;
TL_Delete(TL2);
TL_Delete(TL3);
TL_Delete(TL4);
TL_Delete(TL5);
If TL_GetBeginDate(TL1) == sDate[sBar] and
TL_GetBeginTime(TL1) == sTime[sBar] Then
{
TL_Delete(TL1);
Text_Delete(Text1);
}
TL1 = TL_New(sDate[sBar],sTime[sBar],저점[1,1],sDate[eBar],sTime[eBar],고점[1,1]);
TL2 = TL_New(sDate[sBar],sTime[sBar],저점[1,1],sDate[eBar],sTime[eBar],저점[1,1]);
TL3 = TL_New(sDate[sBar],sTime[sBar],저점[1,1]+(고점[1,1]-저점[1,1])*0.382,sDate[eBar],sTime[eBar],저점[1,1]+(고점[1,1]-저점[1,1])*0.382);
TL4 = TL_New(sDate[sBar],sTime[sBar],저점[1,1]+(고점[1,1]-저점[1,1])*0.500,sDate[eBar],sTime[eBar],저점[1,1]+(고점[1,1]-저점[1,1])*0.500);
TL5 = TL_New(sDate[sBar],sTime[sBar],저점[1,1]+(고점[1,1]-저점[1,1])*0.618,sDate[eBar],sTime[eBar],저점[1,1]+(고점[1,1]-저점[1,1])*0.618);
Text1 = Text_New(sDate[eBar],sTime[eBar],고점[1,1],NumToStr(고점[1,1],P));
Var1 = 고점[1,1];
Text_SetStyle(Text1, 2, 1);
Text_SetColor(Text1,Blue);
} # End of If 고점[1,2] < 저점[1,2] or 고점[1,1] < H
} # End of If 처리구분 == "고점처리"...
If 처리구분 == "저점처리" Then
{
lastLoVal = L;
If 저점[1,2] < 고점[1,2] then
{
For j = 10 DownTo 2
{
저점[j,1] = 저점[j-1,1];
저점[j,2] = 저점[j-1,2];
}
}
If 저점[1,2] < 고점[1,2] or 저점[1,1] > L then
{
저점[1,1] = L;
저점[1,2] = Index;
sBar = Index - 고점[1,2];
eBar = 0;
TL_Delete(TL2);
TL_Delete(TL3);
TL_Delete(TL4);
TL_Delete(TL5);
If TL_GetBeginDate(TL1) == sDate[sBar] and TL_GetBeginTime(TL1) == sTime[sBar] Then
{
TL_Delete(TL1);
Text_Delete(Text1);
} # End of If TL_GetBeginDate(TL1) ==
TL1 = TL_New(sDate[sBar],sTime[sBar],고점[1,1],sDate[eBar],sTime[eBar],저점[1,1]);
TL2 = TL_New(sDate[sBar],sTime[sBar],고점[1,1],sDate[eBar],sTime[eBar],고점[1,1]);
TL3 = TL_New(sDate[sBar],sTime[sBar],고점[1,1]-(고점[1,1]-저점[1,1])*0.382,sDate[eBar],sTime[eBar],고점[1,1]-(고점[1,1]-저점[1,1])*0.382);
TL4 = TL_New(sDate[sBar],sTime[sBar],고점[1,1]-(고점[1,1]-저점[1,1])*0.500,sDate[eBar],sTime[eBar],고점[1,1]-(고점[1,1]-저점[1,1])*0.500);
TL5 = TL_New(sDate[sBar],sTime[sBar],고점[1,1]-(고점[1,1]-저점[1,1])*0.618,sDate[eBar],sTime[eBar],고점[1,1]-(고점[1,1]-저점[1,1])*0.618);
Text1 = Text_New(sDate[eBar],sTime[eBar],저점[1,1],NumToStr(저점[1,1],P));
Var2 = 저점[1,1];
Text_SetStyle(Text1, 2, 8);
Text_SetColor(Text1,Red);
} # End of If 저점[1,2] < 고점[1,2] or 저점[1,1] > L
} # End of If 처리구분 == "저점처리"
TL_SetSize(TL1,0);
TL_SetColor(TL1,GRAY);
2022-10-19
1158
글번호 163117
답변완료
79227 재댓글에 대한 답변부탁드립니다.(냉무)
냉무
2022-10-19
1006
글번호 163112
답변완료
종목검색이 분봉에서 적용이 안됩니다 도와주세요...
친절한 답변 감사합니다
수식을 확인해보니 일봉은 결과값중 대략 90%정로 맞습니다
그런데 실제 사용처는 1분봉 종목 검색으로 사용할려고 합니다
말씀하신것처럼 검색에 필요한 최소기간 체크하고 500봉 입력후
기준봉0 분 1 수정 까지 입력한다음 검색을 하니
분봉은 전혀 다른곳에서 결과가 나타납니다
예전 Q&A 찾아봐서 혹시나 하는 맘에 함수에서 5단위로 240~500까지 바꾸고
필요한 최소 기간도 함수랑 같은 봉수로 바꿔서 일일이 검색해봤는데 결과값이 안나옵니다
만약 답이 없다면 현재 종가가 B 박스선 아래 있을때 찾는다는 수식으로 바꿔보면 if CROSSUP(C,B) Then 을 if C<B Then
으로 바꿔주면 되는건가요?
> 예스스탁 님이 쓴 글입니다.
> 제목 : Re : 종목검색 수식 부탁드립니다
>
안녕하세요
예스스탁입니다.
1
이평을 계산하기 위해서 최소 240봉은 필요하고
avgif ,StdevIf 함수가 차트 전체봉을 대상으로 합니다.
종목검색은 최대 500봉입니다.
종목검색시 속성에서 500봉으로 지정하고 검색하셔야 합니다.
input : 이평기간(240);
var : A(0),value(0),sum(0),ii(0),avgif(0),cnt(0);
var : SumSqrt(0),StdevIf(0),B(0);
Array : diff[500](0);
A= ma(C,이평기간);
value = C-A;
if IsNan(value) == False then
{
if value < 0 Then
{
ii = ii + 1;
diff[ii] = value;
sum = sum + value;
avgif = sum/ii;
}
if ii >= 1 then
{
SumSqrt = 0;
For cnt = 1 To ii
{
SumSqrt = SumSqrt + (diff[cnt] - avgif)^2;
}
StdevIf = SquareRoot(SumSqrt / ii);
B = A + avgif - 2*StdevIf;
if CROSSUP(C,B) Then
Find(1);
}
}
> 불개미미미 님이 쓴 글입니다.
> 제목 : 종목검색 수식 부탁드립니다
> 안녕하세요
고생이 많으십니다 종목검색 수식은 너무 험난하네요
수식 좀 부탁 드리겠습니다
1.1분봉
A = MA(가격,이평기간,이평방법); // 종가,240,단순
b=A + AvgIf( c - A, -1, 0.0 )
-2*StdevIf( c - A, -1, 0.0 );
2022-10-19
1024
글번호 163111