39 lines
879 B
C
39 lines
879 B
C
|
/*
|
||
|
* arngment - random music generator
|
||
|
*
|
||
|
* Written in 2020 by Lucas
|
||
|
*
|
||
|
* To the extent possible under law, the author(s) have dedicated all
|
||
|
* copyright and related and neighboring rights to this software to the
|
||
|
* public domain worldwide. This software is distributed without any
|
||
|
* warranty.
|
||
|
*
|
||
|
* You should have received a copy of the CC0 Public Domain Dedication
|
||
|
* along with this software. If not, see
|
||
|
* <http://creativecommons.org/publicdomain/zero/1.0/>.
|
||
|
*/
|
||
|
|
||
|
#include <math.h>
|
||
|
|
||
|
#define CLAMP(x, a, b) ((x) < (a) ? (a) : (x) > (b) ? (b) : (x))
|
||
|
|
||
|
double
|
||
|
synth_distortion(double gain, double x)
|
||
|
{
|
||
|
double xg = CLAMP(x * gain, -1.0, 1.0);
|
||
|
return (x + xg) / 2.0;
|
||
|
}
|
||
|
|
||
|
double
|
||
|
synth_sinewave(double t, double a)
|
||
|
{
|
||
|
return sin(2.0 * M_PI * t * a);
|
||
|
}
|
||
|
|
||
|
double
|
||
|
synth_trianglewave(double t, double a)
|
||
|
{
|
||
|
double x = t * a;
|
||
|
return 2.0 * fabs(2.0 * (x - floor(0.5 + x))) - 1.0;
|
||
|
}
|