用R語言實現簡單的交易回測

一、R代碼實現。

用google在網上搜索到的回測語句都大同小異,下面給出一個示例,改編自:量化策略回測

# 以S&P500為例,其雅虎代碼為^GSPC;我們要計算5日均線指標的函數就是SMA(),

# 先載入需要的擴展包
> library(quantmod)
> library(PerformanceAnalytics)

# 先獲取S&P500的交易數據,然后根據其收盤價(由函數Cl()抽?。┯嬎闫?日均線值:
> getSymbols('^GSPC') #S&P500 OHLC data
> close <- Cl(GSPC)
> mv5 <- SMA(close, 5)

# 策略是當收盤價大于5日均線,代表可以入市,取1,否則代表清倉,取0。(-1是代表賣空,不適用。)
> sig <- ifelse(close < mv5, 1, 0)

# 使用Lag()將信號序列向“過去”推遲一天,代表將昨天的信號,應用到今天。
> sig <- Lag(sig) #將該序列向“過去”延遲一天

# 計算收益序列
# discrete代表用離散方式計算當天收益率,即(Close-Close(-1))/Close(-1)
# continous代表用連續方式計算當天收益率,即ln(Close/Close(-1))
> roc <- ROC(type='discrete',close) 
> ret <- roc * sig

# 畫出策略收益圖
> charts.PerformanceSummary(ret)

# 最上面的板塊是積累收益,相當于對cumprod(1+ret)的繪圖;
# 第二個是日收益,相當于對ret原始收益數據的繪圖;
# 最下面的是下跌圖(又稱“水下圖”),將下跌成分獨立繪出,有助于我們分析虧損狀況和研究彌補措施。
回測示意圖

以上需要注意的地方是制定策略的語句

> sig <- ifelse(close < mv5, 1, 0)
# 當收盤價大于5日均線時,sig取1,否則取0。

在網上公布的代碼當中,有的是取-1,這里-1代表賣空,不是清倉,得到的結果是不對的。

二、excel模擬。

當初得到這個結果的時候我很懷疑,用幾條R語句就把量化策略及結果模擬出來了?看上去這么神奇,結果對不對呢?我在excel里對該策略進行模擬:

以上面的策略為基礎,細化得到的交易方案是這樣的:

  1. 當股票收盤價格高于五日均線,且無持倉,那么第二天滿倉入市。
  2. 當股票收盤價格高于五日均線,且滿倉,那么第二天繼續持倉。
  3. 當股票收盤價格低于五日均線,且無持倉,那么第二天繼續空倉。
  4. 當股票收盤價格低于五日均線,且滿倉,那么第二天全部平倉。

為了簡化計算,假設以前一天的收盤價作為成交價:即以前一天的收盤價滿倉入市,或以前一天的收盤價全部平倉。當然這可以在進一步的研究中細化,但這里我們只是為了演示,就不過于復雜了。

excel表格里得到的結果如下:

CLOSE SMA sig ROC ROC*sig 股票 現金 總收益
1994-1-3 5.6 0 1 1
1994-1-4 5.55 0 1 1
1994-1-5 5.65 0 1 1
1994-1-6 6.1 0 1 1
1994-1-7 6.25 5.83 0 1 1
1994-1-10 6.45 6 1 0.032 0.032 1.032 0 1.032
1994-1-11 6.15 6.12 1 -0.047 -0.047 0.984 0 0.984
1994-1-12 6.15 6.22 1 0 0 0.984 0 0.984
1994-1-13 6.25 6.25 0 0.016 0 0 0.984 0.984
1994-1-14 6.1 6.22 0 -0.024 0 0 0.984 0.984
1994-1-17 6 6.13 0 -0.016 0 0 0.984 0.984
1994-1-18 6.2 6.14 0 0.033 0 0 0.984 0.984
1994-1-19 6 6.11 1 -0.032 -0.032 0.952 0 0.952
1994-1-20 6 6.06 0 0 0 0 0.952 0.952

由于是取5日平均,所以5日平均值SMA從第5個交易日開始出現。這幾天的資產都是現金,總收益為1。

從第6個交易日開始,通過判斷收盤價與5日均線之間的大小,得到交易信號sig,注意,這里的sig是滯后一日的,代表前一天的收盤價與5日均線之間的相對大小。

  1. 1994-1-10 close>SMA,sig=1,以前一天的收盤價6.25滿倉入市,當天收盤價為6.45,日內收益率為0.032,股票價值1.032,現金為0,總資產價值為1.032。

  2. 1994-1-11 close>SMA,sig=1,鑒于前一天已入市,繼續持倉,當天收盤價為6.15,日內收益率為-0.047,股票價值0.984,現金為0,總資產價值為0.984。

  3. 1994-1-12 close>SMA,sig=1,繼續持倉,當天收盤價為6.15,日內收益率為0,股票價值0.984,現金為0,總資產價值為0.984。

  4. 1994-1-13 close<SMA,sig=0,以前一天的收盤價6.15全部清倉,股票價值為0,現金為前一天的股票價值0.984,總資產價值為0.984。

