noise_functions/base/
cell_distance.rs

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
use crate::{base::impl_noise, from_fast_noise_lite::cell_distance_euclidean_squared, math::sqrt};

#[cfg(feature = "nightly-simd")]
use core::simd::{f32x2, f32x4};

use super::CustomCellDistance;

/// 2/3/4 dimensional noise of the distance to the closest cell.
#[derive(Debug, Clone, Copy, PartialEq)]
pub struct CellDistance {
    pub jitter: f32,
}

impl CellDistance {
    pub const fn jitter(mut self, jitter: f32) -> Self {
        self.jitter = jitter;
        self
    }
}

impl_noise!(234 CellDistance);

impl Default for CellDistance {
    fn default() -> Self {
        Self { jitter: 1.0 }
    }
}

impl CellDistance {
    #[inline]
    fn gen2(self, point: [f32; 2], seed: i32) -> f32 {
        // implementation from FastNoiseLite
        sqrt(cell_distance_euclidean_squared::gen2(self.jitter, point, seed)) * 2.0 - 1.0
    }

    #[inline]
    fn gen3(self, point: [f32; 3], seed: i32) -> f32 {
        // implementation from FastNoiseLite
        sqrt(cell_distance_euclidean_squared::gen3(self.jitter, point, seed)) * 2.0 - 1.0
    }

    #[inline]
    fn gen4(self, point: [f32; 4], seed: i32) -> f32 {
        CustomCellDistance::default().jitter(self.jitter).gen4(point, seed) * 2.0 - 1.0
    }

    #[inline]
    #[cfg(feature = "nightly-simd")]
    fn gen2a(self, point: f32x2, seed: i32) -> f32 {
        // implementation from FastNoiseLite
        sqrt(cell_distance_euclidean_squared::gen2a(self.jitter, point, seed)) * 2.0 - 1.0
    }

    #[inline]
    #[cfg(feature = "nightly-simd")]
    fn gen3a(self, point: f32x4, seed: i32) -> f32 {
        // implementation from FastNoiseLite
        sqrt(cell_distance_euclidean_squared::gen3a(self.jitter, point, seed)) * 2.0 - 1.0
    }

    #[inline]
    #[cfg(feature = "nightly-simd")]
    fn gen4a(self, point: f32x4, seed: i32) -> f32 {
        CustomCellDistance::default().jitter(self.jitter).gen4a(point, seed) * 2.0 - 1.0
    }
}