查看原文
其他

Stata: 日收益转周\月\季\年度数据

stata连享会 Stata连享会 2020-02-10

作者:朱红兵 (南京大学) 
责编:王俊 (中山大学)
Stata 连享会: 知乎 | 简书 | 码云

开始接受报名

特别说明

文中包含的链接在微信中无法生效。请点击本文底部左下角的【阅读原文】,转入本文【简书版】

本文要点

  • 解释简单收益率和对数收益率的差异;

  • 使用 ascol 将日收益率数据转换为**周\月\季\年 度数据;

  • 使用 mtoq 将月数据转换为季度数据;



1 两种收益率的计算

例如 我们有下述股票的日度价格序列:

股票id日期价格
12018010115
12018010219
12018010317
12018010416
12018010520
12018010618
12018010719

根据简单收益率和对数收益率计算公式:

简单算术收益率 EQ1

连续对数收益率 EQ2我们可以计算出简单收益率和对数收益率如下:

股票id日期简单收益率对数收益率1+简单收益率
1201801020.26670.23641.2667
120180103-0.1053-0.11120.8947
120180104-0.0588-0.06060.9412
1201801050.25000.22311.2500
120180106-0.1000-0.10540.9000
1201801070.05560.05411.0556

2 区间内收益率的计算

在实证研究中,很多时候我们希望得到周收益率或者月度收益率,那么如何根据日度收益率得到这些指标呢?

可能很多同学会想当然地认为:直接加总日收益率即可!为题在于:直接对简单收益率进行加总得到的周(月)收益率等于对数日收益率的加总吗?我们可以用上述数据来测试看一下(计算 2018 年 1 月 2 日至 2018 年 1 月 7 日的持有期收益率):

  • 简单收益率的加总:


  • 对数收益率的加总:


  • 两者差异:


问题: 为什么两者会相差 0.0718 呢?哪种计算方法才能准确反应投资者在 2018 年 1 月 2 日至 2018 年 1 月 7 日 期间内的持有收益呢?
     
     
答案对数日收益率的加总,即下式 (EQ3):

因为,区间内简单日收益率的加总意味着投资者每天都在进行交易,而非在区间内买入并持有至末期。当然,我们也可以通过简单算术日收益率计算区间内的持有期收益,但是需要采用下述方法:

持有期收益率 (EQ4):

或者采用 (EQ5):

3 Stata命令介绍:ascol

3.1 安装 ascol

在 Stata 命令框中输入下述命令并回车,即可实现安装:

  1. ssc install ascol, replace

3.2 如何调用该命令进行收益率计算?

ascol 的完整语法格式如下:

  1. ascol varname, returns([simple | log]) ///

  2.      prices ///

  3.      keep([all | vars]) ///

  4.      frequency_options  ///

  5.      timevar(varname) panelvar(varname) ///

  6.      generate(newvar)

其中:

  • varname 主要是收益率序列或者价格序列。

  • returns() 中可选择 simplelog。其中,simple 表明 varname 是简单收益率;log 代表对数收益率。若 varname 设定的是价格序列,则这里的选择会指导具体收益率序列的计算方式。

  • prices 指定了 varname 中序列的类型是否为价格序列,如果是收益率序列则无需填写。

  • keep 选项可保留计算后的重复数据,例如日收益率转换为月收益率后,在相同月会出现多个相同的收益率观测,如果选择了 keep 命令则保留了相同的观测,反之则只每个时间点上保留一个观测,剔除了重复观测

  • frequency_options 中可设定 toweektomonthtoquarter, toyear,即由日收益率转换为不同频率 (周,月,季,年) 的收益率。

  • timevar()panelvar() 选项可设定数据的时间变量和截面变量。

  • generate() 可设定新生产的收益率序列的名称。

3.3 Stata 范例

下述代码来源于 ascol 的官方帮助文档,读者可自行前往查看

  1. /*生产收益率序列*/

  2. clear

  3. set obs 1000

  4. gen date=date("1/1/2012" , "DMY")+_n

  5. format %td date

  6. tsset date

  7. gen pr=10

  8. replace pr=pr[_n-1]+uniform() if _n>1

  9. gen simpleRi=(pr/l.pr)-1

  10. gen logRi = ln(pr/l.pr)

  11. save "stocks.dta", replace


  12. /*Example 1: From Daily to weekly -  simple returns*/

  13. use stocks, clear

  14. ascol simpleRi, toweek returns(simple)


  15. /*Example 2: From Daily to weekly -  log returns*/

  16. use "stocks", clear

  17. ascol logRi, toweek returns(log)


  18. /* Example 3: From Daily to monthly -  prices*/

  19. use "stocks", clear

  20. ascol pr, tomonth price

3.4 补充一个新命令 mtoq

前文介绍的 ascol 命令虽然可以将日收益率转换为其他频率的收益率,但是有些时候我们下载的收益率月度收益率,那如何将其转换为季度收益率呢?我们写了一个新的命令 mtoq 来实现这一功能。

Step1 安装 mtoq
  1. /* 1. 没有安装 github 命令的请先通过下述命令进行安装 */

  2. net install github, from("https://haghish.github.io/github/")  replace


  3. /* 2. 安装过 github 命令的同学可忽略上述命令,直接进行下述安装 */

  4. github install zhbsis/mtoq

Step2 调用 mtoq

mtoq 命令的语法非常简洁,如下:

  1. mtoq varlist, by(string) [Statistics(string)]

其中,

  • varlist 中填写对数收益率序列,可同时填写多个序列。

  • by 选项中填写个体和时间截面的id,例如股票类数据可填写 stkcd(股票代码) ym(年月时间标记)

  • Statistics 选项中可填写 Stata 官方命令 egen 中的常见 option ,例如 mean、sum 等,默认为 mean 处理,在月度收益率转换为季度收益率的时候通常填写 sum 选项。

Tipsmtoq 命令可以有更为广泛的用途。上面的例子是对收益率序列进行转换,但 mtoq 也可以转换其他变量,如 换手率 (TurnOver)。若想通过加总月度换收益率得到季度的换手率,可输入:

  1. mtoq TurnOver, by(stkcd ym) s(sum)

特别说明

文中包含的链接在微信中无法生效。请点击本文底部左下角的【阅读原文】,转入本文【简书版】


关于我们

  • Stata 连享会(公众号:StataChina)】由中山大学连玉君老师团队创办,旨在定期与大家分享 Stata 应用的各种经验和技巧。

  • 公众号推文同步发布于 CSDN-Stata连享会 、简书-Stata连享会 和 知乎-连玉君Stata专栏。可以在上述网站中搜索关键词StataStata连享会后关注我们。

  • 点击推文底部【阅读原文】可以查看推文中的链接并下载相关资料。

  • Stata连享会 精彩推文1  || 精彩推文2

联系我们

  • 欢迎赐稿: 欢迎将您的文章或笔记投稿至Stata连享会(公众号: StataChina),我们会保留您的署名;录用稿件达五篇以上,即可免费获得 Stata 现场培训 (初级或高级选其一) 资格。

  • 意见和资料: 欢迎您的宝贵意见,您也可以来信索取推文中提及的程序和数据。

  • 招募英才: 欢迎加入我们的团队,一起学习 Stata。合作编辑或撰写稿件五篇以上,即可免费获得 Stata 现场培训 (初级或高级选其一) 资格。

  • 联系邮件: StataChina@163.com

往期精彩推文

欢迎加入Stata连享会(公众号: StataChina)



    您可能也对以下帖子感兴趣

    文章有问题?点此查看未经处理的缓存