bem_coulomb_fmm_basis Module

Coulomb FMM の multi-index と微分テーブル計算。


Uses

  • module~~bem_coulomb_fmm_basis~~UsesGraph module~bem_coulomb_fmm_basis bem_coulomb_fmm_basis module~bem_coulomb_fmm_types bem_coulomb_fmm_types module~bem_coulomb_fmm_basis->module~bem_coulomb_fmm_types module~bem_kinds bem_kinds module~bem_coulomb_fmm_basis->module~bem_kinds module~bem_coulomb_fmm_types->module~bem_kinds iso_fortran_env iso_fortran_env module~bem_kinds->iso_fortran_env

Used by

  • module~~bem_coulomb_fmm_basis~~UsedByGraph module~bem_coulomb_fmm_basis bem_coulomb_fmm_basis module~bem_coulomb_fmm_eval_ops bem_coulomb_fmm_eval_ops module~bem_coulomb_fmm_eval_ops->module~bem_coulomb_fmm_basis module~bem_coulomb_fmm_periodic_root_ops bem_coulomb_fmm_periodic_root_ops module~bem_coulomb_fmm_periodic_root_ops->module~bem_coulomb_fmm_basis module~bem_coulomb_fmm_plan_ops bem_coulomb_fmm_plan_ops module~bem_coulomb_fmm_plan_ops->module~bem_coulomb_fmm_basis module~bem_coulomb_fmm_plan_ops->module~bem_coulomb_fmm_periodic_root_ops module~bem_coulomb_fmm_core_build bem_coulomb_fmm_core_build module~bem_coulomb_fmm_core_build->module~bem_coulomb_fmm_plan_ops module~bem_coulomb_fmm_core_eval bem_coulomb_fmm_core_eval module~bem_coulomb_fmm_core_eval->module~bem_coulomb_fmm_eval_ops

Subroutines

public subroutine initialize_basis_tables(plan, order)

FMM の多重指数テーブルと評価用補助テーブルを初期化する。

Arguments

Type IntentOptional Attributes Name
type(fmm_plan_type), intent(inout) :: plan

初期化対象の FMM plan。

integer(kind=i32), intent(in) :: order

展開次数。

public subroutine build_axis_powers(d, order, xpow, ypow, zpow)

3 軸の冪を order まで順に計算する。

Arguments

Type IntentOptional Attributes Name
real(kind=dp), intent(in) :: d(3)
integer(kind=i32), intent(in) :: order

計算する最大次数。

real(kind=dp), intent(out) :: xpow(0:order)
real(kind=dp), intent(out) :: ypow(0:order)
real(kind=dp), intent(out) :: zpow(0:order)

public subroutine compute_laplace_derivatives(plan, r, deriv)

ラプラス核の多重微分係数を計算する。

Arguments

Type IntentOptional Attributes Name
type(fmm_plan_type), intent(in) :: plan

FMM 計画。

real(kind=dp), intent(in) :: r(3)
real(kind=dp), intent(out) :: deriv(:)