1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
//! # finql
//!
//! Purpose of this library is to provide over time a comprehensive toolbox
//! for quantitative analysis of financial assets in rust.
//! The project is licensed under Apache 2.0 or MIT license (see files LICENSE-Apache2.0 and LICENSE-MIT)
//! at the option of the user.
//!
//! The goal is to provide a toolbox for pricing various financial products, like bonds options or maybe
//! even more complex products. In the near term, calculation of the discounted cash flow value of bonds
//! is in the focus, based on what information is given by a standard prospect. Building blocks to achieve
//! this target include time periods (e.g. "3M" or "10Y"), bank holiday calendars, business day adjustment
//! rules, calculation of year fraction with respect to typical day count convention methods, roll-out of
//! cash flows, and calculating valuation and risk figures like internal yield or duration that are useful
//! for an investor in these products.
//!
//! Functionality to calculate of figures like fair values which are primarily interesting in scenarios
//! where one is fully hedged are not in the initial focus, since an investor is by definition not
//! fully hedged. Nevertheless, they might be added later for comparison and estimating market prices.
//!
//! The library also supports storing data, like market data, e.g. market quote information, data related
//! to portfolio and transaction management to be able to support portfolio analysis (e.g. calculation
//! of risk figures), and generic storage of product details (e.g. bond specification). This is done by
//! defining data handler traits for various data categories, with concrete implementations supporting
//! storage in memory or in a databases (supporting `sqlite3` and `postgreSQL`).
//!
//! Market data quotes can be fetched automatically from various vendors and stored into a database.
//! Fetching the (realtime) quote or a quote history is implemented for the vendors
//! [yahoo! finance](https://finance.yahoo.com/),
//! [alpha vantage](https://www.alphavantage.co/),
//! [gurufocus](https://www.gurufocus.com/new_index/) and
//! [eodhistoricaldata](https://eodhistoricaldata.com/). Please note that all except yahoo! finance
//! require a user token that is only provided after registration with the service. For gurufocus,
//! this required a paid license.
//!

// macro exports
#[macro_use]
pub mod macros;

// module exports
pub mod bond;
pub mod coupon_date;
pub mod datatypes;
pub mod day_adjust;
pub mod day_count_conv;
pub mod fixed_income;
pub mod fx_rates;
pub mod helpers;
pub mod market;
pub mod market_quotes;
pub mod period_date;
pub mod portfolio;
pub mod postgres;
pub mod rates;
pub mod strategy;
pub mod time_period;
pub mod time_series;

pub use market::Market;