A Finance Library
Project description
FinancePy
FinancePy is a library of native Python functions which covers the following functionality:
- Valuation and risk of a wide range of equity, FX, interest rate and credit derivatives.
- Valuation models for a range of bonds including callable and puttable bonds.
- Portfolio risk measures for portfolios of the securities above.
- Optimal Portfolio asset allocation using Markovitz and other methods.
- Time series analysis of financial data using econometric techniques.
The aim of this library for me has been to provide a comprehensive and accessible Python library for financial calculations that can be used by students to learn about financial derivatives. It can also be used by academics and practitioners to perform the pricing and risk-management of complex financial products, albeit without any warranties. Users should perform their own testing. See the license for the full disclaimer.
I intend that subsequent versions will also include asset selection, portfolio-level risk management, regulatory calculations and market analysis tools.
In general my objectives have been:
- To make the code as simple as possible so that students and those with a basic Python fluency can understand and check the code.
- To keep all the code in Python so users can look through the code to the lowest level.
- To offset the performance impact of (2) by leveraging Numba to make the code as fast as possible without resorting to Cython.
- To make the design product-based rather than model-based so someone wanting to price a specific exotic option can easily find that without having to worry too much about the model – just use the default – unless they want to.
- To make the library as complete as possible so a user can find all their required finance-related functionality in one place. This is better for the user as they only have to learn one interface.
- To avoid complex designs as I do not want to make it too hard for unskilled Python programmers to use the library.
- To have good documentation and easy-to-follow examples.
- To make it easy for interested parties to contribute.
In many cases the valuations should be close to if not identical to those produced by financial systems such as Bloomberg. However for some products, larger value differences may arise due to differences in date generation and interpolation schemes. Over time I expect to reduce the size of such differences.
Dependencies
FinancePy depends on Numpy and Numba and Scipy.
Installation
FinancePy can be installed via pip as
pip install financepy
Changelog
See the changelog for a detailed history of changes
Contributions
Contributions are welcome. There are a number of requirements:
- You should use CamelCase i.e. variables of the form optionPrice
- Comments are required for every class and function and they should be clear
- At least one test case must be provided for every module
- Use a dict if you are planning to return multiple values. Makes it easier for users to understand values.
License
MIT
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
Hashes for financepy-0.160-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 80b04c793ecc5c948756449dcdc2a0314e5b179296240c2e0d49cce17880d270 |
|
MD5 | 878a950334698c3530553e9f4dd03608 |
|
BLAKE2b-256 | 4de65f35e120cea2c759295dcae5e64fc77c712ce79b1625ea6fae4375a93cff |