커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
6060
글번호 230811
답변완료
안녕 하세요
안녕 하세요.^^
매번 도움주셔서 감사 드립니다.^^
아래수식은 파동선 색상과 수치만 표시되도록 되어 있습니다.
아래 수식에서 수치가 표시되는부분에 매▼도 (파란색) 매▲수 (빨간색)을 표시하고싶습니다.
상승파동이 완성되어 수치를 표시할 때 캔들위에 매▼도 (파란색)으로 먼저 표시되고 그 위에 수치가 표시 되었으면 합니다.
하락파동이 완성되어 수치를 표시할 때 캔들밑에 매▲수 (빨간색)으로 먼저 표시되고 그 아래 수치가 표시 되었으면 합니다.
결론은 기존 수식에서 파동 완성 시 캔들과 수치 사이에 매▼도 또는 매▲수 을 삽입하고 싶다는 의미입니다.
2 아래 수식을 강조식으로 변환을 부탁드립니다
소리도 나도록 해주시면 감사 하겟습니다
Input:length(10),종가사용여부(0),파동선두께(0.8),수치표시(1);
Var:j(0),jj(0),HH(0),LL(0),최종고가(0),최종저가(0),최종꼭지점(""),처리구분(""),
TL1(0),Text1(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);
}
TL_SetSize(TL1,파동선두께);
TL_SetColor(TL1,RED);
}
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
{
최종저가 = 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, 0);
}
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));
}
}
최종꼭지점 = "저점";
}
도움주셔서 감사합니다.
2018-12-06
223
글번호 124210
해결
해결
2018-12-05
160
글번호 124209
답변완료
수식문의드립니다
60337번재문의 드립니다 (전봉이,양봉이나,음봉일때,종가보다)현재봉이10틱이상상승시 레드색 현재봉이 10틱이상하락시 블루색 강조식수정부탁드립니다
***예를들어,전봉종가보다 현재봉에서10틱이상상승하여,레드색이나왔는데,갑자기반대로,전봉종가보다10틱하락하였다면다시블루색으로색갈이변하게끔**
2018-12-05
201
글번호 124208
답변완료
수식부탁드립니다
캔들이 양봉일때 시가를 깨지않고
반대로 음봉일때 마찬가지인 강조식이나 캔들에 색을
입혀 표현되는 수식 부탁드립니다
2018-12-05
219
글번호 124207
답변완료
30분봉 참조 부탁드립니다.
var1 = ma(C,20);
var2 = ma(C,60);
if MarketPosition == 0 and
var2 > var2[1] and
O < var1 and
C > O Then
buy();
if MarketPosition == 0 and
var2 < var2[1] and
O > var1 and
C < O Then
sell();
SetStopLoss(PriceScale*15,PointStop);
SetStopProfittarget(PriceScale*30,PointStop);
위에 수식을
1. 30분봉을 참조하여 30분봉상 볼린저밴드 20,2 돌파하는 시점 부터 위의 수식이 적용 될수 있게 부탁 드립니다. 30분봉상 볼밴 돌파 없으면 신호 없습니다.
2. 그리고 위에 수식을 보면 청산과 진입신호가 동시에 같은 봉에서 나오는데 청산 이후 그다음 봉부터 조건 만족시 신호 나오게 부탁 드립니다.
3. 그리고 한국시간으로 저녁7시부터 새벽 3시까지만 신호 나오게 해주시고 마지막 진입 신호는 청산까지만 되게 부탁 드립니다.
항상 감사드립니다.
2018-12-05
239
글번호 124206
답변완료
선물에서 미니로
안녕하세요
1.
저희가 연결선물시장 시스템 10개
있습니다 아이디어 생각나서 문의드립니다
연결선물 시스템에
맞게 식을 짲지만 이것을
미니선물 시스템 에 맞게 하려면
뭘 해야 서로 비슷 일치할수있을까요?
미니선물이랑 연결선물 종가를보면 항상 비슷한
가격에끝납니다 둘다 일치하게 수익률
만들고싶은데요
있다면 저희 있는 식 그대로에 추가해서 미니로
바꿔 거래하고싶네요 또는 선물
미니선물식은 연결선물식으로
연결선물식은 미니선물 식으로 할수있는지요
감사해요 ^^😚
2018-12-05
214
글번호 124203
답변완료
지표식 수정 부탁 드립니다
여러가지 도움에 감사드립니다
다음 수식에서 나타나는 파동 꼭지점(고점 또는 저점) 위치에 해당 가격을 표시(고점 가격은 꼭지점 위에, 저점가격은 꼭지점 아래에)하여 주시고,
고점과 저점의 변동 틱수(상승틱은 빨강색으로 +00, 하락틱은 파랑색으로 -00)를 해당가격 위또는 아래에 표시해 주십시요~~
#==========================================#
Input:length(10);
Var:TL1(0),TL2(0),TL2_exist(0),color(0),
종가사용여부(0), // 종가로 계산하려면 1로 설정한다.
TL_NewBit(0), // 1:NewLine 2:SetEndLine
slope(0),mid_idx(0),mid_val(0);
Array:고[10,4](0),저[10,4](0); // 1:가격,2:Index,3:sDate,4:sTime
#==========================================#
Value1 = HiLoLineZigZag(length,종가사용여부,고,저,TL_NewBit);
If Value1 == 1 Then { // 고점
If TL_NewBit == 1 Then { // 신규
If 고[2,1] < 고[1,1] Then { // 신규 고점이 이전 고점을 상향 돌파
// y = 기울기 * x + 절편
// x = (y - 절편) / 기울기
// y = 고[2,1]
// 절편 = 저[1,1]
slope = (고[1,1] - 저[1,1]) / (고[1,2] - 저[1,2]); // 추세선의 기울기
mid_idx = Floor((고[2,1] - 저[1,1]) / slope); // 고[2,1]과 만나는 지점
mid_val = slope * mid_idx + 저[1,1];
Var1 = Index - (저[1,2] + mid_idx); // 추세선의 중간지점 x좌표
//TL1 = TL_New(저[1,3],저[1,4],저[1,1],sDate[Var1],sTime[Var1],mid_val);
TL2 = TL_New(sDate[Var1],sTime[Var1],mid_val,고[1,3],고[1,4],고[1,1]);
Var2 = Index - 저[1,2]; // 이전 색깔을 따라감
TL_SetColor(TL1,color[Var2]);
color = RED; // 상향 돌파했으므로 빨간색으로 전환
TL_SetColor(TL2,color);
TL2_exist = 1; // 추세선 2개를 연결해서 그린 것이므로 추세선이 2개임을 저장
} Else {
TL1 = TL_New(저[1,3],저[1,4],저[1,1],고[1,3],고[1,4],고[1,1]);
TL_SetColor(TL1,color);
TL2_exist = 0;
}
}
If TL_NewBit == 2 Then { // 연장
TL_Delete(TL1);
If TL2_exist == 1 Then TL_Delete(TL2); // 추세선이 2개면 두번째 추세선도 삭제
If 고[2,1] < 고[1,1] Then {
slope = (고[1,1] - 저[1,1]) / (고[1,2] - 저[1,2]);
mid_idx = Floor((고[2,1] - 저[1,1]) / slope);
mid_val = slope * mid_idx + 저[1,1];
Var1 = Index - (저[1,2] + mid_idx);
TL1 = TL_New(저[1,3],저[1,4],저[1,1],sDate[Var1],sTime[Var1],mid_val);
TL2 = TL_New(sDate[Var1],sTime[Var1],mid_val,고[1,3],고[1,4],고[1,1]);
Var2 = Index - 저[1,2];
TL_SetColor(TL1,color[Var2]);
color = RED;
TL_SetColor(TL2,color);
TL2_exist = 1;
} Else {
TL1 = TL_New(저[1,3],저[1,4],저[1,1],고[1,3],고[1,4],고[1,1]);
TL_SetColor(TL1,color);
TL2_exist = 0;
}
}
} Else If Value1 == -1 Then { // 저점
If TL_NewBit == 1 Then { // 신규
If 저[2,1] > 저[1,1] Then {
slope = (저[1,1] - 고[1,1]) / (저[1,2] - 고[1,2]);
mid_idx = Floor((저[2,1] - 고[1,1]) / slope);
mid_val = slope * mid_idx + 고[1,1];
Var1 = Index - (고[1,2] + mid_idx);
TL1 = TL_New(고[1,3],고[1,4],고[1,1],sDate[Var1],sTime[Var1],mid_val);
TL2 = TL_New(sDate[Var1],sTime[Var1],mid_val,저[1,3],저[1,4],저[1,1]);
Var2 = Index - 고[1,2];
TL_SetColor(TL1,color[Var2]);
color = BLUE;
TL_SetColor(TL2,color);
TL2_exist = 1;
} Else {
TL1 = TL_New(고[1,3],고[1,4],고[1,1],저[1,3],저[1,4],저[1,1]);
TL_SetColor(TL1,color);
TL2_exist = 0;
}
}
If TL_NewBit == 2 Then { // 연장
TL_Delete(TL1);
If TL2_exist == 1 Then TL_Delete(TL2);
If 저[2,1] > 저[1,1] Then {
slope = (저[1,1] - 고[1,1]) / (저[1,2] - 고[1,2]);
mid_idx = Floor((저[2,1] - 고[1,1]) / slope);
mid_val = slope * mid_idx + 고[1,1];
Var1 = Index - (고[1,2] + mid_idx);
TL1 = TL_New(고[1,3],고[1,4],고[1,1],sDate[Var1],sTime[Var1],mid_val);
TL2 = TL_New(sDate[Var1],sTime[Var1],mid_val,저[1,3],저[1,4],저[1,1]);
Var2 = Index - 고[1,2];
TL_SetColor(TL1,color[Var2]);
color = BLUE;
TL_SetColor(TL2,color);
TL2_exist = 1;
} Else {
TL1 = TL_New(고[1,3],고[1,4],고[1,1],저[1,3],저[1,4],저[1,1]);
TL_SetColor(TL1,color);
TL2_exist = 0;
}
}
}
TL_SetSize(TL1,3);
TL_SetSize(TL2,3);
2018-12-05
246
글번호 124201
답변완료
문의드립니다
안녕하세요.
유진 예스트레이더 사용자입니다.
4등분선 수식을 알려주시면 고맙겠습니다.
그리고 그 수식을 어데로 들어가서 기입해야하는지도 알려주시면 합니다
키움증권을 사용하다가 오니 모르는 것이 많습니다. 감사합니다
2018-12-05
228
글번호 124200
답변완료
문의 드립니다.
항상 고맙습니다.
타주기(분용) 수식 부탁 드립니다.
수식1)
var1 = highest(H,100);
value1 = C/var1*100;
수식2)
var2 = lowest(L,100);
value2 = C/var2*100;
참고수식)
input : 타주기분(30),Period(20);
var : S1(0),D1(0),TM(0),TF(0),cnt(0),WR(0);
Array : HH[100](0),LL[100](0);
if Bdate != Bdate[1] Then
{
S1 = TimeToMinutes(stime);
D1 = sdate;
}
if D1 > 0 then
{
if sdate == D1 Then
TM = TimeToMinutes(stime)-S1;
Else
TM = TimeToMinutes(stime)+1440-S1;
TF = TM%타주기분;
if Bdate != Bdate[1] or (Bdate == Bdate[1] and TF < TF[1]) Then
{
2018-12-05
218
글번호 124198