# risktools
Python implementation of the R package RTL.
See CRAN for original R version
https://cran.r-project.org/web/packages/RTL/index.html
## Purpose
Purposely designed functions for trading, trading analytics and risk practitioners in Commodities and Finance.
Build to support delivery of Finance classes from one of the co-authors of RTL at the Alberta School of Business.
## Version Notes
Note that the latest version will require compilation on Windows for python version 3.11 due to the
dependency on arch. Arch does not come with binaries and must be compiled on Windows which can be
avoided by installing numba, however numba is not yet available for python 3.11.
## Features
Historical forward curves charting.
Calendars and expiry dates data objects for a wide range of commodity futures contracts.
roll_adjust to adjust continuous contracts returns for roll adjustments using expiries above.
Morningstar Marketplace API functions getPrice(), getPrices() and getCurve() using your own Morningstar credentials. Current feeds included:
ICE_EuroFutures
ICE_EuroFutures_continuous
CME_NymexFutures_EOD
CME_NymexFutures_EOD_continuous
CME_NymexOptions_EOD
CME_CbotFuturesEOD
CME_CbotFuturesEOD_continuous
CME_Comex_FuturesSettlement_EOD
CME_Comex_FuturesSettlement_EOD_continuous
LME_AskBidPrices_Delayed
SHFE_FuturesSettlement_RT
CME_CmeFutures_EOD
CME_CmeFutures_EOD_continuous
CME_STLCPC_Futures
CFTC_CommitmentsOfTradersCombined
ICE_NybotCoffeeSugarCocoaFutures
ICE_NybotCoffeeSugarCocoaFutures_continuous
Morningstar_FX_Forwards
ERCOT_LmpsByResourceNodeAndElectricalBus
PJM_Rt_Hourly_Lmp
AESO_ForecastAndActualPoolPrice
LME_MonthlyDelayed_Derived
… see ?getPrice for up to date selection and examples.
chart_zscore() supports seasonality adjusted analysis of residuals, particularly useful when dealing with commodity stocks and/or days demand time series with trends as well as non-constant variance across seasonal periods.
chart_eia_steo() and chart_eia_sd() return either a chart or dataframe of supply demand balances from the EIA.
chart_spreads() to generate specific contract spreads across years e.g. ULSD March/April. Requires Morningstar credentials.
swapInfo() returns all information required to price first line futures contract averaging swap or CMA physical trade, including a current month instrument with prior settlements.
## Data Sets
Accessible via risktools.data.open_data(datsetname). Also use risktools.data.get_names() to get list of available data.
expiry_table: Historical and forward futures contract metadata.
holidaysOil: Holiday calendars for ICE and NYMEX.
tickers_eia: Mapping of EIA tickers to crude and refined products markets for building supply demand balances.
usSwapIRDef: Data frame of definitions for instruments to build a curve for use with RQuantlib. Use getIRswapCurve() to extract the latest data from FRED and Morningstar.
usSwapIR: Sample data set output of getIRswapCurve.
usSwapCurves: Sample data set output of RQuantlib::DiscountCurve().
cancrudeassays contains historical Canadian crude assays by batch from Crudemonitor. cancrudeassayssum is a summarised average assays version.
crudeassaysXOM for all publicly available complete assays in Excel format from ExxonMobil
crudeassaysBP for all publicly available complete assays in Excel format from BP
eiaStocks: Sample data set of EIA.gov stocks for key commodiities.
eiaStorageCap: EIA crude storage capacity by PADD.
dflong and dfwide contain continuous futures prices sample data sets for Nymex (CL, HO, RB and NG contracts) and ICE Brent.
crudepipelines and refineries contain GIS information in the North American crude space.
...
Usernames and password for API services are required.
## Changelog
### Version 0.2.0
New functions added:
- get_curves
- get_gis
- get_ir_swap_curve
- refineryLP
- swap_fut_weight
- swap_info
- dist_desc_plot
New feeds for get_prices:
- ERCOT_LmpsByResourceNodeAndElectricalBus
- PJM_Rt_Hourly_Lmp
- AESO_ForecastAndActualPoolPrice
- LME_MonthlyDelayed_Derived
- SHFE_FuturesSettlement_RT
- CFTC_CommitmentsOfTradersCombined
New datasets for risktools.data.open_data function
- Replicated/refreshed RTL datsets
removed geojson files and dependencies to geopandas - replaced with get_gis function
removed support for Python 3.6. Supports >= 3.7
Companion package to https://github.com/bbcho/finoptions-dev
Raw data
{
"_id": null,
"home_page": "https://github.com/bbcho/risktools-dev",
"name": "risktools",
"maintainer": null,
"docs_url": null,
"requires_python": ">=3.7",
"maintainer_email": null,
"keywords": "RTL, Risk, Tools, Trading, Crude, Oil, Refinery, Refined Products, Products",
"author": "Ben Cho",
"author_email": "ben.cho@gmail.com",
"download_url": "https://files.pythonhosted.org/packages/a1/91/20df567bdd8fdb97d904f59da21fb095b590fdb3230e6ec1d7a745b6099c/risktools-0.2.8.7.tar.gz",
"platform": null,
"description": "# risktools\n\nPython implementation of the R package RTL. \n\nSee CRAN for original R version\n\nhttps://cran.r-project.org/web/packages/RTL/index.html\n\n## Purpose\n\n Purposely designed functions for trading, trading analytics and risk practitioners in Commodities and Finance.\n Build to support delivery of Finance classes from one of the co-authors of RTL at the Alberta School of Business.\n\n## Version Notes\n\n Note that the latest version will require compilation on Windows for python version 3.11 due to the \n dependency on arch. Arch does not come with binaries and must be compiled on Windows which can be\n avoided by installing numba, however numba is not yet available for python 3.11.\n\n## Features\n\n Historical forward curves charting.\n\n Calendars and expiry dates data objects for a wide range of commodity futures contracts.\n\n roll_adjust to adjust continuous contracts returns for roll adjustments using expiries above.\n\n Morningstar Marketplace API functions getPrice(), getPrices() and getCurve() using your own Morningstar credentials. Current feeds included:\n ICE_EuroFutures\n ICE_EuroFutures_continuous\n CME_NymexFutures_EOD\n CME_NymexFutures_EOD_continuous\n CME_NymexOptions_EOD\n CME_CbotFuturesEOD\n CME_CbotFuturesEOD_continuous\n CME_Comex_FuturesSettlement_EOD\n CME_Comex_FuturesSettlement_EOD_continuous\n LME_AskBidPrices_Delayed\n SHFE_FuturesSettlement_RT\n CME_CmeFutures_EOD\n CME_CmeFutures_EOD_continuous\n CME_STLCPC_Futures\n CFTC_CommitmentsOfTradersCombined\n ICE_NybotCoffeeSugarCocoaFutures\n ICE_NybotCoffeeSugarCocoaFutures_continuous\n Morningstar_FX_Forwards\n ERCOT_LmpsByResourceNodeAndElectricalBus\n PJM_Rt_Hourly_Lmp\n AESO_ForecastAndActualPoolPrice\n LME_MonthlyDelayed_Derived\n \u2026 see ?getPrice for up to date selection and examples.\n\n chart_zscore() supports seasonality adjusted analysis of residuals, particularly useful when dealing with commodity stocks and/or days demand time series with trends as well as non-constant variance across seasonal periods.\n\n chart_eia_steo() and chart_eia_sd() return either a chart or dataframe of supply demand balances from the EIA.\n\n chart_spreads() to generate specific contract spreads across years e.g. ULSD March/April. Requires Morningstar credentials.\n\n swapInfo() returns all information required to price first line futures contract averaging swap or CMA physical trade, including a current month instrument with prior settlements.\n\n## Data Sets\n\nAccessible via risktools.data.open_data(datsetname). Also use risktools.data.get_names() to get list of available data.\n\n expiry_table: Historical and forward futures contract metadata.\n holidaysOil: Holiday calendars for ICE and NYMEX.\n tickers_eia: Mapping of EIA tickers to crude and refined products markets for building supply demand balances.\n usSwapIRDef: Data frame of definitions for instruments to build a curve for use with RQuantlib. Use getIRswapCurve() to extract the latest data from FRED and Morningstar.\n usSwapIR: Sample data set output of getIRswapCurve.\n usSwapCurves: Sample data set output of RQuantlib::DiscountCurve().\n cancrudeassays contains historical Canadian crude assays by batch from Crudemonitor. cancrudeassayssum is a summarised average assays version.\n crudeassaysXOM for all publicly available complete assays in Excel format from ExxonMobil\n crudeassaysBP for all publicly available complete assays in Excel format from BP\n eiaStocks: Sample data set of EIA.gov stocks for key commodiities.\n eiaStorageCap: EIA crude storage capacity by PADD.\n dflong and dfwide contain continuous futures prices sample data sets for Nymex (CL, HO, RB and NG contracts) and ICE Brent.\n crudepipelines and refineries contain GIS information in the North American crude space.\n ...\n\nUsernames and password for API services are required.\n\n## Changelog\n\n### Version 0.2.0\n\nNew functions added:\n- get_curves\n- get_gis\n- get_ir_swap_curve\n- refineryLP\n- swap_fut_weight\n- swap_info\n- dist_desc_plot\n\nNew feeds for get_prices:\n- ERCOT_LmpsByResourceNodeAndElectricalBus\n- PJM_Rt_Hourly_Lmp\n- AESO_ForecastAndActualPoolPrice\n- LME_MonthlyDelayed_Derived\n- SHFE_FuturesSettlement_RT\n- CFTC_CommitmentsOfTradersCombined\n\nNew datasets for risktools.data.open_data function\n- Replicated/refreshed RTL datsets\n\nremoved geojson files and dependencies to geopandas - replaced with get_gis function\nremoved support for Python 3.6. Supports >= 3.7\n\nCompanion package to https://github.com/bbcho/finoptions-dev\n\n",
"bugtrack_url": null,
"license": "gpl-3.0",
"summary": "Python implementation of the R package RTL",
"version": "0.2.8.7",
"project_urls": {
"Documentation": "https://risktools.readthedocs.io/en/latest/",
"Homepage": "https://github.com/bbcho/risktools-dev"
},
"split_keywords": [
"rtl",
" risk",
" tools",
" trading",
" crude",
" oil",
" refinery",
" refined products",
" products"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "620e6fe073946de2d6bc40a2389e887a51ca589cfa824c4c48584ede5de9c52a",
"md5": "d15e2f271f5b075fb6631172e7faad07",
"sha256": "98555b75884a5b5aaf8e0d10433aff818fd66bb47fcaca8ccbc338d59b56aabc"
},
"downloads": -1,
"filename": "risktools-0.2.8.7-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
"has_sig": false,
"md5_digest": "d15e2f271f5b075fb6631172e7faad07",
"packagetype": "bdist_wheel",
"python_version": "cp310",
"requires_python": ">=3.7",
"size": 7586578,
"upload_time": "2024-12-07T19:47:45",
"upload_time_iso_8601": "2024-12-07T19:47:45.386540Z",
"url": "https://files.pythonhosted.org/packages/62/0e/6fe073946de2d6bc40a2389e887a51ca589cfa824c4c48584ede5de9c52a/risktools-0.2.8.7-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "87fedf4500806dae01bbd8c53fe4b50cb44492fd2e5830f9ec4d77f65bb4a174",
"md5": "58191f4c86bb2e00364456388bfa5aac",
"sha256": "9de3052f7d8d132a7dfca2987ea3554465c6eb8fd55cf167fec828b1d2376b5d"
},
"downloads": -1,
"filename": "risktools-0.2.8.7-cp310-cp310-win_amd64.whl",
"has_sig": false,
"md5_digest": "58191f4c86bb2e00364456388bfa5aac",
"packagetype": "bdist_wheel",
"python_version": "cp310",
"requires_python": ">=3.7",
"size": 7061147,
"upload_time": "2024-12-07T19:45:33",
"upload_time_iso_8601": "2024-12-07T19:45:33.556928Z",
"url": "https://files.pythonhosted.org/packages/87/fe/df4500806dae01bbd8c53fe4b50cb44492fd2e5830f9ec4d77f65bb4a174/risktools-0.2.8.7-cp310-cp310-win_amd64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "a2965247c9d010795f5d5ea3cfd00c8cb1fd664e8bfc2b71a523f192061ae26f",
"md5": "9266bc1d1aa2897fc69aad349c28952f",
"sha256": "fae721c3cd7e82c141489d04ecf2c82c0e028b0184568587b9a99ec112de985d"
},
"downloads": -1,
"filename": "risktools-0.2.8.7-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
"has_sig": false,
"md5_digest": "9266bc1d1aa2897fc69aad349c28952f",
"packagetype": "bdist_wheel",
"python_version": "cp311",
"requires_python": ">=3.7",
"size": 7622900,
"upload_time": "2024-12-07T19:47:46",
"upload_time_iso_8601": "2024-12-07T19:47:46.943701Z",
"url": "https://files.pythonhosted.org/packages/a2/96/5247c9d010795f5d5ea3cfd00c8cb1fd664e8bfc2b71a523f192061ae26f/risktools-0.2.8.7-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "39bd184e3f7ea05a01ed17c96494d1d4128048866a48fa6b0bfa6909db894b62",
"md5": "8a44a105f18613e4941acae28344480f",
"sha256": "9066ad6e604b2fd3eb9e3c88493c44b46eb43328204c447d42d5ba07f8a1a613"
},
"downloads": -1,
"filename": "risktools-0.2.8.7-cp311-cp311-win_amd64.whl",
"has_sig": false,
"md5_digest": "8a44a105f18613e4941acae28344480f",
"packagetype": "bdist_wheel",
"python_version": "cp311",
"requires_python": ">=3.7",
"size": 7061272,
"upload_time": "2024-12-07T19:45:50",
"upload_time_iso_8601": "2024-12-07T19:45:50.821049Z",
"url": "https://files.pythonhosted.org/packages/39/bd/184e3f7ea05a01ed17c96494d1d4128048866a48fa6b0bfa6909db894b62/risktools-0.2.8.7-cp311-cp311-win_amd64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "94cd903b02aa96ac7167120e344358e0508200990c6cc6f4883b0c51737f29e7",
"md5": "bc821d4cafa2c5dbd2864dcf779a2758",
"sha256": "2e31994f33c4ba4eea9dc2545e79c1beba82e02df42fc9a6d7ac7f3c30c896d1"
},
"downloads": -1,
"filename": "risktools-0.2.8.7-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
"has_sig": false,
"md5_digest": "bc821d4cafa2c5dbd2864dcf779a2758",
"packagetype": "bdist_wheel",
"python_version": "cp312",
"requires_python": ">=3.7",
"size": 7615810,
"upload_time": "2024-12-07T19:47:48",
"upload_time_iso_8601": "2024-12-07T19:47:48.469735Z",
"url": "https://files.pythonhosted.org/packages/94/cd/903b02aa96ac7167120e344358e0508200990c6cc6f4883b0c51737f29e7/risktools-0.2.8.7-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "d0e0e2bb3c72ca1bcda56510d1c937d8d7b4b4ffc6c25cf932bf1baa5f386b11",
"md5": "de2c3b06ddf655b3d9305c292e81cffc",
"sha256": "02d2cead42d67e6a797430d8de3facf34f13f96536c6e267e2a25ff3cf81b3e1"
},
"downloads": -1,
"filename": "risktools-0.2.8.7-cp312-cp312-win_amd64.whl",
"has_sig": false,
"md5_digest": "de2c3b06ddf655b3d9305c292e81cffc",
"packagetype": "bdist_wheel",
"python_version": "cp312",
"requires_python": ">=3.7",
"size": 7061863,
"upload_time": "2024-12-07T19:45:50",
"upload_time_iso_8601": "2024-12-07T19:45:50.374997Z",
"url": "https://files.pythonhosted.org/packages/d0/e0/e2bb3c72ca1bcda56510d1c937d8d7b4b4ffc6c25cf932bf1baa5f386b11/risktools-0.2.8.7-cp312-cp312-win_amd64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "2f0c2cffc066ece0d041746729c944bf73e53d882210729760e5afcfdb0cc624",
"md5": "92b05827f08acfe7ba5cd5782ab7a940",
"sha256": "f620881dd1729ecd9d951481787ff210731132f145b645f0806b2c002bd45910"
},
"downloads": -1,
"filename": "risktools-0.2.8.7-cp37-cp37m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
"has_sig": false,
"md5_digest": "92b05827f08acfe7ba5cd5782ab7a940",
"packagetype": "bdist_wheel",
"python_version": "cp37",
"requires_python": ">=3.7",
"size": 7559646,
"upload_time": "2024-12-07T19:47:49",
"upload_time_iso_8601": "2024-12-07T19:47:49.945952Z",
"url": "https://files.pythonhosted.org/packages/2f/0c/2cffc066ece0d041746729c944bf73e53d882210729760e5afcfdb0cc624/risktools-0.2.8.7-cp37-cp37m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "56a700d92b7aff7394c6d4c815b68dc818f545527198e830d706b594e1b0d6b9",
"md5": "2f52a4c55ea6648bc75cca2434c5ee1e",
"sha256": "4cdb63968dcda8d1130375e0625e604cfce62f2e2feed9b9a3207c7b0cd5f27a"
},
"downloads": -1,
"filename": "risktools-0.2.8.7-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
"has_sig": false,
"md5_digest": "2f52a4c55ea6648bc75cca2434c5ee1e",
"packagetype": "bdist_wheel",
"python_version": "cp38",
"requires_python": ">=3.7",
"size": 7595825,
"upload_time": "2024-12-07T19:47:52",
"upload_time_iso_8601": "2024-12-07T19:47:52.407659Z",
"url": "https://files.pythonhosted.org/packages/56/a7/00d92b7aff7394c6d4c815b68dc818f545527198e830d706b594e1b0d6b9/risktools-0.2.8.7-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "772380e80883daeb2fd021a4ac5c9838570671b320372938048af9018f734ad8",
"md5": "4150f89fa2c4dd1bb256aa1609bd425e",
"sha256": "b2e0ea951e594c61a9507d5f43de16eeb1158779802ab3a37d028b3221530a2e"
},
"downloads": -1,
"filename": "risktools-0.2.8.7-cp38-cp38-win_amd64.whl",
"has_sig": false,
"md5_digest": "4150f89fa2c4dd1bb256aa1609bd425e",
"packagetype": "bdist_wheel",
"python_version": "cp38",
"requires_python": ">=3.7",
"size": 7074292,
"upload_time": "2024-12-07T19:45:38",
"upload_time_iso_8601": "2024-12-07T19:45:38.692240Z",
"url": "https://files.pythonhosted.org/packages/77/23/80e80883daeb2fd021a4ac5c9838570671b320372938048af9018f734ad8/risktools-0.2.8.7-cp38-cp38-win_amd64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "9666e2d25e85fce9c9aaf7df39a51c2c45356e4c17d95ab6b7725a3b90da4000",
"md5": "92c53d47855b2b899ab1056f99642eab",
"sha256": "b5f7bb86a5faa5b1e7786efa0dbddb4fc3591fd5f1e3351bf4430802f067b8bf"
},
"downloads": -1,
"filename": "risktools-0.2.8.7-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
"has_sig": false,
"md5_digest": "92c53d47855b2b899ab1056f99642eab",
"packagetype": "bdist_wheel",
"python_version": "cp39",
"requires_python": ">=3.7",
"size": 7589415,
"upload_time": "2024-12-07T19:47:53",
"upload_time_iso_8601": "2024-12-07T19:47:53.981128Z",
"url": "https://files.pythonhosted.org/packages/96/66/e2d25e85fce9c9aaf7df39a51c2c45356e4c17d95ab6b7725a3b90da4000/risktools-0.2.8.7-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "55c0abfff52f410d3715613ca420238997535876aacbe2fc011c8dfd382d3526",
"md5": "bc3a766758627a2f1317e79abdd0e19e",
"sha256": "34ed2dc0dbd5e7ba8f0bf4b4d28016790c6e2520ce5cf6093ac6e50859db37e9"
},
"downloads": -1,
"filename": "risktools-0.2.8.7-cp39-cp39-win_amd64.whl",
"has_sig": false,
"md5_digest": "bc3a766758627a2f1317e79abdd0e19e",
"packagetype": "bdist_wheel",
"python_version": "cp39",
"requires_python": ">=3.7",
"size": 7074208,
"upload_time": "2024-12-07T19:45:31",
"upload_time_iso_8601": "2024-12-07T19:45:31.458281Z",
"url": "https://files.pythonhosted.org/packages/55/c0/abfff52f410d3715613ca420238997535876aacbe2fc011c8dfd382d3526/risktools-0.2.8.7-cp39-cp39-win_amd64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "a19120df567bdd8fdb97d904f59da21fb095b590fdb3230e6ec1d7a745b6099c",
"md5": "be8fb744eb3b960e87724acf06cf9415",
"sha256": "57973ce132d85fb03cffbde922f7381269709ba4fc50b457c88266f34a124508"
},
"downloads": -1,
"filename": "risktools-0.2.8.7.tar.gz",
"has_sig": false,
"md5_digest": "be8fb744eb3b960e87724acf06cf9415",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.7",
"size": 6576969,
"upload_time": "2024-12-07T19:44:33",
"upload_time_iso_8601": "2024-12-07T19:44:33.406187Z",
"url": "https://files.pythonhosted.org/packages/a1/91/20df567bdd8fdb97d904f59da21fb095b590fdb3230e6ec1d7a745b6099c/risktools-0.2.8.7.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-12-07 19:44:33",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "bbcho",
"github_project": "risktools-dev",
"travis_ci": true,
"coveralls": false,
"github_actions": true,
"requirements": [],
"lcname": "risktools"
}