커뮤니티
글번호 43874 재질문
2015-09-04 14:54:51
106
글번호 90068
글번호 43874번 재질문입니다.
답변해주신 함수에 진입한 봉에서 청산이 아닌
진입 봉 이후 익봉 이상에서 청산하는 함수를 추가해서 다시 한번 수정 부탁드립니다.
답변 1
예스스탁 예스스탁 답변
2015-09-04 15:50:09
안녕하세요
예스스탁입니다.
var : entry1(0),entry2(0),entry3(0),Entry(0);
var : ho1(0),OL1(0),HL1(0);
var : maho1(0),maOL1(0),maHL1(0);
var : cnt1(0),sumho1(0),sumOL1(0),sumHL1(0);
var : EntryCnt1(0);
var : V1(0),V2(0),V3(0),V4(0),V5(0);
var : V6(0),V7(0),V8(0),V9(0),V10(0);
if bdate != bdate[1] Then{
Entry = 0;
entry1 = 0;
entry2 = 0;
entry3 = 0;
}
if MarketPosition != 0 and MarketPosition != MarketPosition[1] Then
Entry = Entry+1;
if MarketPosition != 0 and MarketPosition != MarketPosition[1] and IsEntryName("s1") == true Then
entry1 = entry1+1;
if MarketPosition != 0 and MarketPosition != MarketPosition[1] and IsEntryName("s2") == true Then
entry2 = entry2+1;
if MarketPosition != 0 and MarketPosition != MarketPosition[1] and IsEntryName("b") == true Then
entry3 = entry3+1;
ho1 = Dayhigh-Dayopen;
OL1 = DayOpen-DayLow;
HL1 = DayHigh-DayLow;
sumho1 = 0;
sumOL1 = 0;
sumHL1 = 0;
for cnt1 = 1 to 10{
sumho1 = sumho1 + (dayhigh(cnt1)-dayopen(cnt1));
sumOL1 = sumOL1 + (DayOpen(cnt1)-DayLow(cnt1));
sumHL1 = sumHL1 + (DayHigh(cnt1)-DayLow(cnt1));
}
maho1 = sumho1/10;
maOL1 = sumOL1/10;
maHL1 = sumHL1/10;
V1 = dayopen(0)+maho1;
V2 = DayOpen(0)-maOL1;
V3 = DayOpen(0)+maHL1;
V4 = DayOpen(0)-maHL1;
V5 = NthMaxList(1,V1,V2,V3,V4);
V6 = NthMaxList(2,V1,V2,V3,V4);
V9 = NthMaxList(3,V1,V2,V3,V4);
V10 = NthMaxList(4,V1,V2,V3,V4);
V7 = (V5+V10)/2;
V8 = (V6+V9)/2;
if MarketPosition == 0 AND Entry == 0 Then{
if V7 > V8 and entry1 == 0 Then
sell("s1",AtStop,V7-0.02);
if V7 < V8 and entry2 == 0 Then
sell("s2",Atlimit,V8-0.02);
}
if MarketPosition == -1 and IsEntryName("s1") == true Then{
ExitShort("sp1",atlimit,V9-0.03);
ExitShort("sl1",AtStop,V6);
}
if MarketPosition == -1 and IsEntryName("s2") == true Then{
ExitShort("sp2",atlimit,V9-0.03);
ExitShort("sl2",AtStop,V6);
}
var : TF(0);
var : Xtime(0), Etime(false),cnt(0),mav1(0),mav2(0);
var : HV(0),LV(0),HV1(0),LV1(0),HV2(0),LV2(0);
Array : HH[50](0),LL[50](0),CC[50](0);
mav1 = ma(c,5);
mav2 = ma(C,20);
TF = TimeToMinutes(stime)%30;
if Bdate != Bdate[1] Then{
Etime = true;
if stime >= 090000 Then
Xtime = 050000;
Else
Xtime = 060000;
}
if Bdate != Bdate[1] or (TF < TF[1] and stime > stime[1]) or date != date[1] Then{
HH[0] = H;
LL[0] = L;
for cnt = 1 to 49{
HH[cnt] = HH[cnt-1][1];
LL[cnt] = LL[cnt-1][1];
CC[cnt] = CC[cnt-1][1];
}
}
if H > HH[0] Then
HH[0] = H;
if L < LL[0] Then
LL[0] = L;
CC[0] = C;
if HH[25+2] > 0 Then{
HV = HH[0];
LV = LL[0];
HV1 = HH[1];
LV1 = LL[1];
HV2 = HH[2];
LV2 = LL[2];
for cnt = 0 to 25{
if HH[cnt] > HV Then
HV = HH[cnt];
if LL[cnt] < LV Then
LV = LL[cnt];
if HH[cnt+1] > HV Then
HV = HH[cnt+1];
if LL[cnt+1] < LV Then
LV = LL[cnt+1];
if HH[cnt+2] > HV Then
HV = HH[cnt+2];
if LL[cnt+2] < LV Then
LV = LL[cnt+2];
}
var1 = (HV+LV)/2;
var2 = (HV1+LV1)/2;
var3 = (HV2+LV2)/2;
if Etime == true then{
if MarketPosition == 0 and CC[0] > var1 and CC[1] < var2 and CC[2] < var3 and C >= daylow+0.5 and entry3 == 0 AND Entry == 0 Then
buy("b",AtMarket);
if MarketPosition == 1 and c <= highest(H,BarsSinceEntry)-0.5 and CrossDown(mav1,mav2) Then
ExitLong("bx",AtMarket);
}
}
if stime == Xtime or (stime > Xtime and stime[1] < Xtime) Then{
Etime = false;
ExitLong();
}
if MarketPosition == 1 Then{
ExitLong("bl",AtStop,EntryPrice*0.992);
ExitLong("bp",Atlimit,EntryPrice*1.03);
if highest(H,BarsSinceEntry) < EntryPrice*1.03 and BarsSinceEntry == 23 Then
exitlong("bi");
}
if MarketPosition == -1 Then{
ExitShort("sl",AtStop,EntryPrice*1.008);
ExitShort("sp",Atlimit,EntryPrice*0.97);
if Lowest(L,BarsSinceEntry) > EntryPrice*0.97 and BarsSinceEntry == 23 Then
ExitShort("si");
}
2.
var : entry1(0),entry2(0),entry3(0),entry(0);
var : NP(0),NP1(0),NP2(0);
var : ho(0),OL(0),HL(0);
var : maho(0),maOL(0),maHL(0);
var : cnt(0),sumho(0),sumOL(0),sumHL(0);
var : EntryCnt(0),cond1(false);
var : V1(0),V2(0),V3(0),V4(0),V5(0),V6(0),V7(0),V8(0),V9(0),V10(0);
NP = NetProfit;
if bdate != bdate[1] Then{
entry = 0;
entry1 = 0;
entry2 = 0;
entry3 = 0;
NP1 = NP[1];
NP2 = NP1[1];
Cond1 = true;
if NP1 > NP2 Then
cond1 = false;
}
if MarketPosition != 0 and MarketPosition != MarketPosition[1] Then
entry = entry+1;
if MarketPosition != 0 and MarketPosition != MarketPosition[1] and IsEntryName("s1") == true Then
entry1 = entry1+1;
if MarketPosition != 0 and MarketPosition != MarketPosition[1] and IsEntryName("s2") == true Then
entry2 = entry2+1;
if MarketPosition != 0 and MarketPosition != MarketPosition[1] and IsEntryName("b") == true Then
entry3 = entry3+1;
ho = Dayhigh-Dayopen;
OL = DayOpen-DayLow;
HL = DayHigh-DayLow;
sumho = 0;
sumOL = 0;
sumHL = 0;
for cnt = 1 to 10{
sumho = sumho + (dayhigh(cnt)-dayopen(cnt));
sumOL = sumOL + (DayOpen(cnt)-DayLow(cnt));
sumHL = sumHL + (DayHigh(cnt)-DayLow(cnt));
}
maho = sumho/10;
maOL = sumOL/10;
maHL = sumHL/10;
V1 = dayopen(0)+maho;
V2 = DayOpen(0)-maOL;
V3 = DayOpen(0)+maHL;
V4 = DayOpen(0)-maHL;
V5 = NthMaxList(1,V1,V2,V3,V4);
V6 = NthMaxList(2,V1,V2,V3,V4);
V9 = NthMaxList(3,V1,V2,V3,V4);
V10 = NthMaxList(4,V1,V2,V3,V4);
V7 = (V5+V10)/2;
V8 = (V6+V9)/2;
if MarketPosition == 0 and cond1 == true and entry == 0 Then{
if V7 > V8 and entry1 == 0 Then
sell("s1",AtStop,V7-0.02);
if V7 < V8 and entry2 == 0 Then
sell("s2",Atlimit,V8-0.02);
}
if MarketPosition == -1 and IsEntryName("s1") == true Then{
ExitShort("sp1",atlimit,V9-0.03);
ExitShort("sl1",AtStop,V6);
}
if MarketPosition == -1 and IsEntryName("s2") == true Then{
ExitShort("sp2",atlimit,V9-0.03);
ExitShort("sl2",AtStop,V6);
}
var : TF(0);
var : Xtime(0), Etime(false),mav1(0),mav2(0);
var : HV(0),LV(0),HV1(0),LV1(0),HV2(0),LV2(0);
Array : HH[50](0),LL[50](0),CC[50](0);
mav1 = ma(c,5);
mav2 = ma(C,20);
TF = TimeToMinutes(stime)%30;
if Bdate != Bdate[1] Then{
Etime = true;
if stime >= 090000 Then
Xtime = 060000;
Else
Xtime = 060000;
}
if Bdate != Bdate[1] or (TF < TF[1] and stime > stime[1]) or date != date[1] Then{
HH[0] = H;
LL[0] = L;
for cnt = 1 to 49{
HH[cnt] = HH[cnt-1][1];
LL[cnt] = LL[cnt-1][1];
CC[cnt] = CC[cnt-1][1];
}
}
if H > HH[0] Then
HH[0] = H;
if L < LL[0] Then
LL[0] = L;
CC[0] = C;
if HH[25+2] > 0 Then{
HV = HH[0];
LV = LL[0];
HV1 = HH[1];
LV1 = LL[1];
HV2 = HH[2];
LV2 = LL[2];
for cnt = 0 to 25{
if HH[cnt] > HV Then
HV = HH[cnt];
if LL[cnt] < LV Then
LV = LL[cnt];
if HH[cnt+1] > HV Then
HV = HH[cnt+1];
if LL[cnt+1] < LV Then
LV = LL[cnt+1];
if HH[cnt+2] > HV Then
HV = HH[cnt+2];
if LL[cnt+2] < LV Then
LV = LL[cnt+2];
}
var1 = (HV+LV)/2;
var2 = (HV1+LV1)/2;
var3 = (HV2+LV2)/2;
if Etime == true then{
if MarketPosition == 0 and CC[0] > var1 and CC[1] < var2 and CC[2] < var3 and C >= daylow+0.5 and entry3 == 0 and entry == 0 Then
buy("b",AtMarket);
if MarketPosition == 1 and c <= highest(H,BarsSinceEntry)-0.5 and CrossDown(mav1,mav2) Then
ExitLong("bx",AtMarket);
}
}
if stime == Xtime or (stime > Xtime and stime[1] < Xtime) Then{
Etime = false;
ExitLong();
}
if MarketPosition == 1 Then{
ExitLong("bl",AtStop,EntryPrice*0.992);
ExitLong("bp",Atlimit,EntryPrice*1.03);
if highest(H,BarsSinceEntry) < EntryPrice*1.03 and BarsSinceEntry == 23 Then
exitlong("bi");
}
if MarketPosition == -1 Then{
ExitShort("sl",AtStop,EntryPrice*1.008);
ExitShort("sp",Atlimit,EntryPrice*0.97);
if Lowest(L,BarsSinceEntry) > EntryPrice*0.97 and BarsSinceEntry == 23 Then
ExitShort("si");
}
즐거운 하루되세요
> 통큰베팅 님이 쓴 글입니다.
> 제목 : 글번호 43874 재질문
> 글번호 43874번 재질문입니다.
답변해주신 함수에 진입한 봉에서 청산이 아닌
진입 봉 이후 익봉 이상에서 청산하는 함수를 추가해서 다시 한번 수정 부탁드립니다.