7 unstable releases (3 breaking)

0.4.1 Jan 2, 2023
0.4.0 Dec 29, 2022
0.3.0 Dec 9, 2022
0.2.2 Jul 22, 2022
0.1.0 Jun 29, 2022

#353 in Math

Download history 19/week @ 2023-12-14 4/week @ 2024-01-11 9/week @ 2024-01-18 6/week @ 2024-01-25 4/week @ 2024-02-01 7/week @ 2024-02-08 16/week @ 2024-02-15 39/week @ 2024-02-22 73/week @ 2024-02-29 63/week @ 2024-03-07 60/week @ 2024-03-14 33/week @ 2024-03-21 46/week @ 2024-03-28

214 downloads per month

MIT license

180KB
484 lines

wavegen

github Crates.io docs Build status

wavegen is a wavefrom generator made with 🦀

How to use it?

  1. Add wavegen to your project:
[dependencies]
wavegen = "0.4"

Or, to use the no_std version (custom global allocator is required):

[dependencies]
wavegen = { version = "0.4", default-features = false, features = ["libm"] }
  1. Define a waveform with sampling frequency and function components:
let waveform = wf!(f64, 200., sine!(frequency: 100., amplitude: 10.), dc_bias!(20.));
  1. Turn it into an iterator and sample:
let some_samples: Vec<f64> = waveform.iter().take(200).collect();

Refer to documentation for more exhaustive usage examples.

Show me some examples!

Interactive demo

Check out the demo at https://wavegen-demo.netlify.app

Plot charts

  • Simple sine

Sine plot

  • Two superposed phase-shifted sines

Superposed sines plot

  • "Real life" example: 300Hz sine signal with 50Hz interference noise

300_50_hz_sines

  • Sawtooth

Sawtooth plot

  • Superposition of sine + sawtooth

Sine and sawtooth superposed

  • Square wave

Square wave

  • Superposition of Sine, Square and Sawtooth with different frequencies

Something funky

All above examples are generated with simple program found in examples/plot.rs. Run cargo run --example plot to generate them yourself.

MSRV

The Minimum Supported Rust Version is 1.60.

Similar crates

  • Waver which was the inspiration for this crate

Breaking changes

0.2

  • Braking change in how macros are annotated, changing the annotation form from frequency = n to frequency: n

0.4

  • Waveform::get_sample_rate renamed to Waveform::sample_rate and now returns a borrowed values, as per rust API specs.
  • Waveform::get_components_len removed. The functionality can be achieved by a new getter Waveform::components.

Dependencies