PyPortfolioOpt

PyPortfolioOpt

功能强大的Python投资组合优化库

PyPortfolioOpt是一个用于投资组合优化的Python库。它实现了经典的均值-方差优化、Black-Litterman模型等方法,还包含风险平价等新型技术。该库适用于个人和专业投资者,可高效组合多种投资策略。PyPortfolioOpt提供收益估算、风险建模、目标函数优化等核心功能,采用模块化设计便于扩展。它能帮助用户在考虑风险的同时优化投资组合表现。

PyPortfolioOpt投资组合优化均值方差优化夏普比率风险模型Github开源项目
<p align="center"> <img width=60% src="https://yellow-cdn.veclightyear.com/835a84d5/16d53ee0-8837-4f61-a2f4-f7e25d99cff9.png?raw=true"> </p> <!-- 按钮 --> <p align="center"> <a href="https://www.python.org"> <img src="https://yellow-cdn.veclightyear.com/835a84d5/e0375844-0e66-4a98-a401-20cafb80bcff.svg" alt="python"></a> &nbsp; <a href="https://www.python.org"> <img src="https://yellow-cdn.veclightyear.com/835a84d5/9eb0b30b-344b-4068-8a17-276e58e59ef5.svg?style=flat-square" alt="platforms"></a> &nbsp; <a href="https://pypi.org/project/PyPortfolioOpt/"> <img src="https://yellow-cdn.veclightyear.com/835a84d5/411603fc-afd0-4e63-ab62-1b6e839e83b7.svg" alt="pypi"></a> &nbsp; <a href="https://opensource.org/licenses/MIT"> <img src="https://yellow-cdn.veclightyear.com/835a84d5/abfc621c-580d-4e0d-9906-4837432d2b49.svg" alt="MIT license"></a> &nbsp; <a href="https://github.com/robertmartin8/PyPortfolioOpt/actions"> <img src="https://yellow-cdn.veclightyear.com/835a84d5/15fa5543-8a7e-4af7-83e2-8b9211e2a303.svg?branch=master" alt="build"></a> &nbsp; <a href="https://app.codecov.io/gh/robertmartin8/PyPortfolioOpt"> <img src="https://yellow-cdn.veclightyear.com/835a84d5/b3f6616e-fc46-404e-a147-c9ad5b4ef72e.svg?branch=main" alt="codecov"></a> &nbsp; <a href="https://pepy.tech/project/pyportfolioopt"> <img src="https://pepy.tech/badge/pyportfolioopt" alt="downloads"></a> &nbsp; <a href="https://mybinder.org/v2/gh/robertmartin8/pyportfolioopt/master/?filepath=cookbook"> <img src="https://yellow-cdn.veclightyear.com/835a84d5/94837f5a-f959-4d65-8b9c-0db360fedef5.svg" alt="binder"></a> &nbsp; </p> <!-- 内容 -->

PyPortfolioOpt是一个实现投资组合优化方法的库,包括经典的均值-方差优化技术和Black-Litterman配置,以及该领域的一些最新发展,如收缩和层次风险平价。

它既全面又易于扩展,可以为普通投资者或寻求简单原型工具的专业人士提供帮助。无论你是一个发现了少数被低估股票的基本面投资者,还是拥有一篮子策略的算法交易者,PyPortfolioOpt都可以帮助你以风险效率的方式组合你的alpha来源。

PyPortfolioOpt已在开源软件期刊上发表 🎉

PyPortfolioOpt现由Tuan Tran维护。

前往**ReadTheDocs上的文档**深入了解该项目,或查看cookbook以查看从下载数据到构建投资组合的完整过程示例。

<center> <img src="https://yellow-cdn.veclightyear.com/835a84d5/bf41e8e4-da3c-4bd6-8639-25f47e1f1337.png?raw=true" style="width:70%;"/> </center>

目录

入门

如果你想在浏览器中交互式地试用PyPortfolioOpt,可以在这里启动Binder。虽然设置需要一些时间,但它可以让你尝试cookbook中的示例,而无需处理所有依赖项。

注意:macOS用户需要安装命令行工具

