커뮤니티
예스랭귀지 Q&A
답변완료
[공지] 예스랭귀지 AI 어시스턴트, '예스나 AI' 출시 및 무료 체험 안내
안녕하세요, 예스스탁 입니다.복잡한 수식 공부 없이 여러분의 아이디어를 말하면 시스템 트레이딩 언어 예스랭귀지로 작성해주는 서비스예스나 AI(YesNa AI)가 출시되었습니다.지금 예스나 AI를 직접 경험해 보실 수 있도록 20크레딧(질문권 20회)를 무료로 증정해 드리고 있습니다.바로 여러분의 아이디어를 코드로 변환해보세요.--------------------------------------------------🚀 YesNa AI 핵심 기능- 지표식/전략식/종목검색식 생성: 자연어로 요청하면 예스랭귀지 문법에 맞는 코드를 작성합니다.- 종목검색식 변환 지원: K증권의 종목 검색식을 예스랭귀지로 변환 지원합니다.- 컴파일 검증: 작성된 코드가 실행 가능한지 컴파일러를 통해 문법 검증을 거쳐 결과물을 제공합니다.상세한 서비스 개요 및 활용 방법은 [서비스 소개 페이지]에서 확인하실 수 있습니다.▶ 서비스 소개 페이지: 바로가기서비스 사용 유의사항 및 결제 환불정책은 [이용약관]을 참고 부탁드립니다.▶ 서비스 이용약관: 바로가기💬 이용 문의사용 중 문의사항은 [프로그램 사용법 Q&A] 게시판에서 [예스나 AI] 카테고리를 설정 후 문의해 주시면 상세히 안내해 드리겠습니다.--------------------------------------------------앞으로도 AI를 활용한 다양한 트레이딩 기능들을 지속적으로 선보일 예정입니다.많은 관심과 기대 부탁드립니다.
2026-02-27
3444
글번호 230811
답변완료
수정부탁드립니다.
안녕하세요? 답변받은 아래의 수식에서 약간 수정하여 사용하고있습니다.
추가로 더 수정할 부분이있는데 도움을 받으려합니다.
<현재>
정배열에서 음봉연속 2개일시 매도
역배열에서 양봉연속 2개일시 매수
<수정후>
정배열에서 음봉 다음 갭상승한 음봉일시 매도
역베열에서 양봉 다음 갭하락한 양봉일시 매수
이렇게 수정부탁드립니다.
감사합니다.
input : 매수전봉양봉틱수(5),매수현재양봉틱수(5);
input : 매도전봉음봉틱수(5),매도현재음봉틱수(5);
input : 진입횟수(5);
input : 익절틱수(50),손절틱수(4);
input : P1(5),P2(20);
var : entry(0),mav1(0),mav2(0),T1(0);
mav1 = ma(C,P1);
mav2 = ma(C,P2);
#영업일 변경
if bdate != bdate[1] Then
{
T1 = TotalTrades;
}
if MarketPosition == 0 Then
entry = TotalTrades-T1;
Else
entry = TotalTrades-T1+1;
if mav1 > mav2 and #정배열
entry < 진입횟수 and #진입횟수가 지정한 값 이하
bdate == bdate[1] and
MarketPosition == 0 and #매수나 무포지션 상태
C[1] == O[1]-매도전봉음봉틱수*PriceScale and
C[0] == O[0]-매도현재음봉틱수*PriceScale Then
{
sell("s");
if entry < 진입횟수-1 then
buy("bs1",AtStop,C+PriceScale*4);
Else
ExitShort("sx1",AtStop,C+PriceScale*4);
}
if mav1 < mav2 and #역배열
entry < 진입횟수 and #진입횟수가 지정한 값 이하
bdate == bdate[1] and
MarketPosition == 0 and #매도나 무포지션 상태
C[1] == O[1]+매수전봉양봉틱수*PriceScale and
C[0] == O[0]+매수현재양봉틱수*PriceScale Then
{
buy("b");
if entry < 진입횟수-1 Then
sell("sb1",AtStop,C-PriceScale*4);
Else
ExitShort("bx1",AtStop,C-PriceScale*4);
}
#매수진입 후 손절되면 매도로 스위칭
if MarketPosition == 1 Then
{
if entry < 진입횟수 Then
sell("bs",AtStop,EntryPrice-PriceScale*손절틱수);
Else
ExitLong("bsx",AtStop,EntryPrice-PriceScale*손절틱수);
}
#매도진입 후 손절되면 매수로 스위칭
if MarketPosition == -1 and entry < 진입횟수 Then
{
if entry < 진입횟수 Then
buy("sb",AtStop,EntryPrice+PriceScale*손절틱수);
Else
ExitShort("sbx",AtStop,EntryPrice+PriceScale*손절틱수);
}
#목표수익 설정
SetStopProfittarget(PriceScale*익절틱수,PointStop);
2020-03-26
652
글번호 137255
답변완료
수식부탁합니다.
아래 답변주신 내용중에 진입신호를
5일 이평선이 20이평선 상향돌파하면 매수 하향돌파하면 매도로 설정.
그 이후는
1. 첫 진입 즉시 1 포인트 손실일 경우 청산 및 포지션 변경
(ex. 1000 포인트 매수로 진입시 999포인트 자동 청산 및 매도로 포지션 변경. 매도로 진입시 반대로 동일하게 적용.)
2. 진입 이후 시장가격(현재가)이 변동할때 최고가격에서 -2 포인트 하락시 자동 청산 및 포지션 변경. 변경된 포지션도 동일하게 적용
(ex1. 1000 포인트 매수로 진입시 순간적으로 1010포인트까지 상승 후 1008포인트로 하락할 경우 매수 청산 및 매도로 포지션 변경. 변경된 매도 포지션이 1008포인트 진입한 이후 1002포인트까지 하락 후 1004포인트로 2포인트 상승할 경우 자동 청산 및 포지션 변경)
안녕하세요
예스스탁입니다.
문의하신 내용은 가능하지 않습니다.
랭귀지의 청산함수는 차트에 진입신호가 있어야 발동하는데
랭귀지에서 수동으로 주문한 내용을 알지 못합니다.
즐거운 하루되세요
> 경매story 님이 쓴 글입니다.
> 제목 : 수식 부탁드립니다.
> 수식 부탁드리겠습니다.
1. 첫 진입은 수동.
1-1. 첫 진입 즉시 1 포인트 손실일 경우 청산 및 포지션 변경
(ex. 1000 포인트 매수로 진입시 999포인트 자동 청산 및 매도로 포지션 변경. 매도로 진입시 반대로 동일하게 적용.)
2. 진입 이후 시장가격(현재가)이 변동할때 최고가격에서 -2 포인트 하락시 자동 청산 및 포지션 변경. 변경된 포지션도 동일하게 적용
(ex1. 1000 포인트 매수로 진입시 순간적으로 1010포인트까지 상승 후 1008포인트로 하락할 경우 매수 청산 및 매도로 포지션 변경. 변경된 매도 포지션이 1008포인트 진입한 이후 1002포인트까지 하락 후 1004포인트로 2포인트 상승할 경우 자동 청산 및 포지션 변경)
2020-03-26
714
글번호 137252
답변완료
시스템수식 부탁드립니다.
안녕하세요
아래의 시스템수식 요청드립니다.
감사합니다.
----- 아 래 -----
1-1. MACD Oscillatror > 0 이상
BinaryWave > 0 이상
Price Oscillator > 0 이상
현재주가 > 20 이평 이상
위의 4가지 만족하는 경우 ==> 매수 진입
1-2. 위의 조건 중 1개라도 만족하지 않는 경우에 청산
또는 수익 15틱이상이면 익절 청산,
손실 -12틱이면 손절청산 한다.
2-1. MACD Oscillatror < 0 이하
BinaryWave < 0 이하
Price Oscillator < 0 이하
현재주가 < 20 이평 이하
위의 4가지 만족하는 경우 ==> 매도 진입
2-2. 위의 조건 중 1개라도 만족하지 않는 경우에 청산
또는 수익 15틱이상이면 익절 청산,
손실 -12틱이면 손절청산 한다.
3. 스탑트레일링을 구현하고자 하는 경우,
예스랭귀지에서 설정하는 것이 좋은 가요?
아니면, 예스스팟에서 설정하는 것이 좋은 지요 ?
-끝.-
2020-03-26
706
글번호 137251
답변완료
문의드립니다.
inp_Period = input(title = "Trend", type = input.integer, defval = 8)
inp_Source = input(title = "Source", type = input.source, defval = close)
da_StdDev = stdev(inp_Source, inp_Period)
da_StdDev_Avg = sma(da_StdDev, inp_Period)
da_Line = da_StdDev_Avg == 0 ? 1 : da_StdDev / da_StdDev_Avg
plot(da_Line, color = da_Line > 0.2 ? color.green : color.red)
변환 문의드립니다.
감사합니다.
2020-03-26
673
글번호 137250
답변완료
문의
10시대에 3번 들어가는 경우도 있는데
같은 시간대에는 1번만 진입하는 조건 추가바랍니다.
***********************************************************
input:시간(091000);
input : 강제손절(0.46),강제추적(6.00),강제익절(1000);
var : HH(0),LL(0);
if stime < 시간 Then{
HH = dayhigh;
LL = daylow;
}
if stime >= 시간 and crossup(c,HH) then
sell();
SetStopLoss(강제손절,PointStop);
SetStopTrailing(강제추적,0,PointStop);
SetStopProfittarget(강제익절,PointStop);
2020-03-26
682
글번호 137249
답변완료
문의드립니다.
아래식은 지난 선배님의 수식인데...
에러가나서 어떻게 해결할지 못해 문의드립니다.
Input:Rate(3),
kind(1); // 1:일반다이버전스,2:히든다이버전스,3:과장된다이버전스,4:3중다이버전스
Var:j(0),jj(0),iValue(0),
고저구분(0), // 1: 고점, 2: 저점
신규여부(0); // 1: 신규, 2: 연장
Array:HH[10,4](0),LL[10,4](0), // 1:가격, 2:Index, 3:sDate, 4:sTime
IH[10,4](0),IL[10,4](0), // 지표의 고,저점을 관리
TL[10](0),
BeginIndex[4](0);
var : tx1(0),tx2(0);
#==========================================#
iValue = RSI(9); // 지표값은 아래와 같이 다양하게 변경 가능
// iValue = StochasticsK(10,5);
// iValue = StochasticsD(5,3,3);
// iValue = MACD(12,26);
// iValue = MACD_OSC(12,26,9);
// iValue = CCI(9);
// iValue = LRS(C,14);
// iValue = Volume;
Plot1(iValue);
#==========================================#
// 주가 차트에 대한 파동선
고저구분 = ChgRateZigZag(Rate,0,HH,LL,신규여부); // 최소변동률지그재그
If 고저구분 == 1 Then { // 고점
If 신규여부 == 1 Then
{
TL[0] = TL_New(LL[1,3],LL[1,4],LL[1,1],HH[1,3],HH[1,4],HH[1,1]);
}
If 신규여부 == 2 Then // 고점 연장
{
TL_SetEnd(TL[0],HH[1,3],HH[1,4],HH[1,1]);
}
} Else If 고저구분 == -1 Then { // 저점
If 신규여부 == 1 Then
{
TL[0] = TL_New(HH[1,3],HH[1,4],HH[1,1],LL[1,3],LL[1,4],LL[1,1]);
}
If 신규여부 == 2 Then // 저점 연장
{
TL_SetEnd(TL[0],LL[1,3],LL[1,4],LL[1,1]);
}
}
TL_SetSize(TL[0],1);
TL_SetColor(TL[0],PINK);
if 고저구분 == 1 Then
{
if 고저구분[1] != 1 Then
{
tx1 = Text_New(HH[1,3],HH[1,4],HH[1,1],NumToStr(HH[1,1],2));
Text_SetStyle(tx1,2,1);
}
Else
{
Text_SetString(tx1,NumToStr(HH[1,1],2));
Text_SetLocation(tx1,HH[1,3],HH[1,4],HH[1,1]);
}
}
if 고저구분 == -1 Then
{
if 고저구분[1] != -1 Then
{
tx1 = Text_New(LL[1,3],LL[1,4],LL[1,1],NumToStr(LL[1,1],2));
Text_SetStyle(tx1,2,0);
}
Else
{
Text_SetString(tx1,NumToStr(LL[1,1],2));
Text_SetLocation(tx1,LL[1,3],LL[1,4],LL[1,1]);
}
}
#==========================================#
// 보조지표에 대한 파동선
Value1 = IndiDivergence(고저구분,신규여부,iValue,IH,IL); // 주가의 지그재그파동 결과를 입력
// 결과값이 1이면 정상, 0이면 오류
If Value1 == 1 Then {
If 고저구분 == 1 Then { // 고점
If 신규여부 == 1 Then // 주가 파동에 신규 고점 발생
{
TL[1] = TL_New_Self(IL[1,3],IL[1,4],IL[1,1],IH[1,3],IH[1,4],IH[1,1]);
tx2 = Text_New_Self(IH[1,3],IH[1,4],IH[1,1],NumToStr(IH[1,1],2));
Text_SetStyle(tx2,2,1);
}
Else // 주가의 꼭지점이 그대로라도 지표는 변하므로 매봉마다 연장처리
{
TL_SetEnd(TL[1],IH[1,3],IH[1,4],IH[1,1]);
Text_SetString(tx2,NumToStr(IH[1,1],2));
Text_SetLocation(tx2,IH[1,3],IH[1,4],IH[1,1]);
}
} Else If 고저구분 == -1 Then { // 저점
If 신규여부 == 1 Then // 주가 파동에 신규 저점 발생
{ TL[1] = TL_New_Self(IH[1,3],IH[1,4],IH[1,1],IL[1,3],IL[1,4],IL[1,1]);
tx2 = Text_New_Self(IL[1,3],IL[1,4],IL[1,1],NumToStr(IL[1,1],2));
Text_SetStyle(tx2,2,0);
}
Else
{
TL_SetEnd(TL[1],IL[1,3],IL[1,4],IL[1,1]);
Text_SetString(tx2,NumToStr(IL[1,1],2));
Text_SetLocation(tx2,IL[1,3],IL[1,4],IL[1,1]);
}
}
TL_SetSize(TL[1],1);
TL_SetColor(TL[1],BLUE);
}
#==========================================#
// 다이버전스 표시
If (kind == 1 and HH[2,1] < HH[1,1] and IH[2,1] > IH[1,1]) or
// 일반 약세 다이버전스 : 주가 고점 상승, 보조지표 고점 하락
(kind == 2 and HH[2,1] > HH[1,1] and IH[2,1] < IH[1,1]) or
// 히든 약세 다이버전스 : 주가 고점 하락, 보조지표 고점 상승
(kind == 3 and abs(HH[2,1] - HH[1,1]) <= 2 * PriceScale and IH[2,1] > IH[1,1]) Then {
// 과장된 약세 다이버전스 : 주가 고점의 차이가 2틱 이내이고 보조지표 고점 하락
Value2 = (HH[1,1]-HH[2,1])/(HH[1,2]-HH[2,2])*(Index-HH[2,2])+HH[2,1];
Value3 = (IH[1,1]-IH[2,1])/(IH[1,2]-IH[2,2])*(Index-IH[2,2])+IH[2,1];
If BeginIndex[0] == HH[2,2] Then {
// 다이버전스를 나타내는 추세선의 시작점이 변함이 없으면 추세선 끝점만 연장
TL_SetEnd(TL[2],sDate,sTime,Value2);
TL_SetEnd(TL[3],sDate,sTime,Value3);
} Else {
TL[2] = TL_New(HH[2,3],HH[2,4],HH[2,1],sDate,sTime,Value2);
TL[3] = TL_New_Self(IH[2,3],IH[2,4],IH[2,1],sDate,sTime,Value3);
BeginIndex[0] = HH[2,2]; // 추세선 시작점인 2번 고점의 index 값을 저장
}
TL_SetSize(TL[2],3);
TL_SetSize(TL[3],3);
TL_SetColor(TL[2],LGREEN);
TL_SetColor(TL[3],LGREEN);
}
If (kind == 1 and LL[2,1] > LL[1,1] and IL[2,1] < IL[1,1]) or
// 일반 강세 다이버전스 : 주가 저점 하락, 보조지표 저점 상승
(kind == 2 and LL[2,1] < LL[1,1] and IL[2,1] > IL[1,1]) or
// 히든 강세 다이버전스 : 주가 저점 상승, 보조지표 저점 하락
(kind == 3 and abs(LL[2,1] - LL[1,1]) <= 2 * PriceScale and IL[2,1] < IL[1,1]) Then {
// 과장된 강세 다이버전스 : 주가 저점의 차이가 2틱 이내, 보조지표 저점 상승
Value4 = (LL[1,1]-LL[2,1])/(LL[1,2]-LL[2,2])*(Index-LL[2,2])+LL[2,1];
Value5 = (IL[1,1]-IL[2,1])/(IL[1,2]-IL[2,2])*(Index-IL[2,2])+IL[2,1];
If BeginIndex[1] == LL[2,2] Then {
TL_SetEnd(TL[4],sDate,sTime,Value4);
TL_SetEnd(TL[5],sDate,sTime,Value5);
} Else {
TL[4] = TL_New(LL[2,3],LL[2,4],LL[2,1],sDate,sTime,Value4);
TL[5] = TL_New_Self(IL[2,3],IL[2,4],IL[2,1],sDate,sTime,Value5);
BeginIndex[1] = LL[2,2];
}
TL_SetSize(TL[4],3);
TL_SetSize(TL[5],3);
TL_SetColor(TL[4],MAGENTA);
TL_SetColor(TL[5],MAGENTA);
}
If kind == 4 and HH[3,1] < HH[1,1] and // 주가 고점 상승
(HH[1,1]-HH[3,1])/(HH[1,2]-HH[3,2])*(HH[2,2]-HH[3,2])+HH[3,1] > HH[2,1] and
// 2번 고점은 1번과 3번 고점을 잇는 선보다 밑에 위치
IH[3,1] > IH[1,1] and // 보조지표 고점 하락
(IH[1,1]-IH[3,1])/(IH[1,2]-IH[3,2])*(IH[2,2]-IH[3,2])+IH[3,1] > IH[2,1] Then {
// 2번 고점은 1번과 3번 고점을 잇는 선보다 밑에 위치
Value2 = (HH[1,1]-HH[3,1])/(HH[1,2]-HH[3,2])*(Index-HH[3,2])+HH[3,1];
Value3 = (IH[1,1]-IH[3,1])/(IH[1,2]-IH[3,2])*(Index-IH[3,2])+IH[3,1];
If BeginIndex[0] == HH[3,2] Then {
TL_SetEnd(TL[2],sDate,sTime,Value2);
TL_SetEnd(TL[3],sDate,sTime,Value3);
} Else {
TL[2] = TL_New(HH[3,3],HH[3,4],HH[3,1],sDate,sTime,Value2);
TL[3] = TL_New_Self(IH[3,3],IH[3,4],IH[3,1],sDate,sTime,Value3);
BeginIndex[0] = HH[3,2];
}
TL_SetSize(TL[2],3);
TL_SetSize(TL[3],3);
TL_SetColor(TL[2],LGREEN);
TL_SetColor(TL[3],LGREEN);
}
If kind == 4 and LL[3,1] > LL[1,1] and // 주가 저점 하락
(LL[1,1]-LL[3,1])/(LL[1,2]-LL[3,2])*(LL[2,2]-LL[3,2])+LL[3,1] < LL[2,1] and
// 2번 저점이 1번,3번 저점을 잇는 선보다 위에 위치
IL[3,1] < IL[1,1] and // 보조지표 저점 상승
(IL[1,1]-IL[3,1])/(IL[1,2]-IL[3,2])*(IL[2,2]-IL[3,2])+IL[3,1] < IL[2,1] Then {
Value4 = (LL[1,1]-LL[3,1])/(LL[1,2]-LL[3,2])*(Index-LL[3,2])+LL[3,1];
Value5 = (IL[1,1]-IL[3,1])/(IL[1,2]-IL[3,2])*(Index-IL[3,2])+IL[3,1];
If BeginIndex[1] == LL[3,2] Then {
TL_SetEnd(TL[4],sDate,sTime,Value4);
TL_SetEnd(TL[5],sDate,sTime,Value5);
} Else {
TL[4] = TL_New(LL[3,3],LL[3,4],LL[3,1],sDate,sTime,Value4);
TL[5] = TL_New_Self(IL[3,3],IL[3,4],IL[3,1],sDate,sTime,Value5);
BeginIndex[1] = LL[3,2];
}
TL_SetSize(TL[4],3);
TL_SetSize(TL[5],3);
TL_SetColor(TL[4],MAGENTA);
TL_SetColor(TL[5],MAGENTA);
}
2020-03-26
938
글번호 137246
wko7856 님에 의해서 삭제되었습니다.
2020-03-26
0
글번호 137242
답변완료
로직부탁드립니다
예스그로벌을 이용해 NH선물에서 거래하려고 합니다
수식을 부탁드립니다
요청수식
20ma-120ma 골든크로시하였을 때
시가(dayopen(0)) 위에서
v3<v4 이면 매수 진입 후
매수 청산은 v3>v4 또는 익절 100틱이던지 손절 50틱 매수 청산
{v3 = (DayHigh(0)+ DayLow(0))/2;
v4 = (DayHigh(0)+ DayLow(0) + DayClose(0))/3;}
20ma-120ma 대드크로시하였을 때
시가(dayopen(0)) 아래에서
v3>v4 이면 매도 진입 후
매수 청산은 v3<v4 또는 익절 100틱이던지 손절 50틱 매도 청산
{v3 = (DayHigh(0)+ DayLow(0))/2;
v4 = (DayHigh(0)+ DayLow(0) + DayClose(0))/3;}
2020-03-26
699
글번호 137241
답변완료
Trix지표와 함수결과값의 차이
아래코딩 (1)에서 특정분봉(여기선 하루) Trix 값을 현재분봉에 나타내는 코딩으로 이전분의 질문을 바탕으로 공부하고 있는데 이것을 사용자함수(2번)로 전환하여 비교해 보니까 값이 다르게 나옵니다. (1)의 내용을 사용자함수로 만들고 싶은데 어떻게 수정해야 할까요?
항상 감사합니다.
(1)
Input : ntime(390),Period(20),signal(9);
var : S1(0),D1(0),TM(0),TF1(0),EP1(0),EP2(0);
Var : emav1(0),PreEmav1(0);
Var : emav2(0),PreEmav2(0);
Var : emav3(0),PreEmav3(0);
var : TRIXv(0),TRIXs(0),PreTRIXs(0);
EP1 = 2/(Period+1);
EP2 = 2/(Signal+1);
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;
TF1 = TM%ntime;
if Bdate != Bdate[1] or (Bdate == Bdate[1] and TF1 < TF1[1]) Then
{
value1 = value1+1;
PreEmav1 = emav1[1];
PreEmav2 = emav2[1];
PreEmav3 = emav3[1];
PreTRIXs = TRIXs[1];
}
if value1 <= 1 then {
emav1 = C;
emav2 = emav1;
emav3 = emav2;
TRIXv = (emav3 - PreEmav3) / PreEmav3 * 100;
TRIXS = TRIXv;
}
else{
emav1 = C * EP1 + PreEmav1 * (1-EP1);
emav2 = emav1 * EP1 + PreEmav2 * (1-EP1);
emav3 = emav2 * EP1 + PreEmav3 * (1-EP1);
TRIXv = (emav3 - PreEmav3) / PreEmav3 * 100;
TRIXs = TRIXv * EP2 + PreTRIXs * (1-EP2);
}
PLOT1(TRIXv);
PLOT2(TRIXs);
if CrossUp(TRIXv, TRIXs) then Plot3(TRIXv, "GC"); else NoPlot(3);
}
2)
var50 = D_Trix(360, 20, 9);
if var50 == 1 then Plot4(5, "Check"); else NoPlot(4);
<사용자함수 >
Input : ntime(Numeric),Period(Numeric),signal(Numeric);
var : S1(0),D1(0),TM(0),TF1(0),EP1(0),EP2(0);
Var : emav1(0),PreEmav1(0);
Var : emav2(0),PreEmav2(0);
Var : emav3(0),PreEmav3(0);
var : TRIXv(0),TRIXs(0),PreTRIXs(0);
EP1 = 2/(Period+1);
EP2 = 2/(Signal+1);
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;
TF1 = TM%ntime;
if Bdate != Bdate[1] or (Bdate == Bdate[1] and TF1 < TF1[1]) Then
{
value1 = value1+1;
PreEmav1 = emav1[1];
PreEmav2 = emav2[1];
PreEmav3 = emav3[1];
PreTRIXs = TRIXs[1];
}
if value1 <= 1 then {
emav1 = C;
emav2 = emav1;
emav3 = emav2;
TRIXv = (emav3 - PreEmav3) / PreEmav3 * 100;
TRIXS = TRIXv;
}
else{
emav1 = C * EP1 + PreEmav1 * (1-EP1);
emav2 = emav1 * EP1 + PreEmav2 * (1-EP1);
emav3 = emav2 * EP1 + PreEmav3 * (1-EP1);
TRIXv = (emav3 - PreEmav3) / PreEmav3 * 100;
TRIXs = TRIXv * EP2 + PreTRIXs * (1-EP2);
}
# PLOT1(TRIXv);
# PLOT2(TRIXs);
if CrossUp(TRIXv, TRIXs) then var30 = 1; else var30 = 0;
}
내_Trix = var30;
2020-03-26
763
글번호 137236