36 {
37 int X, Y;
38 fl::i16 x16, y16;
41 X &= 255;
42 Y &= 255;
43
44
45
46 fl::i32 u =
fade(x16, fade_lut);
47 fl::i32 v =
fade(y16, fade_lut);
48
49 int A = perm[X & 255] + Y;
50 int AA = perm[A & 255];
51 int AB = perm[(A + 1) & 255];
52 int B = perm[(X + 1) & 255] + Y;
53 int BA = perm[
B & 255];
54 int BB = perm[(
B + 1) & 255];
55
56
57 fl::i32 g00 =
grad_i16(perm[AA & 255], x16, y16);
61
62
63 fl::i32 lerp0 =
lerp(u, g00, g10);
64 fl::i32 lerp1 =
lerp(u, g01, g11);
66
68}
FL_DISABLE_WARNING_PUSH unsigned char * B
expected< T, E > result
Alias for expected (Rust-style naming)
static FASTLED_FORCE_INLINE void floor_frac_i16(fl::i32 fp16, int &ifloor, fl::i16 &frac16)
static constexpr fl::i32 HP_ONE_I16
static FASTLED_FORCE_INLINE fl::i32 grad_i16(int hash, fl::i16 x, fl::i16 y)
static FASTLED_FORCE_INLINE fl::i32 lerp(fl::i32 t, fl::i32 a, fl::i32 b)
static FASTLED_FORCE_INLINE fl::i32 fade(fl::i16 t, const fl::i32 *table)