MACD應用於RandomForestRegressor量化交易模型

使用 RandomForestRegressor 並投入 MACD 的三個關鍵變數,模型能夠學習到比單純訊號線突破更豐富和細緻的市場模式,從而做出更明智的預測和交易決策,這可能是實證結果優於傳統 MACD 量化交易策略的原因。

金融市場的預測一直是金融研究的核心焦點,對於投資者和金融機構而言,精確的股價預測至關重要 。然而,這個領域充滿挑戰,因為金融市場本質上是複雜、動態且高度波動的,並呈現出非線性模式 。傳統的統計方法在捕捉這些錯綜複雜的關係方面往往力有未逮,這使得機器學習(ML)方法受到廣泛關注,因其能夠處理高維數據中的複雜關係,並在一定程度上提升預測效率 。  

在眾多機器學習演算法中,集成學習(Ensemble Learning)是一種特別強大的技術,它結合多個機器學習演算法的預測結果,以期達到比任何單一模型更準確、更穩健的成果 。隨機森林(Random Forest)演算法正是集成學習中的一個突出代表,它是一種基於「套袋法」(Bagging)的技術,廣泛應用於分類和迴歸任務,因其多功能性和有效性而備受青睞 。  

sklearn.ensemble.RandomForestRegressor 模型中,投入三個變數因子:

  1. MACD 線 (DIF, 快線):這是 MACD 的核心線,代表短期 EMA 與長期 EMA 之間的差值 。
  2. 訊號線 (DEA, 慢線):訊號線是 MACD 線的九週期 EMA。  
  3. 柱狀圖 (MACD Histogram):柱狀圖是 MACD 線與訊號線之間差異的視覺化呈現 。

台灣加權指數:

交易明細

Entry_DateEntry_PriceExit_DateExit_PriceProfitProfit_Ratio
02020-03-169234.0898442020-08-2412728.8496093494.7597660.378463
12020-10-2612546.3398442021-07-1917572.9199225026.5800780.400641
22022-10-1712819.2001952024-07-0123556.58984410737.3896480.837602
32025-04-0719528.7695312025-05-1221843.6894532314.9199220.118539
42025-05-1921670.9609382025-05-1921670.9609380.0000000.000000

統計結果

指標數值
總交易次數5
總損益 (基於每次1股)21573.65
平均每次交易報酬率34.70%
總累積報酬率 (假設利潤再投資)296.85%

標普500指數:

交易明細

Entry_DateEntry_PriceExit_DateExit_PriceProfitProfit_Ratio
02020-03-142304.9199222022-03-194543.0600592238.1401370.971027
12022-06-253825.3300782022-08-134228.479980403.1499020.105390
22022-09-243585.6201172022-11-123965.340088379.7199710.105901
32022-12-243839.5000002025-03-015770.2001951930.7001950.502852
42025-03-295074.0800782025-05-175854.180176780.1000980.153742

統計結果

指標數值
總交易次數5
總損益 (基於每次1股)5731.81
平均每次交易報酬率36.78%
總累積報酬率 (假設利潤再投資)317.78%

RandomForestRegressor 的 產生的報酬遠遠優於傳統 MACD 中單純使用訊號線突破策略:

實證於台股加權指數及標普500,隨機森林模型報酬,均優於同期大盤240%之報酬。

在傳統 MACD 量化交易中,「訊號線突破」通常指的是 MACD 線 (DIF) 穿越訊號線 (DEA)

  • 看漲訊號 (買入): 當 MACD 線從下方往上穿越訊號線時。
  • 看跌訊號 (賣出): 當 MACD 線從上方往下穿越訊號線時。

為什麼投入 MACD 線 (DIF)、訊號線 (DEA) 和柱狀圖作為 RandomForestRegressor 的輸入變數,所產生的報酬率遠優於傳統 MACD 中單純使用訊號線突破策略:

  1. 模型學習複雜的非線性關係:
    • RandomForestRegressor 是一種非線性模型,它可以學習到輸入變數(DIF, DEA, 柱狀圖)與未來報酬率之間更複雜的關係。
    • 傳統的訊號線突破策略僅基於一個簡單的交叉事件,無法捕捉這些複雜的模式。
  2. 整合多個資訊來源:
    • RandomForestRegressor 同時考慮了 MACD 線、訊號線和柱狀圖這三個資訊來源。這使得模型能夠從更全面的角度評估市場狀況,而不僅僅依賴單一的交叉事件。
    • 柱狀圖的變化可以提供額外的佐證或預警訊號線突破的發生。
  3. 預測未來報酬率而非僅產生交易訊號:
    • RandomForestRegressor 的目標是預測未來的報酬率。這使得它能夠根據預測的報酬率大小來決定是否進行交易以及交易的倉位大小(如果策略允許)。
    • 傳統的訊號線突破策略通常只產生買入或賣出的訊號,不涉及對未來報酬率的預測。
  4. 適應性強:
    • 機器學習模型可以通過訓練資料學習市場的動態變化,並在一定程度上適應不同的市場環境。
    • 傳統的固定參數技術指標策略可能在某些市場環境下表現良好,但在其他環境下表現不佳。

總結來說,使用 RandomForestRegressor 並投入 MACD 的三個關鍵變數,模型能夠學習到比單純訊號線突破更豐富和細緻的市場模式,從而做出更明智的預測和交易決策,這可能是實證結果優於傳統 MACD 量化交易策略的原因。


探索更多來自 TWstockIndicator 的內容

訂閱即可透過電子郵件收到最新文章。


Categories:

Tags:


Comments

發佈留言