此時,經歷了一次持倉以及清倉之后,投資者手里只擁有現金資產,總資產價值為0.984,虧損0.016。

通過對比excel計算的ret(ROC*sig)與R代碼計算的ret,兩者的結果完全一致。

通過用excel對以上回測策略的模擬,可以發現以上回測策略的隱含前提:

(1) 入市價格和清倉價格均為前一天的收盤價。

(2) 入市則全部滿倉,離市則全部清倉。

三、神秘的charts.PerformanceSummary()函數。

在R代碼中,一條charts.PerformanceSummary()語句,畫出在該策略下,對應股票的總資產收益,日收益和下跌圖。它就像一個神奇的黑箱,給我們以策略是否有效以最直觀的圖形表示。但光有圖形還不夠,這三條曲線分別對應哪些數據,能不能分別導出方便進一步研究呢?

  1. 總資產收益。

    對應的是excle表格當中的總收益,直觀表示了應用該策略,投資者總資產在回測時間內的增減情況。雖然在excel模擬中用股票、現金、總資產三個條目來代表,但其實用一條R代碼就可以實現了:

     cumprod(1+ret)
    

    也就是對(1+ret)的連乘。很容易理解:假設到了第n天,那么這一天的總收益Rn應該等于前一天的總收益R(n-1)乘以當天的收益率,不是ret,而應當是(1+ret)。

    R代碼得到的結果與excel是一致的。

  2. 日收益。

    就是R代碼當中的ret和excel表格中的ROC*sig。

  3. 下跌圖(這部分參考了R包計算回撤)。

    這里只是將下跌成分獨立繪出,對應的excel數據也是ROC*sig,但這里的下跌圖經過了整理。對應的R函數有:

    a)chart.Drawdown:下跌圖,也就是charts.PerformanceSummary()的第三張圖。

     data(edhec)
     chart.Drawdown(edhec[,c(1,2)], main="Drawdown from Peak Equity Attained", legend.loc="bottomleft")
    

    b)findDrawdowns:返回回撤的起始時間,時間間隔,回撤數值,常與sortDrawdowns連用找最大回撤。

     data(edhec)     
     findDrawdowns(edhec[,"Funds of Funds", drop=FALSE])     
     sortDrawdowns(findDrawdowns(edhec[,"Funds of Funds", drop=FALSE]))
    

    c)maxDrawdown:返回收益時間序列的最大回撤。

     data(edhec)
     t(round(maxDrawdown(edhec[,"Funds of Funds"]),4))
    

    d)table.Drawdowns:返回最差回撤的統計量表格。

     data(edhec)
     table.Drawdowns(edhec[,1,drop=FALSE])
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,117評論 6 537
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,860評論 3 423
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事?!?“怎么了?”我有些...
    開封第一講書人閱讀 177,128評論 0 381
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,291評論 1 315
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,025評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,421評論 1 324
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,477評論 3 444
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,642評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,177評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,970評論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,157評論 1 371
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,717評論 5 362
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,410評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,821評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,053評論 1 289
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,896評論 3 395
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,157評論 2 375

推薦閱讀更多精彩內容

  • 技術分析:股指是最好的參照基本分析:把握宏觀經濟投資組合:根據行情調整成功者的啟示:具備與眾不同的思維方式超越專家...
    你在學校閱讀 4,574評論 0 13
  • 美豹金融的美股大學--https://www.usmeibao.com/knowledge.html 一、基礎篇 ...
    格式化_001閱讀 2,589評論 1 5
  • 你根本就不知道每個夜深人靜的時候,我的心有多痛,有多么的思念你!可是,這一切只有我自己明白,沒有誰會理解那...
    凱麗818閱讀 186評論 0 1
  • 在iOS開發當中,我們有很多選擇可以做半透明模糊效果,下面就是一些常見的方式或者說工具。1. Core Image...
    sky_kYU閱讀 1,065評論 2 2
  • 當我們老了 吃過午飯,一起去樓下的河邊曬太陽 你拿著魚竿釣魚 我拿著相機拍照 波光粼粼的小河 在你裝魚的小桶里,也...
    李公子Alice34閱讀 143評論 0 0