1.0.3 • Published 5 years ago

compact-prediction-tree v1.0.3

Weekly downloads
-
License
MIT
Repository
-
Last release
5 years ago

Compact Prediction Tree

npm version

This is an implementation of CPT algorithm for Fast Sequence Prediction. Its written in Pure Javascript and can be run both in NodeJS and the browser.

The library is based on these research papers:

  1. Compact Prediction Tree: A Losless Model for Accurate Sequence Prediction

  2. CPT+: Decreasing the time/space complexity of the Compact Prediction Tree

Install

$ npm i compact-prediciton-tree

Usage

import CPT from 'compact-prediction-tree';

let model = new CPT();
let data = [
    ['hello', 'how', 'are', 'you'],
    ['hello', 'how', 'are', 'your', 'studies', 'going', '?'],
    ['This', 'is', 'a', 'test'],
    ['How', 'does', 'this', 'work']
]
model.train(
    data // Training Data
);

let target = [
    ['how', 'are']
];
let predictions = model.predict(
    target, // Test input
    2, // The number of last elements that will be used
       // to find similar sequences, (default: target.length)
    2  // The number of predictions required.
);

console.log(predictions) // [['you'], ['your']]

It works on Strings/Number sequences. Optimizations are pending such as compression of frequenct sequences. Pull requests are welcome!