Skip to main content

MlfmmSystem

Struct MlfmmSystem 

Source
pub struct MlfmmSystem {
    pub num_levels: usize,
    pub near_matrix: Vec<NearFieldBlock>,
    pub t_matrices: Vec<LevelMatrices>,
    pub d_matrices: Vec<Vec<DMatrixEntry>>,
    pub s_matrices: Vec<LevelMatrices>,
    pub rhs: Array1<Complex64>,
    pub num_dofs: usize,
    pub leaf_dof_indices: Vec<Vec<usize>>,
    pub sphere_points_per_level: Vec<usize>,
    /* private fields */
}
Expand description

Result of MLFMM assembly

Fields§

§num_levels: usize

Number of levels in the tree

§near_matrix: Vec<NearFieldBlock>

Near-field coefficient matrix at leaf level (sparse, stored as dense blocks)

§t_matrices: Vec<LevelMatrices>

T-matrices at each level (child-to-parent aggregation) Level 0 has no T-matrices (root)

§d_matrices: Vec<Vec<DMatrixEntry>>

D-matrices for far-field translation at each level

§s_matrices: Vec<LevelMatrices>

S-matrices at each level (parent-to-child disaggregation)

§rhs: Array1<Complex64>

RHS vector

§num_dofs: usize

Number of DOFs

§leaf_dof_indices: Vec<Vec<usize>>

DOF mappings at leaf level: for each leaf cluster, the global DOF indices

§sphere_points_per_level: Vec<usize>

Number of sphere points at each level

Implementations§

Source§

impl MlfmmSystem

Source

pub fn new( num_dofs: usize, num_levels: usize, cluster_levels: Vec<ClusterLevel>, ) -> Self

Create a new empty MLFMM system

Source

pub fn matvec(&self, x: &Array1<Complex64>) -> Array1<Complex64>

Apply the MLFMM operator: y = ([N] + [S][D][T]) * x

Multi-level version with upward/downward passes.

The algorithm proceeds as follows:

  1. Near-field: Direct interactions between nearby leaf clusters
  2. Upward pass: Aggregate source multipoles from leaves to root (M2M translations)
  3. Translation: Translate multipoles to locals between far clusters at each level (M2L)
  4. Downward pass: Disaggregate local expansions from root to leaves (L2L translations)
  5. Evaluation: Evaluate local expansions at leaf DOFs
§Arguments
  • x - Input vector (length = num_dofs)
§Returns
  • y - Output vector (length = num_dofs), y = A*x
Source

pub fn get_cluster(&self, level: usize, index: usize) -> Option<&Cluster>

Get cluster at given level and index

Source

pub fn num_clusters_at_level(&self, level: usize) -> usize

Get number of clusters at a given level

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.