您現在的位置:程序化交易>> 期貨公式>> 交易開拓者(TB)>> 開拓者知識>>正文內容

開拓者參數聲明的數據類型錯誤 [開拓者 TB]

  • 咨詢內容: Params
            Numeric TimeFrame(1440);   
            // 目標時間周期:月線=40320,周線=10080,日線=1440,4小時線=240
            // 其他1小時內的周期等于相應的分鐘數,如:1小時=60, 30分鐘=30。。。
            // 支持不規則分鐘數,如3分鐘,8分鐘,之類都行
            
            Numeric BarsBack(1);
            // 目標時間周期BAR偏移:
            // 1--表示將目標時間周期下的前1根K線數據作為與當前Bar對應的目標時間周期下的K線數據
            // 0--表示將目標時間周期下的截止到目前為止的數據轉換為與當前BAR對應的目標時間周期下K線數據
            
            NumericRef oCurBar;                 // 目標時間周期下的Bar索引
            NumericRef oOPenHT;         // 目標時間周期下的開盤價
            NumericRef oHighHT;         // 目標時間周期下的最高價
            NumericRef oLowHT;          // 目標時間周期下的最低價
            NumericRef oCloseHT;        // 目標時間周期下的收盤價
            NumericRef oVolHT;          // 目標時間周期下的成交量
            NumericRef oOpenIntHT;      // 目標時間周期下的持倉量

    Vars
            NumericSeries barCnt;
            NumericSeries CurBar;
            NumericSeries barCntSum;
            NumericSeries OpenHT;
            NumericSeries HighHT;
            NumericSeries LowHT;
            NumericSeries CloseHT;
            NumericSeries VolHT;
            NumericSeries OpenIntHT;
            Numeric CurTime;
            Numeric PreTime;
            bool condition(false);
            Numeric i;
    Begin
            If (TimeFrame == 40320)                 // 月線
            {
                    CurTime = Month;
                    PreTime = Month[1];
            }
            Else If (TimeFrame == 10080)                        // 周線
            {
                    CurTime = IntPart(DateDiff(19700105,Date)/7);
                    PreTime = IntPart(DateDiff(19700105,Date[1])/7);
            }
            Else                                                                        // 其他時間周期
            {
                    CurTime = IntPart((DateDiff(19700105,date)*1440 + Hour*60 + Minute)/TimeFrame);
                    PreTime = IntPart((DateDiff(19700105,date[1])*1440 + Hour[1]*60 + Minute[1])/TimeFrame);
            }
            condition = CurTime != PreTime;

            If (CurrentBar==0)                // 如果是第一根Bar, CurBar=0
            {
                    barCnt = 0;
                    CurBar = 0;
                    OpenHT = Open;
                    HighHT = High;
                    LowHT = Low;
                    CloseHT = Close;
                    VolHT = Vol;
                    OpenIntHT = OpenInt;
            }
            Else
            {
                    If(Condition)               
                    // 如果在目標周期下,屬于另一根K線,則CurBar加1
                    {
                            barCnt = 1;
                            CurBar = CurBar[1] + 1;
                            OpenHT = Open;
                            HighHT = High;
                            LowHT = Low;
                            VolHT = Vol;
                    }Else
                    // 如果在目標周期下,屬于同一根K線,則CurBar不變,但最高價和最低價要記錄價格的變化,成交量要累加
                    {
                            barCnt = barCnt[1] + 1;
                            CurBar = CurBar[1];
                            OpenHT = OpenHT[1];
                            HighHT = Max(HighHT[1],High);
                            LowHT = Min(LowHT[1],Low);
                            VolHT = VolHT[1] + Vol;
                    }
                    // 收盤價和持倉量總是取最新值
                    CloseHT = Close;
                    OpenIntHT = OpenInt;
            }
            
            // 上面的程序,在每根小周期的K線上,記錄了它所屬的大時間周期下的開高低收等值的變化。
            // 接下來,要把在大的時間周期級別上,屬于同一根K線的開高低收這些數據,記錄在這一組小周期K線的最后一根上。
            barCntSum = barCnt ;
            If(BarsBack == 0)
            // 如果Bar偏移參數為0,則取每根小周期K線上保留的大時間周期截止到這根小周期K線為止的BAR數據
            {
                    barCntSum = 0 ;
            }Else If(BarsBack == 1)
            // 如果Bar偏移參數為1,則取大時間周期的上一根K線的BAr數據
            {
                    barCntSum = barCnt ;
            }Else
            // 如果BAR偏移參數為其他,則取大時間周期的指定偏移后的那根K線的BAR數據
            {
                    For i = 2 To BarsBack
                    {
                            barCntSum = barCntSum + barCnt[barCntSum];
                    }
            }

            // 最后將相應的K線數據作為引用參數返回
            oCurBar = CurBar;
            oOpenHT = OpenHT[barCntSum];
            oHighHT = HighHT[barCntSum];
            oLowHT = LowHT[barCntSum];
            oCloseHT = CloseHT[barCntSum];
            oVolHT = VolHT[barCntSum];
            oOpenIntHT = OpenIntHT[barCntSum];
            Return barCnt;
    End

     

  • TB技術人員: 回復 1# kspdjm


    公式應用中不需要使用NumericRef引用參數類型

 

有思路,想編寫各種指標公式,程序化交易模型,選股公式,預警公式的朋友

可聯系技術人員 QQ: 262069696  點擊在線交流進行 有償 編寫!不貴!點擊查看價格!


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

相關文章

    沒有相關內容
主站蜘蛛池模板: 相泽南亚洲一区二区在线播放| 91大神在线看| 最近中文字幕免费版在线3| 免费精品久久久久久中文字幕| 国产色在线|亚洲| 在线观看免费午夜大片| 中日韩欧美在线观看| 欧美a级黄色片| 亚洲视频中文字幕在线| 中文字幕久久久人妻无码| 欧美性猛交xxxx乱大交丰满| 又爽又黄又无遮挡的视频在线观看| 亚洲精品中文字幕无乱码麻豆| 女主调教贱女m视频| 久久久久亚洲av无码尤物| 欧美换爱交换乱理伦片不卡片| 免费高清在线影片一区| 青青网在线视频| 国产精品免费无遮挡无码永久视频| www.日韩精品| 日出水了特别黄的视频| 亚洲videos| 波多野结衣一二三区| 卡通动漫精品一区二区三区| 黄瓜视频在线观看网址| 国产精品色午夜视频免费看| www色在线观看| 无码人妻精品丰满熟妇区| 亚洲av无码专区在线观看成人| 热久久综合这里只有精品电影| 四虎影院在线免费播放| 黄色软件下载免费观看| 成人H动漫精品一区二区| 从镜子里看我怎么c你| 69av在线播放| 大香伊蕉在人线国产最新75| 中文字幕无码日韩专区| 日韩成人精品日本亚洲| 免费大片av手机看片| 蜜芽国产尤物AV尤物在线看| 夜来香免费观看视频在线|