forked from M-Labs/nalgebra
Add doc-tests for reshape_generic.
This commit is contained in:
parent
d7cb138e22
commit
e89a26cbd0
@ -819,10 +819,55 @@ where
|
|||||||
R: Dim,
|
R: Dim,
|
||||||
C: Dim,
|
C: Dim,
|
||||||
{
|
{
|
||||||
/// Reshapes `self` in-place such that it has dimensions `new_nrows × new_ncols`.
|
/// Reshapes `self` such that it has dimensions `new_nrows × new_ncols`.
|
||||||
///
|
///
|
||||||
/// The values are not copied or moved. This function will panic if dynamic sizes are provided
|
/// This will reinterpret `self` as if it is a matrix with `new_nrows` rows and `new_ncols`
|
||||||
/// and not compatible.
|
/// columns. The arrangements of the component in the output matrix are the same as what
|
||||||
|
/// would be obtained by `Matrix::from_slice_generic(self.as_slice(), new_nrows, new_ncols)`.
|
||||||
|
///
|
||||||
|
/// If `self` is a dynamically-sized matrix, then its components are neither copied nor moved.
|
||||||
|
/// If `self` is staticyll-sized, then a copy may happen in some situations.
|
||||||
|
/// This function will panic if the given dimensions are such that the number of elements of
|
||||||
|
/// the input matrix are not equal to the number of elements of the output matrix.
|
||||||
|
///
|
||||||
|
/// # Examples
|
||||||
|
///
|
||||||
|
/// ```
|
||||||
|
/// # use nalgebra::{Matrix3x2, Matrix2x3, DMatrix, U2, U3, Dynamic};
|
||||||
|
///
|
||||||
|
/// let m1 = Matrix2x3::new(
|
||||||
|
/// 1.1, 1.2, 1.3,
|
||||||
|
/// 2.1, 2.2, 2.3
|
||||||
|
/// );
|
||||||
|
/// let m2 = Matrix3x2::new(
|
||||||
|
/// 1.1, 2.2,
|
||||||
|
/// 2.1, 1.3,
|
||||||
|
/// 1.2, 2.3
|
||||||
|
/// );
|
||||||
|
/// let reshaped = m1.reshape_generic(U3, U2);
|
||||||
|
/// assert_eq!(reshaped, m2);
|
||||||
|
///
|
||||||
|
/// let dm1 = DMatrix::from_row_slice(
|
||||||
|
/// 4,
|
||||||
|
/// 3,
|
||||||
|
/// &[
|
||||||
|
/// 1.0, 0.0, 0.0,
|
||||||
|
/// 0.0, 0.0, 1.0,
|
||||||
|
/// 0.0, 0.0, 0.0,
|
||||||
|
/// 0.0, 1.0, 0.0
|
||||||
|
/// ],
|
||||||
|
/// );
|
||||||
|
/// let dm2 = DMatrix::from_row_slice(
|
||||||
|
/// 6,
|
||||||
|
/// 2,
|
||||||
|
/// &[
|
||||||
|
/// 1.0, 0.0, 0.0, 0.0, 0.0, 1.0,
|
||||||
|
/// 0.0, 0.0, 0.0, 0.0, 1.0, 0.0
|
||||||
|
/// ],
|
||||||
|
/// );
|
||||||
|
/// let reshaped = dm1.reshape_generic(Dynamic::new(6), Dynamic::new(2));
|
||||||
|
/// assert_eq!(reshaped, dm2);
|
||||||
|
/// ```
|
||||||
pub fn reshape_generic<R2, C2>(
|
pub fn reshape_generic<R2, C2>(
|
||||||
self,
|
self,
|
||||||
new_nrows: R2,
|
new_nrows: R2,
|
||||||
|
Loading…
Reference in New Issue
Block a user