]> de.git.xonotic.org Git - xonotic/xonotic-data.pk3dir.git/blob - qcsrc/lib/noise.qh
pow(a, b) -> a ** b
[xonotic/xonotic-data.pk3dir.git] / qcsrc / lib / noise.qh
1 #pragma once
2
3 // noises "usually" start in the range -1..1
4 entityclass(Noise);
5 class(Noise).float noise_baccum;
6 class(Noise).float noise_paccum;
7 class(Noise).float noise_paccum2;
8 class(Noise).float noise_paccum3;
9 class(Noise).float noise_bstate;
10
11 float Noise_Brown(entity e, float dt)
12 {
13         e.noise_baccum += random() * sqrt(dt);  // same stddev for all dt
14         return e.noise_baccum;
15 }
16 float Noise_Pink(entity e, float dt)
17 {
18         float f;
19         f = dt * 60;
20         // http://home.earthlink.net/~ltrammell/tech/pinkalg.htm
21         if (random() > (0.3190 ** f)) e.noise_paccum = 0.34848 * (2 * random() - 1);
22         if (random() > (0.7756 ** f)) e.noise_paccum2 = 0.28768 * (2 * random() - 1);
23         if (random() > (0.9613 ** f)) e.noise_paccum3 = 0.43488 * (2 * random() - 1);
24         return e.noise_paccum + e.noise_paccum2 + e.noise_paccum3;
25 }
26 float Noise_White(entity e, float dt)
27 {
28         return random() * 2 - 1;
29 }
30 /** +1 or -1 */
31 float Noise_Burst(entity e, float dt, float p)
32 {
33         if (random() > (p ** dt)) e.noise_bstate = !e.noise_bstate;
34         return 2 * e.noise_bstate - 1;
35 }