ml-finance-python
python scripts for finance machine learning
git clone https://9o.is/git/ml-finance-python.git
README.md
(12885B)
1 # Chapter 9: Bayesian Machine Learning
2
3 Bayesian statistics allows us to quantify uncertainty about future events and refine our estimates in a principled way as new information arrives. This dynamic approach adapts well to the evolving nature of financial markets. It is particularly useful when there are fewer relevant data and we require methods that systematically integrate prior knowledge or assumptions.
4
5 Bayesian approaches to machine learning allow for richer insights into the uncertainty around statistical metrics, parameters estimates and predictions. The applications range from more granular risk management to dynamic updates of predictive models that incorporate changes in the market environment. The Black-Litterman approach to asset allocation (see [Chapter 5](../05_strategy_evaluation)) can be interpreted as a Bayesian model. It computes the expected return as an average of the market equilibrium and the investor’s views, weighted by each asset’s volatility, cross-asset correlations and the confidence in each forecast. More specifically, this chapter covers:
6 - How Bayesian statistics apply to machine learning
7 - How to use probabilistic programming with PyMC3
8 - How to define and train machine learning models
9 - How to run state-of-the-art sampling methods to conduct approximate inference
10 - How to apply Bayesian machine learning to compute dynamic Sharpe ratios, build Bayesian classifiers, and estimate stochastic volatility
11
12
13 ## How Bayesian Machine Learning Works
14
15 Classical statistics is also called frequentist because it interprets probability as the relative frequency of an event over the long run, i.e. after observing a large number of trials. In the context of probabilities, an event is a combination of one or more elementary outcomes of an experiment, such as any of six equal results in rolls of two dice or an asset price dropping by 10% or more on a given day).
16
17 Bayesian statistics, in contrast, views probability as a measure of the confidence or belief in the occurrence of an event. The Bayesian perspective on probability leaves more room for subjective views and, consequently, differences in opinions than the frequentist interpretation. This difference is most striking for events that do not happen often enough to arrive at an objective measure of long-term frequency.
18
19 This chapter first introduces the Bayes Theorem that crystallizes the concept of updating beliefs by combining prior assumptions with new empirical evidence and compare the resulting parameter estimates with their frequentist counterparts. We then demonstrate two approaches to Bayesian statistical inference that produce insights into the posterior distribution of the latent, i.e. unobserved parameters, such as their expected values, under different circumstances:
20 1. Conjugate priors facilitate the updating process by providing a closed-form solution, but exact, analytical methods are not always available.
21 2. Approximate inference simulates the distribution that results from combining assumptions and data and uses samples from this distribution to compute statistical insights.
22
23 #### References
24
25 - [Bayesian Methods for Hackers](http://camdavidsonpilon.github.io/Probabilistic-Programming-and-Bayesian-Methods-for-Hackers/)
26 - [Andrew Gelman's Blog](https://andrewgelman.com/)
27 - [Thomas Wiecki's Blog](https://twiecki.github.io/)
28
29
30 ### How to update assumptions from empirical evidence
31
32 The theorem that Reverend Thomas Bayes came up with over 250 years ago uses fundamental probability theory to prescribe how probabilities or beliefs should change as relevant new information arrives as captured by John Maynard Keynes’ quote “When the facts change, I change my mind. What do you do, sir?”.
33
34 - [Bayes' rule: Guide](https://arbital.com/p/bayes_rule/?l=1zq)
35 - [Bayesian Updating with Continuous Priors](https://ocw.mit.edu/courses/mathematics/18-05-introduction-to-probability-and-statistics-spring-2014/readings/MIT18_05S14_Reading13a.pdf), MIT Open Courseware, 18.05 Introduction to Probability and Statistics
36
37 ### Exact Inference: Maximum a Posterior Estimation
38
39 Practical applications of Bayes’ rule to exactly compute posterior probabilities are quite limited because the computation of the evidence term in the denominator is quite challenging.
40
41 #### How to keep inference simple: Conjugate Priors
42
43 A prior distribution is conjugate with respect to the likelihood when the resulting posterior is of the same type of distribution as the prior except for different parameters. The conjugacy of prior and likelihood implies a closed-form solution for the posterior that facilitates the update process and avoids the need to use numerical methods to approximate the posterior.
44
45 #### How to dynamically estimate the probabilities of asset price moves
46
47 The notebook [updating_conjugate_priors](01_updating_conjugate_priors.ipynb) demonstrates how to use a conjugate prior to update price movement estimates from S&P 500 samples.
48
49 ### Approximate Inference: Stochastic vs Deterministic Approaches
50
51 For most models of practical relevance, it will not be possible to derive the exact posterior distribution analytically and compute expected values for the latent parameters.
52
53 Although for some applications the posterior distribution over unobserved parameters
54 will be of interest, most often it is primarily required to evaluate expectations, e.g. to make predictions. In such situations, we can rely on approximate inference:
55 - Stochastic techniques based on Markov Chain Monte Carlo (MCMC) sampling have popularized the use of Bayesian methods across many domains. They generally have the property to converge to the exact result. In practice, sampling methods can be computationally demanding and are often limited to small-scale problems.
56 - [A Conceptual Introduction to Hamiltonian Monte Carlo](https://arxiv.org/pdf/1701.02434.pdf), Michael Betancourt, 2018
57 - [The No-U-Turn Sampler: Adaptively Setting Path Lengths in Hamiltonian Monte Carlo](https://arxiv.org/abs/1111.4246), Matthew D. Hoffman, Andrew Gelman, 2011
58 - [ML, MAP, and Bayesian — The Holy Trinity of Parameter Estimation and Data Prediction](https://engineering.purdue.edu/kak/Trinity.pdf)
59
60 - Deterministic methods called variational inference or variational Bayes are based on analytical approximations to the posterior distribution and can scale well to large applications. They make simplifying assumptions, e.g., that the posterior factorizes in a particular way or it has a specific parametric form such as a Gaussian. Hence, they do not generate exact results and can be used as complements to sampling methods.
61 - [Variational Inference: A Review for Statisticians](https://arxiv.org/pdf/1601.00670.pdf), David Blei et al, 2018
62
63
64 ## Probabilistic Programming with PyMC3
65
66 Probabilistic programming provides a language to describe and fit probability distributions so that we can design, encode and automatically estimate and evaluate complex models. It aims to abstract away some of the computational and analytical complexity to allow us to focus on the conceptually more straightforward and intuitive aspects of Bayesian reasoning and inference.
67 The field has become quite dynamic since new languages emerged since Uber open-sourced Pyro (based on PyTorch) and Google more recently added a probability module to TensorFlow.
68
69 - [Probabilistic Programming](http://www.probabilistic-programming.org/wiki/Home) Community Repository with links to papers and software
70 - [Stan](https://mc-stan.org/)
71 - [Edward](http://edwardlib.org/)
72 - [TensorFlow Probability](https://github.com/tensorflow/probability)
73 - [Pyro](http://pyro.ai/)
74
75 ### Bayesian ML with Theano
76
77 PyMC3 was released in January 2017 to add Hamiltonian MC methods to the Metropolis-Hastings sampler used in PyMC2 (released 2012). PyMC3 uses [Theano](http://www.deeplearning.net/software/theano/) as its computational backend for dynamic C compilation and automatic differentiation. Theano is a matrix-focused and GPU-enabled optimization library developed at Yoshua Bengio’s Montreal Institute for Learning Algorithms (MILA) that inspired TensorFlow. MILA recently ceased to further develop Theano due to the success of newer deep learning libraries (see chapter 16 for details). PyMC4, planned for 2019, will use TensorFlow instead, with presumably limited impact on the API.
78
79 ### The PyMC3 Workflow
80
81 PyMC3 aims for intuitive and readable, yet powerful syntax that reflects how statisticians describe models. The modeling process generally follows these three steps:
82 1) Encode a probability model by defining:
83 1) The prior distributions that quantify knowledge and uncertainty about latent variables
84 2) The likelihood function that conditions the parameters on observed data
85 2) Analyze the posterior using one of the options described in the previous section:
86 1) Obtain a point estimate using MAP inference
87 2) Sample from the posterior using MCMC methods
88 3)Approximate the posterior using variational Bayes
89 3) Check your model using various diagnostic tools
90 4) Generate predictions
91
92 - [Documentation](https://docs.pymc.io/)
93 - [Probabilistic Programming in Python using PyMC](https://arxiv.org/abs/1507.08050), Salvatier et al 2015
94 - [Theano: A Python framework for fast computation of mathematical expressions](https://pdfs.semanticscholar.org/6b57/0069f14c7588e066f7138e1f21af59d62e61.pdf), Al-Rfou et al, 2016
95 - [Bayesian Methods for Hackers](https://github.com/CamDavidsonPilon/Probabilistic-Programming-and-Bayesian-Methods-for-Hackers)
96 - [Bad Traces, or, Don't Use Metropolis](https://colindcarroll.com/2018/01/01/bad-traces-or-dont-use-metropolis/)
97
98 ### Model Definition: Bayesian Logistic Regression
99
100 As discussed in [Linear Models](../07_linear_models), logistic regression estimates a linear relationship between a set of features and a binary outcome, mediated by a sigmoid function to ensure the model produces probabilities. The frequentist approach resulted in point estimates for the parameters that measure the influence of each feature on the probability that a data point belongs to the positive class, with confidence intervals based on assumptions about the parameter distribution.
101
102 Bayesian logistic regression, in contrast, estimates the posterior distribution over the parameters itself. The posterior allows for more robust estimates of what is called a Bayesian credible interval for each parameter with the benefit of more transparency about the model’s uncertainty.
103
104 The notebook [bayesian_logistic_regression](02_bayesian_logistic_regression.ipynb) demonstrates the PYMC3 workflow, including
105 - MAP Inference
106 - Markov Chain Monte Carlo Estimate
107 - Metropolis-Hastings
108 - NUTS Sampler
109 - Variational Inference
110 - Model Diagnostics
111 - Energy Plot
112 - Forest Plot
113 - Posterior Predictive Credible Intervals (CI)
114 - Prediction
115 - MCMC Sampler Animation
116
117
118 ### Practical Applications
119
120 - [Tackling the Poor Assumptions of Naive Bayes Text Classifiers](http://people.csail.mit.edu/jrennie/papers/icml03-nb.pdf), Rennie, et al, MIT SAIL, 2003
121 - [On Discriminative vs Generative Classifiers: A comparison of logistic regression and naive Bayes](https://ai.stanford.edu/~ang/papers/nips01-discriminativegenerative.pdf), Jordan, Ng, 2002
122 - [Bayesian estimation supersedes the t test](http://www.indiana.edu/~kruschke/BEST/BEST.pdf), John K. Kruschke, Journal of Experimental Psychology, 2012
123 - [Automatic Differentiation Variational Inference](https://arxiv.org/pdf/1603.00788.pdf)
124
125 #### Bayesian Linear Regression for Pairs Trading
126
127 The chapter [Time Series Models](../08_time_series_models) introduced pairs trading as a popular algorithmic trading strategy that relies on cointegration of two or more assets. Given such assets, we need to estimate the hedging ratio to decide on the relative magnitude of long and short positions. A basic approach uses linear regression.
128 The notebook [linear_regression](04_linear_regression.ipynb) illustrates how Bayesian linear regression tracks changes in the relationship between two assets over time.
129
130 #### Bayesian Time Series Models
131
132 PyMC3 includes AR(p) models that allow us to gain similar insights into the parameter uncertainty as for the previous models. The notebook [bayesian_time_series](05_bayesian_time_series.ipynb)notebook illustrates time series model for one and more lags.
133
134 #### Stochastic Volatility Models
135 As discussed in the chapter [Time Series Models](../08_time_series_models), asset prices have time-varying volatility. In some periods, returns are highly variable, while in others very stable. Stochastic volatility models model this with a latent volatility variable, modeled as a stochastic process. The No-U-Turn Sampler was introduced using such a model, and the notebook [stochastic_volatility](06_stochastic_volatility.ipynb) illustrates this use case.