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 🙏

© 2025 – Pkg Stats / Ryan Hefner

@stdlib/stats-base-dists-normal

v0.2.2

Published

Normal distribution.

Downloads

1,099

Readme

Normal

NPM version Build Status Coverage Status

Normal distribution.

Installation

npm install @stdlib/stats-base-dists-normal

Usage

var normal = require( '@stdlib/stats-base-dists-normal' );

normal

Normal distribution.

var dist = normal;
// returns {...}

The namespace contains the following distribution functions:

The namespace contains the following functions for calculating distribution properties:

The namespace contains a constructor function for creating a normal distribution object.

var Normal = require( '@stdlib/stats-base-dists-normal' ).Normal;

var dist = new Normal( 2.0, 4.0 );

var y = dist.pdf( 2.0 );
// returns ~0.1

Examples

var normal = require( '@stdlib/stats-base-dists-normal' );

/*
A bakery is analyzing cake baking times to ensure consistency and better schedule their baking processes.

The Central Limit Theorem (CLT) states that the average baking times from many batches will follow a normal distribution if there are enough batches (typically n > 30).

Assuming each record represents the average baking time per batch and the bakery has collected the following data:

-      Mean baking time (μ/mu): 20 minutes.
-      Standard deviation in baking time (σ/sigma): 3 minutes.

We can model the average bake times using a normal distribution with μ (mu) = 20.0 minutes and σ = 3.0 minutes.
*/

var mu = 20.0;
var sigma = 3.0;

var normalDist = new normal.Normal( mu, sigma );

// Output the standard deviation of the baking times:
console.log( normalDist.sigma );
// => 3.0

// Adjust distribution parameters
normalDist.sigma = 4.0;

// Adjusted standard deviation to reflect different variance scenario:
console.log( normalDist.sigma );
// => 4.0

// Excess kurtosis of a normal distribution (measure of "tailedness"):
console.log( normalDist.kurtosis );
// => 0.0

// Median baking time:
console.log( normalDist.median );
// => 20.0

// Variance of the baking times after adjusting sigma:
console.log( normalDist.variance );
// => 16.0

// Probability density function at the mean baking time:
console.log( normal.pdf( 20.0, mu, sigma ) );
// => ~0.133

// Cumulative distribution function at the mean (portion of times ≤ 20 minutes):
console.log( normal.cdf( 20.0, mu, sigma ) );
// => ~0.5

// 50th percentile (median) of the baking times:
console.log( normal.quantile( 0.5, mu, sigma ) );
// => 20.0

// Moment-generating function value at 0.5 (used in probability theory):
console.log( normal.mgf( 0.5, mu, sigma ) );
// => ~67846.291

// Entropy of the normal distribution (measure of uncertainty):
console.log( normal.entropy( mu, sigma ) );
// => ~2.518

// Mean baking time:
console.log( normal.mean( mu, sigma ) );
// => 20.0

// Median baking time:
console.log( normal.median( mu, sigma ) );
// => 20.0

// Mode of the baking times (most frequent value):
console.log( normal.mode( mu, sigma ) );
// => 20.0

// Variance of the baking times:
console.log( normal.variance( mu, sigma ) );
// => 9.0

// Skewness of the distribution (symmetry measure):
console.log( normal.skewness( mu, sigma ) );
// => 0.0

var myquantile = normal.quantile.factory( 20.0, 3.0 );

// 20th percentile (value below which 20% baking times fall):
console.log( myquantile( 0.2 ) );
// => ~17.475

// 80th percentile (value below which 80% baking times fall):
console.log( myquantile( 0.8 ) );
// => ~22.525

var mylogpdf = normal.logpdf.factory( 20.0, 3.0 );

// Logarithm of the probability density function at the mean:
console.log( mylogpdf( 20.0 ) );
// => ~-2.018

// Logarithm of the probability density function at 15 minutes:
console.log( mylogpdf( 15.0 ) );
// => ~-3.406

Notice

This package is part of stdlib, a standard library for JavaScript and Node.js, with an emphasis on numerical and scientific computing. The library provides a collection of robust, high performance libraries for mathematics, statistics, streams, utilities, and more.

For more information on the project, filing bug reports and feature requests, and guidance on how to develop stdlib, see the main project repository.

Community

Chat


License

See LICENSE.

Copyright

Copyright © 2016-2024. The Stdlib Authors.