如何计算投资回报率

Basic Rate of Return

最naive的想法是,计算投资回报率就直接把一段时间内的利润除以本金即可,即:

Basic Return = (EV – BV) / BV

其中EV是Ending Value, BV是Beginning Value。但是有资金的流入流出怎么办?最naive的方法就是把净资金流入算作本金,即:

Basic Return = [EV – (BV+CF)] / (BV+CF)

其中CF是 Net Cash Flow。这样计算,最大的好处自然是简单粗暴;但是有一个致命问题就是,当资金流入流出很多或很大的时候,会让结果变得不准确。

举一个简单而极端的例子:假设年初投入本金$1千,某一天投入资金$1百万,一天后涨了1%赚了$1万之后把这$1百万撤走了,到了年末的时候,投资的股票价格正好跌回和年初一样。这样的话,这一年中净资金流入CF为0,本金BV为$1千,而EV是$1.1万,最后计算回报率的时候如果按上面公式计算分母(BV+CF)是$1千,于是回报率1000%。显然,这个结果没有任何意义。

大家每个月都有新的收入进来,都会投入到股市当中,因此资金的流入流出肯定是投资的重要一部分,因此 Basic Rate of Return 这种计算投资回报率的方式基本上可以说是错误计算方式了。而正确的计算方式有两种:时间加权收益率 Time-Weighted Return (TWR) 和内部收益率 Internal Rate of Return (IRR)。

Time-Weighted Return (TWR) 时间加权收益率

Time-Weighted Return (TWR) 时间加权收益率的宗旨是把整个时间段分成一个个小的时间段,在每个小时间段内资金流入流出为0,然后再把各个是简单的回报率相乘得到总的投资回报率。写成公式就是:

TWR = (1 + m1) * (1 + m2) * …* (1 + mN) – 1

其中mi为每一个小是简单的收益率。貌似通常小时间段的选取是一个月,但是随着信息时代的到来不需要手工计算了其实划分成一天甚至更短更靠谱一点。

TWR这种计算投资回报率的方式意图去掉资金量大小对投资回报率的影响。继续看上一段举的那个极端例子,如果小时间段的选取是一天,那么TWR计算出来的回报率就是一个不到1%的很小的数字了。

TWR这种计算方式的好处是便于和benchmark(例如SP500基金)进行比较。

Internal Rate of Return (IRR) 内部收益率

TWR固然方便和benchmark进行比较,但是忽略掉资金流入流出的影响也让它有很重要的缺陷。假设一年11个月收益都是正的,只有1个月的收益是负的,结果投资人很不幸就是在那回报为负的一个月加了重仓,就有可能导致这样的结果:TWR收益是正的,但是其实这位投资者这一年却赔了不少钱。这时就要引入另一种计算方式,内部收益率 Internal Rate of Return (IRR),或者叫金钱加权收益率 Money-Weighted Return (MWR)。

内部收益率 Internal Rate of Return (IRR) 的宗旨是给重仓的时间更大的权重,轻仓的时间更低的权重。其具体计算方式稍微有点复杂,为了避免误导我这里还是直接引用阅微堂写的介绍吧:

将初始投入视为现金流入(大于 0 ),期末资产视为现金流出(小于 0 ),那么 IRR 即使得现金流的现值等于 0 的折现率。我们使用下述公式:∑𝑖=1𝑇𝑓𝑡𝑖(1+𝑟)−𝑡𝑖=0

其中𝑓𝑡𝑖为时间点𝑡𝑖上的现金流,𝑟即 IRR。在 IRR 的计算中,钱在不同时候收益率是一样的。并且它只对期间整体进行定义,分期的收益率和整体的收益率并无直接的关系。上述的定义较为复杂,掩盖了 IRR 的一些本质。事实上,IRR 近似等于收益额除以平均占用资金。这里平均占用资金是指各期占用资金的算术平均值。

IRR 这种计算方式的好处是能体现出投资者择时的影响,能反应出真实的总个人得失,但是拿 IRR 和 SP500 直接比较就比较不合理了。

如何查看/计算自己的投资收益率

在券商的界面中,他们总是会给出一个Portfolio Performance,大家可以仔细看看说明页他们给出的到底是哪个数字。例如下图是Schwab的界面,点开设置的话发现这俩都能选择,其中默认选择是 TWR。M1finance显示的回报率数字则是 IRR,不能更改。

如果你的投资分散在几个不同的券商中,则单一券商显示的结果就不完整了,这时需要自己计算。TWR 的计算需要完整的每天的余额或者需要全部交易记录,如果没有自动化工具的话计算起来会相当繁琐,不过只要你不是准备自己开基金的话那其实还是 IRR 对你更有意义一点。

计算 IRR 的话可以自己建一个Excel表格,然后在各个券商中找到activities页面把该时间段内所有资金进出和对应的日期填入Excel,然后用XIRR函数计算即可。以及需要该时间段起始日期时候的余额,以及结束日期时候的余额(需要添加一个负号填入)。注意IRR的计算并不需要导入交易记录也不需要知道每日余额(当然,该时间段开始和结束这两天的余额需要填入)。一个简单的例子见下面的截图:

总结

TWR 和 IRR 这两种计算方式,一个侧重反应投资策略本身的回报试图避免资金流入流出的影响,一个侧重考虑不同时间仓位轻重的影响反应总的个人得失。总的来说,这两种计算方式都是有意义的,但是看待这个数字的时候应该清楚自己的目的是什么以便选择更合理的那一个。

By physixfan