注意:如果你使用Windows系统,首先需要安装C++。(下载安装说明

该项目可在PyPI上获得,这意味着你只需:

pip install PyPortfolioOpt

(你可能需要按照单独的安装说明安装cvxoptcvxpy)。

然而,最佳实践是在虚拟环境中使用依赖管理器。 我目前的建议是使用poetry进行设置,然后运行

poetry add PyPortfolioOpt

或者,克隆/下载项目并在项目目录中运行:

python setup.py install

PyPortfolioOpt支持Docker。使用docker build -f docker/Dockerfile . -t pypfopt构建你的第一个容器。你可以使用该镜像运行测试或启动Jupyter服务器。

# iPython解释器: docker run -it pypfopt poetry run ipython # Jupyter notebook服务器: docker run -it -p 8888:8888 pypfopt poetry run jupyter notebook --allow-root --no-browser --ip 0.0.0.0 # 点击http://127.0.0.1:8888/?token=xxx # Pytest docker run -t pypfopt poetry run pytest # Bash docker run -it pypfopt bash

更多信息,请阅读本指南

开发用途

如果你想进行重大更改以将其集成到你的专有系统中,最好克隆此存储库并直接使用源代码。

git clone https://github.com/robertmartin8/PyPortfolioOpt

或者,你可以尝试:

pip install -e git+https://github.com/robertmartin8/PyPortfolioOpt.git

快速示例

以下是使用真实股票数据的示例,演示了如何轻松找到最大化夏普比率(风险调整后收益的衡量指标)的仅多头投资组合。

import pandas as pd from pypfopt import EfficientFrontier from pypfopt import risk_models from pypfopt import expected_returns # 读取价格数据 df = pd.read_csv("tests/resources/stock_prices.csv", parse_dates=True, index_col="date") # 计算预期收益和样本协方差 mu = expected_returns.mean_historical_return(df) S = risk_models.sample_cov(df) # 优化以获得最大夏普比率 ef = EfficientFrontier(mu, S) raw_weights = ef.max_sharpe() cleaned_weights = ef.clean_weights() ef.save_weights_to_file("weights.csv") # 保存到文件 print(cleaned_weights) ef.portfolio_performance(verbose=True)

这将输出以下权重:

{'GOOG': 0.03835, 'AAPL': 0.0689, 'FB': 0.20603, 'BABA': 0.07315, 'AMZN': 0.04033, 'GE': 0.0, 'AMD': 0.0, 'WMT': 0.0, 'BAC': 0.0, 'GM': 0.0, 'T': 0.0, 'UAA': 0.0, 'SHLD': 0.0, 'XOM': 0.0, 'RRC': 0.0, 'BBY': 0.01324, 'MA': 0.35349, 'PFE': 0.1957, 'JPM': 0.0, 'SBUX': 0.01082} 预期年化收益率: 30.5% 年化波动率: 22.2% 夏普比率: 1.28

这些数据本身很有趣但不太实用。不过,PyPortfolioOpt提供了一种方法,可以将上述连续权重转换为您实际可以购买的分配。只需输入最新价格和所需的投资组合规模(本例中为10,000美元):

from pypfopt.discrete_allocation import DiscreteAllocation, get_latest_prices latest_prices = get_latest_prices(df) da = DiscreteAllocation(weights, latest_prices, total_portfolio_value=10000) allocation, leftover = da.greedy_portfolio() print("离散分配:", allocation) print("剩余资金: ${:.2f}".format(leftover))
20个股票中有12个被移除 离散分配: {'GOOG': 1, 'AAPL': 4, 'FB': 12, 'BABA': 4, 'BBY': 2, 'MA': 20, 'PFE': 54, 'SBUX': 1} 剩余资金: $11.89

免责声明:本项目不构成投资建议,作者对您后续的投资决策不承担任何责任。更多信息请参阅许可证

经典投资组合优化方法概述

Harry Markowitz 1952年的论文无疑是一个经典,它将投资组合优化从艺术转变为科学。其关键洞见是,通过结合具有不同预期收益和波动性的资产,可以决定一个数学上最优的分配,在目标收益下最小化风险 - 所有这些最优投资组合的集合被称为有效前沿

<center> <img src="https://yellow-cdn.veclightyear.com/835a84d5/9a4918dc-e108-4ee9-8710-8c2434984e44.png?raw=true" style="width:60%;"/> </center>

尽管该主题已有了很大发展,但半个多世纪后,Markowitz的核心思想仍然具有根本重要性,并在许多投资组合管理公司中得到日常使用。 均值-方差优化的主要缺点是,理论处理需要了解资产的预期收益和未来风险特征(协方差)。显然,如果我们知道股票的预期收益,生活会容易得多,但整个游戏的关键是股票收益是出了名的难以预测。作为替代,我们可以基于历史数据得出预期收益和协方差的估计 - 尽管我们失去了Markowitz提供的理论保证,但我们的估计越接近真实值,我们的投资组合就会越好。

因此,本项目提供了四个主要功能集(当然它们是密切相关的)

  • 预期收益的估计
  • 风险估计(即资产收益的协方差)
  • 待优化的目标函数
  • 优化器

PyPortfolioOpt的一个关键设计目标是模块化 - 用户应该能够在仍然利用PyPortfolioOpt提供的框架的同时交换他们的组件。

特性

在本节中,我们详细介绍了PyPortfolioOpt的一些可用功能。更多示例可以在这里的Jupyter笔记本中找到。另一个好资源是测试

ReadTheDocs上可以找到更全面的版本,以及针对更高级用户的可能扩展。

预期收益

  • 平均历史收益:
    • 最简单和最常见的方法,它认为每个资产的预期收益等于其历史收益的平均值。
    • 易于理解和非常直观
  • 指数加权平均历史收益:
    • 类似于平均历史收益,但它对最近的价格给予指数级更多的权重
    • 在估计未来收益时,资产最近的收益可能比10年前的收益更有权重。
  • 资本资产定价模型(CAPM):
    • 一个基于市场贝塔系数预测收益的简单模型
    • 这在金融领域广泛使用!

风险模型(协方差)

协方差矩阵不仅编码了资产的波动性,还编码了它与其他资产的相关性。这很重要,因为为了获得分散化的好处(从而增加每单位风险的回报),投资组合中的资产应该尽可能不相关。

  • 样本协方差矩阵:
    • 协方差矩阵的无偏估计
    • 计算相对容易
    • 多年来的事实标准
    • 然而,它有较高的估计误差,这在均值-方差优化中特别危险,因为优化器可能会对这些错误估计给予过多权重。
  • 半协方差:一种专注于下行变动的风险衡量指标。
  • 指数协方差:对样本协方差的改进,给予最近数据更多权重
  • 协方差收缩:涉及将样本协方差矩阵与结构化估计器结合的技术,以减少错误权重的影响。PyPortfolioOpt提供了围绕sklearn.covariance提供的高效向量化实现的包装器。
    • 手动收缩
    • Ledoit Wolf收缩,选择最优收缩参数。我们提供三个收缩目标:constant_variancesingle_factorconstant_correlation
    • Oracle近似收缩
  • 最小协方差行列式:
    • 协方差的稳健估计
    • sklearn.covariance中实现
<p align="center"> <img width=60% src="https://yellow-cdn.veclightyear.com/835a84d5/ef96c38b-8811-4cea-92eb-f8f52906f498.png?raw=true"> </p>

(此图是使用plotting.plot_covariance生成的)

目标函数

  • 最大夏普比率:这会产生一个_切线投资组合_,因为在收益vs风险图上,这个投资组合对应于有效前沿的切线,其y轴截距等于无风险利率。这是默认选项,因为它找到了每单位风险的最优回报。
  • 最小波动率。如果你想了解波动率_可能_有多低,这可能很有用,但在实践中,使用最大化夏普比率的投资组合对我来说更有意义。
  • 有效收益,又称Markowitz投资组合,它在给定目标收益的情况下最小化风险 - 这是Markowitz 1952年的主要关注点
  • 有效风险:给定目标风险的夏普最大化投资组合。
  • 最大二次效用。您可以提供自己的风险厌恶水平并计算适当的投资组合。

添加约束或不同目标

  • 多头/空头:默认情况下,PyPortfolioOpt中的所有均值-方差优化方法都是仅多头的,但可以通过更改权重界限来允许空头头寸:
ef = EfficientFrontier(mu, S, weight_bounds=(-1, 1))
  • 市场中性:对于efficient_riskefficient_return方法,PyPortfolioOpt提供了形成市场中性投资组合的选项(即权重之和为零)。这对于最大夏普投资组合和最小波动率投资组合是不可能的,因为在这些情况下,它们对杠杆不变。市场中性需要负权重:
ef = EfficientFrontier(mu, S, weight_bounds=(-1, 1)) ef.efficient_return(target_return=0.2, market_neutral=True)
  • 最小/最大头寸规模:可能你希望没有证券占你投资组合的10%以上。这很容易编码:
ef = EfficientFrontier(mu, S, weight_bounds=(0, 0.1))

均值-方差优化的一个问题是它会导致许多零权重。虽然这些在样本内是"最优的",但有大量研究表明,这一特征导致均值-方差投资组合在样本外表现不佳。为此,我引入了一个目标函数,可以减少任何目标函数的可忽略权重的数量。本质上,它对小权重添加了一个惩罚(由gamma参数化),其形式看起来就像机器学习中的L2正则化。可能需要尝试几个gamma值来达到所需的非可忽略权重数量。对于20只证券的测试投资组合,gamma ~ 1就足够了

ef = EfficientFrontier(mu, S) ef.add_objective(objective_functions.L2_reg, gamma=1) ef.max_sharpe()

Black-Litterman分配

从v0.5.0版本开始,我们现在支持Black-Litterman资产配置,它允许您将先验收益估计(例如市场隐含收益)与您自己的观点相结合,形成后验估计。这比仅使用历史平均收益能得到更好的预期收益估计。查看文档了解理论讨论以及输入格式的建议。

S = risk_models.sample_cov(df) viewdict = {"AAPL": 0.20, "BBY": -0.30, "BAC": 0, "SBUX": -0.2, "T": 0.131321} bl = BlackLittermanModel(S, pi="equal", absolute_views=viewdict, omega="default") rets = bl.bl_returns() ef = EfficientFrontier(rets, S) ef.max_sharpe()

其他优化器

上述功能主要涉及通过二次规划解决均值-方差优化问题(尽管这由cvxpy处理)。然而,我们还提供了不同的优化器:

  • 均值-半方差优化
  • 均值-CVaR优化
  • 分层风险平价,使用聚类算法选择不相关资产
  • Markowitz的临界线算法(CLA)

更多详情请参阅文档

相较于现有实现的优势

  • 包括经典方法(Markowitz 1952和Black-Litterman)、建议的最佳实践(如协方差收缩),以及许多近期发展和新颖特性,如L2正则化、收缩协方差、分层风险平价。
  • 原生支持pandas数据框:轻松输入您的日常价格数据。
  • 广泛的实际测试,使用真实生活数据。
  • 易于与您的专有策略和模型结合。
  • 对缺失数据和不同长度的价格序列具有鲁棒性(例如,FB数据仅追溯到2012年,而AAPL数据可追溯到1980年)。

项目原则和设计决策

  • 应该易于用户自己的专有改进替换优化过程的各个组件。
  • 可用性至关重要:宁可自解释也不要一致性。
  • 除非能实际应用于真实资产价格,否则投资组合优化毫无意义。
  • 所有已实现的内容都应该经过测试。
  • 内联文档很好:专门(单独)的文档更好。两者并不互相排斥。
  • 格式永远不应妨碍编码:因此,我将所有格式决策交给了Black

测试

测试使用pytest编写(在我看来比unittest及其变体更直观),我尽力确保接近100%的覆盖率。通过导航到包目录并在命令行上简单运行pytest来运行测试。

PyPortfolioOpt提供了20支股票的每日收益测试数据集:

['GOOG', 'AAPL', 'FB', 'BABA', 'AMZN', 'GE', 'AMD', 'WMT', 'BAC', 'GM', 'T', 'UAA', 'SHLD', 'XOM', 'RRC', 'BBY', 'MA', 'PFE', 'JPM', 'SBUX']

这些股票经非正式选择,以满足几个标准:

  • 合理的流动性
  • 不同的表现和波动性
  • 不同数量的数据以测试鲁棒性

目前,测试尚未探索所有边缘情况以及目标函数和参数的组合。然而,每种方法和参数都已经过测试,确保按预期工作。

引用PyPortfolioOpt

如果您在已发表的工作中使用PyPortfolioOpt,请引用JOSS论文

引用字符串:

Martin, R. A., (2021). PyPortfolioOpt: portfolio optimization in Python. Journal of Open Source Software, 6(61), 3066, https://doi.org/10.21105/joss.03066

BibTex:

@article{Martin2021, doi = {10.21105/joss.03066}, url = {https://doi.org/10.21105/joss.03066}, year = {2021}, publisher = {The Open Journal}, volume = {6}, number = {61}, pages = {3066}, author = {Robert Andrew Martin}, title = {PyPortfolioOpt: portfolio optimization in Python}, journal = {Journal of Open Source Software} }

贡献

欢迎贡献。请查看贡献指南了解更多信息。

我要感谢自2018年发布以来为PyPortfolioOpt做出贡献的所有人。 特别感谢:

  • Tuan Tran(现在是主要维护者!)
  • Philipp Schiele
  • Carl Peasnell
  • Felipe Schneider
  • Dingyuan Wang
  • Pat Newell
  • Aditya Bhutra
  • Thomas Schmelzer
  • Rich Caputo
  • Nicolas Knudde

联系方式

如果您在使用PyPortfolioOpt时遇到问题,请在GitHub上提出issue。对于其他任何事情,您可以通过以下方式联系我:

<center> <img src="https://yellow-cdn.veclightyear.com/835a84d5/d5007324-0bd4-42bd-a1b8-328e47d44736.png?raw=true" style="width:60%;"/> </center>

编辑推荐精选

讯飞智文

讯飞智文

一键生成PPT和Word,让学习生活更轻松

讯飞智文是一个利用 AI 技术的项目,能够帮助用户生成 PPT 以及各类文档。无论是商业领域的市场分析报告、年度目标制定,还是学生群体的职业生涯规划、实习避坑指南,亦或是活动策划、旅游攻略等内容,它都能提供支持,帮助用户精准表达,轻松呈现各种信息。

AI办公办公工具AI工具讯飞智文AI在线生成PPTAI撰写助手多语种文档生成AI自动配图热门
讯飞星火

讯飞星火

深度推理能力全新升级,全面对标OpenAI o1

科大讯飞的星火大模型,支持语言理解、知识问答和文本创作等多功能,适用于多种文件和业务场景,提升办公和日常生活的效率。讯飞星火是一个提供丰富智能服务的平台,涵盖科技资讯、图像创作、写作辅助、编程解答、科研文献解读等功能,能为不同需求的用户提供便捷高效的帮助,助力用户轻松获取信息、解决问题,满足多样化使用场景。

热门AI开发模型训练AI工具讯飞星火大模型智能问答内容创作多语种支持智慧生活
Spark-TTS

Spark-TTS

一种基于大语言模型的高效单流解耦语音令牌文本到语音合成模型

Spark-TTS 是一个基于 PyTorch 的开源文本到语音合成项目,由多个知名机构联合参与。该项目提供了高效的 LLM(大语言模型)驱动的语音合成方案,支持语音克隆和语音创建功能,可通过命令行界面(CLI)和 Web UI 两种方式使用。用户可以根据需求调整语音的性别、音高、速度等参数,生成高质量的语音。该项目适用于多种场景,如有声读物制作、智能语音助手开发等。

Trae

Trae

字节跳动发布的AI编程神器IDE

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
咔片PPT

咔片PPT

AI助力,做PPT更简单!

咔片是一款轻量化在线演示设计工具,借助 AI 技术,实现从内容生成到智能设计的一站式 PPT 制作服务。支持多种文档格式导入生成 PPT,提供海量模板、智能美化、素材替换等功能,适用于销售、教师、学生等各类人群,能高效制作出高品质 PPT,满足不同场景演示需求。

讯飞绘文

讯飞绘文

选题、配图、成文,一站式创作,让内容运营更高效

讯飞绘文,一个AI集成平台,支持写作、选题、配图、排版和发布。高效生成适用于各类媒体的定制内容,加速品牌传播,提升内容营销效果。

热门AI辅助写作AI工具讯飞绘文内容运营AI创作个性化文章多平台分发AI助手
材料星

材料星

专业的AI公文写作平台,公文写作神器

AI 材料星,专业的 AI 公文写作辅助平台,为体制内工作人员提供高效的公文写作解决方案。拥有海量公文文库、9 大核心 AI 功能,支持 30 + 文稿类型生成,助力快速完成领导讲话、工作总结、述职报告等材料,提升办公效率,是体制打工人的得力写作神器。

openai-agents-python

openai-agents-python

OpenAI Agents SDK,助力开发者便捷使用 OpenAI 相关功能。

openai-agents-python 是 OpenAI 推出的一款强大 Python SDK,它为开发者提供了与 OpenAI 模型交互的高效工具,支持工具调用、结果处理、追踪等功能,涵盖多种应用场景,如研究助手、财务研究等,能显著提升开发效率,让开发者更轻松地利用 OpenAI 的技术优势。

Hunyuan3D-2

Hunyuan3D-2

高分辨率纹理 3D 资产生成

Hunyuan3D-2 是腾讯开发的用于 3D 资产生成的强大工具,支持从文本描述、单张图片或多视角图片生成 3D 模型,具备快速形状生成能力,可生成带纹理的高质量 3D 模型,适用于多个领域,为 3D 创作提供了高效解决方案。

3FS

3FS

一个具备存储、管理和客户端操作等多种功能的分布式文件系统相关项目。

3FS 是一个功能强大的分布式文件系统项目,涵盖了存储引擎、元数据管理、客户端工具等多个模块。它支持多种文件操作,如创建文件和目录、设置布局等,同时具备高效的事件循环、节点选择和协程池管理等特性。适用于需要大规模数据存储和管理的场景,能够提高系统的性能和可靠性,是分布式存储领域的优质解决方案。

下拉加载更多