forked from M-Labs/nalgebra
Add Matrix::try_polar that returns Option and make Matrix::polar not return Option
This commit is contained in:
parent
43c1f8fb9d
commit
cc10b67dd1
@ -188,13 +188,37 @@ impl<T: ComplexField, R: Dim, C: Dim, S: Storage<T, R, C>> Matrix<T, R, C, S> {
|
|||||||
SVD::try_new_unordered(self.into_owned(), compute_u, compute_v, eps, max_niter)
|
SVD::try_new_unordered(self.into_owned(), compute_u, compute_v, eps, max_niter)
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Attempts to compute the Polar Decomposition of a `matrix` (indirectly uses SVD)
|
/// Computes the Polar Decomposition of a `matrix` (indirectly uses SVD).
|
||||||
|
pub fn polar(self) -> (OMatrix<T, R, R>, OMatrix<T, R, C>)
|
||||||
|
where
|
||||||
|
R: DimMin<C>,
|
||||||
|
DimMinimum<R, C>: DimSub<U1>, // for Bidiagonal.
|
||||||
|
DefaultAllocator: Allocator<T, R, C>
|
||||||
|
+ Allocator<T, DimMinimum<R, C>, R>
|
||||||
|
+ Allocator<T, DimMinimum<R, C>>
|
||||||
|
+ Allocator<T, R, R>
|
||||||
|
+ Allocator<T, DimMinimum<R, C>, DimMinimum<R, C>>
|
||||||
|
+ Allocator<T, C>
|
||||||
|
+ Allocator<T, R>
|
||||||
|
+ Allocator<T, DimDiff<DimMinimum<R, C>, U1>>
|
||||||
|
+ Allocator<T, DimMinimum<R, C>, C>
|
||||||
|
+ Allocator<T, R, DimMinimum<R, C>>
|
||||||
|
+ Allocator<T, DimMinimum<R, C>>
|
||||||
|
+ Allocator<T::RealField, DimMinimum<R, C>>
|
||||||
|
+ Allocator<T::RealField, DimDiff<DimMinimum<R, C>, U1>>,
|
||||||
|
{
|
||||||
|
SVD::new_unordered(self.into_owned(), true, true)
|
||||||
|
.to_polar()
|
||||||
|
.unwrap()
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Attempts to compute the Polar Decomposition of a `matrix` (indirectly uses SVD).
|
||||||
///
|
///
|
||||||
/// # Arguments
|
/// # Arguments
|
||||||
///
|
///
|
||||||
/// * `eps` − tolerance used to determine when a value converged to 0.
|
/// * `eps` − tolerance used to determine when a value converged to 0 when computing the SVD.
|
||||||
/// * `max_niter` − maximum total number of iterations performed by the algorithm
|
/// * `max_niter` − maximum total number of iterations performed by the SVD computation algorithm.
|
||||||
pub fn polar(
|
pub fn try_polar(
|
||||||
self,
|
self,
|
||||||
eps: T::RealField,
|
eps: T::RealField,
|
||||||
max_niter: usize,
|
max_niter: usize,
|
||||||
|
@ -642,10 +642,10 @@ where
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// converts SVD results to Polar decomposition form of the original Matrix
|
/// converts SVD results to Polar decomposition form of the original Matrix: `A = P' * U`.
|
||||||
/// A = P' * U
|
///
|
||||||
/// The polar decomposition used here is Left Polar Decomposition (or Reverse Polar Decomposition)
|
/// The polar decomposition used here is Left Polar Decomposition (or Reverse Polar Decomposition)
|
||||||
/// Returns None if the SVD hasn't been calculated
|
/// Returns None if the singular vectors of the SVD haven't been calculated
|
||||||
pub fn to_polar(&self) -> Option<(OMatrix<T, R, R>, OMatrix<T, R, C>)>
|
pub fn to_polar(&self) -> Option<(OMatrix<T, R, R>, OMatrix<T, R, C>)>
|
||||||
where
|
where
|
||||||
DefaultAllocator: Allocator<T, R, C> //result
|
DefaultAllocator: Allocator<T, R, C> //result
|
||||||
|
Loading…
Reference in New Issue
Block a user