[求助]請(qǐng)文華老師幫俺寫(xiě)個(gè)公式模型。 [文華財(cái)經(jīng)]

  • 咨詢內(nèi)容: 下面是公式的源碼,好像是開(kāi)拓者的,請(qǐng)轉(zhuǎn)化成文華的,謝謝! --------------------------------------------------------------- 海龜交易系統(tǒng)公式源碼如下: //------------------------------------------------------------------------ // 簡(jiǎn)稱: TurtleTrader // 名稱: 海龜交易系統(tǒng) // 類別: 交易指令 // 類型: 其他 // 輸出: //------------------------------------------------------------------------ Params Numeric RiskRatio(1); // % Risk Per N ( 0 - 100) Numeric ATRLength(20); // 平均波動(dòng)周期 ATR Length Numeric boLength(20); // 短周期 BreakOut Length Numeric fsLength(55); // 長(zhǎng)周期 FailSafe Length Numeric teLength(10); // 離市周期 Trailing Exit Length Bool LastProfitableTradeFilter(True); // 使用入市過(guò)濾條件 Vars Numeric MinPoint; // 最小變動(dòng)單位 NumericSeries AvgTR; // ATR Numeric N; // N 值 Numeric TotalEquity; // 按最新收盤(pán)價(jià)計(jì)算出的總資產(chǎn) Numeric TurtleUnits; // 交易單位 NumericSeries DonchianHi; // 唐奇安通道上軌,延后1個(gè)Bar NumericSeries DonchianLo; // 唐奇安通道下軌,延后1個(gè)Bar NumericSeries fsDonchianHi; // 唐奇安通道上軌,延后1個(gè)Bar,長(zhǎng)周期 NumericSeries fsDonchianLo; // 唐奇安通道下軌,延后1個(gè)Bar,長(zhǎng)周期 Numeric ExitHighestPrice; // 離市時(shí)判斷需要的N周期最高價(jià) Numeric ExitLowestPrice; // 離市時(shí)判斷需要的N周期最低價(jià) Numeric myEntryPrice; // 開(kāi)倉(cāng)價(jià)格 Numeric myExitPrice; // 平倉(cāng)價(jià)格 Bool SendOrderThisBar(False); // 當(dāng)前Bar有過(guò)交易 NumericSeries preEntryPrice(0); // 前一次開(kāi)倉(cāng)的價(jià)格,存放到全局變量0號(hào)位置 BoolSeries PreBreakoutFailure(false); // 前一次突破是否失敗 Begin If(BarStatus == 0) { preEntryPrice = InvalidNumeric; PreBreakoutFailure = false; }Else { preEntryPrice = preEntryPrice[1]; PreBreakoutFailure = PreBreakoutFailure[1]; } MinPoint = MinMove*PriceScale; AvgTR = XAverage(TrueRange,ATRLength); N = AvgTR[1]; TotalEquity = CurrentCapital()+ Abs(CurrentContracts()*Close*ContractUnit()*BigPointValue()*MarginRatio()); TurtleUnits = (TotalEquity*RiskRatio/100) /(N * ContractUnit()*BigPointValue()); TurtleUnits = IntPart(TurtleUnits); // 對(duì)小數(shù)取整 DonchianHi = HighestFC(High[1],boLength); DonchianLo = LowestFC(Low[1],boLength); fsDonchianHi = HighestFC(High[1],fsLength); fsDonchianLo = LowestFC(Low[1],fsLength); Commentary("N="+Text(N)); Commentary("preEntryPrice="+Text(preEntryPrice)); Commentary("PreBreakoutFailure="+IIFString(PreBreakoutFailure,"True","False")); // 當(dāng)不使用過(guò)濾條件,或者使用過(guò)濾條件并且條件為PreBreakoutFailure為T(mén)rue進(jìn)行后續(xù)操作 If(MarketPosition == 0 && ((!LastProfitableTradeFilter) Or (PreBreakoutFailure))) { // 突破開(kāi)倉(cāng) If(CrossOver(High,DonchianHi) && TurtleUnits >= 1) { // 開(kāi)倉(cāng)價(jià)格取突破上軌+一個(gè)價(jià)位和最高價(jià)之間的較小值,這樣能更接近真實(shí)情況,并能盡量保證成交 myEntryPrice = min(high,DonchianHi + MinPoint); myEntryPrice = IIF(myEntryPrice < Open, Open,myEntryPrice); // 大跳空的時(shí)候用開(kāi)盤(pán)價(jià)代替 preEntryPrice = myEntryPrice; Buy(TurtleUnits,myEntryPrice); SendOrderThisBar = True; PreBreakoutFailure = False; } If(CrossUnder(Low,DonchianLo) && TurtleUnits >= 1) { // 開(kāi)倉(cāng)價(jià)格取突破下軌-一個(gè)價(jià)位和最低價(jià)之間的較大值,這樣能更接近真實(shí)情況,并能盡量保證成交 myEntryPrice = max(low,DonchianLo - MinPoint); myEntryPrice = IIF(myEntryPrice > Open, Open,myEntryPrice); // 大跳空的時(shí)候用開(kāi)盤(pán)價(jià)代替 preEntryPrice = myEntryPrice; SendOrderThisBar = True; SellShort(TurtleUnits,myEntryPrice);//本海龜交易系統(tǒng)來(lái)自智冠豐銀www.fxsola.com SendOrderThisBar = True; PreBreakoutFailure = False;//sg } } // 長(zhǎng)周期突破開(kāi)倉(cāng) Failsafe Breakout point If(MarketPosition == 0) { Commentary("fsDfsDExitLowestPrice="+Text(ExitLowestPrice)); If(Low < ExitLowestPrice) { myExitPrice = max(Low,ExitLowestPrice - MinPoint); myExitPrice = IIF(myExitPrice > Open, Open,myExitPrice); // 大跳空的時(shí)候用開(kāi)盤(pán)價(jià)代替 Sell(0,myExitPrice); // 數(shù)量用0的情況下將全部平倉(cāng) }Else { If(preEntryPrice!=InvalidNumeric && TurtleUnits >= 1) { If(Open >= preEntryPrice + 0.5*N) // 如果開(kāi)盤(pán)就超過(guò)設(shè)定的1/2N,則直接用開(kāi)盤(pán)價(jià)增倉(cāng)。 { myEntryPrice = Open; preEntryPrice = myEntryPrice; Buy(TurtleUnits,myEntryPrice); SendOrderThisBar = True; } while(High >= preEntryPrice + 0.5*N) // 以最高價(jià)為標(biāo)準(zhǔn),判斷能進(jìn)行幾次增倉(cāng) { myEntryPrice = preEntryPrice + 0.5 * N; preEntryPrice = myEntryPrice; Buy(TurtleUnits,myEntryPrice); SendOrderThisBar = True; } } // 止損指令 If(Low <= preEntryPrice - 2 * N && SendOrderThisBar == false) // 加倉(cāng)Bar不止損 { myExitPrice = preEntryPrice - 2 * N; Sell(0,myExitPrice); // 數(shù)量用0的情況下將全部平倉(cāng) PreBreakoutFailure = True; } } }Else If(MarketPosition ==-1) // 有空倉(cāng)的情況 { // 求出持空倉(cāng)時(shí)離市的條件比較值 ExitHighestPrice = Highest(High[1],teLength); Commentary("ExitHighestPrice="+Text(ExitHighestPrice)); If(High > ExitHighestPrice) { myExitPrice = Min(High,ExitHighestPrice + MinPoint); myExitPrice = IIF(myExitPrice < Open, Open,myExitPrice); // 大跳空的時(shí)候用開(kāi)盤(pán)價(jià)代替 BuyToCover(0,myExitPrice); // 數(shù)量用0的情況下將全部平倉(cāng) }Else { If(preEntryPrice!=InvalidNumeric && TurtleUnits >= 1) { If(Open <= preEntryPrice - 0.5*N) // 如果開(kāi)盤(pán)就超過(guò)設(shè)定的1/2N,則直接用開(kāi)盤(pán)價(jià)增倉(cāng)。 { myEntryPrice = Open; preEntryPrice = myEntryPrice; SellShort(TurtleUnits,myEntryPrice);//本海龜交易系統(tǒng)來(lái)自智冠豐銀www.fxsola.com SendOrderThisBar = True; } while(Low <= preEntryPrice - 0.5*N) // 以最低價(jià)為標(biāo)準(zhǔn),判斷能進(jìn)行幾次增倉(cāng) { myEntryPrice = preEntryPrice - 0.5 * N; preEntryPrice = myEntryPrice; SellShort(TurtleUnits,myEntryPrice); SendOrderThisBar = True; } } // 止損指令 If(High >= preEntryPrice + 2 * N &&SendOrderThisBar==false) // 加倉(cāng)Bar不止損 { myExitPrice = preEntryPrice + 2 * N; BuyToCover(0,myExitPrice); // 數(shù)量用0的情況下將全部平倉(cāng) PreBreakoutFailure = True; } } } End

     

  • 文華技術(shù)人員:        海龜交易系統(tǒng)公式源碼如下:

    //------------------------------------------------------------------------
    // 簡(jiǎn)稱: TurtleTrader
    // 名稱: 海龜交易系統(tǒng)
    // 類別: 交易指令
    // 類型: 其他
    // 輸出: 
    //------------------------------------------------------------------------

    Params
        Numeric RiskRatio(1);                   // % Risk Per N ( 0 - 100)
        Numeric ATRLength(20);                  // 平均波動(dòng)周期 ATR Length
        Numeric boLength(20);                   // 短周期 BreakOut Length
        Numeric fsLength(55);                   // 長(zhǎng)周期 FailSafe Length
        Numeric teLength(10);                   // 離市周期 Trailing Exit Length
        Bool LastProfitableTradeFilter(True);   // 使用入市過(guò)濾條件
    Vars
     Numeric MinPoint;                       // 最小變動(dòng)單位
     NumericSeries AvgTR;      // ATR
        Numeric N;                              // N 值
        Numeric TotalEquity;                    // 按最新收盤(pán)價(jià)計(jì)算出的總資產(chǎn)
        Numeric TurtleUnits;                    // 交易單位
        NumericSeries DonchianHi;              // 唐奇安通道上軌,延后1個(gè)Bar
        NumericSeries DonchianLo;              // 唐奇安通道下軌,延后1個(gè)Bar
        NumericSeries fsDonchianHi;            // 唐奇安通道上軌,延后1個(gè)Bar,長(zhǎng)周期
        NumericSeries fsDonchianLo;            // 唐奇安通道下軌,延后1個(gè)Bar,長(zhǎng)周期
        Numeric ExitHighestPrice;               // 離市時(shí)判斷需要的N周期最高價(jià)
        Numeric ExitLowestPrice;                // 離市時(shí)判斷需要的N周期最低價(jià)
        Numeric myEntryPrice;                   // 開(kāi)倉(cāng)價(jià)格
        Numeric myExitPrice;                    // 平倉(cāng)價(jià)格
        Bool SendOrderThisBar(False);          // 當(dāng)前Bar有過(guò)交易
     NumericSeries preEntryPrice(0);       // 前一次開(kāi)倉(cāng)的價(jià)格,存放到全局變量0號(hào)位置
     BoolSeries PreBreakoutFailure(false); // 前一次突破是否失敗
    Begin
        If(BarStatus == 0)
        {
      preEntryPrice = InvalidNumeric;
      PreBreakoutFailure = false;
     }Else
     {
      preEntryPrice = preEntryPrice[1];
            PreBreakoutFailure = PreBreakoutFailure[1];
        }

     MinPoint = MinMove*PriceScale;
        AvgTR = XAverage(TrueRange,ATRLength);
     N = AvgTR[1];
        TotalEquity = CurrentCapital()+ Abs(CurrentContracts()*Close*ContractUnit()*BigPointValue()*MarginRatio());
        TurtleUnits = (TotalEquity*RiskRatio/100) /(N * ContractUnit()*BigPointValue());
        TurtleUnits = IntPart(TurtleUnits); // 對(duì)小數(shù)取整

        DonchianHi = HighestFC(High[1],boLength);
        DonchianLo = LowestFC(Low[1],boLength);

     fsDonchianHi = HighestFC(High[1],fsLength);
        fsDonchianLo = LowestFC(Low[1],fsLength);

     Commentary("N="+Text(N));
     Commentary("preEntryPrice="+Text(preEntryPrice));
     Commentary("PreBreakoutFailure="+IIFString(PreBreakoutFailure,"True","False"));
     
        // 當(dāng)不使用過(guò)濾條件,或者使用過(guò)濾條件并且條件為PreBreakoutFailure為T(mén)rue進(jìn)行后續(xù)操作
        If(MarketPosition == 0 && ((!LastProfitableTradeFilter) Or (PreBreakoutFailure)))
        {
            // 突破開(kāi)倉(cāng)
            If(CrossOver(High,DonchianHi) && TurtleUnits >= 1)
            {
                // 開(kāi)倉(cāng)價(jià)格取突破上軌+一個(gè)價(jià)位和最高價(jià)之間的較小值,這樣能更接近真實(shí)情況,并能盡量保證成交
                myEntryPrice = min(high,DonchianHi + MinPoint);
                myEntryPrice = IIF(myEntryPrice < Open, Open,myEntryPrice); // 大跳空的時(shí)候用開(kāi)盤(pán)價(jià)代替
       preEntryPrice = myEntryPrice;
                Buy(TurtleUnits,myEntryPrice);
       SendOrderThisBar = True;
       PreBreakoutFailure = False;
            }

            If(CrossUnder(Low,DonchianLo) && TurtleUnits >= 1)
            {
                // 開(kāi)倉(cāng)價(jià)格取突破下軌-一個(gè)價(jià)位和最低價(jià)之間的較大值,這樣能更接近真實(shí)情況,并能盡量保證成交
                myEntryPrice = max(low,DonchianLo - MinPoint);
                myEntryPrice = IIF(myEntryPrice > Open, Open,myEntryPrice); // 大跳空的時(shí)候用開(kāi)盤(pán)價(jià)代替
                preEntryPrice = myEntryPrice;
                SendOrderThisBar = True;
                SellShort(TurtleUnits,myEntryPrice);//本海龜交易系統(tǒng)來(lái)自智冠豐銀www.fxsola.com
       SendOrderThisBar = True;
       PreBreakoutFailure = False;//sg 
            }
        }

        // 長(zhǎng)周期突破開(kāi)倉(cāng) Failsafe Breakout point
        If(MarketPosition == 0)
        {
      Commentary("fsDfont-family: 宋體; font-size: 12px;">  Commentary("fsDfont-family: 宋體; font-size: 12px;">    If(MarketPosition == 1) // 有多倉(cāng)的情況
        {
            // 求出持多倉(cāng)時(shí)離市的條件比較值
            ExitLowestPrice = Lowest(Low[1],teLength);
      Commentary("ExitLowestPrice="+Text(ExitLowestPrice));
            If(Low < ExitLowestPrice)
            {
                myExitPrice = max(Low,ExitLowestPrice - MinPoint);
       myExitPrice = IIF(myExitPrice > Open, Open,myExitPrice); // 大跳空的時(shí)候用開(kāi)盤(pán)價(jià)代替
                Sell(0,myExitPrice);    // 數(shù)量用0的情況下將全部平倉(cāng)
            }Else
            {
                If(preEntryPrice!=InvalidNumeric && TurtleUnits >= 1)
                {
                    If(Open >= preEntryPrice + 0.5*N) // 如果開(kāi)盤(pán)就超過(guò)設(shè)定的1/2N,則直接用開(kāi)盤(pán)價(jià)增倉(cāng)。
                    {
                        myEntryPrice = Open;
         preEntryPrice = myEntryPrice;
                        Buy(TurtleUnits,myEntryPrice);
         SendOrderThisBar = True;
                    }

                    while(High >= preEntryPrice + 0.5*N) // 以最高價(jià)為標(biāo)準(zhǔn),判斷能進(jìn)行幾次增倉(cāng)
                    {
                        myEntryPrice = preEntryPrice + 0.5 * N;
                        preEntryPrice = myEntryPrice;
                        Buy(TurtleUnits,myEntryPrice);
         SendOrderThisBar = True;     
                    }
                }
       
                // 止損指令
       If(Low <= preEntryPrice - 2 * N && SendOrderThisBar == false) // 加倉(cāng)Bar不止損
       {
        myExitPrice = preEntryPrice - 2 * N;
        Sell(0,myExitPrice); // 數(shù)量用0的情況下將全部平倉(cāng)
        PreBreakoutFailure = True;
       }
            }
        }Else If(MarketPosition ==-1) // 有空倉(cāng)的情況
        {
            // 求出持空倉(cāng)時(shí)離市的條件比較值
            ExitHighestPrice = Highest(High[1],teLength);
      Commentary("ExitHighestPrice="+Text(ExitHighestPrice));
            If(High > ExitHighestPrice)
            {
                myExitPrice = Min(High,ExitHighestPrice + MinPoint);
       myExitPrice = IIF(myExitPrice < Open, Open,myExitPrice); // 大跳空的時(shí)候用開(kāi)盤(pán)價(jià)代替
                BuyToCover(0,myExitPrice);    // 數(shù)量用0的情況下將全部平倉(cāng)
            }Else
            {
                If(preEntryPrice!=InvalidNumeric && TurtleUnits >= 1)
                {
                    If(Open <= preEntryPrice - 0.5*N) // 如果開(kāi)盤(pán)就超過(guò)設(shè)定的1/2N,則直接用開(kāi)盤(pán)價(jià)增倉(cāng)。
                    {
                        myEntryPrice = Open;
         preEntryPrice = myEntryPrice;
                        SellShort(TurtleUnits,myEntryPrice);//本海龜交易系統(tǒng)來(lái)自智冠豐銀www.fxsola.com

         SendOrderThisBar = True;
                    }

                    while(Low <= preEntryPrice - 0.5*N) // 以最低價(jià)為標(biāo)準(zhǔn),判斷能進(jìn)行幾次增倉(cāng)
                    {
                        myEntryPrice = preEntryPrice - 0.5 * N;
                        preEntryPrice = myEntryPrice;
                        SellShort(TurtleUnits,myEntryPrice);
         SendOrderThisBar = True;
                    }
                }

                // 止損指令
       If(High >= preEntryPrice + 2 * N &&SendOrderThisBar==false) // 加倉(cāng)Bar不止損
       {
        myExitPrice = preEntryPrice + 2 * N;
        BuyToCover(0,myExitPrice); // 數(shù)量用0的情況下將全部平倉(cāng)
        PreBreakoutFailure = True;
       }
            }
        }
    End

     

  • 文華客服: RiskRatio:=1;                   // % Risk Per N ( 0 - 100)  賬戶的1%
    ATRLength:=20;                  // 平均波動(dòng)周期 ATR Length
    boLength:=20;                   // 短周期BreakOut Length
    fsLength:=55;                   // 長(zhǎng)周期FailSafe Length
    teLength:=10;                   // 離市周期 Trailing Exit Length
    DW:=300;                        //合約的單位(請(qǐng)自行設(shè)定)
    TR:= MAX(MAX((HIGH-LOW),ABS(REF(CLOSE,1)-HIGH)),ABS(REF(CLOSE,1)-LOW));
    ATR:= MA(TR,ATRLength);
    N:=REF(ATR,1);
    TU:=FLOOR(MONEYTOT*RiskRatio/100)/(N*DW);
    DonchianHi:= HHV(REF(H,1),boLength);//系統(tǒng)一:20日高點(diǎn)突破
    DonchianLo:= LLV(REF(L,1),boLength);//系統(tǒng)一:20日低點(diǎn)突破
    fsDonchianHi:= HHV(REF(H,1),fsLength);//系統(tǒng)二:55日高點(diǎn)突破
    fsDonchianLo:= LLV(REF(L,1),fsLength);//系統(tǒng)二:55日低點(diǎn)突破
    ExitLowestPrice:= LLV(REF(L,1),teLength);//系統(tǒng)一多頭離市
    ExitHighestPrice:= HHV(REF(H,1),teLength);//系統(tǒng)一空頭離市
    H>DonchianHi&&BKVOL=0&&NOT(ISLASTBK||ISLASTSK)&&TU>=1,BK(TU);
    L<DonchianLo&&SKVOL=0&&NOT(ISLASTBK||ISLASTSK)&&TU>=1,SK(TU);
    H>fsDonchianHi&&BKVOL=0&&NOT(ISLASTBK||ISLASTSK)&&TU>=1,BK(TU);
    L<fsDonchianLo&&SKVOL=0&&NOT(ISLASTBK||ISLASTSK)&&TU>=1,SK(TU);
    L<ExitLowestPrice&&BKVOL>0,SP(BKVOL);
    L>=ExitLowestPrice&&H>=BKPRICE+N&&BKVOL<3*TU,BK(TU);
    L<=BKPRICE-2*N&&BKVOL>0,SP(BKVOL);
    H>ExitHighestPrice&&SKVOL>0,BP(SKVOL);
    H>ExitHighestPrice&&L<=SKPRICE-N&&SKVOL<3*TU,SK(TU);
    H>=SKPRICE+2*N&&SKVOL>0,BP(SKVOL);
    MONO_SIGNAL;

     

  • 網(wǎng)友回復(fù):  

 

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

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


【字體: 】【打印文章】【查看評(píng)論

相關(guān)文章

    沒(méi)有相關(guān)內(nèi)容
主站蜘蛛池模板: 久久国产精品无码HDAV| 欧美日韩国产伦理| 男人猛躁进女人免费观看| 特级aa**毛片免费观看| 欧美成人四级剧情在线播放| 最近中文字幕mv在线视频www | 国产www视频| 伊人久久大香线蕉综合爱婷婷| 亚洲娇小性色xxxx| 久久亚洲AV无码精品色午夜麻豆 | 亚洲日韩国产精品无码av| 久久人妻无码中文字幕| 一区二区乱子伦在线播放| 天堂在线免费观看| 美女露100%胸无遮挡免费观看| 污污视频网站免费| 日韩人妻无码一区二区三区 | 欧美aaaaaa级爽激情会所| 成人国产精品免费视频| 国产精品资源在线观看| 国产三区视频在线观看| 亚洲爆乳精品无码一区二区| 久久免费看黄a级毛片| JAPANESEHD熟女熟妇伦| 青春草在线视频观看| 爽爽影院在线看| 日本三级中文字版电影| 国产精品高清2021在线| 四虎8848精品永久在线观看| 亚洲最大免费视频网| 东北美女野外bbwbbw免费| 三级国产女主播在线观看| 精品国产一区二区三区无码| 日韩精品欧美视频| 天天摸天天做天天爽水多| 国产区在线视频| 亚洲最大在线视频| 一区二区乱子伦在线播放| 麻豆视频免费看| 欧美精品一区二区三区在线| 成人性生话视频|