Skip to main content

Professional portfolio analysis tools for DIY investors

Project description

Portfolio-Analysis

Streamlit App PyPI version Documentation Tests License: MIT

Open-source portfolio analysis tools for DIY investors and finance enthusiasts. This repository aims to provide a comprehensive suite of tools to analyze and optimize investment portfolios, with an emphasis on transparency, flexibility, and extensibility.

Documentation

Read the Full Documentation - Comprehensive guides, API reference, and examples.

Quick Start

Try Online (No Installation)

Google Colab Notebooks:

Install as Python Package

pip install engineer-investor-portfolio

Or install from source with all features:

git clone https://github.com/engineerinvestor/Portfolio-Analysis.git
cd Portfolio-Analysis
pip install -e ".[all]"

Run the Streamlit Web App

pip install -r requirements-streamlit.txt
streamlit run streamlit_app/app.py

Or Use the Live App

Launch Streamlit App

Features

Core Analysis

  • Performance Metrics: Annual return, volatility, Sharpe ratio, Sortino ratio, max drawdown, VaR
  • Portfolio Analysis: Weighted returns, covariance-based volatility, cumulative returns
  • Monte Carlo Simulation: Project future portfolio values with confidence intervals
  • Benchmark Comparison: Alpha, beta, tracking error, information ratio, capture ratios

Optimization

  • Maximum Sharpe Ratio portfolio
  • Minimum Volatility portfolio
  • Risk Parity (equal risk contribution)
  • Target Return optimization
  • Efficient Frontier visualization

Factor Analysis

  • Fama-French Models: CAPM, FF3, FF5, and Carhart 4-factor regressions
  • Factor Data: Auto-fetch from Kenneth French Data Library with local caching
  • Return Attribution: Decompose returns into factor contributions + alpha
  • Risk Attribution: Variance decomposition by systematic factor
  • Rolling Analysis: Time-varying factor exposures
  • Characteristic Tilts: Size, value, momentum, quality, investment tilts
  • Factor Optimization: Target specific factor exposures or neutralize factors

Factor Attribution

HTML Tear Sheet Reports

  • Professional portfolio reports inspired by QuantStats
  • Embedded charts (cumulative returns, drawdowns, monthly heatmap)
  • Comprehensive metrics tables (risk, return, ratios)
  • Optional benchmark comparison section
  • Self-contained HTML files with no external dependencies

Interactive Tools

  • Jupyter widgets for Colab/notebook analysis
  • Streamlit web application
  • Preset portfolios (60/40, Three-Fund, All-Weather, etc.)

Usage Examples

Python Package

from portfolio_analysis import DataLoader, PortfolioAnalysis, MonteCarloSimulation

# Load data
loader = DataLoader(['VTI', 'VXUS', 'BND'], '2018-01-01', '2024-01-01')
data = loader.fetch_data()

# Analyze portfolio
portfolio = PortfolioAnalysis(data, weights=[0.4, 0.2, 0.4])
portfolio.print_summary()

# Run Monte Carlo simulation
mc = MonteCarloSimulation(data, weights=[0.4, 0.2, 0.4], num_simulations=1000)
mc.print_summary()
mc.plot_simulation()

Optimization

from portfolio_analysis import PortfolioOptimizer

optimizer = PortfolioOptimizer(data, risk_free_rate=0.04)
optimal = optimizer.optimize_max_sharpe()
print(f"Optimal weights: {optimal['weights']}")

# Visualize efficient frontier
optimizer.plot_efficient_frontier()

HTML Tear Sheet

from portfolio_analysis import DataLoader, PortfolioAnalysis, BenchmarkComparison
from portfolio_analysis.reporting import ReportBuilder

# Load data and create portfolio
loader = DataLoader(['VTI', 'BND'], '2020-01-01', '2024-01-01')
data = loader.fetch_data()
portfolio = PortfolioAnalysis(data, [0.6, 0.4])

# Generate basic report
report = ReportBuilder(portfolio, title="60/40 Portfolio")
report.generate("tearsheet.html")

# With benchmark comparison
benchmark = BenchmarkComparison(data, [0.6, 0.4], benchmark_ticker='SPY')
report = ReportBuilder(portfolio, benchmark=benchmark, title="60/40 Portfolio")
report.generate("tearsheet_with_benchmark.html")

Factor Analysis

from portfolio_analysis import DataLoader, PortfolioAnalysis
from portfolio_analysis.factors import FactorDataLoader, FactorRegression, FactorAttribution

# Load portfolio data
loader = DataLoader(['VTI', 'VBR', 'VTV', 'BND'], '2019-01-01', '2024-01-01')
data = loader.fetch_data()
portfolio = PortfolioAnalysis(data, [0.4, 0.2, 0.2, 0.2])
returns = portfolio.calculate_portfolio_returns()

