답변완료
문의드립니다.
차트내 분홍색 사각형 발생시 사각형고점을 돌파하는 수식 요청합니다.
input:length(12);
Var:j(0),lastHiVal(0),lastLoVal(0),sBar(0),eBar(0),TL1(0),Text1(0),process(0),T(0);
Array:HH[10,2](0),LL[10,2](0);
process=0;
If Highest(H,length)==H and lastHiVal <> H and Lowest(L,length)==L and lastLoVal<>L Then
{
If LL[1,1]>L Then process=-1;
If HH[1,1]<H Then process=1;
}
Else If Highest(H,length)==H and lastHiVal <> H Then process=1;
Else If Lowest(L,length)==L and lastLoVal <> L Then process=-1;
If process==1 Then
{
T=1;
lastHiVal=H;
If HH[1,2]<LL[1,2] Then
{
For j=10 DownTo 2
{
HH[j,1]=HH[j-1,1];
HH[j,2]=HH[j-1,2];
}
}
If HH[1,2]<LL[1,2] or HH[1,1]<H Then
{
HH[1,1]=H;
HH[1,2]=Index;
sBar=Index-LL[1,2];
eBar=0;
If TL_GetBeginDate(TL1)==sDate[sBar]and TL_GetBeginTime(TL1)==sTime[sBar] Then
{
TL_Delete(TL1);
Text_Delete(Text1);
}
if LL[1,1]>0 Then
{
TL1=TL_New(sDate[sBar],sTime[sBar],LL[1,1],sDate[eBar],sTime[eBar],HH[1,1]);
Text1=Text_New(sDate[eBar],sTime[eBar],HH[1,1],NewLine+NumToStr(HH[1,1],2));
Text_SetStyle(Text1,2,1);
}
Else
{
Text_Delete(text1);
Text1=Text_New(sDate[eBar],sTime[eBar],HH[1,1],NewLine+NumToStr(HH[1,1],2));
Text_SetStyle(Text1,2,1);
}
Text_SetStyle(Text1,2,1);
}
}
If process==-1 Then
{
T=-1;
lastLoVal=L;
If LL[1,2]<HH[1,2] Then
{
For j=10 DownTo 2
{
LL[j,1]=LL[j-1,1];
LL[j,2]=LL[j-1,2];
}
}
If LL[1,2]<HH[1,2] or LL[1,1]> L Then
{
LL[1,1]=L;
LL[1,2]=Index;
sBar=Index-HH[1,2];
eBar=0;
If TL_GetBeginDate(TL1)==sDate[sBar] and TL_GetBeginTime(TL1)==sTime[sBar] Then
{
TL_Delete(TL1);
Text_Delete(Text1);
}
if HH[1,1]> 0 Then
{
TL1=TL_New(sDate[sBar],sTime[sBar],HH[1,1],sDate[eBar],sTime[eBar],LL[1,1]);
Text1=Text_New(sDate[eBar],sTime[eBar],LL[1,1],NumToStr(LL[1,1],2));
Text_SetStyle(Text1,2,0);
}
Else
{
Text_Delete(text1);
Text1=Text_New(sDate[eBar],sTime[eBar],LL[1,1],NumToStr(LL[1,1],2));
Text_SetStyle(Text1,2,0);
}
}
}
2023-02-07
1356
글번호 166053
종목검색
답변완료
함수요청
안녕하세요?
아래 글번호 80621번 재질문입니다.
답변주신 스크랩트에 하루 n번 진입 제어를 하고 싶습니다.
스크립트 수정 부탁드립니다.
아래와 같이 변경해보았는데 신호가 생성안되네요
1
input : 최대진입횟수(5);
Var : Entry(0);
Var : mav(0);
mav = ma(c,100);
if (MarketPosition != 0 and MarketPosition != MarketPosition[1]) or
(MarketPosition == MarketPosition[1] and TotalTrades > TotalTrades[1]) Then
entry = entry+1;
if MarketPosition <= 0 and
NextBarSdate == sDate and
((Bdate != Bdate[2] and CountIF(C>DayOpen,2) == 2) or
(Bdate == Bdate[2] and CountIF(C>DayOpen,2) == 2 and C[2] < DayOpen)) and entry < 최대진입횟수 Then
Buy("b",AtMarket);
if MarketPosition == 1 Then
{
if CountIf(C<DayOpen,2) == 2 and BarsSinceEntry >= 2 Then
ExitLong("bx1",AtMarket);
if CountIf(C>DayOpen,4) == 4 and BarsSinceEntry >= 4 Then
ExitLong("bx2",AtMarket);
if CrossUp(c,mav) or CrossDown(c,mav) then
ExitLong("bx3",AtMarket);
}
SetStopEndofday(152000);
---------------------------------------------------------------------------
안녕하세요
예스스탁입니다.
1
Var : mav(0);
mav = ma(c,100);
if MarketPosition <= 0 and
NextBarSdate == sDate and
((Bdate != Bdate[2] and CountIF(C>DayOpen,2) == 2) or
(Bdate == Bdate[2] and CountIF(C>DayOpen,2) == 2 and C[2] < DayOpen)) Then
Buy("b",AtMarket);
if MarketPosition == 1 Then
{
if CountIf(C<DayOpen,2) == 2 and BarsSinceEntry >= 2 Then
ExitLong("bx1",AtMarket);
if CountIf(C>DayOpen,4) == 4 and BarsSinceEntry >= 4 Then
ExitLong("bx2",AtMarket);
if CrossUp(c,mav) or CrossDown(c,mav) then
ExitLong("bx3",AtMarket);
}
SetStopEndofday(152000);
2
Var : mav(0);
mav = ma(c,100);
if MarketPosition >= 0 and
NextBarSdate == sDate and
((Bdate != Bdate[2] and CountIF(C<DayOpen,2) == 2) or
(Bdate == Bdate[2] and CountIF(C<DayOpen,2) == 2 and C[2] > DayOpen)) Then
Sell("s",AtMarket);
if MarketPosition == -1 Then
{
if CountIf(C>DayOpen,2) == 2 and BarsSinceEntry >= 2 Then
ExitShort("sx1",AtMarket);
if CountIf(C<DayOpen,4) == 4 and BarsSinceEntry >= 4 Then
ExitShort("sx2",AtMarket);
if CrossUp(c,mav) or CrossDown(c,mav) then
ExitLong("bx3",AtMarket);
}
SetStopEndofday(152000);
즐거운 하루되세요
> 흰둥이아빠 님이 쓴 글입니다.
> 제목 : 함수요청
> 안녕하세요?
아래 글번호 80612번 연장선상에서 질문드립니다.
(답변주신 스크립트는 첫봉에서 부터 신호가 생성됩니다.)
국내선물 1분봉으로 일중거래를 하고자 합니다.
[1]
당일 시가선 기준으로 2번 연속 돌파되면 익봉 시가 매수
당일 시가선 기준으로 2번 연속 이탈되면 익봉 시가 매수청산
당일 시가선 기준으로 4번 연속 돌파되면 익봉 시가 매수청산
100ma 돌파 및 이탈시 익봉 시가 매수청산
[2]
당일 시가선 기준으로 2번 연속 이탈되면 익봉 시가 매도
당일 시가선 기준으로 2번 연속 돌파되면 익봉 시가 매도청산
당일 시가선 기준으로 4번 연속 이탈되면 익봉 시가 매도청산
100ma 돌파 및 이탈시 익봉 시가 매도청산
청산조건은 or이며 15:20에는 강제청산입니다.
1번과 2번 각각의 스크립트 작성을 부탁드립니다.
2023-02-07
1044
글번호 166052
시스템
답변완료
추세선 반등
input : Period(35);
Var:j(0),T(0);
Var: date11(0),date12(0),time11(0),time12(0),TL1(0),TL(0),tl9(0),
date21(0),date22(0),time21(0),time22(0),txx(0), vTL(0), vTL9(0),txxx(0),
date31(0),date32(0),time31(0),time32(0),tx(0),tx1(0),tl4(0);
Array:HiVal[20](0),LoVal[20](0),HiBar[20](0),LoBar[20](0);
Array:r[7](0),fr[7](0),TL2[7](0),TL3[7](0),TX2[7](0),TX3[7](0);
For j = 0 To 19
Plot1(0);
{
HiBar[j] = HiBar[j] + 1;
LoBar[j] = LoBar[j] + 1;
}
if crossup(c,highest(H,Period)[1]) Then
T = 1;
if CrossDown(c,Lowest(L,Period)[1]) Then
T = -1;
If T == -1 Then
{
If T[1] != -1 Then
{
For j = 18 DownTo 0
{
LoVal[j+1] = LoVal[j];
LoBar[j+1] = LoBar[j];
}
LoVal[0] = L;
LoBar[0] = 0;
date11 = date[HiBar[0]];
time11 = stime[HiBar[0]];
Value11 = HiVal[0];
date12 = date[LoBar[0]];
time12 = stime[LoBar[0]];
Value12 = LoVal[0];
date21 = date[HiBar[0]];
time21 = stime[HiBar[0]];
date22 = date[0];
time22 = stime[0];
for j = 0 to 6
{
fr[j] = LoVal[1] + ((HiVal[0] - LoVal[1]) * r[j]);
}
Condition1 = False;
}
Else
{
If LoVal[0] > L Then
{
LoVal[0] = L;
LoBar[0] = 0;
date12 = date[LoBar[0]];
time12 = stime[LoBar[0]];
Value12 = LoVal[0];
date22 = date[0];
time22 = stime[0];
Text_Delete(tx);
Condition1 = False;
}
Else
{
if Condition1 == False and Value12 <= value11-0.3 and Value12 >= value11-0.45 and
C >= value12+PriceScale*2 Then
{
Condition1 = true;
Text_Delete(txx-2);
txx = Text_New(sdate,sTime,H-PriceScale*4,"●");
Text_SetStyle(txx,2,2);
Text_SetColor(txx,Green);
Text_SetSize(txx,15);
}
}
}
}
If T == 1 Then
{
If T[1] != 1 Then
{
For j = 18 DownTo 0
{
HiVal[j+1] = HiVal[j];
HiBar[j+1] = HiBar[j];
}
HiVal[0] = H;
HiBar[0] = 0;
date11 = date[LoBar[0]];
time11 = stime[LoBar[0]];
Value11 = LoVal[0];
date12 = date[HiBar[0]];
time12 = stime[HiBar[0]];
Value12 = HiVal[0];
date31 = date[LoBar[0]];
time31 = stime[LoBar[0]];
date32 = date[0];
time32 = stime[0];
for j = 0 to 5
{
fr[j] = LoVal[0] + ((HiVal[1] - LoVal[0]) * r[j]);
}
}
If HiVal[0] < H Then
{
HiVal[0] = H;
HiBar[0] = 0;
date12 = date[HiBar[0]];
time12 = stime[HiBar[0]];
Value12 = HiVal[0];
date32 = date[0];
time32 = stime[0];
}
}
반등의 저점이(종가도 무관) 당일 고점에서 -1.2p 아래일 때만 동그라미 표시되게 부탁드립니다.
2023-02-07
1075
글번호 166051
지표
답변완료
부탁 드립니다
항상 노고에 감사 드리며
다름이 아니라 chandelier Exit 에 박스처리를 하려했는데...짜집기 오류가되서
수정 부탁드립니다
input : length(28),mult(5.0),showLabels(true),useClose(true),highlightState(true);
var : ATrv(0),longStop(0),longStopprev(0),shortStop(0),shortStopPrev(0);
var : dir(1),longcolor(Red),shortcolor(Blue),tx(0);
var : Tsl(0),linecolor(0);
var : hv(0),lv(0),dv(0),tv(0),box(0),tx(0);
atrv = mult * atr(length);
longStop = IFf(useClose , highest(close, length) , highest(h,length)) - atrv;
longStopPrev = longStop[1];
longStop = iff(close[1] > longStopPrev , max(longStop, longStopPrev) , longStop);
shortStop = IFf(useClose , lowest(close, length) , lowest(L,length)) + atrv;
shortStopPrev = shortStop[1];
shortStop = iff(close[1] < shortStopPrev , min(shortStop, shortStopPrev) , shortStop);
dir = iff(close > shortStopPrev , 1 ,iff( close < longStopPrev , -1 , dir));
IF dir == 1 Then
{
plot1(longStop,"Long Stop",longColor);
NoPlot(2);
}
Else
{
NoPlot(1);
plot2(shortStop,"Short Stop",shortColor);
}
if dir == 1 and dir[1] == -1 Then
{
tx = Text_New(sDate,sTime,longStop,"▲");
Text_SetStyle(tx,2,0);
Text_SetColor(tx,longcolor);
Text_setsize(Tx,25);
}
if dir == -1 and dir[1] == 1 Then
{
tx = Text_New(sDate,sTime,shortStop,"▼");
Text_SetStyle(tx,2,1);
Text_SetColor(tx,shortcolor);
Text_setsize(Tx,25);
}
if Long Stop == 1 Then
if Long Stop !=Long Stop [1] Then
{
if hv-lv < 0.5 Then
Text_Delete(tx);
Else
Text_SetSize(tx,15);
hv = Tsl;
lv = Tsl;
dv = sDate;
tv = sTime;
box = Box_New(sDate,sTime,hv,NextBarSdate,NextBarStime,lv);
tx = Text_New(NextBarSdate,NextBarStime,hv,NumToStr(hv-lv,2));
Text_SetStyle(tx,2,1);
Text_SetSize(tx,20);
}
Else
{
if Tsl > hv Then
hv = Tsl;
if Tsl < lv Then
lv = Tsl;
Box_SetBegin(box,dv,tv,hv);
Box_SetEnd(box,NextBarSdate,NextBarStime,lv);
Box_SetColor(box,Red);
Box_SetFill(box,true);
Text_SetString(tx,NumToStr(hv-lv,2));
Text_SetLocation(tx,NextBarSdate,NextBarStime,hv);
}
}
if Short Stop == -1 Then
{
if Short Stop != Short Stop[1] Then
{
if hv-lv < 0.5 Then
Text_Delete(tx);
Else
Text_SetSize(tx,15);
hv = Tsl;
lv = Tsl;
dv = sDate;
tv = sTime;
box = Box_New(sDate,sTime,hv,NextBarSdate,NextBarStime,lv);
tx = Text_New(NextBarSdate,NextBarStime,hv,NumToStr(hv-lv,2));
Box_SetColor(box,Blue);
Box_SetFill(box,true);
Text_SetStyle(tx,2,1);
Text_SetSize(tx,20);
}
Else
{
if Tsl > hv Then
hv = Tsl;
if Tsl < lv Then
lv = Tsl;
Box_SetBegin(box,dv,tv,hv);
Box_SetEnd(box,NextBarSdate,NextBarStime,lv);
Text_SetString(tx,NumToStr(hv-lv,2));
Text_SetLocation(tx,NextBarSdate,NextBarStime,hv);
}
}
2023-02-06
569
글번호 166047
지표