Socket
Book a DemoInstallSign in
Socket

categorical

Package Overview
Dependencies
Maintainers
1
Versions
3
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

categorical

An implementation of a categorical distribution in JavaScript. Allows you to do draw randomly from many events that have different probabilities.

1.0.0
latest
npmnpm
Version published
Weekly downloads
98
-34.23%
Maintainers
1
Weekly downloads
 
Created
Source

categorical

categorical is an impementation of a categorical distribution in JavaScript. Why do you care about it?

It allows you to do fancy things like randomly draw from several different outcomes that all have different probabilities. Imagine you have a bunch of different fruits, and you want to randomly pick one to eat. However, you like some fruits more than others.

var fruits = [
  { name: "apple", like: 10 },
  { name: "banana", like: 15 },
  { name: "peach", like: 20 }
];

Fruits that you like more should show up more when you randomly draw, but you still sometimes want to pick fruits that you like less. Categorical to the rescue!

var categorical = require("categorical"),
  distribution,
  fruitResults = [0, 0, 0],
  fruit,
  i;

function calculateScoreForFruit(fruit) {
  return fruit.like;
}

distribution = categorical.createDistribution(fruits, calculateScoreForFruit);

// test the results
for (i = 0; i < 10000; i++) {
  fruit = categorical.draw(distribution);
  if (fruit.name === "apple") {
    fruit[0]++;
  } else if (fruit.name === "banana") {
    fruit[1]++;
  } else {
    fruit[2]++;
  }
}

console.log(
  "apple: " + fruit[0] + ", banana: " + fruit[1] + ", peach: " + fruit[2]
);

Installation

npm install categorical

API

categorical is pretty simple. It only has two calls:

categorical.createDistribution(items, scoreFunction)

Creates and returns a categorical distribution.

items - An array of items to use to create the distribution.

scoreFunction - function(item) that returns a numeric score for an individual item from items.

Returns the distribution. An array of objects containing the probability windows for each item, along with the item itself.

var fruits = [
  { name: "apple", like: 10 },
  { name: "banana", like: 15 },
  { name: "peach", like: 20 }
];

function calculateScoreForFruit(fruit) {
  return fruit.like;
}

distribution = categorical.createDistribution(fruits, calculateScoreForFruit);

categorical.draw(distribution)

Draw a random item from the distribution.

distribution is the distribution returned from a call to createDistribution.

Returns the random item returned from the distribution.

var fruit = categorical.draw(distribution);
console.log(fruit); // will be either 'apple', 'banana', or 'peach'

FAQs

Package last updated on 26 Nov 2017

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

About

Packages

Stay in touch

Get open source security insights delivered straight into your inbox.

  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc

U.S. Patent No. 12,346,443 & 12,314,394. Other pending.