npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

livsey-finance-library

v1.1.1

Published

a simple financial library with most important ratios for investors/traders/etc

Downloads

14

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!

  1. Fork the Project
  2. Create your Feature Branch (git checkout -b feature/Features)
  3. Commit your Changes (git commit -m 'Add some Features')
  4. Push to the Branch (git push origin feature/Features)
  5. 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/