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
67
68
69
mod origin;

mod array_ref;
pub use self::array_ref::{ArrayRef, ArrayRefMut};

mod array;
pub use self::array::Array;
pub use self::array::EmptyArray;


#[cfg(test)]
mod tests {
    use ndarray::ArrayD;

    use crate::c_api::mts_sample_mapping_t;

    use super::*;
    use super::origin::get_data_origin;

    #[test]
    fn shape() {
        let array = Box::new(ArrayD::from_elem(vec![3, 4, 2], 1.0)) as Box<dyn Array>;
        let mut array = unsafe { ArrayRefMut::new(array.into()) };

        assert_eq!(array.as_raw().shape().unwrap(), [3, 4, 2]);
        array.as_raw_mut().reshape(&[12, 2]).unwrap();
        assert_eq!(array.as_raw().shape().unwrap(), [12, 2]);
        assert_eq!(array.as_array(), ArrayD::from_elem(vec![12, 2], 1.0));

        array.as_raw_mut().swap_axes(0, 1).unwrap();
        assert_eq!(array.as_raw().shape().unwrap(), [2, 12]);
    }

    #[test]
    fn create() {
        let array = Box::new(ArrayD::from_elem(vec![4, 2], 1.0)) as Box<dyn Array>;
        let array = unsafe { ArrayRef::from_raw(array.into()) };

        assert_eq!(get_data_origin(array.as_raw().origin().unwrap()).unwrap(), "rust.Box<dyn Array>");
        assert_eq!(array.as_array(), ArrayD::from_elem(vec![4, 2], 1.0));

        let other = unsafe { ArrayRef::from_raw(array.as_raw().create(&[5, 3, 7, 12]).unwrap()) };
        assert_eq!(other.as_raw().shape().unwrap(), [5, 3, 7, 12]);
        assert_eq!(get_data_origin(other.as_raw().origin().unwrap()).unwrap(), "rust.Box<dyn Array>");
        assert_eq!(other.as_array(), ArrayD::from_elem(vec![5, 3, 7, 12], 0.0));
    }

    #[test]
    fn move_samples_from() {
        let array = Box::new(ArrayD::from_elem(vec![3, 2, 2, 4], 1.0)) as Box<dyn Array>;
        let array = unsafe { ArrayRef::from_raw(array.into()) };

        let mut other = unsafe { ArrayRefMut::new(array.as_raw().create(&[1, 2, 2, 8]).unwrap()) };
        assert_eq!(other.as_array(), ArrayD::from_elem(vec![1, 2, 2, 8], 0.0));

        let mapping = mts_sample_mapping_t {
            output: 0,
            input: 1,
        };
        other.as_raw_mut().move_samples_from(array.as_raw(), &[mapping], 2..6).unwrap();
        let expected = ArrayD::from_shape_vec(vec![1, 2, 2, 8], vec![
                0.0, 0.0, 1.0, 1.0, 1.0, 1.0, 0.0, 0.0,
                0.0, 0.0, 1.0, 1.0, 1.0, 1.0, 0.0, 0.0,
                0.0, 0.0, 1.0, 1.0, 1.0, 1.0, 0.0, 0.0,
                0.0, 0.0, 1.0, 1.0, 1.0, 1.0, 0.0, 0.0,
        ]).unwrap();
        assert_eq!(other.as_array(), expected);
    }
}