人人爽天天爽夜夜爽qc-人人爽天天爽夜夜爽曰-人人天天爱天天做天天摸-人人天天夜夜-色网站在线-色网站在线看

您現(xiàn)在的位置:程序化交易>> 程序化交易>> 系統(tǒng)交易>>正文內(nèi)容

Super Cobmo超級組合當(dāng)沖交易系統(tǒng)[系統(tǒng)交易]

Super Cobmo超級組合當(dāng)沖交易系統(tǒng)


今天想要報(bào)告的是Building Winning Trading Systems with TradeStation裡面的最后一個(gè)交易系統(tǒng)。名稱叫做Super Combo Day Trading Strategy,中文我翻譯成超級組合當(dāng)沖交易系統(tǒng)。

 

 

這個(gè)系統(tǒng)的內(nèi)容就像他的名字一樣,把相當(dāng)多的觀念和技術(shù)組合起來,以致于讓這個(gè)系統(tǒng)太複雜,跟我認(rèn)為交易系統(tǒng)應(yīng)該要越簡單越好的觀念稍有出入。所以我就不仔細(xì)介紹這個(gè)當(dāng)沖系統(tǒng)的觀念,只把他的程式碼分享出來。如果有人想試用這個(gè)系統(tǒng)的話,記得要在chart 裡面insert兩個(gè)symbol, 分別是這個(gè)商品的5min的線圖,和1日的線圖。因?yàn)檫@個(gè)系統(tǒng)會用到data2(也就是日線)的資料。我自己是簡單測試過臺指期的資料了,看來績效很爛,所以怕麻煩的人可以不用試了。

 

以下是EASYLANUAGE 語言

 

 

 

{Super Combo by George Pruitt

This intraday trading system will illustrate the multiple data handling

capabilities of TradeStation. All pertinent buy and sell calculations will be

based on daily bars and actual trades will be executed on 5-min bars. I have

made most of the parameters input variables.}

 

Inputs:waitPeriodMins(30),initTradesEndTime(1430),liqRevEndTime(1200),

thrustPrcnt1(0.30),thrustPrcnt2(0.60),breakOutPrcnt(0.25),

failedBreakOutPrcnt(0.25),protStopPrcnt1(0.25),protStopPrcnt2(0.15),

protStopAmt(3.00),breakEvenPrcnt(0.50),avgRngLength(10),avgOCLength(10);

Variables:averageRange(0),averageOCRange(0),canTrade(0),buyEasierDay(FALSE),

sellEasierDay(FALSE),buyBOPoint(0),sellBOPoint(0),longBreakPt(0),

shortBreakPt(0),longFBOPoint(0),shortFBOPoint(0),barCount(0),

intraHigh(0),intraLow(999999),buysToday(0),sellsToday(0),

currTrdType(0),longLiqPoint(0),shortLiqPoint(0),yesterdayOCRRange(0),

intraTradeHigh(0),intraTradeLow(999999);

{Just like we did in the pseudocode—let's start out with the daily bar

calculations. If Date <> Date[1]—first bar of day}

if(Date <> Date[1]) then {save time by doing these calculations once per day}

begin

averageRange = Average(Range,10) of Data2; {Data 2 points to daily bars}

yesterdayOCRRange = AbsValue(Open of Data2-Close of Data2);

averageOCRange = Average(AbsValue(Open of Data2-Close of Data2),10);

canTrade = 0;

if(yesterdayOCRRange< 0.85*averageOCRange) then canTrade = 1;

buyEasierDay = FALSE;

sellEasierDay = FALSE;

{See how we refer to Data2 - the daily data}

if(Close of Data2 <= Close[1] of Data2) then buyEasierDay = TRUE;

if(Close of Data2 > Close[1] of Data2) then sellEasierDay = TRUE;

if(buyEasierDay) then

begin

buyBOPoint = Open of data1 + thrustPrcnt1*averageRange;

sellBOPoint = Open of data1 - thrustPrcnt2*averageRange;

 

 

 

end;

if(sellEasierDay) then

begin

sellBOPoint = Open of data1 - thrustPrcnt1*averageRange;

buyBOPoint = Open of data1 + thrustPrcnt2*averageRange;

end;

longBreakPt = High of Data2 + breakOutPrcnt*averageRange;

shortBreakPt = Low of Data2 - breakOutPrcnt*averageRange;

shortFBOPoint = High of Data2 - failedBreakOutPrcnt*averageRange;

longFBOPoint = Low of Data2 + failedBreakOutPrcnt*averageRange;

{Go ahead and initialize any variables that we may need later on in the day}

barCount = 0;

