61 lines
1.8 KiB
Markdown
61 lines
1.8 KiB
Markdown
[data:image/s3,"s3://crabby-images/57215/572152a373dcff38e0c990aa7ba14fcc60c6eb13" alt="NPM Version"](https://npmjs.org/package/ewma)
|
|
[data:image/s3,"s3://crabby-images/3eda0/3eda0db697414cc8503b0e5187d53a998ff07782" alt="Build Status"](https://travis-ci.org/ReactiveSocket/ewma)
|
|
|
|
# EWMA
|
|
|
|
An exponential weighted moving average for Node.js and the browser!
|
|
|
|
```bash
|
|
npm install -g ewma
|
|
```
|
|
|
|
## Usage
|
|
|
|
Compute the exponential weighted moving average of a series of values. The
|
|
time at which you insert the value into `Ewma` is used to compute a weight
|
|
(recent points are weighted higher). The parameter for defining the
|
|
convergence speed (like most decay process) is the half-life.
|
|
|
|
e.g. with a half-life of 10 unit, if you insert 100 at t=0 and 200 at t=10 the
|
|
ewma will be equal to (200 - 100)/2 = 150 (half of the distance between the new
|
|
and the old value).
|
|
|
|
### `var ewma = new EWMA(halfLifeMs, initialValue, clock)`
|
|
|
|
* `halfLifeMs` - `{Number}` parameter representing the speed of convergence
|
|
* `initialValue` - `{Number}` initial value
|
|
* `clock` - Optional `{Number}` clock object used to read time, must support
|
|
`Date.now()` style method. Defaults to `Date`.
|
|
|
|
returns an object computing the ewma average
|
|
|
|
### `ewma.insert(x)`
|
|
|
|
* `x` - The next value, `ewma` will automatically compute the EWMA based on the
|
|
clock difference between this value and the last time `insert` was
|
|
called
|
|
|
|
### `ewma.reset(x)`
|
|
|
|
* `x` - Set the EWMA to exactly `x`.
|
|
|
|
### `ewma.value()`
|
|
|
|
Returns the current EWMA value.
|
|
|
|
## Examples
|
|
|
|
These are generated using a 500ms interval with a half life indicated in the
|
|
key. For the source code, or to reproduce yourself, check the
|
|
[Example](./example) directory.
|
|
|
|
data:image/s3,"s3://crabby-images/6d820/6d820673bb27cc888b4668957f717d9324f37368" alt=""
|
|
data:image/s3,"s3://crabby-images/050a3/050a385a5c34f0ce130df4d43f2aafb969c912e3" alt=""
|
|
data:image/s3,"s3://crabby-images/6da8f/6da8fb06b4e587e583b2a85db955473a07e7aba4" alt=""
|
|
|
|
## Contributions
|
|
Contributions welcome, please ensure `make` runs clean.
|
|
|
|
## License
|
|
MIT
|