This library provides high-performance components leveraging the hardware acceleration support and automatic differentiation of TensorFlow. The library will provide TensorFlow support for foundational mathematical methods, mid-level methods, and specific pricing models. The coverage is being expanded over the next few months.
The library is structured along three tiers:
Foundational methods. Core mathematical methods - optimisation, interpolation, root finders, linear algebra, random and quasi-random number generation, etc.
Mid-level methods. ODE & PDE solvers, Ito process framework, Diffusion Path Generators, Copula samplers etc.
Pricing methods and other quant finance specific utilities. Specific Pricing models (e.g., Local Vol (LV), Stochastic Vol (SV), Stochastic Local Vol (SLV), Hull-White (HW)) and their calibration. Rate curve building, payoff descriptions, and schedule generation.
We aim for the library components to be easily accessible at each level. Each layer will be accompanied by many examples that can run independently of higher-level components.
The easiest way to get started with the library is via the pip package.
Note that the library requires Python 3.7 and Tensorflow >= 2.7.
First, please install the most recent version of TensorFlow by following the TensorFlow installation instructions. For example, you could install TensorFlow
pip3 install --upgrade tensorflow
Then run
pip3 install --upgrade tf-quant-finance
You maybe also have to use the option --user
.
If you are not familiar with TensorFlow, an excellent place to get started is with the following self-study introduction to TensorFlow notebooks:
We are working on expanding the coverage of the library. Areas under active development are:
See tf_quant_finance/examples/
for end-to-end examples. It includes tutorial notebooks such as:
The above links will open Jupyter Notebooks in Colab.
We're eager to collaborate with you! See CONTRIBUTING.md for a guide on how to contribute. This project adheres to TensorFlow's code of conduct. By participating, you are expected to uphold this code.
This section is for developers who want to contribute code to the library. If you are only interested in using the library, please follow the instructions in the Installation section.
This library has the following dependencies:
This library requires the Bazel build system. Please follow the Bazel installation instructions for your platform.
You can install TensorFlow and related dependencies using the pip3 install
command:
pip3 install --upgrade tf-nightly tensorflow-probability==0.12.1 numpy==1.21 attrs dataclasses
Clone the GitHub repository:
git clone https://github.com/google/tf-quant-finance.git
After you run
cd tf_quant_finance
you can execute tests using the bazel test
command. For example,
bazel test tf_quant_finance/math/random_ops/sobol:sobol_test
will run tests in sobol_test.py .
Tests run using Python version 3. Please make sure that you can
run import tensorflow
in the Python 3 shell. Otherwise, tests might fail.
The following commands will build custom pip package from source and install it:
# sudo apt-get install bazel git python python-pip rsync # For Ubuntu.
git clone https://github.com/google/tf-quant-finance.git
cd tf-quant-finance
bazel build :build_pip_pkg
./bazel-bin/build_pip_pkg artifacts
pip install --user --upgrade artifacts/*.whl
GitHub repository: Report bugs or make feature requests.
TensorFlow Blog: Stay up to date on content from the TensorFlow team and best articles from the community.
[email protected]: Open mailing list for discussion and questions of this library.
TensorFlow Probability: This library will leverage methods from TensorFlow Probability (TFP).
Google does not officially support this product. This library is under active development, and interfaces may change at any time.
This library is licensed under the Apache 2 license (see LICENSE). This library uses Sobol primitive polynomials and initial direction numbers which are licensed under the BSD license.