pub struct Lu<const D: usize> { /* private fields */ }Expand description
LU decomposition (PA = LU) with partial pivoting.
Implementations§
Source§impl<const D: usize> Lu<D>
impl<const D: usize> Lu<D>
Sourcepub fn solve_vec(&self, b: Vector<D>) -> Result<Vector<D>, LaError>
pub fn solve_vec(&self, b: Vector<D>) -> Result<Vector<D>, LaError>
Solve A x = b using this LU factorization.
§Examples
use la_stack::prelude::*;
let a = Matrix::<2>::from_rows([[1.0, 2.0], [3.0, 4.0]]);
let lu = a.lu(DEFAULT_PIVOT_TOL)?;
let b = Vector::<2>::new([5.0, 11.0]);
let x = lu.solve_vec(b)?.into_array();
assert!((x[0] - 1.0).abs() <= 1e-12);
assert!((x[1] - 2.0).abs() <= 1e-12);§Errors
Returns LaError::Singular if a diagonal of U is (numerically) zero.
Returns LaError::NonFinite if NaN/∞ is detected.
Trait Implementations§
impl<const D: usize> Copy for Lu<D>
impl<const D: usize> StructuralPartialEq for Lu<D>
Auto Trait Implementations§
impl<const D: usize> Freeze for Lu<D>
impl<const D: usize> RefUnwindSafe for Lu<D>
impl<const D: usize> Send for Lu<D>
impl<const D: usize> Sync for Lu<D>
impl<const D: usize> Unpin for Lu<D>
impl<const D: usize> UnwindSafe for Lu<D>
Blanket Implementations§
§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§unsafe fn clone_to_uninit(&self, dest: *mut u8)
unsafe fn clone_to_uninit(&self, dest: *mut u8)
🔬This is a nightly-only experimental API. (
clone_to_uninit)