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
use super::*;

/// Directivity of spherical wave
pub struct Sphere {}

impl Directivity for Sphere {
    fn directivity(_: f64) -> f64 {
        1.
    }

    fn directivity_from_tr(_: &Transducer, _: &Vector3) -> f64 {
        1.
    }
}

#[cfg(test)]
mod tests {
    use crate::geometry::{Quaternion, UnitQuaternion};

    use super::*;

    use rand::prelude::*;

    #[test]
    fn test_directivity() {
        let mut rng = rand::thread_rng();
        assert_eq!(1.0, Sphere::directivity(rng.gen()));
    }

    #[rstest::fixture]
    fn tr() -> Transducer {
        let mut rng = rand::thread_rng();
        Transducer::new(
            rng.gen::<u8>() as usize,
            Vector3::new(rng.gen(), rng.gen(), rng.gen()),
            UnitQuaternion::from_quaternion(Quaternion::new(
                rng.gen(),
                rng.gen(),
                rng.gen(),
                rng.gen(),
            )),
        )
    }

    #[rstest::rstest]
    #[test]
    #[case::dir_x(1., Vector3::x())]
    #[case::dir_y(1., Vector3::y())]
    #[case::dir_z(1., Vector3::z())]
    fn test_directivity_sphere_from_tr(
        #[case] expected: f64,
        #[case] target: Vector3,
        tr: Transducer,
    ) {
        assert_eq!(expected, Sphere::directivity_from_tr(&tr, &target));
    }
}