From a27855c3384436e5045b19e25bdb24d0381a6794 Mon Sep 17 00:00:00 2001 From: andrei Date: Tue, 24 Nov 2020 14:58:09 +0300 Subject: [PATCH 1/2] Renamed stack and concatenate to be compliant with numpy naming. --- src/lib.rs | 1 - src/stacking.rs | 94 ++++++++++++++++++++++++----------------------- tests/stacking.rs | 35 ++++-------------- 3 files changed, 55 insertions(+), 75 deletions(-) diff --git a/src/lib.rs b/src/lib.rs index 1b7590da1..1775d07a7 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -132,7 +132,6 @@ use crate::iterators::{ElementsBase, ElementsBaseMut, Iter, IterMut, Lanes, Lane pub use crate::arraytraits::AsArray; pub use crate::linalg_traits::{LinalgScalar, NdFloat}; -#[allow(deprecated)] pub use crate::stacking::{concatenate, stack, stack_new_axis}; pub use crate::impl_views::IndexLonger; diff --git a/src/stacking.rs b/src/stacking.rs index 3e3b1afd8..864c40998 100644 --- a/src/stacking.rs +++ b/src/stacking.rs @@ -9,6 +9,42 @@ use crate::error::{from_kind, ErrorKind, ShapeError}; use crate::imp_prelude::*; +/// Stack arrays along the new axis. +/// +/// ***Errors*** if the arrays have mismatching shapes. +/// ***Errors*** if `arrays` is empty, if `axis` is out of bounds, +/// if the result is larger than is possible to represent. +/// +/// ``` +/// extern crate ndarray; +/// +/// use ndarray::{arr2, arr3, stack, Axis}; +/// +/// # fn main() { +/// +/// let a = arr2(&[[2., 2.], +/// [3., 3.]]); +/// assert!( +/// stack(Axis(0), &[a.view(), a.view()]) +/// == Ok(arr3(&[[[2., 2.], +/// [3., 3.]], +/// [[2., 2.], +/// [3., 3.]]])) +/// ); +/// # } +/// ``` +pub fn stack( + axis: Axis, + arrays: &[ArrayView], +) -> Result, ShapeError> +where + A: Copy, + D: Dimension, + D::Larger: RemoveAxis, +{ + stack_new_axis(axis, arrays) +} + /// Concatenate arrays along the given axis. /// /// ***Errors*** if the arrays have mismatching shapes, apart from along `axis`. @@ -17,23 +53,20 @@ use crate::imp_prelude::*; /// if the result is larger than is possible to represent. /// /// ``` -/// use ndarray::{arr2, Axis, stack}; +/// use ndarray::{arr2, Axis, concatenate}; /// /// let a = arr2(&[[2., 2.], /// [3., 3.]]); /// assert!( -/// stack(Axis(0), &[a.view(), a.view()]) +/// concatenate(Axis(0), &[a.view(), a.view()]) /// == Ok(arr2(&[[2., 2.], /// [3., 3.], /// [2., 2.], /// [3., 3.]])) /// ); /// ``` -#[deprecated( - since = "0.13.2", - note = "Please use the `concatenate` function instead" -)] -pub fn stack(axis: Axis, arrays: &[ArrayView]) -> Result, ShapeError> +#[allow(deprecated)] +pub fn concatenate(axis: Axis, arrays: &[ArrayView]) -> Result, ShapeError> where A: Copy, D: RemoveAxis, @@ -77,35 +110,6 @@ where Ok(res) } -/// Concatenate arrays along the given axis. -/// -/// ***Errors*** if the arrays have mismatching shapes, apart from along `axis`. -/// (may be made more flexible in the future).
-/// ***Errors*** if `arrays` is empty, if `axis` is out of bounds, -/// if the result is larger than is possible to represent. -/// -/// ``` -/// use ndarray::{arr2, Axis, concatenate}; -/// -/// let a = arr2(&[[2., 2.], -/// [3., 3.]]); -/// assert!( -/// concatenate(Axis(0), &[a.view(), a.view()]) -/// == Ok(arr2(&[[2., 2.], -/// [3., 3.], -/// [2., 2.], -/// [3., 3.]])) -/// ); -/// ``` -#[allow(deprecated)] -pub fn concatenate(axis: Axis, arrays: &[ArrayView]) -> Result, ShapeError> -where - A: Copy, - D: RemoveAxis, -{ - stack(axis, arrays) -} - /// Stack arrays along the new axis. /// /// ***Errors*** if the arrays have mismatching shapes. @@ -173,7 +177,7 @@ where Ok(res) } -/// Concatenate arrays along the given axis. +/// Stack arrays along the new axis. /// /// Uses the [`stack`][1] function, calling `ArrayView::from(&a)` on each /// argument `a`. @@ -183,7 +187,9 @@ where /// ***Panics*** if the `stack` function would return an error. /// /// ``` -/// use ndarray::{arr2, stack, Axis}; +/// extern crate ndarray; +/// +/// use ndarray::{arr2, arr3, stack, Axis}; /// /// # fn main() { /// @@ -191,17 +197,13 @@ where /// [3., 3.]]); /// assert!( /// stack![Axis(0), a, a] -/// == arr2(&[[2., 2.], -/// [3., 3.], -/// [2., 2.], -/// [3., 3.]]) +/// == arr3(&[[[2., 2.], +/// [3., 3.]], +/// [[2., 2.], +/// [3., 3.]]]) /// ); /// # } /// ``` -#[deprecated( - since = "0.13.2", - note = "Please use the `concatenate!` macro instead" -)] #[macro_export] macro_rules! stack { ($axis:expr, $( $array:expr ),+ ) => { diff --git a/tests/stacking.rs b/tests/stacking.rs index 94077def2..032525ffa 100644 --- a/tests/stacking.rs +++ b/tests/stacking.rs @@ -1,31 +1,7 @@ -#![allow(deprecated)] - use ndarray::{arr2, arr3, aview1, concatenate, stack, Array2, Axis, ErrorKind, Ix1}; #[test] fn concatenating() { - let a = arr2(&[[2., 2.], [3., 3.]]); - let b = ndarray::stack(Axis(0), &[a.view(), a.view()]).unwrap(); - assert_eq!(b, arr2(&[[2., 2.], [3., 3.], [2., 2.], [3., 3.]])); - - let c = stack![Axis(0), a, b]; - assert_eq!( - c, - arr2(&[[2., 2.], [3., 3.], [2., 2.], [3., 3.], [2., 2.], [3., 3.]]) - ); - - let d = stack![Axis(0), a.row(0), &[9., 9.]]; - assert_eq!(d, aview1(&[2., 2., 9., 9.])); - - let res = ndarray::stack(Axis(1), &[a.view(), c.view()]); - assert_eq!(res.unwrap_err().kind(), ErrorKind::IncompatibleShape); - - let res = ndarray::stack(Axis(2), &[a.view(), c.view()]); - assert_eq!(res.unwrap_err().kind(), ErrorKind::OutOfBounds); - - let res: Result, _> = ndarray::stack(Axis(0), &[]); - assert_eq!(res.unwrap_err().kind(), ErrorKind::Unsupported); - let a = arr2(&[[2., 2.], [3., 3.]]); let b = ndarray::concatenate(Axis(0), &[a.view(), a.view()]).unwrap(); assert_eq!(b, arr2(&[[2., 2.], [3., 3.], [2., 2.], [3., 3.]])); @@ -52,16 +28,19 @@ fn concatenating() { #[test] fn stacking() { let a = arr2(&[[2., 2.], [3., 3.]]); - let b = ndarray::stack_new_axis(Axis(0), &[a.view(), a.view()]).unwrap(); + let b = ndarray::stack(Axis(0), &[a.view(), a.view()]).unwrap(); assert_eq!(b, arr3(&[[[2., 2.], [3., 3.]], [[2., 2.], [3., 3.]]])); + let c = stack![Axis(0), a, a]; + assert_eq!(c, arr3(&[[[2., 2.], [3., 3.]], [[2., 2.], [3., 3.]]])); + let c = arr2(&[[3., 2., 3.], [2., 3., 2.]]); - let res = ndarray::stack_new_axis(Axis(1), &[a.view(), c.view()]); + let res = ndarray::stack(Axis(1), &[a.view(), c.view()]); assert_eq!(res.unwrap_err().kind(), ErrorKind::IncompatibleShape); - let res = ndarray::stack_new_axis(Axis(3), &[a.view(), a.view()]); + let res = ndarray::stack(Axis(3), &[a.view(), a.view()]); assert_eq!(res.unwrap_err().kind(), ErrorKind::OutOfBounds); - let res: Result, _> = ndarray::stack_new_axis::<_, Ix1>(Axis(0), &[]); + let res: Result, _> = ndarray::stack::<_, Ix1>(Axis(0), &[]); assert_eq!(res.unwrap_err().kind(), ErrorKind::Unsupported); } From 13dbaf1ab271403ebebf2fc12bc68d3548866fab Mon Sep 17 00:00:00 2001 From: andrei-papou Date: Tue, 24 Nov 2020 15:05:03 +0300 Subject: [PATCH 2/2] Removed allow deprecated macro from concatenate implementation. --- src/stacking.rs | 1 - 1 file changed, 1 deletion(-) diff --git a/src/stacking.rs b/src/stacking.rs index 864c40998..981f37ef3 100644 --- a/src/stacking.rs +++ b/src/stacking.rs @@ -65,7 +65,6 @@ where /// [3., 3.]])) /// ); /// ``` -#[allow(deprecated)] pub fn concatenate(axis: Axis, arrays: &[ArrayView]) -> Result, ShapeError> where A: Copy,