pub struct FiniteRankOperator<const P: usize, const Q: usize, const R: usize> { /* private fields */ }Expand description
A finite-rank operator represented as a sum of rank-1 operators.
T = Σᵢ |vᵢ⟩⟨wᵢ|
where |vᵢ⟩⟨wᵢ| maps x to ⟨wᵢ, x⟩vᵢ.
Implementations§
Source§impl<const P: usize, const Q: usize, const R: usize> FiniteRankOperator<P, Q, R>
impl<const P: usize, const Q: usize, const R: usize> FiniteRankOperator<P, Q, R>
Sourcepub fn new(
left_vectors: Vec<Multivector<P, Q, R>>,
right_vectors: Vec<Multivector<P, Q, R>>,
) -> Result<Self>
pub fn new( left_vectors: Vec<Multivector<P, Q, R>>, right_vectors: Vec<Multivector<P, Q, R>>, ) -> Result<Self>
Create a new finite-rank operator from left and right vectors.
Sourcepub fn rank_one(v: Multivector<P, Q, R>, w: Multivector<P, Q, R>) -> Self
pub fn rank_one(v: Multivector<P, Q, R>, w: Multivector<P, Q, R>) -> Self
Create a rank-1 operator |v⟩⟨w|.
Sourcepub fn to_matrix(&self) -> Result<MatrixOperator<P, Q, R>>
pub fn to_matrix(&self) -> Result<MatrixOperator<P, Q, R>>
Convert to a matrix representation.
Trait Implementations§
Source§impl<const P: usize, const Q: usize, const R: usize> BoundedOperator<Multivector<P, Q, R>> for FiniteRankOperator<P, Q, R>
impl<const P: usize, const Q: usize, const R: usize> BoundedOperator<Multivector<P, Q, R>> for FiniteRankOperator<P, Q, R>
Source§fn operator_norm(&self) -> f64
fn operator_norm(&self) -> f64
Compute or estimate the operator norm ||T||.
Source§fn is_bounded_by(&self, bound: f64) -> bool
fn is_bounded_by(&self, bound: f64) -> bool
Check if the operator is bounded by a given constant.
Source§impl<const P: usize, const Q: usize, const R: usize> Clone for FiniteRankOperator<P, Q, R>
impl<const P: usize, const Q: usize, const R: usize> Clone for FiniteRankOperator<P, Q, R>
Source§fn clone(&self) -> FiniteRankOperator<P, Q, R>
fn clone(&self) -> FiniteRankOperator<P, Q, R>
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl<const P: usize, const Q: usize, const R: usize> CompactOperator<Multivector<P, Q, R>> for FiniteRankOperator<P, Q, R>
impl<const P: usize, const Q: usize, const R: usize> CompactOperator<Multivector<P, Q, R>> for FiniteRankOperator<P, Q, R>
Source§impl<const P: usize, const Q: usize, const R: usize> FredholmOperator<Multivector<P, Q, R>> for FiniteRankOperator<P, Q, R>
impl<const P: usize, const Q: usize, const R: usize> FredholmOperator<Multivector<P, Q, R>> for FiniteRankOperator<P, Q, R>
Source§fn kernel_dimension(&self) -> usize
fn kernel_dimension(&self) -> usize
Compute the dimension of the kernel.
Source§fn cokernel_dimension(&self) -> usize
fn cokernel_dimension(&self) -> usize
Compute the dimension of the cokernel.
Source§fn is_isomorphism(&self) -> bool
fn is_isomorphism(&self) -> bool
Check if the operator is an isomorphism (index 0, trivial kernel).
Source§impl<const P: usize, const Q: usize, const R: usize> LinearOperator<Multivector<P, Q, R>> for FiniteRankOperator<P, Q, R>
impl<const P: usize, const Q: usize, const R: usize> LinearOperator<Multivector<P, Q, R>> for FiniteRankOperator<P, Q, R>
Source§fn apply(&self, x: &Multivector<P, Q, R>) -> Result<Multivector<P, Q, R>>
fn apply(&self, x: &Multivector<P, Q, R>) -> Result<Multivector<P, Q, R>>
Apply the operator to an element.
Source§fn domain_dimension(&self) -> Option<usize>
fn domain_dimension(&self) -> Option<usize>
Get the domain dimension (None if infinite).
Source§fn codomain_dimension(&self) -> Option<usize>
fn codomain_dimension(&self) -> Option<usize>
Get the codomain dimension (None if infinite).
Auto Trait Implementations§
impl<const P: usize, const Q: usize, const R: usize> Freeze for FiniteRankOperator<P, Q, R>
impl<const P: usize, const Q: usize, const R: usize> RefUnwindSafe for FiniteRankOperator<P, Q, R>
impl<const P: usize, const Q: usize, const R: usize> Send for FiniteRankOperator<P, Q, R>
impl<const P: usize, const Q: usize, const R: usize> Sync for FiniteRankOperator<P, Q, R>
impl<const P: usize, const Q: usize, const R: usize> Unpin for FiniteRankOperator<P, Q, R>
impl<const P: usize, const Q: usize, const R: usize> UnwindSafe for FiniteRankOperator<P, Q, R>
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