1 unstable release
Uses old Rust 2015
0.0.0 | Jul 30, 2016 |
---|
#32 in #financial
11KB
125 lines
Finance
This crate (Rust library) provides utility functions for the most common operations (calculations) in Finance.
Usage
Include this library with the following:
[dependencies]
finance = "0.0.0" // preferably the latest version on crates.io
Examples
extern crate finance;
extern crate round;
use round::round;
use finance::{ present_value, future_value };
fn main() {
let test_value = round(present_value(0.1, 1., 1000.), 2); // 909.09
let test_value = round(future_value(0.1, 1., 1000.), 2); // 1100.00
// and so on with the other apis just feed what's expected
// particularly the exact types
}
API | arguments | abbr |
---|---|---|
present_value | (rate: f64, compounding_periods: f64, future_value: f64) | PV |
future_value | (rate: f64, compounding_periods: f64, present_value: f64) | FV |
net_present_value | (rate: f64, cfs: &[f64]) | npv |
periodic_interest_rate | (annual_percentage_rate: f64, number_of_compounding: f64) | r |
holding_period_return | (profit: f64, cost: f64) | HPR |
number_of_compounding | (future_value: f64, present_value: f64, rate: f64) | n |
ROI return_on_investment | (earnings: f64, cf0: f64) | ROI |
interest_rate | (future_value: f64, present_value: f64, number_of_compounding: f64) | r |
rule_of_72 | (rate: f64) | ... |
rule_of_70 | (rate: f64) | ... |
leverage_ratio | (total_liabilities: f64, total_debts: f64, total_income: f64) | LR |
weighted_cost_of_capital | (market_value_of_equity: f64, market_value_of_debt: f64, cost_of_equity: f64, cost_of_debt: f64, tax_rate: f64) | WACC |
payment | (present_value: f64, number_of_compounding: f64, rate: f64) | PMT |
effective_annual_rate | (annual_rate: f64, number_of_compounding: f64) | EAR |
Note that all output are of type f64
, you are free to choose what degree of rounding is right for your project.
Unless specified the inputs are expected to be floats. Your program will
panic
if you pass integers.
Input accordingly if calculating in (monthly, semi-annual, daily) terms. In another words, make sure that your compounding_periods (daily, monthly, annual...) is used with corresponding rates (daily, monthly, annual).
For consistency sake
rate
is getting passed as a plain float and not as a percentage (%)
If you are wondering about compounding calculation. I got you here
Raison d'etre
Well save yourself some googling or fiddling wiki pages. All formulas have test cases. Feel free to send a PR if you feel like a missing formula should be included (preferably open an issue first 😎)
Do not worry about the functions taking owernership of anything. As primitives support the copy trait.
In the case an array or vector is being processed be assured that they are getting passed as reference and cloned if there is complex operations that have to be made.
Also some of the function names can be judged as quiet verbose and it is worthit. Abbreviations that you have no idea about is the last thing you would want. (There aren't many programmers with a Finance background anyways)
Maintenance
In the forseeable future, I plan to actively manage the repos, so I will follow the salesman motto "If you open it, I will close", meaning that I will fix issues in a speedy matter.
License
This library is distributed with the GPLv2 software license.
finance (rust library - crate)
Copyright (C) 2016 Mohamed Hayibor
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License along
with this program; if not, write to the Free Software Foundation, Inc.,
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
Dependencies
~9KB