livsey-finance-library
v1.1.1
Published
a simple financial library with most important ratios for investors/traders/etc
Downloads
14
Maintainers
Readme
livsey-finance-library
The Livesey Finance Library is a financial library designed for various financial calculations and data analysis. This library provides tools and functions essential for handling financial computations, making it easier for developers to implement financial logic in their projects. By integrating this library, users can efficiently manage and analyze financial data, leading to more productive and accurate financial software development.
Getting Started
Installation
Here you can get in touch with installation and basic setup guide
Firstly, you should install a package from npm
npm (as a simple dependency):
npm i livsey-finance-library
npm (as a dev dependency):
npm install livsey-finance-library --save-dev
Secondly, you should import package in your project
using CommonJS:
const { calculateLTDebtEquity } = require("livsey-finance-library");
using ES module:
import { calculateLTDebtEquity } from "livsey-finance-library";
Features
Debt ratios
Debt-to-Equity Ratio
The debt-to-equity (D/E) ratio assesses a company's financial leverage by dividing its total liabilities by shareholder equity. This crucial metric in corporate finance indicates the extent to which a company relies on debt to fund its operations, as opposed to using its own resources.
$$ \text{Debt/Equity} = \frac{\text{Total Liabilities}}{\text{Total Shareholders' Equity}} $$
Usage:
import { calculateDebtEquity } from "livsey-finance-library"
const totalDebt = 2000;
const equity = 20;
const res = calculateDebtEquity(totalDebt, equity)
console.log(res) // res: 100
Long-term Debt to Equity Ratio
The long-term debt to equity ratio indicates the proportion of a company's assets that are funded through long-term financial commitments, such as loans. This ratio is computed by dividing long-term debt by shareholders' equity.
$$ \text{Long-term D/E} = \frac{\text{Long-term Debt}}{\text{Equity}} $$
Usage:
import { calculateLTDebtEquity } from "livsey-finance-library"
const longTermDebt = 2000;
const equity = 20;
const res = calculateLTDebtEquity(longTermDebt, equity)
console.log(res) // res: 100
Efficiency ratios
Earnings Per Share
Earnings per share (EPS) measures a company's profitability by showing the profit earned on each outstanding share of common stock. It is calculated by dividing the company's net income by the number of outstanding shares.
$$ \text{EPS} = \frac{\text{Net Income - Preferred Dividents}}{\text{End-of-Period Common Shares Outstanding}} $$
Usage:
import { calculateEPS } from "livsey-finance-library"
const netIncome = 1000000;
const preferredDividends = 50000;
const sharesOutstanding = 200000;
const eps = calculateEPS(netIncome, preferredDividends, sharesOutstanding);
console.log(eps); // Output: 20
Return on Assets
The term "return on assets" (ROA) describes a financial ratio that measures a company's profitability relative to its total assets. Corporate management, analysts, and investors use ROA to assess how effectively a company utilizes its assets to produce profit.
$$ \text{ROA} = \frac{\text{Net Income}}{\text{Total Assets}} $$
Usage:
import { calculateROA } from "livsey-finance-library"
const netIncome = 1000000;
const totalAssets = 5000000;
const roa = calculateROA(netIncome, totalAssets);
console.log(roa); // Output: 0.2
Return on Equity
Return on equity (ROE) is a financial performance metric obtained by dividing net income by shareholders' equity. Since shareholders' equity equals a company's assets minus its debt, ROE is viewed as the return on net assets. ROE serves as an indicator of a corporation's profitability and efficiency in generating profits. A higher ROE signifies that the company's management is more effective at generating income and growth from its equity financing.
$$ \text{ROE} = \frac{\text{Net Income}}{\text{Shareholder's Equity}} $$
Usage:
import { calculateROE } from "livsey-finance-library"
const netIncome = 1000000;
const shareholdersEquity = 3000000;
const roe = calculateROE(netIncome, shareholdersEquity);
console.log(roe); // Output: 0.3333333333333333
Return on Investment
Return on investment (ROI) is a metric used to assess how efficiently or profitably an investment is performing, or to compare the effectiveness of multiple investments. It aims to quantify the return generated by a specific investment in relation to its cost.
$$ \text{ROI} = \frac{\text{Current Value of Investment} - \text{Cost of Investment}}{\text{Cost of Investment}} $$
Usage:
import { calculateROI } from "livsey-finance-library"
const currentValue = 1500000;
const cost = 1000000;
const roi = calculateROI(currentValue, cost);
console.log(roi); // Output: 0.5
Liquidity ratios
Current Ratio
The current ratio is a liquidity metric that assesses a company’s capacity to meet its short-term liabilities, due within a year. It indicates to investors and analysts how effectively a company can utilize its current assets to cover its current debts and other payables. A current ratio that matches or slightly exceeds the industry average is typically deemed acceptable. A ratio below the industry average may signal a higher risk of financial distress or default. Conversely, a significantly high current ratio compared to peers suggests that the company might not be using its assets efficiently. This ratio is termed "current" because it includes all current assets and liabilities, unlike some other liquidity ratios. It is also known as the working capital ratio.
$$ \text{Current Ratio} = \frac{\text{Current Assets}}{\text{Current Liabilities}} $$
Usage:
import { calculateCurrentRatio } from "livsey-finance-library";
const currentAssets = 600000;
const currentLiabilities = 300000;
const currentRatio = calculateCurrentRatio(currentAssets, currentLiabilities);
console.log(currentRatio); // Output: 2
Quick Ratio
The quick ratio is an indicator of a company’s short-term liquidity position and measures a company’s ability to meet its short-term obligations with its most liquid assets. Since it indicates the company’s ability to instantly use its near-cash assets (assets that can be converted quickly to cash) to pay down its current liabilities, it is also called the acid test ratio. An “acid test” is a slang term for a quick test designed to produce instant results.
$$ \text{Quick Ratio} = \frac{\text{Cash} + \text{Marketable Securities} + \text{Accounts Receivable}}{\text{Current Liabilities}} $$
Usage:
import { calculateQuickRatio } from "livsey-finance-library";
const currentLiabilities = 300000;
const cash = 200000;
const marketableSecurities = 100000;
const accountsReceivable = 100000;
const quickRatio = calculateQuickRatio(cash, marketableSecurities, accountsReceivable, currentLiabilities);
console.log(quickRatio); // Output: 1.3333333333333333
Cash Ratio
The cash ratio is a measurement of a company's liquidity. It calculates the ratio of a company's total cash and cash equivalents to its current liabilities. The metric evaluates a company's ability to repay its short-term debt with cash or near-cash resources such as easily marketable securities. This information is useful to creditors when they decide how much money, if any, they would be willing to loan to a company.
$$ \text{Cash Ratio} = \frac{\text{Cash}}{\text{Current Liabilities}} $$
Usage:
import { calculateCashRatio } from "livsey-finance-library";
const currentLiabilities = 300000;
const cash = 200000;
const cashRatio = calculateCashRatio(cash, currentLiabilities);
console.log(cashRatio); // Output: 0.6666666666666666
Net Working Capital to Revenue
Net Working Capital (NWC) % Revenue is a financial metric that measures the proportion of a company's net working capital relative to its total revenue. Net working capital is calculated as current assets minus current liabilities, and it represents the short-term liquidity and operational efficiency of a company. This ratio provides insights into how effectively a company is managing its working capital in relation to its revenue generation. A higher NWC % Revenue indicates that a larger portion of the company's revenue is tied up in working capital, which might affect its ability to invest in growth opportunities. Conversely, a lower ratio suggests more efficient working capital management, allowing more revenue to be available for other purposes such as reinvestment or debt repayment. This metric is particularly useful for investors and financial analysts in assessing a company's operational health and its ability to meet short-term obligations.
$$ \text{NWC % Revenue} = \frac{\text{Net Working Capital}}{\text{Revenue}} $$
Usage:
import { calculateNWCPercentageRevenue } from "livsey-finance-library";
const netWorkingCapital = 300000;
const revenue = 2000000;
const nwcRevenue = calculateNWCPercentageRevenue(netWorkingCapital, revenue);
console.log(nwcRevenue); // Output: 0.15
Net Debt
Net debt is a liquidity metric that's used to determine how well a company can pay all its debts if they come due immediately. Net debt shows how much debt a company has on its balance sheet compared to its liquid assets. It shows how much cash would remain if all debts were paid off and if a company has sufficient liquidity to meet its debt obligations.
$$ \text{Net Debt} = \text{Total Debt} - \text{Cash} $$
Usage:
import { calculateNetDebt } from "livsey-finance-library";
const totalDebt = 500000;
const cash = 200000;
const netDebt = calculateNetDebt(totalDebt, cash);
console.log(netDebt); // Output: 300000
Valuation ratios
Price-to-Earnings
The price-to-earnings ratio (P/E) is one of the most widely used metrics for investors and analysts to determine stock valuation. It shows whether a company’s stock price is overvalued or undervalued and can reveal how a stock’s valuation compares with its industry group or a benchmark like the S&P 500 Index. A good P/E for one group or sector could be a poor P/E for another sector, so comparisons should compare similar companies.
The P/E ratio helps investors determine the market value of a stock compared with the company’s earnings. It shows what the market is willing to pay for a stock based on its past or future earnings.
$$ \text{P/E} = \frac{\text{Price}}{\text{EPS}} $$
Usage:
import { calculatePE } from "livsey-finance-library";
const price = 150;
const eps = 5;
const peRatio = calculatePE(price, eps);
console.log(peRatio); // Output: 30
Forward Price-to-Earnings
The forward P/E ratio (or forward price-to-earnings ratio) divides the current share price of a company by the estimated future (“forward”) earnings per share (EPS) of that company. For valuation purposes, a forward P/E ratio is typically considered more relevant than a historical P/E ratio.
$$ \text{Forward P/E} = \frac{\text{Price}}{\text{Forward EPS}} $$
Usage:
import { calculateForwardPE } from "livsey-finance-library";
const priceForwardPE = 150;
const forwardEps = 6;
const forwardPeRatio = calculateForwardPE(priceForwardPE, forwardEps);
console.log(forwardPeRatio); // Output: 25
Price-to-Earnings-to-Growth
The price/earnings to growth ratio (PEG ratio) is a stock's price-to-earnings (P/E) ratio divided by the growth rate of its earnings for a specified time period.
The PEG ratio is used to determine a stock's value while also factoring in the company's expected earnings growth, and it is thought to provide a more complete picture than the more standard P/E ratio.
$$ \text{PEG} = \frac{\text{Price/EPS}}{\text{EPS Growth}} $$
Usage:
import { calculatePEG } from "livsey-finance-library";
const pe = 30;
const growthRate = 15;
const pegRatio = calculatePEG(pe, growthRate);
console.log(pegRatio); // Output: 2
Price-to-Sales
The price-to-sales (P/S) ratio is a valuation ratio that compares a company’s stock price to its revenues. It is an indicator of the value that financial markets have placed on each dollar of a company’s sales or revenues.
$$ \text{P/S} = \frac{\text{Market Value per Share}}{\text{Sales per Share}} $$
Usage:
import { calculatePS } from "livsey-finance-library";
const marketCap = 500000000;
const revenue = 100000000;
const psRatio = calculatePS(marketCap, revenue);
console.log(psRatio); // Output: 5
Price-to-Book
A company's price-to-book ratio is the company's current stock price per share divided by its book value per share (BVPS). This shows the market valuation of a company compared to its book value.
If your goal as an investor is to unearth high-growth companies selling at low-growth prices, the price-to-book ratio (P/B) offers an effective approach to finding undervalued companies. The P/B ratio can also help investors identify and avoid overvalued companies.
However, this ratio has its limitations and there are circumstances where it may not be the most effective metric for valuation.
$$ \text{P/B} = \frac{\text{Market Price per Share}}{\text{Book Value per Share}} $$
Usage:
import { calculatePB } from "livsey-finance-library";
const pricePB = 150;
const bookValuePerShare = 50;
const pbRatio = calculatePB(pricePB, bookValuePerShare);
console.log(pbRatio); // Output: 3
Price-to-Cash Flow
The price-to-cash flow (P/CF) ratio is a stock valuation indicator or multiple that measures the value of a stock’s price relative to its operating cash flow per share. The ratio uses operating cash flow (OCF), which adds back non-cash expenses such as depreciation and amortization to net income.
P/CF is especially useful for valuing stocks that have positive cash flow but are not profitable because of large non-cash charges.
$$ \text{P/CF} = \frac{\text{Share Price}}{\text{Operating Cash Flow per Share}} $$
Usage:
import { calculatePC } from "livsey-finance-library";
const pricePC = 150;
const cashFlowPerShare = 10;
const pcRatio = calculatePC(pricePC, cashFlowPerShare);
console.log(pcRatio); // Output: 15
Price to Free Cash Flow
Price to free cash flow (P/FCF) is an equity valuation metric that compares a company's per-share market price to its free cash flow (FCF). This metric is very similar to the valuation metric of price to cash flow but is considered a more exact measure because it uses free cash flow, which subtracts capital expenditures (CAPEX) from a company's total operating cash flow, thereby reflecting the actual cash flow available to fund non-asset-related growth.
Companies can use this metric to base growth decisions and maintain acceptable free cash flow levels.
$$ \text{P/FCF} = \frac{\text{Market Capitalization}}{\text{Free Cash Flow}} $$
Usage:
import { calculatePFCF } from "livsey-finance-library";
const pricePFCF = 150;
const freeCashFlowPerShare = 8;
const pfcfRatio = calculatePFCF(pricePFCF, freeCashFlowPerShare);
console.log(pfcfRatio); // Output: 18.75
CAPE Ratio
The CAPE ratio is a valuation measure that uses real earnings per share (EPS) over a 10-year period to smooth out fluctuations in corporate profits that occur over different periods of a business cycle.
The CAPE ratio, an acronym for cyclically adjusted price-to-earnings ratio, was popularized by Yale University professor Robert Shiller. It is also known as the Shiller P/E ratio. The P/E ratio is a valuation metric that measures a stock’s price relative to the company’s earnings per share. EPS is a company’s profit divided by the outstanding equity shares.
The CAPE ratio is generally applied to broad equity indexes to assess whether the market is undervalued or overvalued. While it is a popular and widely followed measure, several leading industry practitioners have called into question its utility as a predictor of future stock market returns.
$$ \text{CAPE} = \frac{\text{Share Price}}{\text{Average, Inflation-Adjusted Earnings over 10 Years}} $$
Usage:
import { calculateCAPE } from "livsey-finance-library";
const priceCAPE = 150;
const avgEarnings10Years = 12;
const capeRatio = calculateCAPE(priceCAPE, avgEarnings10Years);
console.log(capeRatio); // Output: 12.5
Other ratios
Enterprise Value
Enterprise value (EV) measures a company’s total value, often used as a more comprehensive alternative to market capitalization. EV includes in its calculation not only the market capitalization of a company but also short-term and long-term debt and any cash or cash equivalents on the company’s balance sheet.
$$ \text{EV} = \text{Market Capitalization} + \text{Total Debt} - \text{Cash} $$
Usage:
import { calculateEV } from 'livsey-finance-library';
const marketCap = 5000000; // Market Capitalization
const totalDebt = 2000000; // Total Debt
const cash = 1000000; // Cash on Hand
const ev = calculateEV(marketCap, totalDebt, cash);
console.log(ev); // Output: 6000000
EV to EBITDA
The EV/EBITDA ratio is a popular metric used as a valuation tool to compare the value of a company, debt included, to the company’s cash earnings less non-cash expenses. It's ideal for analysts and investors looking to compare companies within the same industry.
The enterprise-value-to-EBITDA ratio is calculated by dividing EV by EBITDA or earnings before interest, taxes, depreciation, and amortization. Typically, EV/EBITDA values below 10 are seen as healthy. However, the comparison of relative values among companies within the same industry is the best way for investors to determine companies with the healthiest EV/EBITDA within a specific sector.
$$ \text{EV/EBITDA} = \frac{\text{Enterprise Value}}{\text{EBITDA}} $$
Usage:
import { calculateEV, calculateEVtoEBITDA } from 'livsey-finance-library';
const marketCap = 5000000; // Market Capitalization
const totalDebt = 2000000; // Total Debt
const cash = 1000000; // Cash on Hand
const ebitda = 1500000; // Earnings Before Interest, Taxes, Depreciation, and Amortization
const ev = calculateEV(marketCap, totalDebt, cash);
const evToEbitda = calculateEVtoEBITDA(ev, ebitda);
console.log(evToEbitda); // Output: 4
EV to Cash Flow from Operations
Cash Flow from Operations (CFO) represents the net cash generated from a company’s core business operations, excluding capital expenditures and financing activities. It measures the company's ability to generate cash flow from its regular business activities.
$$ \text{EV/CFO} = \frac{\text{Enterprise Value}}{\text{Cash Flow from Operations}} $$
Usage:
import { calculateEV, calculateEVCFO } from 'livsey-finance-library';
const marketCap = 5000000; // Market Capitalization
const totalDebt = 2000000; // Total Debt
const cash = 1000000; // Cash on Hand
const cfo = 1200000; // Cash Flow from Operations
const ev = calculateEV(marketCap, totalDebt, cash);
const evToCfo = calculateEVCFO(ev, cfo);
console.log(evToCfo); // Output: 5
EV to Free Cash Flow to Firm
Free Cash Flow to Firm (FCFF) represents the net cash available to the firm after accounting for capital expenditures and operating expenses, before any interest payments are made. It measures the company's ability to generate cash flow from its operations that can be used for expansion, debt repayment, or other purposes.
$$ \text{EV/FCFF} = \frac{\text{Enterprise Value}}{\text{Free Cash Flow to Firm}} $$
Usage:
import { calculateEV, calculateEVFCFF } from 'livsey-finance-library';
const marketCap = 5000000; // Market Capitalization
const totalDebt = 2000000; // Total Debt
const cash = 1000000; // Cash on Hand
const fcff = 1100000; // Free Cash Flow to Firm
const ev = calculateEV(marketCap, totalDebt, cash);
const evToFcff = calculateEVFCFF(ev, fcff);
console.log(evToFcff); // Output: 5.454545454545454
Exceptions
ZeroDivisionError
Raised when the second argument of a division or modulo operation is zero. The associated value is a string indicating the type of the operands and the operation.
Contributing
Contributions are what make the open source community such an amazing place to learn, inspire, and create. Any contributions you make are greatly appreciated.
If you have a suggestion that would make this better, please fork the repo and create a pull request. You can also simply open an issue with the tag "enhancement". Don't forget to give the project a star! Thanks again!
- Fork the Project
- Create your Feature Branch (
git checkout -b feature/Features
) - Commit your Changes (
git commit -m 'Add some Features'
) - Push to the Branch (
git push origin feature/Features
) - Open a Pull Request
License
Distributed under the MIT License. See LICENSE.txt
for more information.
Contact
Heorhii Huziuk - [email protected]
Sources:
https://www.investopedia.com/
https://corporatefinanceinstitute.com/
https://optionstrategiesinsider.com/