Skip to content

Latest commit

 

History

History

math

@thi.ng/math

npm version npm downloads Mastodon Follow

This project is part of the @thi.ng/umbrella monorepo.

For the Clojure version, please visit: thi.ng/math-clj

About

Assorted common math functions & utilities.

Partially ported from Clojure version thi.ng/math-clj, c.thi.ng and thi.ng/vexed-generation.

Status

STABLE - used in production

Search or submit any issues for this package

Breaking changes in v4.0.0

The introduction of several standard libc math functions causes a behavior change of the existing fmod() function...

  • rename fmod() => mod() to align w/ GLSL counterpart
  • add new fmod() w/ standard libc behavior (same as JS % op)
  • add remainder() w/ standard libc behavior

Installation

yarn add @thi.ng/math

ES module import:

<script type="module" src="https://cdn.skypack.dev/@thi.ng/math"></script>

Skypack documentation

For Node.js REPL:

const math = await import("@thi.ng/math");

Package sizes (brotli'd, pre-treeshake): ESM: 4.04 KB

Dependencies

Usage examples

Several demos in this repo's /examples directory are using this package.

A selection:

Screenshot Description Live demo Source
Basic crypto-currency candle chart with multiple moving averages plots Demo Source
2D Bezier curve-guided particle system Demo Source
Animated sine plasma effect visualized using contour lines Demo Source
Worker based, interactive Mandelbrot visualization Demo Source
Unison wavetable synth with waveform editor Demo Source
2D scenegraph & shape picking Demo Source
2D scenegraph & image map based geometry manipulation Demo Source
Simplistic SVG bar chart component Demo Source
SVG path parsing & dynamic resampling Demo Source

API

Generated API docs

TODO

Authors

If this project contributes to an academic publication, please cite it as:

@misc{thing-math,
  title = "@thi.ng/math",
  author = "Karsten Schmidt and others",
  note = "https://thi.ng/math",
  year = 2013
}

License

© 2013 - 2023 Karsten Schmidt // Apache License 2.0