9#define VARIABLE_LENGTH_ARRAY_NEEDS_EMULATION 1
12#define VARIABLE_LENGTH_ARRAY_NEEDS_EMULATION 0
15#if !VARIABLE_LENGTH_ARRAY_NEEDS_EMULATION
16#define VARIABLE_LENGTH_ARRAY(TYPE, NAME, SIZE) TYPE NAME[SIZE]
17#elif __has_include(<alloca.h>)
19#define VARIABLE_LENGTH_ARRAY(TYPE, NAME, SIZE) \
20 TYPE* NAME = reinterpret_cast<TYPE*>(alloca(sizeof(TYPE) * (SIZE)))
21#elif __has_include(<cstdlib>)
23#define VARIABLE_LENGTH_ARRAY(TYPE, NAME, SIZE) \
24 TYPE* NAME = reinterpret_cast<TYPE*>(alloca(sizeof(TYPE) * (SIZE)))
26#error "Compiler does not allow variable type arrays."
32#define FASTLED_INTERNAL
38#pragma GCC diagnostic push
39#if defined(__GNUC__) && (__GNUC__ >= 6)
40 #pragma GCC diagnostic ignored "-Wstack-usage="
42 #pragma GCC diagnostic ignored "-Wunknown-warning-option"
48#define P(x) FL_PGM_READ_BYTE_NEAR(p + x)
54 151, 160, 137, 91, 90, 15, 131, 13, 201, 95, 96, 53, 194, 233, 7, 225,
55 140, 36, 103, 30, 69, 142, 8, 99, 37, 240, 21, 10, 23, 190, 6, 148,
56 247, 120, 234, 75, 0, 26, 197, 62, 94, 252, 219, 203, 117, 35, 11, 32,
57 57, 177, 33, 88, 237, 149, 56, 87, 174, 20, 125, 136, 171, 168, 68, 175,
58 74, 165, 71, 134, 139, 48, 27, 166, 77, 146, 158, 231, 83, 111, 229, 122,
59 60, 211, 133, 230, 220, 105, 92, 41, 55, 46, 245, 40, 244, 102, 143, 54,
60 65, 25, 63, 161, 1, 216, 80, 73, 209, 76, 132, 187, 208, 89, 18, 169,
61 200, 196, 135, 130, 116, 188, 159, 86, 164, 100, 109, 198, 173, 186, 3, 64,
62 52, 217, 226, 250, 124, 123, 5, 202, 38, 147, 118, 126, 255, 82, 85, 212,
63 207, 206, 59, 227, 47, 16, 58, 17, 182, 189, 28, 42, 223, 183, 170, 213,
64 119, 248, 152, 2, 44, 154, 163, 70, 221, 153, 101, 155, 167, 43, 172, 9,
65 129, 22, 39, 253, 19, 98, 108, 110, 79, 113, 224, 232, 178, 185, 112, 104,
66 218, 246, 97, 228, 251, 34, 242, 193, 238, 210, 144, 12, 191, 179, 162, 241,
67 81, 51, 145, 235, 249, 14, 239, 107, 49, 192, 214, 31, 181, 199, 106, 157,
68 184, 84, 204, 176, 115, 121, 50, 45, 127, 4, 150, 254, 138, 236, 205, 93,
69 222, 114, 67, 29, 24, 72, 243, 141, 128, 195, 78, 66, 215, 61, 156, 180,
76#if FASTLED_NOISE_ALLOW_AVERAGE_TO_OVERFLOW == 1
77#define AVG15(U,V) (((U)+(V)) >> 1)
80#if defined(__AVR__) && (LIB8_ATTINY == 0)
81#define AVG15(U,V) (avg15_inline_avr_mul((U),(V)))
85static int16_t
inline __attribute__((always_inline)) avg15_inline_avr_mul( int16_t i, int16_t j)
95 "adc %A[i], %A[j] \n\t"
96 "adc %B[i], %B[j] \n\t"
102#define AVG15(U,V) (avg15((U),(V)))
108#if FASTLED_NOISE_FIXED == 0
109#define EASE8(x) (FADE(x) )
110#define EASE16(x) (FADE(x) )
112#define EASE8(x) (ease8InOutQuad(x) )
113#define EASE16(x) (ease16InOutQuad(x))
120#define FADE logfade12
121#define LERP(a,b,u) lerp15by12(a,b,u)
123#define FADE(x) scale16(x,x)
124#define LERP(a,b,u) lerp15by16(a,b,u)
130static int16_t
inline __attribute__((always_inline)) grad16(uint8_t hash, int16_t x, int16_t y, int16_t z) {
133 case 0:
return (( x) + ( y))>>1;
134 case 1:
return ((-x) + ( y))>>1;
135 case 2:
return (( x) + (-y))>>1;
136 case 3:
return ((-x) + (-y))>>1;
137 case 4:
return (( x) + ( z))>>1;
138 case 5:
return ((-x) + ( z))>>1;
139 case 6:
return (( x) + (-z))>>1;
140 case 7:
return ((-x) + (-z))>>1;
141 case 8:
return (( y) + ( z))>>1;
142 case 9:
return ((-y) + ( z))>>1;
143 case 10:
return (( y) + (-z))>>1;
144 case 11:
return ((-y) + (-z))>>1;
145 case 12:
return (( y) + ( x))>>1;
146 case 13:
return ((-y) + ( z))>>1;
147 case 14:
return (( y) + (-x))>>1;
148 case 15:
return ((-y) + (-z))>>1;
152 int16_t u = hash<8?x:y;
153 int16_t v = hash<4?y:hash==12||hash==14?x:z;
154 if(hash&1) { u = -u; }
155 if(hash&2) { v = -v; }
161static int16_t
inline __attribute__((always_inline)) grad16(uint8_t hash, int16_t x, int16_t y) {
164 if(hash < 4) { u = x; v = y; }
else { u = y; v = x; }
165 if(hash&1) { u = -u; }
166 if(hash&2) { v = -v; }
171static int16_t
inline __attribute__((always_inline)) grad16(uint8_t hash, int16_t x) {
174 if(hash > 8) { u=x;v=x; }
175 else if(hash < 4) { u=x;v=1; }
177 if(hash&1) { u = -u; }
178 if(hash&2) { v = -v; }
187static int8_t
inline __attribute__((always_inline)) selectBasedOnHashBit(uint8_t hash, uint8_t bitnumber, int8_t a, int8_t b) {
190 result = (hash & (1<<bitnumber)) ? a : b;
193 "mov %[result],%[a] \n\t"
194 "sbrs %[hash],%[bitnumber] \n\t"
195 "mov %[result],%[b] \n\t"
196 : [result]
"=r" (result)
198 [bitnumber]
"M" (bitnumber),
206static int8_t
inline __attribute__((always_inline)) grad8(uint8_t hash, int8_t x, int8_t y, int8_t z) {
209 case 0:
return (( x) + ( y))>>1;
210 case 1:
return ((-x) + ( y))>>1;
211 case 2:
return (( x) + (-y))>>1;
212 case 3:
return ((-x) + (-y))>>1;
213 case 4:
return (( x) + ( z))>>1;
214 case 5:
return ((-x) + ( z))>>1;
215 case 6:
return (( x) + (-z))>>1;
216 case 7:
return ((-x) + (-z))>>1;
217 case 8:
return (( y) + ( z))>>1;
218 case 9:
return ((-y) + ( z))>>1;
219 case 10:
return (( y) + (-z))>>1;
220 case 11:
return ((-y) + (-z))>>1;
221 case 12:
return (( y) + ( x))>>1;
222 case 13:
return ((-y) + ( z))>>1;
223 case 14:
return (( y) + (-x))>>1;
224 case 15:
return ((-y) + (-z))>>1;
232 u = selectBasedOnHashBit( hash, 3, y, x);
235 v = hash<4?y:hash==12||hash==14?x:z;
241 if( hash==12 || hash==14) {
249 if(hash&1) { u = -u; }
250 if(hash&2) { v = -v; }
256static int8_t
inline __attribute__((always_inline)) grad8(uint8_t hash, int8_t x, int8_t y)
269 if(hash&1) { u = -u; }
270 if(hash&2) { v = -v; }
275static int8_t
inline __attribute__((always_inline)) grad8(uint8_t hash, int8_t x)
292 if(hash&1) { u = -u; }
293 if(hash&2) { v = -v; }
300uint16_t logfade12(uint16_t val) {
304static int16_t
inline __attribute__((always_inline)) lerp15by12( int16_t a, int16_t b,
fract16 frac)
309 uint16_t delta = b - a;
310 uint16_t scaled =
scale16(delta,frac<<4);
313 uint16_t delta = a - b;
314 uint16_t scaled =
scale16(delta,frac<<4);
321static int8_t
inline __attribute__((always_inline)) lerp7by8( int8_t a, int8_t b,
fract8 frac)
330 uint8_t delta = b - a;
331 uint8_t scaled =
scale8( delta, frac);
334 uint8_t delta = a - b;
335 uint8_t scaled =
scale8( delta, frac);
344 uint8_t X = (x>>16)&0xFF;
345 uint8_t Y = (y>>16)&0xFF;
346 uint8_t Z = (z>>16)&0xFF;
351 uint8_t AB =
P(A+1)+Z;
352 uint8_t B =
P(X+1)+Y;
353 uint8_t BA =
P(B) + Z;
354 uint8_t BB =
P(B+1)+Z;
357 uint16_t u = x & 0xFFFF;
358 uint16_t v = y & 0xFFFF;
359 uint16_t w = z & 0xFFFF;
362 int16_t xx = (u >> 1) & 0x7FFF;
363 int16_t yy = (v >> 1) & 0x7FFF;
364 int16_t zz = (w >> 1) & 0x7FFF;
365 uint16_t N = 0x8000L;
367 u = EASE16(u); v = EASE16(v); w = EASE16(w);
371 int16_t X1 = LERP(grad16(
P(AA), xx, yy, zz), grad16(
P(BA), xx - N, yy, zz), u);
372 int16_t X2 = LERP(grad16(
P(AB), xx, yy-N, zz), grad16(
P(BB), xx - N, yy - N, zz), u);
373 int16_t X3 = LERP(grad16(
P(AA+1), xx, yy, zz-N), grad16(
P(BA+1), xx - N, yy, zz-N), u);
374 int16_t X4 = LERP(grad16(
P(AB+1), xx, yy-N, zz-N), grad16(
P(BB+1), xx - N, yy - N, zz - N), u);
376 int16_t Y1 = LERP(X1,X2,v);
377 int16_t Y2 = LERP(X3,X4,v);
379 int16_t ans = LERP(Y1,Y2,w);
384uint16_t
inoise16(uint32_t x, uint32_t y, uint32_t z) {
410 uint8_t B =
P(X+1)+Y;
415 uint16_t u = x & 0xFFFF;
416 uint16_t v = y & 0xFFFF;
419 int16_t xx = (u >> 1) & 0x7FFF;
420 int16_t yy = (v >> 1) & 0x7FFF;
421 uint16_t N = 0x8000L;
423 u = EASE16(u); v = EASE16(v);
425 int16_t X1 = LERP(grad16(
P(AA), xx, yy), grad16(
P(BA), xx - N, yy), u);
426 int16_t X2 = LERP(grad16(
P(AB), xx, yy-N), grad16(
P(BB), xx - N, yy - N), u);
428 int16_t ans = LERP(X1,X2,v);
460 uint16_t u = x & 0xFFFF;
463 int16_t xx = (u >> 1) & 0x7FFF;
464 uint16_t N = 0x8000L;
468 int16_t ans = LERP(grad16(
P(AA), xx), grad16(
P(BA), xx - N), u);
474 return ((uint32_t)((int32_t)
inoise16_raw(x) + 17308L)) << 1;
487 uint8_t AB =
P(A+1)+Z;
488 uint8_t B =
P(X+1)+Y;
489 uint8_t BA =
P(B) + Z;
490 uint8_t BB =
P(B+1)+Z;
498 int8_t xx = ((uint8_t)(x)>>1) & 0x7F;
499 int8_t yy = ((uint8_t)(y)>>1) & 0x7F;
500 int8_t zz = ((uint8_t)(z)>>1) & 0x7F;
503 u = EASE8(u); v = EASE8(v); w = EASE8(w);
505 int8_t X1 = lerp7by8(grad8(
P(AA), xx, yy, zz), grad8(
P(BA), xx - N, yy, zz), u);
506 int8_t X2 = lerp7by8(grad8(
P(AB), xx, yy-N, zz), grad8(
P(BB), xx - N, yy - N, zz), u);
507 int8_t X3 = lerp7by8(grad8(
P(AA+1), xx, yy, zz-N), grad8(
P(BA+1), xx - N, yy, zz-N), u);
508 int8_t X4 = lerp7by8(grad8(
P(AB+1), xx, yy-N, zz-N), grad8(
P(BB+1), xx - N, yy - N, zz - N), u);
510 int8_t Y1 = lerp7by8(X1,X2,v);
511 int8_t Y2 = lerp7by8(X3,X4,v);
513 int8_t ans = lerp7by8(Y1,Y2,w);
518uint8_t
inoise8(uint16_t x, uint16_t y, uint16_t z) {
522 uint8_t ans =
qadd8( n, n);
536 uint8_t B =
P(X+1)+Y;
545 int8_t xx = ((uint8_t)(x)>>1) & 0x7F;
546 int8_t yy = ((uint8_t)(y)>>1) & 0x7F;
549 u = EASE8(u); v = EASE8(v);
551 int8_t X1 = lerp7by8(grad8(
P(AA), xx, yy), grad8(
P(BA), xx - N, yy), u);
552 int8_t X2 = lerp7by8(grad8(
P(AB), xx, yy-N), grad8(
P(BB), xx - N, yy - N), u);
554 int8_t ans = lerp7by8(X1,X2,v);
566 uint8_t ans =
qadd8( n, n);
586 int8_t xx = ((uint8_t)(x)>>1) & 0x7F;
591 int8_t ans = lerp7by8(grad8(
P(AA), xx), grad8(
P(BA), xx - N), u);
599 uint8_t ans =
qadd8(n,n);
617void fill_raw_noise8(uint8_t *pData, uint8_t num_points, uint8_t octaves, uint16_t x,
int scale, uint16_t time) {
619 uint32_t scx = scale;
620 for(
int o = 0; o < octaves; ++o) {
621 for(
int i = 0,xx=_xx; i < num_points; ++i, xx+=scx) {
630void fill_raw_noise16into8(uint8_t *pData, uint8_t num_points, uint8_t octaves, uint32_t x,
int scale, uint32_t time) {
632 uint32_t scx = scale;
633 for(
int o = 0; o < octaves; ++o) {
634 for(
int i = 0,xx=_xx; i < num_points; ++i, xx+=scx) {
635 uint32_t accum = (
inoise16(xx,time))>>o;
636 accum += (pData[i]<<8);
637 if(accum > 65535) { accum = 65535; }
660void fill_raw_2dnoise8(uint8_t *pData,
int width,
int height, uint8_t octaves,
q44 freq44,
fract8 amplitude,
int skip, uint16_t x, int16_t scalex, uint16_t y, int16_t scaley, uint16_t time) {
662 fill_raw_2dnoise8(pData, width, height, octaves-1, freq44, amplitude, skip+1, x*freq44, freq44 * scalex, y*freq44, freq44 * scaley, time);
671 fract8 invamp = 255-amplitude;
673 for(
int i = 0; i < height; ++i, y+=scaley) {
674 uint8_t *pRow = pData + (i*width);
676 for(
int j = 0; j < width; ++j, xx+=scalex) {
677 uint8_t noise_base =
inoise8(xx,y,time);
678 noise_base = (0x80 & noise_base) ? (noise_base - 127) : (127 - noise_base);
679 noise_base =
scale8(noise_base<<1,amplitude);
681 pRow[j] =
scale8(pRow[j],invamp) + noise_base;
683 for(
int ii = i; ii<(i+skip) && ii<height; ++ii) {
684 uint8_t *pRow = pData + (ii*width);
685 for(
int jj=j; jj<(j+skip) && jj<width; ++jj) {
686 pRow[jj] =
scale8(pRow[jj],invamp) + noise_base;
694void fill_raw_2dnoise8(uint8_t *pData,
int width,
int height, uint8_t octaves, uint16_t x,
int scalex, uint16_t y,
int scaley, uint16_t time) {
695 fill_raw_2dnoise8(pData, width, height, octaves,
q44(2,0), 128, 1, x, scalex, y, scaley, time);
698void fill_raw_2dnoise16(uint16_t *pData,
int width,
int height, uint8_t octaves,
q88 freq88,
fract16 amplitude,
int skip, uint32_t x, int32_t scalex, uint32_t y, int32_t scaley, uint32_t time) {
700 fill_raw_2dnoise16(pData, width, height, octaves-1, freq88, amplitude, skip, x *freq88 , scalex *freq88, y * freq88, scaley * freq88, time);
708 fract16 invamp = 65535-amplitude;
709 for(
int i = 0; i < height; i+=skip, y+=scaley) {
710 uint16_t *pRow = pData + (i*width);
711 for(
int j = 0,xx=x; j < width; j+=skip, xx+=scalex) {
712 uint16_t noise_base =
inoise16(xx,y,time);
713 noise_base = (0x8000 & noise_base) ? noise_base - (32767) : 32767 - noise_base;
714 noise_base =
scale16(noise_base<<1, amplitude);
716 pRow[j] =
scale16(pRow[j],invamp) + noise_base;
718 for(
int ii = i; ii<(i+skip) && ii<height; ++ii) {
719 uint16_t *pRow = pData + (ii*width);
720 for(
int jj=j; jj<(j+skip) && jj<width; ++jj) {
721 pRow[jj] =
scale16(pRow[jj],invamp) + noise_base;
736void fill_raw_2dnoise16into8(uint8_t *pData,
int width,
int height, uint8_t octaves,
q44 freq44,
fract8 amplitude,
int skip, uint32_t x, int32_t scalex, uint32_t y, int32_t scaley, uint32_t time) {
738 fill_raw_2dnoise16into8(pData, width, height, octaves-1, freq44, amplitude, skip+1, x*freq44, scalex *freq44, y*freq44, scaley * freq44, time);
747 fract8 invamp = 255-amplitude;
748 for(
int i = 0; i < height; i+=skip, y+=scaley) {
749 uint8_t *pRow = pData + (i*width);
751 for(
int j = 0; j < width; j+=skip, xx+=scalex) {
752 uint16_t noise_base =
inoise16(xx,y,time);
753 noise_base = (0x8000 & noise_base) ? noise_base - (32767) : 32767 - noise_base;
754 noise_base =
scale8(noise_base>>7,amplitude);
756 pRow[j] =
qadd8(
scale8(pRow[j],invamp),noise_base);
758 for(
int ii = i; ii<(i+skip) && ii<height; ++ii) {
759 uint8_t *pRow = pData + (ii*width);
760 for(
int jj=j; jj<(j+skip) && jj<width; ++jj) {
761 pRow[jj] =
scale8(pRow[jj],invamp) + noise_base;
769void fill_raw_2dnoise16into8(uint8_t *pData,
int width,
int height, uint8_t octaves, uint32_t x,
int scalex, uint32_t y,
int scaley, uint32_t time) {
770 fill_raw_2dnoise16into8(pData, width, height, octaves,
q44(2,0), 171, 1, x, scalex, y, scaley, time);
774 uint8_t octaves, uint16_t x,
int scale,
775 uint8_t hue_octaves, uint16_t hue_x,
int hue_scale,
778 if (num_leds <= 0)
return;
780 for (
int j = 0; j < num_leds; j += 255) {
781 const int LedsRemaining = num_leds - j;
782 const int LedsPer = LedsRemaining > 255 ? 255 : LedsRemaining;
784 if (LedsPer <= 0)
continue;
785 VARIABLE_LENGTH_ARRAY(uint8_t, V, LedsPer);
786 VARIABLE_LENGTH_ARRAY(uint8_t, H, LedsPer);
788 memset(V, 0, LedsPer);
789 memset(H, 0, LedsPer);
794 for (
int i = 0; i < LedsPer; ++i) {
795 leds[i + j] =
CHSV(H[i], 255, V[i]);
801 uint8_t octaves, uint16_t x,
int scale,
802 uint8_t hue_octaves, uint16_t hue_x,
int hue_scale,
803 uint16_t time, uint8_t hue_shift) {
805 if (num_leds <= 0)
return;
807 for (
int j = 0; j < num_leds; j += 255) {
808 const int LedsRemaining = num_leds - j;
809 const int LedsPer = LedsRemaining > 255 ? 255 : LedsRemaining;
810 if (LedsPer <= 0)
continue;
811 VARIABLE_LENGTH_ARRAY(uint8_t, V, LedsPer);
812 VARIABLE_LENGTH_ARRAY(uint8_t, H, LedsPer);
814 memset(V, 0, LedsPer);
815 memset(H, 0, LedsPer);
820 for (
int i = 0; i < LedsPer; ++i) {
821 leds[i + j] =
CHSV(H[i] + hue_shift, 255, V[i]);
827 uint8_t octaves, uint16_t x,
int xscale, uint16_t y,
int yscale, uint16_t time,
828 uint8_t hue_octaves, uint16_t hue_x,
int hue_xscale, uint16_t hue_y, uint16_t hue_yscale,uint16_t hue_time,
bool blend) {
829 const size_t array_size = (size_t)height * width;
830 if (array_size <= 0)
return;
831 VARIABLE_LENGTH_ARRAY(uint8_t, V, array_size);
832 VARIABLE_LENGTH_ARRAY(uint8_t, H, array_size);
834 memset(V,0,height*width);
835 memset(H,0,height*width);
838 fill_raw_2dnoise8((uint8_t*)H,width,height,hue_octaves,hue_x,hue_xscale,hue_y,hue_yscale,hue_time);
842 for(
int i = 0; i < height; ++i) {
844 for(
int j = 0; j < width; ++j) {
845 CRGB led(
CHSV(H[(h1-i)*width + (w1-j)], 255, V[i*width + j]));
848 if(serpentine && (i & 0x1)) {
854 CRGB temp = leds[wb+pos];
857 leds[wb+pos] = temp + led;
867 uint8_t octaves, uint32_t x,
int xscale, uint32_t y,
int yscale, uint32_t time,
868 uint8_t hue_octaves, uint16_t hue_x,
int hue_xscale, uint16_t hue_y, uint16_t hue_yscale,uint16_t hue_time,
bool blend, uint16_t hue_shift) {
870 VARIABLE_LENGTH_ARRAY(uint8_t, V, height*width);
871 VARIABLE_LENGTH_ARRAY(uint8_t, H, height*width);
873 memset(V,0,height*width);
874 memset(H,0,height*width);
876 fill_raw_2dnoise16into8((uint8_t*)V,width,height,octaves,
q44(2,0),171,1,x,xscale,y,yscale,time);
879 fill_raw_2dnoise8((uint8_t*)H,width,height,hue_octaves,hue_x,hue_xscale,hue_y,hue_yscale,hue_time);
886 for(
int i = 0; i < height; ++i) {
888 for(
int j = 0; j < width; ++j) {
889 CRGB led(
CHSV(hue_shift + (H[(h1-i)*width + (w1-j)]), 196, V[i*width + j]));
892 if(serpentine && (i & 0x1)) {
897 leds[wb+pos] >>= 1; leds[wb+pos] += (led>>=1);
907#pragma GCC diagnostic pop
central include file for FastLED, defines the CFastLED class/object
Template class for representing fractional ints.
#define FL_PROGMEM
PROGMEM keyword for storage.
CRGB blend(const CRGB &p1, const CRGB &p2, fract8 amountOfP2)
Computes a new color blended some fraction of the way between two other colors.
qfx< uint8_t, 4, 4 > q44
A 4.4 integer (4 bits integer, 4 bits fraction)
uint8_t fract8
ANSI: unsigned short _Fract.
uint16_t fract16
ANSI: unsigned _Fract.
LIB8STATIC_ALWAYS_INLINE uint8_t qadd8(uint8_t i, uint8_t j)
Add one byte to another, saturating at 0xFF.
LIB8STATIC_ALWAYS_INLINE int8_t avg7(int8_t i, int8_t j)
Calculate an integer average of two signed 7-bit integers (int8_t).
void fill_raw_noise8(uint8_t *pData, uint8_t num_points, uint8_t octaves, uint16_t x, int scale, uint16_t time)
Fill a 1D 8-bit buffer with noise, using inoise8()
void fill_raw_2dnoise16into8(uint8_t *pData, int width, int height, uint8_t octaves, q44 freq44, fract8 amplitude, int skip, uint32_t x, int32_t scalex, uint32_t y, int32_t scaley, uint32_t time)
Fill a 2D 8-bit buffer with noise, using inoise16()
void fill_raw_2dnoise8(uint8_t *pData, int width, int height, uint8_t octaves, q44 freq44, fract8 amplitude, int skip, uint16_t x, int16_t scalex, uint16_t y, int16_t scaley, uint16_t time)
Fill a 2D 8-bit buffer with noise, using inoise8()
void fill_2dnoise8(CRGB *leds, int width, int height, bool serpentine, uint8_t octaves, uint16_t x, int xscale, uint16_t y, int yscale, uint16_t time, uint8_t hue_octaves, uint16_t hue_x, int hue_xscale, uint16_t hue_y, uint16_t hue_yscale, uint16_t hue_time, bool blend)
Fill an LED matrix with random colors, using 8-bit noise.
void fill_2dnoise16(CRGB *leds, int width, int height, bool serpentine, uint8_t octaves, uint32_t x, int xscale, uint32_t y, int yscale, uint32_t time, uint8_t hue_octaves, uint16_t hue_x, int hue_xscale, uint16_t hue_y, uint16_t hue_yscale, uint16_t hue_time, bool blend, uint16_t hue_shift)
Fill an LED matrix with random colors, using 16-bit noise.
void fill_noise8(CRGB *leds, int num_leds, uint8_t octaves, uint16_t x, int scale, uint8_t hue_octaves, uint16_t hue_x, int hue_scale, uint16_t time)
Fill an LED array with random colors, using 8-bit noise.
void fill_noise16(CRGB *leds, int num_leds, uint8_t octaves, uint16_t x, int scale, uint8_t hue_octaves, uint16_t hue_x, int hue_scale, uint16_t time, uint8_t hue_shift)
Fill an LED array with random colors, using 16-bit noise.
void fill_raw_2dnoise16(uint16_t *pData, int width, int height, uint8_t octaves, q88 freq88, fract16 amplitude, int skip, uint32_t x, int32_t scalex, uint32_t y, int32_t scaley, uint32_t time)
Fill a 2D 16-bit buffer with noise, using inoise16()
void fill_raw_noise16into8(uint8_t *pData, uint8_t num_points, uint8_t octaves, uint32_t x, int scale, uint32_t time)
Fill a 1D 8-bit buffer with noise, using inoise16()
int8_t inoise8_raw(uint16_t x, uint16_t y, uint16_t z)
8-bit, fixed point implementation of Perlin's noise without scaling.
int16_t inoise16_raw(uint32_t x, uint32_t y, uint32_t z)
16-bit, fixed point implementation of Perlin's noise without scaling.
uint16_t inoise16(uint32_t x, uint32_t y, uint32_t z)
16-bit, fixed point implementation of Perlin's noise.
uint8_t inoise8(uint16_t x, uint16_t y, uint16_t z)
8-Bit, fixed point implementation of Perlin's noise.
LIB8STATIC uint16_t scale16(uint16_t i, fract16 scale)
Scale a 16-bit unsigned value by an 16-bit value, which is treated as the numerator of a fraction who...
LIB8STATIC_ALWAYS_INLINE uint8_t scale8(uint8_t i, fract8 scale)
Scale one byte by a second one, which is treated as the numerator of a fraction whose denominator is ...
#define FASTLED_NAMESPACE_END
End of the FastLED namespace.
#define FASTLED_NAMESPACE_BEGIN
Start of the FastLED namespace.
#define P(x)
Reads a single byte from the p array.
Representation of an HSV pixel (hue, saturation, value (aka brightness)).
Representation of an RGB pixel (Red, Green, Blue)
CRGB & nscale8(uint8_t scaledown)
Scale down a RGB to N/256ths of its current brightness, using "plain math" dimming rules.