# minimacd 0.0.2 • Public • Published

# minimacd

A versatile, compact (807 bytes) Javascript implementation of Gerald Appel's MACD (Moving Average Convergence / Divergence) formula.

## Features

• Self-contained: No run-time package dependencies!
• Compact: Only 807 bytes!
• Versatile: The Exponential Moving Average can be seeded in two ways

## ema() : Exponential Moving Average

```function ema(
array: number[],
period: number,
usePeriodAsSeedLength: boolean
): number[] { ... }```

See Gerald Appel's book 'Technical Analysis - Power Tools for Active Investors', chapter 6, pp. 134-137

`const alpha = 2 / (period + 1); // The smoothing constant (Appel p. 134)`

meanValue is the initial value which stabilizes the exponential average. It is the simple average of the first seedLength values in the array, after skipping any initial run of invalid values (e.g. NaN) See the section 'Stabilizing the Exponential Average' (Appel p. 136)

Developers' note: Do not try to replace this:

`result = alpha * element + (1 - alpha) * result;`

... with either of these:

```result += alpha * (element - result);
result = alpha * (element - result) + result;```

They are the same algebraically, but the latter two provide different results than the former due to limited floating-point precision.

## macd() : Moving Average Convergence / Divergence

```function macd(
array: number[],
fastPeriod = 12,
slowPeriod = 26,
signalPeriod = 9,
usePeriodAsSeedLength = false
): number[][] { ... }```

This function returns a two-element tuple consisting of [macdArray, signalArray].

• When usePeriodAsSeedLength is falsy, this algorithm behaves like the npm package macd written by Kael Zhang; i.e. the EMA will be seeded with the first value in the array.
• When usePeriodAsSeedLength is truthy, this algorithm behaves like indicatorMacd in the npm package @d3fc/d3fc-technical-indicator; i.e. the EMA will be seeded with the simple average (the mean) of the first n values in the array, where n is the EMA's period.

In general terms, macd is defined as this:

```function macd(array, fastPeriod, slowPeriod) {
return ema(array, fastPeriod) - ema(array, slowPeriod);
}```

A signal(n) value is the EMA (with period = n) of consecutive MACD values.

MIT

## Package Sidebar

### Install

`npm i minimacd`

4

0.0.2

MIT

12.6 kB

5