開拓者 TB 強悍的全局變量功能 及 源碼范例 想成為開拓者高手必看
作者:開拓者 TB 來源:cxh99.com 發(fā)布時間:2012年12月08日
|
全自動的程序化交易必須解決以下三大難題:
⒈既要保證交易信號的及時性,又要做到信號不能反復;
⒉記錄每一次系統(tǒng)開、平倉的價格,以及賬戶的持倉變動,以便進行加減頭寸及資金管理的安排;
⒊在同一根K線上進行交易控制,實現(xiàn)跨周期數據引用,以便精確實現(xiàn)短線交易時機的把握。
通過三天的學習,依托交易開拓者軟件全局變量的強大功能,我終于攻克了上述三大難關。
除了普通變量外,交易開拓者軟件提供了三種特殊變量,它們分別是:
⒈序列變量:可以進行數據的回溯,從而實現(xiàn)條件、循環(huán)語句的應用;它的運行特點是每一根BAR依次執(zhí)行,這不同于坊間文華等其它交易軟件平臺的一次性運算。而且,它的全部函數均提供了算法,不同于黑箱的做法,有利于校對和修改。
⒉引用型變量:可以通過用戶函數的形式,進行一勞永逸式的編寫,避免程序的冗余。
⒊全局變量:用于中間計算過程的記錄和存取,可以實現(xiàn)同一根BAR上的倉位管理與開平倉價格記錄。
假設我們需要記錄當前BAR的動態(tài)倉位狀態(tài),使用普通變量、序列變量都是無法完成這項任務的,必須使用全局變量來實施控制,并配合A_SENDORDER函數來發(fā)出買賣指令。比如,我們當條件滿足時,分別記錄買賣倉位的動態(tài)變化后,采用SET GLOBALVAR(0,1),記錄當前的倉位為1手多單,然后可以不斷改寫第一個全局變量的值,在需要讀取操作的時候,我們采用cw=getglobvar(0)的方式來實時地取回。使用全局變量時一定要進行初始化的設置,這樣在系統(tǒng)斷線后,只要不關閉相關圖表,重連后的數據依然可以保持正確。切記不可簡單使用BARSTATS的狀態(tài)來確認全局變量,
以下的這個例子較好地表述了套利系統(tǒng)中全局變量的應用。
Params
Bool bInitStatus(False); // 初始化標志,修改初始倉位時需設置為True
Numeric EveryLots(1); // 每次交易數量手數程序化交易
Numeric LongEntryPrice(-100000); // 開多倉的觸發(fā)價格
Numeric LongExitPrice(100000); // 平多倉的觸發(fā)價格
Numeric ShortEntryPrice(100000); // 開空倉的觸發(fā)價格
Numeric ShortExitPrice(-100000); // 平空倉的觸發(fā)價格
Numeric LongStartLots(0); // 多倉的初始倉位(手數),必須是EveryLots的倍數
Numeric LongEndLots(0); // 多倉的最大倉位(手數),必須是EveryLots的倍數
Numeric ShortStartLots(0); // 空倉的初始倉位(手數),必須是EveryLots的倍數
Numeric ShortEndLots(0); // 空倉的最大倉位(手數),必須是EveryLots的倍數
Numeric OffsetPoint(2); // 委托價格的偏移值(點數)
Vars
Numeric SpreadUpper;
Numeric SpreadLower;
Numeric longPosition;
Numeric shortPosition;
Bool bLongEntryCon;
Bool bShortEntryCon;
Bool bLongExitCon;
Bool bShortExitCon;
Bool bTimeCon;
Numeric Data0Lots(1);
Numeric Data1Lots(2);
Begin
longPosition = GetGlobalVar(0);
shortPosition = GetGlobalVar(1);
If (BarStatus == 0)
{
If(longPosition == InvalidNumeric || bInitStatus)
{
longPosition = LongStartLots;
SetGlobalVar(0,longPosition);
}
If(shortPosition == InvalidNumeric || bInitStatus)
{
shortPosition = ShortStartLots;
SetGlobalVar(1,shortPosition);
}
}Else If(BarStatus == 2 && A_AccountID!="")
{
If(EveryLots < 1) Return;
If(Data0.Q_AskPrice <= 0 || Data0.Q_BidPrice <= 0 || Data1.Q_AskPrice <= 0 || Data1.Q_BidPrice <= 0) Return;
If(Data0.Q_BidPrice == Data0.Q_UpperLimit || Data0.Q_AskPrice == Data0.Q_LowerLimit) Return;
If(Data1.Q_BidPrice == Data1.Q_UpperLimit || Data1.Q_AskPrice == Data1.Q_LowerLimit) Return;
SpreadUpper = Data0.Q_AskPrice-Data1.Q_BidPrice;
SpreadLower = Data0.Q_BidPrice-Data1.Q_AskPrice;
// www.tumamayizhan.com
bTimeCon = true;//Time>0.0903 ;//And (Time<0.1127 Or Time>0.1333) And Time<0.1456;
bLongEntryCon = (SpreadUpper<=LongEntryPrice) && (Data0.Q_AskVol>=EveryLots && Data1.Q_BidVol>=EveryLots);
bLongExitCon = (SpreadLower>=LongExitPrice) && (Data1.Q_AskVol>=EveryLots && Data0.Q_BidVol>=EveryLots);
bShortEntryCon = (SpreadLower>=ShortEntryPrice) && (Data1.Q_AskVol>=EveryLots && Data0.Q_BidVol>=EveryLots);
bShortExitCon = (SpreadUpper<=ShortExitPrice) && (Data0.Q_AskVol>=EveryLots && Data1.Q_BidVol>=EveryLots);
If(((bLongExitCon And bTimeCon And longPosition>0) Or longPosition>LongEndLots ))
{
Data0.A_SendOrder(Enum_Sell,Enum_Exit,Data0Lots,Data0.Q_BidPrice-OffsetPoint*MinMove*PriceScale);
Data1.A_SendOrder(Enum_Buy,Enum_Exit,Data1Lots,Data1.Q_AskPrice+OffsetPoint*MinMove*PriceScale);
SetGlobalVar(0,longPosition - EveryLots);
}
If(((bShortExitCon And bTimeCon And shortPosition>0) Or shortPosition>ShortEndLots ))
{
Data0.A_SendOrder(Enum_Buy,Enum_Exit,Data0Lots,Data0.Q_AskPrice+OffsetPoint*MinMove*PriceScale);
Data1.A_SendOrder(Enum_Sell,Enum_Exit,Data1Lots,Data1.Q_BidPrice-OffsetPoint*MinMove*PriceScale);
SetGlobalVar(1,shortPosition - EveryLots);
}
//www.tumamayizhan.com
If((bLongEntryCon And bTimeCon And longPosition<LongEndLots))
{
Data0.A_SendOrder(Enum_Buy,Enum_Entry,Data0Lots,Data0.Q_AskPrice+OffsetPoint*MinMove*PriceScale);
Data1.A_SendOrder(Enum_Sell,Enum_Entry,Data1Lots,Data1.Q_BidPrice-OffsetPoint*MinMove*PriceScale);
SetGlobalVar(0,longPosition + EveryLots);
}
If(( bShortEntryCon And bTimeCon And shortPosition<ShortEndLots))
{
Data0.A_SendOrder(Enum_Sell,Enum_Entry,Data0Lots,Data0.Q_BidPrice-OffsetPoint*MinMove*PriceScale);
Data1.A_SendOrder(Enum_Buy,Enum_Entry,Data1Lots,Data1.Q_AskPrice+OffsetPoint*MinMove*PriceScale);
SetGlobalVar(1,shortPosition + EveryLots);
}
}
Commentary("多頭倉位="+Text(longPosition));
Commentary("空頭倉位="+Text(shortPosition));
End