pub struct Lu<const D: usize> { /* private fields */ }Expand description
Implementations§
Source§impl<const D: usize> Lu<D>
impl<const D: usize> Lu<D>
Sourcepub const fn solve(&self, b: Vector<D>) -> Result<Vector<D>, LaError>
pub const fn solve(&self, b: Vector<D>) -> Result<Vector<D>, LaError>
Solve A x = b using this LU factorization.
Vector is finite by construction, so this method only checks computed
substitution overflows. It performs floating-point forward/back
substitution and does not provide a certified absolute rounding-error
bound for the returned solution.
§Examples
use la_stack::prelude::*;
let a = Matrix::<2>::try_from_rows([[1.0, 2.0], [3.0, 4.0]])?;
let lu = a.lu(DEFAULT_SINGULAR_TOL)?;
let b = Vector::<2>::try_new([5.0, 11.0])?;
let x = lu.solve(b)?.into_array();
assert!((x[0] - 1.0).abs() <= 1e-12);
assert!((x[1] - 2.0).abs() <= 1e-12);§Errors
Returns LaError::NonFinite if a computed substitution intermediate
overflows to NaN or infinity.
Sourcepub const fn det(&self) -> Result<f64, LaError>
pub const fn det(&self) -> Result<f64, LaError>
Determinant of the original matrix.
§Examples
use la_stack::prelude::*;
let a = Matrix::<2>::try_from_rows([[1.0, 2.0], [3.0, 4.0]])?;
let lu = a.lu(DEFAULT_SINGULAR_TOL)?;
let det = lu.det()?;
assert!((det - (-2.0)).abs() <= 1e-12);§Errors
Returns LaError::NonFinite if the determinant product overflows to
NaN or infinity.
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> UnsafeUnpin for Lu<D>
impl<const D: usize> UnwindSafe for Lu<D>
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more