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

beuron

v1.1.0

Published

Binary neuron for JavaScript. A logic port that learns the most probable logical function from samples. Capable of online learning, forgetting and handling noisy data.

Downloads

3

Readme

Beuron.jsv1.1.0

Binary neuron. A logic port that learns the most probable logical function from samples. Capable of online learning and handling noisy data. Tested, optimized and less than 400 bytes when compressed. Compatible with browsers and Node.js.

Basic example

> var b = Beuron.create();
> b.learn([1, 1], 0);
> b.learn([0, 1], 0);
> b.learn([1, 0], 0);
> b.learn([0, 0], 1);
> b.solve([1, 0]);
0
> b.solve([0, 0]);
1

API

Include

Node.js

var Beuron = require('beuron');

Browsers

<script src="beuron.js" />

Beuron.create(sizeLimit?)

> var b = Beuron.create();
> var c = Beuron.create(6);

The sizeLimit is an optional positive number that defines how quickly old samples will be forgotten when new ones are learned. Set to zero to force solve() results to be based on all the learned samples. Set to 2 to base results on approximately two previous samples for each four different sample types. Default is zero. See Under the hood for details.

b.learn(sample, result)

> b.learn([0, 1], 1);
undefined

Sample is an array with length of two. The elements of the array and also the result must be 0 or 1.

Does not return anything (undefined).

b.solve(sample)

> b.solve([0, 1]);
1

Takes in a sample array similar to b.learn(). Returns the most probable result, 0 or 1. If equally probable or no data, returns 0.

b.save()

> b.save();
[3.2, 1.2, 0, 18, 2.9, 1.6, 0, 2.1, 29]

Exports the state of beuron for example to be stored in database. See b.load().

b.load(savedArray)

> b.load(previouslySavedArray);
undefined

Resets beuron back to the saved state. See b.save().

b.setSizeLimit(newSizeLimit)

> b.setSizeLimit(4);
undefined

See Beuron.create().

Customize Beuron

Customize Beuron by:

Beuron.extension.myFunction = function (...) {...};

After that you can:

var b = Beuron.create();
b.myFunction();

Under the hood

Beuron learns a logical 2-to-1 function from a set of samples and is able to adapt quickly if the function changes.

There is four pairs of buckets. Each possible input has its own pair. In a pair the first bucket collects the number of zero outputs and the second collects ones accordingly.

 0,0    0,1    1,0   1,1     Input vector (bucket pair)
   _    _            _ _
 _| |  | |          | | |
| | |  | |_    _    | | |    Likelihood distribution of outputs (buckets)
| | |  | | |  | |   | | |
|_|_|  |_|_|  |_|_  |_|_|
 0 1    0 1    0 1   0 1     Output (bucket labels)

When a input need to be solved, an associated pair is taken under examination. If the bucket of zeros weights more than the bucket of ones, the result is zero. Also when the weights are equal the result is zero. If the bucket of ones weights more, the result is one.

Beuron can adapt to change by forgetting. If the buckets were infinite, the result would simply be the most frequent one. In another words the result would be based on all the learned data. What if the logical function changes? To learn the new function, infinite beuron would need at least same amount of learning samples as it has already learned. To avoid that the bucket pairs can have a size limit.

A bucket pair with a size limit decreases the effect of previous samples as news are learned. Smaller the limit, larger the effect of new samples. In practice, before new sample is added to a bucket, beuron makes sure that there is enough space in the pair of the bucket. If the space would be exceeded both buckets are multiplied with number < 1 so that there is room for one sample. As an outcome the effect of previous samples is reduced.

For example lets take a bucket pair (0,0) and let the first bucket be B0 and the second B1. The limit for the pair is 2. Lets assume B0 equals to 2 and B1 to 0. The sum B0 + B1 equals to 2 so the limit is not exceeded. Now a new sample (0,0) -> 1 is added so it matches with B1. If B1 was increased by one the sum would exceed the limit so before the increase the pair is multiplied by 0.5. B0 becomes to 1 and B1 stays at 0. Now B1 is increased to 1. As a result B0 and B1 are equal, meaning that 0 and 1 are equally likely to be the outcome. It's decided that in this case output will default to 0. After second similar sample B0 decreases to 0.5 and B1 increases to 1.5.

 _
| |     Initial state, size limit 2
|_|_      b.solve([0,0]) === 0
B0 B1

 _ _    State after first (0,0) -> 1
|_|_|     b.solve([0,0]) === 0
B0 B1
   
  |-|   State after second (0,0) -> 1
|-|_|     b.solve([0,0]) === 1
B0 B1

History

The development of Beuron started in 2013 as an experiment about fundamentals of machine learning.

License

MIT License