# Load Fama-French factors
factor_loader = FactorDataLoader()
ff3 = factor_loader.get_ff3_factors('2019-01-01', '2024-01-01')

# Run factor regression
regression = FactorRegression(returns, ff3)
results = regression.run_regression('ff3')
print(results.summary())
# Output: Alpha, Market Beta, SMB, HML with t-stats and p-values

# Decompose returns by factor
attribution = FactorAttribution(returns, ff3)
decomp = attribution.decompose_returns()
print(f"Market contribution: {decomp['Mkt-RF']:.2%}")
print(f"Alpha: {decomp['alpha']:.2%}")

# Compare all factor models
comparison = regression.compare_models()
print(comparison)  # CAPM vs FF3 vs FF5 vs Carhart

Rolling Betas

Repository Structure

Portfolio-Analysis/
├── portfolio_analysis/          # Python package
│   ├── data/                    # Data loading
│   ├── metrics/                 # Performance & benchmark metrics
│   ├── analysis/                # Portfolio & Monte Carlo analysis
│   ├── factors/                 # Factor analysis (Fama-French, etc.)
│   ├── visualization/           # Plotting & interactive widgets
│   ├── reporting/               # HTML tear sheet generation
│   └── utils/                   # Helper functions
├── streamlit_app/               # Web application
│   └── app.py                   # Main Streamlit app
├── tests/                       # pytest test suite
├── docs/images/                 # Documentation images
├── Tutorials/                   # Additional notebooks
├── Visualization/               # Visualization notebooks
├── Basic_Portfolio_Analysis.ipynb
├── Interactive_Portfolio_Analysis.ipynb
├── Factor_Analysis_Demo.ipynb   # Factor analysis tutorial
├── pyproject.toml               # Package configuration
└── requirements*.txt            # Dependencies

Installation Options

Minimal (Core Analysis)

pip install engineer-investor-portfolio

With Optimization

pip install "engineer-investor-portfolio[optimization]"

With Interactive Widgets

pip install "engineer-investor-portfolio[interactive]"

With Factor Analysis

pip install "engineer-investor-portfolio[factors]"

For Streamlit App

pip install "engineer-investor-portfolio[streamlit]"

Full Development

pip install "engineer-investor-portfolio[all]"

Contributing

We welcome contributions from the community. Please read the following guidelines:

  1. Fork the repository
  2. Create a new branch (git checkout -b feature-name)
  3. Commit your changes (git commit -m 'Add feature')
  4. Push to the branch (git push origin feature-name)
  5. Create a Pull Request

See also: Beginner's Guide to Contributing

Roadmap

  • Core portfolio analysis classes
  • Monte Carlo simulation (fixed)
  • Benchmark comparison
  • Interactive widgets for Colab
  • Python package (PyPI-ready)
  • Portfolio optimization
  • Streamlit web application
  • HTML tear sheet reports
  • Factor analysis (Fama-French, Carhart, return/risk attribution)
  • Time-varying risk-free rate (T-bill data)
  • Tax-loss harvesting tools
  • Comprehensive test coverage

Related Resources

License

This project is licensed under the MIT License - see the LICENSE file for details.

Disclaimer

This is not investment advice. These tools are for educational purposes only. Past performance does not guarantee future results. Always do your own research and consider consulting a qualified financial advisor.

Contact

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

engineer_investor_portfolio-0.2.0.tar.gz (57.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

engineer_investor_portfolio-0.2.0-py3-none-any.whl (63.2 kB view details)

Uploaded Python 3

File details

Details for the file engineer_investor_portfolio-0.2.0.tar.gz.

File metadata

File hashes

Hashes for engineer_investor_portfolio-0.2.0.tar.gz
Algorithm Hash digest
SHA256 7debd803eaf90cf57cb5d132d683b87319508b8c967f4ff78ddce0992e22a6ea
MD5 ee010b9e94eb690916bc8fcb36e85d13
BLAKE2b-256 2183951d5203eec23611ab688d9b49200e859fb026005544c63fff72d0094432

See more details on using hashes here.

File details

Details for the file engineer_investor_portfolio-0.2.0-py3-none-any.whl.

File metadata

File hashes

Hashes for engineer_investor_portfolio-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 3b4a9d011e00f2b8ff3b840045b5fea43cb7fe247c44fee61ba6243a9f40ca8f
MD5 8f2836f73f4de5566a04d12c17ae5087
BLAKE2b-256 c165ca2217e9d32b8bc9c81765f75a9ce472991cef176ec9281b1b446fda9c2a

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page