夏普比率和最大回撤公式推导及代码实现

一、夏普比率

夏普比率是衡量一个策略的关键指标,它衡量的是承担每一单位波动的风险,可以多赚取多少的超额收益。

因为要衡量波动量,因此如果只知道初期资产和末期资产,是无法计算夏普比率的,必须知道每日的收益率或者每日对应的收益额。

可以假设年化无风险利率为2%,那么按照A股来说,假设1年252个交易日,则日无风险利率为0.02/252。也有很多人为了省事直接将无风险利率设为0,这个看自身情况设定。

夏普比率一般计算年化夏普比率,也可以计算月度夏普比率等。

夏普比率sharpratio=(策略的预期收益率−无风险利率)/策略收益率的标准差 夏普比率sharp ratio=(策略的预期收益率-无风险利率)/策略收益率的标准差 夏普比率sharpratio=(策略的预期收益率−无风险利率)/策略收益率的标准差

注意:

年化夏普比率=日度夏普比率 ∗252* \sqrt{252}∗252

年化夏普比率=月度夏普比率 ∗12* \sqrt{12}∗12

解释下这是怎么来的呢?

假设说我们已经得到了日超额收益率 序列xtx_txt,注意这里是已经减去日无风险利率得到的日超额收益率序列。

通过xtx_txt计算得到的均值和标准差为μ\muμ和σ\sigmaσ。那么,
年化夏普比率=年化超额收益率平均值年化超额收益率标准差=μ∗252σ∗252=日度夏普比率∗252 年化夏普比率=\frac{年化超额收益率平均值}{年化超额收益率标准差}\\=\frac{\mu*252}{\sigma*\sqrt{252}}\\=日度夏普比率 *\sqrt{252} 年化夏普比率=年化超额收益率标准差年化超额收益率平均值=σ∗252 μ∗252=日度夏普比率∗252

总结

假设已经得到每日的收益率序列,要计算年度夏普比率,共分为三步:

1、设定好年化无风险利率,将日收益率序列-日无风险收益率序列=日超额收益率序列;

2、计算日超额收益率序列的均值和标准差;

3、年化夏普比率=日度夏普比率 ∗252* \sqrt{252}∗252

二、最大回撤

最大回撤是指从最高点跌下来时,跌的最惨有多惨。

假设已经得到每日的收益率序列,计算最大回撤的四个步骤:

1、将每日的收益率序列转换为每日的历史总收益率序列;

2、遍历求出每日的目前为止最高历史收益率;

3、计算每日相对历史最高点的回撤比例;

4、在所有回撤中找到最惨的那一天,那一天的回撤比例即为所求的最大回撤;

三、代码实现

这里使用一个最简单的策略,策略就是买入沪深300ETF,然后放着10年不动,看这个策略的年化夏普比率和最大回撤。这里使用tushare来获取行情数据。

tushare介绍

tushare是一个比较常用的开源数据平台,pro版本对于在校大学生是免费的。

注意,tushare对于个股,ETF数据,指数数据的获取方式是不一样的。分别为pro.daily(),pro.fund_daily(),pro.index_daily(),如果混用了,会返回空值。

python代码实现

python 复制代码
import tushare as ts

def sharp_ratio_test():
    pro = ts.pro_api('your token')

    hushen_df = pro.fund_daily(ts_code='510300.SH', start_date='20150101', end_date='20251001')
    hushen_df = hushen_df.sort_values(by='trade_date', ascending=True)  # 先将df中的数据进行倒序排列,使得日期从前到后
    hushen_df['daily_rate'] = 0  # 每日的收益率,从第1日买入,第2日开始有收益
    for i in range(1, hushen_df.shape[0]):
        hushen_df['daily_rate'][i] = (hushen_df['close'][i] - hushen_df['close'][i - 1]) / hushen_df['close'][i - 1]
    hushen_df['daily_hist_rate'] = 0  # 每日的历史总收益率
    for i in range(1, hushen_df.shape[0]):
        hushen_df['daily_hist_rate'][i] = (hushen_df['close'][i] - hushen_df['close'][0]) / hushen_df['close'][0]
    # 计算夏普比率
    rf_annual = 0.02  # 年化无风险利率
    rf_daily = rf_annual / 252  # 日无风险利率
    hushen_df['daily_super_rate'] = 0  # 每日的日超额总收益率
    for i in range(1, hushen_df.shape[0]):
        hushen_df['daily_super_rate'][i] = hushen_df['daily_rate'][i] - rf_daily
    mu = hushen_df['daily_super_rate'].mean() #注意,这2行代码可以再微调,从第2日开始
    sigma = hushen_df['daily_super_rate'].std() #这里有个除以n-1和除以n的区别,可以微调
    sharp_ratio = mu / sigma * (252 ** 0.5)
    print("sharp ratio:", sharp_ratio)

    # 计算最大回撤
    equity = 1 + hushen_df['daily_hist_rate']  # 每日的净资产是初始资产的多少倍
    roll_max = equity.cummax()
    draw_down = equity / roll_max - 1
    max_draw_down = draw_down.min()
    print("max draw down:", max_draw_down)


if __name__ == '__main__':
    sharp_ratio_test()

按照上述代码,可得到最后的结果

python 复制代码
sharp ratio: -0.16625517304850126
max draw down: -0.45100740485620805
相关推荐
智星云算力9 分钟前
本地GPU与租用GPU混合部署:混合算力架构搭建指南
人工智能·架构·gpu算力·智星云·gpu租用
jinanwuhuaguo10 分钟前
截止到4月8日,OpenClaw 2026年4月更新深度解读剖析:从“能力回归”到“信任内建”的范式跃迁
android·开发语言·人工智能·深度学习·kotlin
xiaozhazha_14 分钟前
效率提升80%:2026年AI CRM与ERP深度集成的架构设计与实现
人工智能
枫叶林FYL15 分钟前
【自然语言处理 NLP】7.2.2 安全性评估与Constitutional AI
人工智能·自然语言处理
AI人工智能+22 分钟前
基于高精度身份证OCR识别、炫彩活体检测及人脸比对技术的人脸核身系统,为通信行业数字化转型提供了坚实的安全底座
人工智能·计算机视觉·人脸识别·ocr·人脸核身
小敬爱吃饭32 分钟前
Ragflow Docker部署及问题解决方案(界面为Welcome to nginx,ragflow上传文件失败,Docker中的ragflow-cpu-1一直重启)
人工智能·python·nginx·docker·语言模型·容器·数据挖掘
宸津-代码粉碎机39 分钟前
Spring Boot 4.0虚拟线程实战调优技巧,最大化发挥并发优势
java·人工智能·spring boot·后端·python
老兵发新帖1 小时前
Hermes:比openclaw更好用的智能体?
人工智能
俊哥V1 小时前
每日 AI 研究简报 · 2026-04-09
人工智能·ai
MicrosoftReactor1 小时前
技术速递|使用 Copilot SDK 构建 AI 驱动的 GitHub Issue 分类系统
人工智能·github·copilot