Statistic tests for Value at Risk (VaR) Models.
Project description
vartests is a Python library to perform some statistical tests to evaluate Value at Risk (VaR) Models, such as:
- T-test: verify if mean of distribution is zero;
- Kupiec Test (1995): verify if the number of violations is consistent with the violations predicted by the model;
- Berkowitz Test (2001): verify if conditional distributions of returns "GARCH(1,1)" used in the VaR Model is adherent to the data. In this specific test, we do not observe the whole data, only the tail;
- Christoffersen and Pelletier Test (2004): also known as Duration Test. Duration is time between violations of VaR. It tests if VaR Model has quickly response to market movements by consequence the violations do not form volatility clusters. This test verifies if violations has no memory i.e. should be independent.
Installation
Using pip
You can install using the pip package manager by running:
pip install vartests
Alternatively, you could install the latest version directly from Github:
pip install https://github.com/rafa-rod/vartests/archive/refs/heads/main.zip
Why vartests is important?
After VaR calculation, it is necessary to perform statistic tests to evaluate the VaR Models. To select the best model, they should be validated by backtests.
Example
First of all, lets read a file with a PnL (distribution of profit and loss) of a portfolio in which also contains the VaR and its violations.
import pandas as pd
data = pd.read_excel("Example.xlsx", index_col=0)
violations = data["Violations"]
pnl = data["PnL"]
data.sample(5)
The dataframe looks like:
' | PnL | VaR | Violations |
| -889.003707 | -2554.503872 | 0 |
| -2554.503872 | -2202.221691 | 1 |
| -887.527423 | -2193.692570 | 0 |
| -274.344126 | -2160.290746 | 0 |
| 1376.018638 | -5719.833100 | 0 |'
Not all tests should be applied to the VaR Model. Some of them should be applied when the VaR Model has the assumption of zero mean or follow a specific distribution.
import vartests
vartests.zero_mean_test(pnl.values, conf_level=0.95)
This assumption is commonly used in parametric VaR like EWMA and GARCH Models. Besides that, is necessary check assumption of the distribution. So you should test with Berkowitz (2001):
import vartests
vartests.berkowtiz_tail_test(pnl, volatility_window=252, var_conf_level=0.99, conf_level=0.95)
The following tests should be used to any kind of VaR Models.
import vartests
vartests.kupiec_test(violations, var_conf_level=0.99, conf_level=0.95)
vartests.duration_test(violations, conf_level=0.95)
If you want to see the failure ratio of the VaR Model, just type:
import vartests
vartests.failure_rate(violations)
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file vartests-0.2.2.tar.gz
.
File metadata
- Download URL: vartests-0.2.2.tar.gz
- Upload date:
- Size: 6.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.8.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1183f3455aca51a6e4a72f485ffdf2c43d914a4f580b7f65ac02873faede73a8 |
|
MD5 | f4ec4ae6ca8ec1dc93de993cdbf8268d |
|
BLAKE2b-256 | b3a48de8c7f5a695c054b60e7db44c3c146036e627ebb0c39620d33ccfeaebaf |
File details
Details for the file vartests-0.2.2-py3-none-any.whl
.
File metadata
- Download URL: vartests-0.2.2-py3-none-any.whl
- Upload date:
- Size: 6.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.8.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | b5edfe0fe171368d80c0fa0fa35e9e4f61eb3e4f43a30ac25bba9ada96ead30d |
|
MD5 | 4a9b80e8e654c16e16359be1b084c350 |
|
BLAKE2b-256 | 1b734ca58d8bfe5f6f420d3011f87cd916887bede14bf155d1ee046823bd185e |