intraHigh = 0;intraLow = 999999; {Didn't know you could do this}

buysToday = 0;sellsToday = 0;{You can put multiple statements on one

line}

currTrdType = 0;

end; {End of the first bar of data}

{Now let's trade and manage on 5-min bars}

if(High > intraHigh) then intraHigh = High;

if(Low < intraLow ) then intraLow = Low;

barCount = barCount + 1; {count the number of bars of intraday data}

if(barCount > waitPeriodMins/BarInterval and canTrade = 1) then

{have we waited long enough—wait PeriodMin is an input variable and

BarInterval is set by TradeStation. Wait PeriodMins = 30 and BarInterval = 5,

so 30/5 = 6}

begin

if(MarketPosition = 0) then

begin

intraTradeHigh = 0;

intraTradeLow = 999999;

end;

if(MarketPosition = 1) then

begin

intraTradeHigh = MaxList(intraTradeHigh,High);

buysToday = 1;

end;

if(MarketPosition =-1) then

begin

intraTradeLow = MinList(intraTradeLow,Low);

sellsToday = 1;

end;

if(buysToday = 0 and Time < initTradesEndTime) then

Buy("LBreakOut") next bar at buyBOPoint stop;

if(sellsToday = 0 and Time < initTradesEndTime) then

 

 

 

SellShort("SBreakout") next bar at sellBOPoint stop;

if(intraHigh > longBreakPt and sellsToday = 0 and Time <

initTradesEndTime) then

SellShort("SfailedBO") next bar at shortFBOPoint stop;

if(intraLow < shortBreakPt and buysToday = 0 and Time <

initTradesEndTime) then

Buy("BfailedBO") next bar at longFBOPoint stop;

{The next module keeps track of positions and places protective stops}

if(MarketPosition = 1) then

begin

longLiqPoint = EntryPrice - protStopPrcnt1*averageRange;

longLiqPoint = MinList(longLiqPoint,EntryPrice - protStopAmt);

if(MarketPosition(1) = -1 and BarsSinceEntry = 1 and

High[1] >= shortLiqPoint and shortLiqPoint < shortFBOPoint)

then

currTrdType = -2; {we just got long from a short liq reversal}

if(currTrdType = -2) then

begin

longLiqPoint = EntryPrice - protStopPrcnt2*averageRange;

longLiqPoint = MinList(longLiqPoint,EntryPrice -

protStopAmt);

end;{ www.kzuj.com.cn }

if(intraTradeHigh >= EntryPrice + breakEvenPrcnt*averageRange)

then

longLiqPoint = EntryPrice; {BreakEven trade}

if(Time >= initTradesEndTime) then

longLiqPoint = MaxList(longLiqPoint,Lowest(Low,3)); {Trailing

stop}

if(Time < liqRevEndTime and sellsToday = 0 and

longLiqPoint <> EntryPrice and BarsSinceEntry >= 4) then

begin

SellShort("LongLiqRev") next bar at longLiqPoint stop;

end

else begin

Sell("LongLiq") next bar at longLiqPoint stop;

end;

end;

if(MarketPosition =-1) then

begin

shortLiqPoint = EntryPrice+protStopPrcnt1*averageRange;

shortLiqPoint = MaxList(shortLiqPoint,EntryPrice + protStopAmt);

if(MarketPosition(1) = 1 and BarsSinceEntry(0) = 1 and

Low [1] <= longLiqPoint and longLiqPoint > longFBOPoint) then

currTrdType = +2; {we just got long from a short liq reversal}

if(currTrdType = +2) then

begin

shortLiqPoint = EntryPrice + protStopPrcnt2*averageRange;

shortLiqPoint = MaxList(shortLiqPoint,EntryPrice + protStopAmt);

end;

 

 

 

if(intraTradeLow <= EntryPrice - breakEvenPrcnt*averageRange) then

shortLiqPoint = EntryPrice; {BreakEven trade}

if(Time >= initTradesEndTime) then

shortLiqPoint = MinList(shortLiqPoint,Highest(High,3));

{Trailing stop}

if(Time < liqRevEndTime and buysToday = 0 and

shortLiqPoint <> EntryPrice and BarsSinceEntry >= 4) then

begin

Buy("ShortLiqRev") next bar at shortLiqPoint stop;

end

else begin

BuyToCover("ShortLiq") next bar at shortLiqPoint stop;

end;

end;

end;

SetExitOnClose;

 

有思路,想編寫各種指標(biāo)公式,程序化交易模型,選股公式,預(yù)警公式的朋友

可聯(lián)系技術(shù)人員 QQ: 511411198   點(diǎn)擊這里給我發(fā)消息進(jìn)行 有償 編寫!不貴!點(diǎn)擊查看價(jià)格!


【字體: 】【打印文章】【查看評論

相關(guān)文章

    沒有相關(guān)內(nèi)容
主站蜘蛛池模板: 国产一级片网址 | 成 人 黄 色视频免费播放 | 欧美在线中文字幕高清的 | 欧美亚洲性色影视在线 | 中国性xxx免费视频 中国野外性xxxx | 国产在线精品一区免费香蕉 | 亚洲欧美日韩综合 | 有码在线 | 日韩高清性爽一级毛片免费 | 国产短视频精品一区二区三区 | 精品一区二区三区亚洲 | 欧美人成网站 | 国产一级理论片 | 国产一区二区三区在线 | 日韩影视在线观看 | 国产无套在线观看视频 | 国产的一级毛片完整 | 日韩精品欧美激情亚洲综合 | 日韩一区在线视频 | 日本xxx18hd | 18av黄动漫网站在线观看 | 一个人在线看的免费视频 | 日本大臿亚洲香蕉大片 | 欧美色图第二页 | 国产精品2020观看久久 | 日韩欧美一及在线播放 | 五月天婷婷在线观看高清 | 免费观看欧美一级片 | 欧美末成年video水多 | a级成人毛片免费视频高清 a级片免费网站 | 黄视频日本 | 日本不卡免费在线 | 亚洲h在线观看 | 日本老年人精品久久中文字幕 | 激情综合图区 | 两性仑乱肉麻小说 | 小明永久免费大陆在线观看 | 黄色理论视频 | 国产欧美日韩另类va在线 | 欧美成人免费一区在线播放 | 抽搐videos|