From 5c9694538f9e0845c55ffdd02522311833052a1f Mon Sep 17 00:00:00 2001 From: "Documenter.jl" Date: Tue, 30 Apr 2024 20:18:14 +0000 Subject: [PATCH] build based on 7dca307 --- dev/.documenter-siteinfo.json | 2 +- dev/guided_examples/index.html | 2 +- dev/index.html | 2 +- dev/objects.inv | Bin 862 -> 895 bytes dev/quickstart/index.html | 2 +- dev/reference/index.html | 2 +- dev/search_index.js | 2 +- dev/theory/index.html | 2 +- 8 files changed, 7 insertions(+), 7 deletions(-) diff --git a/dev/.documenter-siteinfo.json b/dev/.documenter-siteinfo.json index 806fa9b..ca1b1fb 100644 --- a/dev/.documenter-siteinfo.json +++ b/dev/.documenter-siteinfo.json @@ -1 +1 @@ -{"documenter":{"julia_version":"1.10.2","generation_timestamp":"2024-04-23T22:27:34","documenter_version":"1.4.0"}} \ No newline at end of file +{"documenter":{"julia_version":"1.10.3","generation_timestamp":"2024-04-30T20:18:12","documenter_version":"1.4.0"}} \ No newline at end of file diff --git a/dev/guided_examples/index.html b/dev/guided_examples/index.html index a9dc0a0..2bf69bd 100644 --- a/dev/guided_examples/index.html +++ b/dev/guided_examples/index.html @@ -1,2 +1,2 @@ -Guided Examples · FastMultipole.jl
+Guided Examples · FastMultipole.jl
diff --git a/dev/index.html b/dev/index.html index 80d5f44..807c1d9 100644 --- a/dev/index.html +++ b/dev/index.html @@ -1,2 +1,2 @@ -Introduction · FastMultipole.jl

FastMultipole

FastMultipole is a highly performant, CPU parallelized fast multipole code suitable for accelerating large $N$-body problems in scalar and or vector potentials with a wide range of applications, including astronomy, electro-magnetism, and fluid-dynamics. Typical use cases include boundary element problems, such as 3-dimensional panel methods. The code is compatible with ForwardDiff and ReverseDiff algorithmic differentiation for gradient-based design optimization. Its elegant interface makes it extremely easy to incorporate into existing Julia code with minimal modification. Convenience functions are provided for generating the expansions of source and vortex points and constant source and doublet panels, with more support planned for the future. It currently supports only the Laplace kernel, though this may change soon.

+Introduction · FastMultipole.jl

FastMultipole

FastMultipole is a highly performant, CPU parallelized fast multipole code suitable for accelerating large $N$-body problems in scalar and or vector potentials with a wide range of applications, including astronomy, electro-magnetism, and fluid-dynamics. Typical use cases include boundary element problems, such as 3-dimensional panel methods. The code is compatible with ForwardDiff and ReverseDiff algorithmic differentiation for gradient-based design optimization. Its elegant interface makes it extremely easy to incorporate into existing Julia code with minimal modification. Convenience functions are provided for generating the expansions of source and vortex points and constant source and doublet panels, with more support planned for the future. It currently supports only the Laplace kernel, though this may change soon.

diff --git a/dev/objects.inv b/dev/objects.inv index 8cecb79b0e74042f2e164933f210d4721b6636c6..831bbbf56bdf421af660680e749669c001f6c648 100644 GIT binary patch delta 774 zcmV+h1Nr>k2LA?-g?~|R+At7)=T~^zc!N<=q)B}%Z8J?;tFC0-BTAEN@fKp{m==Wi z@4MI#>^K33w$fglu_FG7+D}EF#@LA>UHLSv-#fWohg0oJM~#5ptoQ z*?D{9M{bi*{-gCYr!mB1ScKDA0+}9C+Uk+7(m}2^juwYU;D3-tphp$X9=Y3^EinPc zm-;c~>5)J_Tar?DRIpCM2S`f1KYlWp2RqE-^ad4Ac3Xa!iR*bH=!_*`9+Ufb2K!=f z$6uaOHFvM{{uF1+9m0rmj|>){FM-qNP|#<{MlV!E6Y@Jb6U!M8E3p|EQx1{%&<*B@ zx{~WUkDY>;uz%Q$u8M4XeHGjOGTb~btt5}r={Cc8x^%?HARQb7tDvP7Z~)hWIb=}O zd&}7ajFy>zsUs^HuJh6$s`yziW|MiySkfW(+T;z?U?Zsc(ehunueFJEn=NoWU&faFMoi=yD8~LF&!xF94(rg zExCavj|u`B_wLUWzlcf~tLsp3x>yDNdcD!Fw8_f^8IZtt<7J`mF4UpQkUM8NyRX|j&U+S&cRIIQtQU!N@CHXt zg`8A&3BBEO>zZA?CNPAtq*CF+v=zR7rO$pP&5be$}!_#<$9k1{ZEWzbyA~_e^YvR E$MKwsjQ{`u delta 741 zcmVOad7~tGna#EtuHuzueC{L%=Z+sDF;(z9upD`k-GLdfsWW5R2FMsUk~iF-BRa?rEx-NofbpX z(Rod@c}SHn0!T;bJ!HyEhKMtR_iZa4#x9XeAjx=^_kX6QY5`Io9f3kWzdAi-;*NBE zNG_35*F`1MeO}l_PR)ZkdA}|2LSkP_eG+E#XUtzXIqlYWKBIWK_MFY87!M(%w<$+} zJVy_g61}>w#(9QJ;c#HtPaY0QdnR&bTaE(X<>dZF{rMbd@2gJn?Y{52x^zXUzgqJb z7{h^(lYeVMdE_U~GD6qqymb!mpY?7{6iNBB3j*IdFZ$|~Ew&Etcm17m#OUvvyIq5! zpLG9RbloyETsG?LbGpTyto@niuJ2{2pL`2F2zMO*ejaRyeH(kN?>&#t?!9bd_?SF_vDrOA%>Xg(OeRH6840P9`}!7eWNRf X(7#RfJ_P+wghS_~V> -Quick Start · FastMultipole.jl

Quick Start

The tutorial for FastMultipole is a work in progress. While we work on creating a tutorial, see the example file scripts/simple_gravitational.jl.

+Quick Start · FastMultipole.jl

Quick Start

The tutorial for FastMultipole is a work in progress. While we work on creating a tutorial, see the example file scripts/simple_gravitational.jl.

diff --git a/dev/reference/index.html b/dev/reference/index.html index 314b403..8549896 100644 --- a/dev/reference/index.html +++ b/dev/reference/index.html @@ -1,2 +1,2 @@ -Reference · FastMultipole.jl

Reference

FastMultipole.DerivativesSwitchType
DerivativesSwitch

Switch indicating whether the scalar potential, vector potential, velocity, and/or velocity gradient should be computed for a target system. Information is stored as type parameters, allowing the compiler to compile away if statements.

source
FastMultipole.DerivativesSwitchMethod
DerivativesSwitch(scalar_potential, vector_potential, velocity, velocity_gradient)

Constructs a tuple of DerivativesSwitch objects.

Arguments

  • scalar_potential::Vector{Bool}: a vector of ::Bool indicating whether the scalar potential should be computed for each target system
  • vector_potential::Vector{Bool}: a vector of ::Bool indicating whether the vector potential should be computed for each target system
  • velocity::Vector{Bool}: a vector of ::Bool indicating whether the velocity should be computed for each target system
  • velocity_gradient::Vector{Bool}: a vector of ::Bool indicating whether the velocity gradient should be computed for each target system
source
FastMultipole.DerivativesSwitchMethod
DerivativesSwitch(scalar_potential, vector_potential, velocity, velocity_gradient)

Constructs a single DerivativesSwitch object.

Arguments

  • scalar_potential::Bool: a ::Bool indicating whether the scalar potential should be computed for the target system
  • vector_potential::Bool: a ::Bool indicating whether the vector potential should be computed for the target system
  • velocity::Bool: a ::Bool indicating whether the velocity should be computed for the target system
  • velocity_gradient::Bool: a ::Bool indicating whether the velocity gradient should be computed for the target system
source
FastMultipole.DerivativesSwitchMethod
DerivativesSwitch(scalar_potential, vector_potential, velocity, velocity_gradient, target_systems)

Constructs a ::Tuple of indentical DerivativesSwitch objects of the same length as target_systems (if it is a ::Tuple), or a single DerivativesSwitch (if target_system is not a ::Tuple)

Arguments

  • scalar_potential::Bool: a ::Bool indicating whether the scalar potential should be computed for each target system
  • vector_potential::Bool: a ::Bool indicating whether the vector potential should be computed for each target system
  • velocity::Bool: a ::Bool indicating whether the velocity should be computed for each target system
  • velocity_gradient::Bool: a ::Bool indicating whether the velocity gradient should be computed for each target system
source
FastMultipole.MultiTreeType

bodies[indexlist] is the same sort operation as performed by the tree sortedbodies[inverseindexlist] undoes the sort operation performed by the tree

source
FastMultipole.ProbeSystemType
ProbeSystem

Convenience system for defining locations at which the potential, velocity, or velocity gradient may be desired.

source
FastMultipole.ProbeSystemMethod
ProbeSystem(positions; kwargs...)

A convenience system constructor for calculating the influence of source systems at locations not already described by a system object. It behaves like a system whose elements induce a null potential field.

Arguments

  • positions::Vector{SVector{3,Float64}}: a vector of position vectors of each probe

Optional Arguments

  • scalar_potential::Bool: whether or not to compute the scalar potential at each probe location
  • vector_potential::Bool: whether or not to compute the vector potential at each probe location
  • velocity::Bool: whether or not to compute the velocity at each probe location
  • velocity_gradient::Bool: whether or not to compute the velocity gradient at each probe location
source
FastMultipole.ProbeSystemMethod
ProbeSystem(positions; kwargs...)

Dispatch of ProbeSystem accepting a matrix of horizontally concatenated column vectors describing the position of each probe. Optional arguments are identical.

source
FastMultipole.SortWrapperMethod
SortWrapper(system)

Convenience wrapper for systems whose elements cannot be sorted in-place (e.g. structured grids). The resulting object is treated like any other system.

source
FastMultipole.TreeType
abstract type Tree{TF,P} end

Supertype of all octree structures with TF the floating point type and P the expansion order.

source
FastMultipole.direct!Method
direct!(target_system, source_system; derivatives_switches)

Applies all interactions of source_system acting on target_system without multipole acceleration.

Arguments

  • target_system: either

    • a system object for which compatibility functions have been overloaded, or
    • a tuple of system objects for which compatibility functions have been overloaded
  • source_system: either

    • a system object for which compatibility functions have been overloaded, or
    • a tuple of system objects for which compatibility functions have been overloaded

Optional Arguments

  • derivatives_switches::DerivativesSwitch: determines whether to include the scalar potential, vector potential, velocity, and/or velocity gradient for the target_system; either

    • (if target_system is not a ::Tuple of systems) an instance of DerivativesSwitch
    • (if target_system is a ::Tuple of systems) a ::Tuple of DerivativesSwitch of length length(target_systems)
source
FastMultipole.direct!Method
direct!(systems; derivatives_switches)

Applies all interactions of systems acting on itself without multipole acceleration.

Arguments

  • systems: either

    • a system object for which compatibility functions have been overloaded, or
    • a tuple of system objects for which compatibility functions have been overloaded

Optional Arguments

  • derivatives_switches::DerivativesSwitch: determines whether to include the scalar potential, vector potential, velocity, and/or velocity gradient when solving the n-body problem; either

source
FastMultipole.fmm!Method
fmm!(target_systems, source_systems; kwargs...)

Apply all interactions of source_systems acting on target_systems using the fast multipole method. Assumes compatibility functions have been overloaded for both source and target systems.

Arguments

  • target_systems: either

    • a system object for which compatibility functions have been overloaded, or
    • a tuple of system objects for which compatibility functions have been overloaded
  • source_systems: either

    • a system object for which compatibility functions have been overloaded, or
    • a tuple of system objects for which compatibility functions have been overloaded

Optional Arguments

  • expansion_order::Int: the expansion order to be used
  • n_per_branch_source::Int: maximum number of bodies from source_systems allowed in a leaf-level branch
  • n_per_branch_target::Int: maximum number of bodies from target_systems allowed in a leaf-level branch
  • multipole_acceptance_criterion::Float64: number between 0 and 1 (often denoted theta in [0,1]) controls the accuracy by determining the non-dimensional distance after which multipoles are used; 0 means an infinite distance (no error, high cost), and 1 means barely convergent (high error, low cost)
  • scalar_potential::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(target_systems) indicating whether each system should receive a scalar potential from source_systems
  • vector_potential::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(target_systems) indicating whether each system should receive a vector potential from source_systems
  • velocity::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(target_systems) indicating whether each system should receive a velocity from source_systems
  • velocity_gradient::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(target_systems) indicating whether each system should receive a velocity gradient from source_systems
  • nearfield::Bool: indicates whether near-field (comuted without multipoles) interactions should be included
  • farfield::Bool: indicates whether far-field (comuted with multipoles) interactions should be included
  • self_induced::Bool: indicates whether to include the interactions of each leaf-level branch on itself
  • unsort_source_bodies::Bool: indicates whether or not to undo the sort operation used to generate the octree for the source_systems
  • unsort_target_bodies::Bool: indicates whether or not to undo the sort operation used to generate the octree for the target_systems
  • source_shink_recenter::Bool: indicates whether or not to resize branches for the source_systems octree after it is created to increase computational efficiency
  • target_shink_recenter::Bool: indicates whether or not to resize branches for the target_systems octree after it is created to increase computational efficiency
  • save_tree::Bool: indicates whether or not to save a VTK file for visualizing the octree
  • save_name::String: name and path of the octree visualization if save_tree == true
source
FastMultipole.fmm!Method
fmm!(systems; kwargs...)

Apply all interactions of systems acting on itself using the fast multipole method. Assumes compatibility functions have been overloaded for both source and target systems.

Arguments

  • systems: either

    • a system object for which compatibility functions have been overloaded, or
    • a tuple of system objects for which compatibility functions have been overloaded

Optional Arguments

  • expansion_order::Int: the expansion order to be used
  • n_per_branch::Int: maximum number of bodies from systems allowed in a leaf-level branch
  • multipole_acceptance_criterion::Float64: number between 0 and 1 (often denoted theta in [0,1]) controls the accuracy by determining the non-dimensional distance after which multipoles are used; 0 means an infinite distance (no error, high cost), and 1 means barely convergent (high error, low cost)
  • scalar_potential::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(systems) indicating whether each system should receive a scalar potential from source_systems
  • vector_potential::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(systems) indicating whether each system should receive a vector potential from source_systems
  • velocity::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(systems) indicating whether each system should receive a velocity from source_systems
  • velocity_gradient::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(systems) indicating whether each system should receive a velocity gradient from source_systems
  • nearfield::Bool: indicates whether near-field (comuted without multipoles) interactions should be included
  • farfield::Bool: indicates whether far-field (comuted with multipoles) interactions should be included
  • self_induced::Bool: indicates whether to include the interactions of each leaf-level branch on itself
  • unsort_bodies::Bool: indicates whether or not to undo the sort operation used to generate the octree for systems
  • shink_recenter::Bool: indicates whether or not to resize branches for the octree after it is created to increase computational efficiency
  • save_tree::Bool: indicates whether or not to save a VTK file for visualizing the octree
  • save_name::String: name and path of the octree visualization if save_tree == true
source
FastMultipole.fmm!Method
fmm!(target_tree, target_systems, source_tree, source_systems; kwargs...)

Dispatches fmm! using existing ::Tree objects.

Arguments

  • target_tree::Tree: a <:Tree object (see Tree)

  • target_systems: either

    • a system object for which compatibility functions have been overloaded, or
    • a tuple of system objects for which compatibility functions have been overloaded
  • source_tree::Tree: a <:Tree object (see Tree)

  • source_systems: either

    • a system object for which compatibility functions have been overloaded, or
    • a tuple of system objects for which compatibility functions have been overloaded

Optional Arguments

  • multipole_acceptance_criterion::Float64: number between 0 and 1 (often denoted theta in [0,1]) controls the accuracy by determining the non-dimensional distance after which multipoles are used; 0 means an infinite distance (no error, high cost), and 1 means barely convergent (high error, low cost)
  • scalar_potential::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(target_systems) indicating whether each system should receive a scalar potential from source_systems
  • vector_potential::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(target_systems) indicating whether each system should receive a vector potential from source_systems
  • velocity::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(target_systems) indicating whether each system should receive a velocity from source_systems
  • velocity_gradient::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(target_systems) indicating whether each system should receive a velocity gradient from source_systems
  • nearfield::Bool: indicates whether near-field (comuted without multipoles) interactions should be included
  • farfield::Bool: indicates whether far-field (comuted with multipoles) interactions should be included
  • self_induced::Bool: indicates whether to include the interactions of each leaf-level branch on itself
  • unsort_source_bodies::Bool: indicates whether or not to undo the sort operation used to generate the octree for source_systems
  • unsort_target_bodies::Bool: indicates whether or not to undo the sort operation used to generate the octree for target_systems
source
FastMultipole.fmm!Method
fmm!(tree, systems; kwargs...)

Dispatches fmm! using an existing ::Tree.

Arguments

  • tree::Tree: a <:Tree object (see Tree)

  • systems: either

    • a system object for which compatibility functions have been overloaded, or
    • a tuple of system objects for which compatibility functions have been overloaded

Optional Arguments

  • multipole_acceptance_criterion::Float64: number between 0 and 1 (often denoted theta in [0,1]) controls the accuracy by determining the non-dimensional distance after which multipoles are used; 0 means an infinite distance (no error, high cost), and 1 means barely convergent (high error, low cost)
  • scalar_potential::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(systems) indicating whether each system should receive a scalar potential from source_systems
  • vector_potential::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(systems) indicating whether each system should receive a vector potential from source_systems
  • velocity::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(systems) indicating whether each system should receive a velocity from source_systems
  • velocity_gradient::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(systems) indicating whether each system should receive a velocity gradient from source_systems
  • nearfield::Bool: indicates whether near-field (comuted without multipoles) interactions should be included
  • farfield::Bool: indicates whether far-field (comuted with multipoles) interactions should be included
  • self_induced::Bool: indicates whether to include the interactions of each leaf-level branch on itself
  • unsort_bodies::Bool: indicates whether or not to undo the sort operation used to generate the octree for systems
source
FastMultipole.reset!Method
reset!(probes)

Zeroes all values (e.g. scalar/vector potential, velocity, and/or velocity gradient) of all probes.

Arguments

source
+Reference · FastMultipole.jl

Reference

FastMultipole.DerivativesSwitchType
DerivativesSwitch

Switch indicating whether the scalar potential, vector potential, velocity, and/or velocity gradient should be computed for a target system. Information is stored as type parameters, allowing the compiler to compile away if statements.

source
FastMultipole.DerivativesSwitchMethod
DerivativesSwitch(scalar_potential, vector_potential, velocity, velocity_gradient)

Constructs a tuple of DerivativesSwitch objects.

Arguments

  • scalar_potential::Vector{Bool}: a vector of ::Bool indicating whether the scalar potential should be computed for each target system
  • vector_potential::Vector{Bool}: a vector of ::Bool indicating whether the vector potential should be computed for each target system
  • velocity::Vector{Bool}: a vector of ::Bool indicating whether the velocity should be computed for each target system
  • velocity_gradient::Vector{Bool}: a vector of ::Bool indicating whether the velocity gradient should be computed for each target system
source
FastMultipole.DerivativesSwitchMethod
DerivativesSwitch(scalar_potential, vector_potential, velocity, velocity_gradient)

Constructs a single DerivativesSwitch object.

Arguments

  • scalar_potential::Bool: a ::Bool indicating whether the scalar potential should be computed for the target system
  • vector_potential::Bool: a ::Bool indicating whether the vector potential should be computed for the target system
  • velocity::Bool: a ::Bool indicating whether the velocity should be computed for the target system
  • velocity_gradient::Bool: a ::Bool indicating whether the velocity gradient should be computed for the target system
source
FastMultipole.DerivativesSwitchMethod
DerivativesSwitch(scalar_potential, vector_potential, velocity, velocity_gradient, target_systems)

Constructs a ::Tuple of indentical DerivativesSwitch objects of the same length as target_systems (if it is a ::Tuple), or a single DerivativesSwitch (if target_system is not a ::Tuple)

Arguments

  • scalar_potential::Bool: a ::Bool indicating whether the scalar potential should be computed for each target system
  • vector_potential::Bool: a ::Bool indicating whether the vector potential should be computed for each target system
  • velocity::Bool: a ::Bool indicating whether the velocity should be computed for each target system
  • velocity_gradient::Bool: a ::Bool indicating whether the velocity gradient should be computed for each target system
source
FastMultipole.MultiTreeType

bodies[indexlist] is the same sort operation as performed by the tree sortedbodies[inverseindexlist] undoes the sort operation performed by the tree

source
FastMultipole.ProbeSystemType
ProbeSystem

Convenience system for defining locations at which the potential, velocity, or velocity gradient may be desired.

source
FastMultipole.ProbeSystemMethod
ProbeSystem(positions; kwargs...)

A convenience system constructor for calculating the influence of source systems at locations not already described by a system object. It behaves like a system whose elements induce a null potential field.

Arguments

  • positions::Vector{SVector{3,Float64}}: a vector of position vectors of each probe

Optional Arguments

  • scalar_potential::Bool: whether or not to compute the scalar potential at each probe location
  • vector_potential::Bool: whether or not to compute the vector potential at each probe location
  • velocity::Bool: whether or not to compute the velocity at each probe location
  • velocity_gradient::Bool: whether or not to compute the velocity gradient at each probe location
source
FastMultipole.ProbeSystemMethod
ProbeSystem(positions; kwargs...)

Dispatch of ProbeSystem accepting a matrix of horizontally concatenated column vectors describing the position of each probe. Optional arguments are identical.

source
FastMultipole.SortWrapperMethod
SortWrapper(system)

Convenience wrapper for systems whose elements cannot be sorted in-place (e.g. structured grids). The resulting object is treated like any other system.

source
FastMultipole.TreeType
abstract type Tree{TF,P} end

Supertype of all octree structures with TF the floating point type and P the expansion order.

source
FastMultipole.add_line!Method
add_line!(probes::ProbeSystem, x1, x2, n_probes, i_last)

Adds n_probes probes in a line between x1 and x2. Specifically, they are added at the midpoint of equally partiti oned segments of the line.

Arguments

  • probes::ProbeSystem: the probe system whose .position field is to be updated
  • x1::Vector{Float64}: the first point defining the line along which probes are to be added
  • x2::Vector{Float64}: the second point defining the line along which probes are to be added
  • n_probes::Int: number of probes to be added
  • i_last::Int: index of the last probe in probes

Output

  • i_last::Int: updated index of the last probe in probes
source
FastMultipole.direct!Method
direct!(target_system, source_system; derivatives_switches)

Applies all interactions of source_system acting on target_system without multipole acceleration.

Arguments

  • target_system: either

    • a system object for which compatibility functions have been overloaded, or
    • a tuple of system objects for which compatibility functions have been overloaded
  • source_system: either

    • a system object for which compatibility functions have been overloaded, or
    • a tuple of system objects for which compatibility functions have been overloaded

Optional Arguments

  • derivatives_switches::DerivativesSwitch: determines whether to include the scalar potential, vector potential, velocity, and/or velocity gradient for the target_system; either

    • (if target_system is not a ::Tuple of systems) an instance of DerivativesSwitch
    • (if target_system is a ::Tuple of systems) a ::Tuple of DerivativesSwitch of length length(target_systems)
source
FastMultipole.direct!Method
direct!(systems; derivatives_switches)

Applies all interactions of systems acting on itself without multipole acceleration.

Arguments

  • systems: either

    • a system object for which compatibility functions have been overloaded, or
    • a tuple of system objects for which compatibility functions have been overloaded

Optional Arguments

  • derivatives_switches::DerivativesSwitch: determines whether to include the scalar potential, vector potential, velocity, and/or velocity gradient when solving the n-body problem; either

source
FastMultipole.fmm!Method
fmm!(target_systems, source_systems; kwargs...)

Apply all interactions of source_systems acting on target_systems using the fast multipole method. Assumes compatibility functions have been overloaded for both source and target systems.

Arguments

  • target_systems: either

    • a system object for which compatibility functions have been overloaded, or
    • a tuple of system objects for which compatibility functions have been overloaded
  • source_systems: either

    • a system object for which compatibility functions have been overloaded, or
    • a tuple of system objects for which compatibility functions have been overloaded

Optional Arguments

  • expansion_order::Int: the expansion order to be used
  • n_per_branch_source::Int: maximum number of bodies from source_systems allowed in a leaf-level branch
  • n_per_branch_target::Int: maximum number of bodies from target_systems allowed in a leaf-level branch
  • multipole_acceptance_criterion::Float64: number between 0 and 1 (often denoted theta in [0,1]) controls the accuracy by determining the non-dimensional distance after which multipoles are used; 0 means an infinite distance (no error, high cost), and 1 means barely convergent (high error, low cost)
  • scalar_potential::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(target_systems) indicating whether each system should receive a scalar potential from source_systems
  • vector_potential::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(target_systems) indicating whether each system should receive a vector potential from source_systems
  • velocity::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(target_systems) indicating whether each system should receive a velocity from source_systems
  • velocity_gradient::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(target_systems) indicating whether each system should receive a velocity gradient from source_systems
  • nearfield::Bool: indicates whether near-field (comuted without multipoles) interactions should be included
  • farfield::Bool: indicates whether far-field (comuted with multipoles) interactions should be included
  • self_induced::Bool: indicates whether to include the interactions of each leaf-level branch on itself
  • unsort_source_bodies::Bool: indicates whether or not to undo the sort operation used to generate the octree for the source_systems
  • unsort_target_bodies::Bool: indicates whether or not to undo the sort operation used to generate the octree for the target_systems
  • source_shink_recenter::Bool: indicates whether or not to resize branches for the source_systems octree after it is created to increase computational efficiency
  • target_shink_recenter::Bool: indicates whether or not to resize branches for the target_systems octree after it is created to increase computational efficiency
  • save_tree::Bool: indicates whether or not to save a VTK file for visualizing the octree
  • save_name::String: name and path of the octree visualization if save_tree == true
source
FastMultipole.fmm!Method
fmm!(systems; kwargs...)

Apply all interactions of systems acting on itself using the fast multipole method. Assumes compatibility functions have been overloaded for both source and target systems.

Arguments

  • systems: either

    • a system object for which compatibility functions have been overloaded, or
    • a tuple of system objects for which compatibility functions have been overloaded

Optional Arguments

  • expansion_order::Int: the expansion order to be used
  • n_per_branch::Int: maximum number of bodies from systems allowed in a leaf-level branch
  • multipole_acceptance_criterion::Float64: number between 0 and 1 (often denoted theta in [0,1]) controls the accuracy by determining the non-dimensional distance after which multipoles are used; 0 means an infinite distance (no error, high cost), and 1 means barely convergent (high error, low cost)
  • scalar_potential::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(systems) indicating whether each system should receive a scalar potential from source_systems
  • vector_potential::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(systems) indicating whether each system should receive a vector potential from source_systems
  • velocity::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(systems) indicating whether each system should receive a velocity from source_systems
  • velocity_gradient::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(systems) indicating whether each system should receive a velocity gradient from source_systems
  • nearfield::Bool: indicates whether near-field (comuted without multipoles) interactions should be included
  • farfield::Bool: indicates whether far-field (comuted with multipoles) interactions should be included
  • self_induced::Bool: indicates whether to include the interactions of each leaf-level branch on itself
  • unsort_bodies::Bool: indicates whether or not to undo the sort operation used to generate the octree for systems
  • shink_recenter::Bool: indicates whether or not to resize branches for the octree after it is created to increase computational efficiency
  • save_tree::Bool: indicates whether or not to save a VTK file for visualizing the octree
  • save_name::String: name and path of the octree visualization if save_tree == true
source
FastMultipole.fmm!Method
fmm!(target_tree, target_systems, source_tree, source_systems; kwargs...)

Dispatches fmm! using existing ::Tree objects.

Arguments

  • target_tree::Tree: a <:Tree object (see Tree)

  • target_systems: either

    • a system object for which compatibility functions have been overloaded, or
    • a tuple of system objects for which compatibility functions have been overloaded
  • source_tree::Tree: a <:Tree object (see Tree)

  • source_systems: either

    • a system object for which compatibility functions have been overloaded, or
    • a tuple of system objects for which compatibility functions have been overloaded

Optional Arguments

  • multipole_acceptance_criterion::Float64: number between 0 and 1 (often denoted theta in [0,1]) controls the accuracy by determining the non-dimensional distance after which multipoles are used; 0 means an infinite distance (no error, high cost), and 1 means barely convergent (high error, low cost)
  • scalar_potential::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(target_systems) indicating whether each system should receive a scalar potential from source_systems
  • vector_potential::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(target_systems) indicating whether each system should receive a vector potential from source_systems
  • velocity::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(target_systems) indicating whether each system should receive a velocity from source_systems
  • velocity_gradient::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(target_systems) indicating whether each system should receive a velocity gradient from source_systems
  • nearfield::Bool: indicates whether near-field (comuted without multipoles) interactions should be included
  • farfield::Bool: indicates whether far-field (comuted with multipoles) interactions should be included
  • self_induced::Bool: indicates whether to include the interactions of each leaf-level branch on itself
  • unsort_source_bodies::Bool: indicates whether or not to undo the sort operation used to generate the octree for source_systems
  • unsort_target_bodies::Bool: indicates whether or not to undo the sort operation used to generate the octree for target_systems
source
FastMultipole.fmm!Method
fmm!(tree, systems; kwargs...)

Dispatches fmm! using an existing ::Tree.

Arguments

  • tree::Tree: a <:Tree object (see Tree)

  • systems: either

    • a system object for which compatibility functions have been overloaded, or
    • a tuple of system objects for which compatibility functions have been overloaded

Optional Arguments

  • multipole_acceptance_criterion::Float64: number between 0 and 1 (often denoted theta in [0,1]) controls the accuracy by determining the non-dimensional distance after which multipoles are used; 0 means an infinite distance (no error, high cost), and 1 means barely convergent (high error, low cost)
  • scalar_potential::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(systems) indicating whether each system should receive a scalar potential from source_systems
  • vector_potential::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(systems) indicating whether each system should receive a vector potential from source_systems
  • velocity::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(systems) indicating whether each system should receive a velocity from source_systems
  • velocity_gradient::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(systems) indicating whether each system should receive a velocity gradient from source_systems
  • nearfield::Bool: indicates whether near-field (comuted without multipoles) interactions should be included
  • farfield::Bool: indicates whether far-field (comuted with multipoles) interactions should be included
  • self_induced::Bool: indicates whether to include the interactions of each leaf-level branch on itself
  • unsort_bodies::Bool: indicates whether or not to undo the sort operation used to generate the octree for systems
source
FastMultipole.reset!Method
reset!(probes)

Zeroes all values (e.g. scalar/vector potential, velocity, and/or velocity gradient) of all probes.

Arguments

source
diff --git a/dev/search_index.js b/dev/search_index.js index 7191e52..737661f 100644 --- a/dev/search_index.js +++ b/dev/search_index.js @@ -1,3 +1,3 @@ var documenterSearchIndex = {"docs": -[{"location":"guided_examples/#Guided-Examples","page":"Guided Examples","title":"Guided Examples","text":"","category":"section"},{"location":"guided_examples/","page":"Guided Examples","title":"Guided Examples","text":"This section a work in progress.","category":"page"},{"location":"theory/#Theory","page":"Theory","title":"Theory","text":"","category":"section"},{"location":"theory/","page":"Theory","title":"Theory","text":"An explanation of the theory can be found here.","category":"page"},{"location":"quickstart/#Quick-Start","page":"Quick Start","title":"Quick Start","text":"","category":"section"},{"location":"quickstart/","page":"Quick Start","title":"Quick Start","text":"The tutorial for FastMultipole is a work in progress. While we work on creating a tutorial, see the example file scripts/simple_gravitational.jl.","category":"page"},{"location":"reference/#Reference","page":"Reference","title":"Reference","text":"","category":"section"},{"location":"reference/","page":"Reference","title":"Reference","text":"CurrentModule = FastMultipole","category":"page"},{"location":"reference/","page":"Reference","title":"Reference","text":"Modules = [FastMultipole]\nOrder = [:constant, :type, :function]\n# Pages = [\"fmm.jl\"]","category":"page"},{"location":"reference/","page":"Reference","title":"Reference","text":"Modules = [FastMultipole]\nOrder = [:constant, :type, :function]\n# Pages = [\"fmm.jl\"]","category":"page"},{"location":"reference/#FastMultipole.DerivativesSwitch","page":"Reference","title":"FastMultipole.DerivativesSwitch","text":"DerivativesSwitch\n\nSwitch indicating whether the scalar potential, vector potential, velocity, and/or velocity gradient should be computed for a target system. Information is stored as type parameters, allowing the compiler to compile away if statements.\n\n\n\n\n\n","category":"type"},{"location":"reference/#FastMultipole.DerivativesSwitch-NTuple{4, Any}","page":"Reference","title":"FastMultipole.DerivativesSwitch","text":"DerivativesSwitch(scalar_potential, vector_potential, velocity, velocity_gradient)\n\nConstructs a tuple of DerivativesSwitch objects.\n\nArguments\n\nscalar_potential::Vector{Bool}: a vector of ::Bool indicating whether the scalar potential should be computed for each target system\nvector_potential::Vector{Bool}: a vector of ::Bool indicating whether the vector potential should be computed for each target system\nvelocity::Vector{Bool}: a vector of ::Bool indicating whether the velocity should be computed for each target system\nvelocity_gradient::Vector{Bool}: a vector of ::Bool indicating whether the velocity gradient should be computed for each target system\n\n\n\n\n\n","category":"method"},{"location":"reference/#FastMultipole.DerivativesSwitch-NTuple{4, Bool}","page":"Reference","title":"FastMultipole.DerivativesSwitch","text":"DerivativesSwitch(scalar_potential, vector_potential, velocity, velocity_gradient)\n\nConstructs a single DerivativesSwitch object.\n\nArguments\n\nscalar_potential::Bool: a ::Bool indicating whether the scalar potential should be computed for the target system\nvector_potential::Bool: a ::Bool indicating whether the vector potential should be computed for the target system\nvelocity::Bool: a ::Bool indicating whether the velocity should be computed for the target system\nvelocity_gradient::Bool: a ::Bool indicating whether the velocity gradient should be computed for the target system\n\n\n\n\n\n","category":"method"},{"location":"reference/#FastMultipole.DerivativesSwitch-Tuple{Bool, Bool, Bool, Bool, Tuple}","page":"Reference","title":"FastMultipole.DerivativesSwitch","text":"DerivativesSwitch(scalar_potential, vector_potential, velocity, velocity_gradient, target_systems)\n\nConstructs a ::Tuple of indentical DerivativesSwitch objects of the same length as target_systems (if it is a ::Tuple), or a single DerivativesSwitch (if target_system is not a ::Tuple)\n\nArguments\n\nscalar_potential::Bool: a ::Bool indicating whether the scalar potential should be computed for each target system\nvector_potential::Bool: a ::Bool indicating whether the vector potential should be computed for each target system\nvelocity::Bool: a ::Bool indicating whether the velocity should be computed for each target system\nvelocity_gradient::Bool: a ::Bool indicating whether the velocity gradient should be computed for each target system\n\n\n\n\n\n","category":"method"},{"location":"reference/#FastMultipole.MultiTree","page":"Reference","title":"FastMultipole.MultiTree","text":"bodies[indexlist] is the same sort operation as performed by the tree sortedbodies[inverseindexlist] undoes the sort operation performed by the tree\n\n\n\n\n\n","category":"type"},{"location":"reference/#FastMultipole.ProbeSystem","page":"Reference","title":"FastMultipole.ProbeSystem","text":"ProbeSystem\n\nConvenience system for defining locations at which the potential, velocity, or velocity gradient may be desired.\n\n\n\n\n\n","category":"type"},{"location":"reference/#FastMultipole.ProbeSystem-Union{Tuple{Array{StaticArraysCore.SVector{3, TF}, 1}}, Tuple{TF}} where TF","page":"Reference","title":"FastMultipole.ProbeSystem","text":"ProbeSystem(positions; kwargs...)\n\nA convenience system constructor for calculating the influence of source systems at locations not already described by a system object. It behaves like a system whose elements induce a null potential field.\n\nArguments\n\npositions::Vector{SVector{3,Float64}}: a vector of position vectors of each probe\n\nOptional Arguments\n\nscalar_potential::Bool: whether or not to compute the scalar potential at each probe location\nvector_potential::Bool: whether or not to compute the vector potential at each probe location\nvelocity::Bool: whether or not to compute the velocity at each probe location\nvelocity_gradient::Bool: whether or not to compute the velocity gradient at each probe location\n\n\n\n\n\n","category":"method"},{"location":"reference/#FastMultipole.ProbeSystem-Union{Tuple{Matrix{TF}}, Tuple{TF}} where TF","page":"Reference","title":"FastMultipole.ProbeSystem","text":"ProbeSystem(positions; kwargs...)\n\nDispatch of ProbeSystem accepting a matrix of horizontally concatenated column vectors describing the position of each probe. Optional arguments are identical.\n\n\n\n\n\n","category":"method"},{"location":"reference/#FastMultipole.SortWrapper-Tuple{Any}","page":"Reference","title":"FastMultipole.SortWrapper","text":"SortWrapper(system)\n\nConvenience wrapper for systems whose elements cannot be sorted in-place (e.g. structured grids). The resulting object is treated like any other system.\n\n\n\n\n\n","category":"method"},{"location":"reference/#FastMultipole.Tree","page":"Reference","title":"FastMultipole.Tree","text":"abstract type Tree{TF,P} end\n\nSupertype of all octree structures with TF the floating point type and P the expansion order.\n\n\n\n\n\n","category":"type"},{"location":"reference/#FastMultipole.L2B_velocity-Union{Tuple{VPS}, Tuple{PS}, Tuple{TF2}, Tuple{TF1}, Tuple{TF1, Any, Any, Any, Any, Any, Any, Any, TF2, Any, Any, Any, Any, Any, Any, Any, Any, Any, DerivativesSwitch{PS, VPS}}} where {TF1, TF2, PS, VPS}","page":"Reference","title":"FastMultipole.L2B_velocity","text":"Does not include the rotation matrix R yet. Eq 28 in S&L\n\n\n\n\n\n","category":"method"},{"location":"reference/#FastMultipole.L2B_velocity_gradient-Union{Tuple{VPS}, Tuple{PS}, Tuple{TF}, Tuple{TF, Any, Any, Any, Any, Any, Any, Any, Any, Any, Any, Any, Any, Any, Any, Any, Any, Any, Any, Any, Any, Any, Any, Any, Any, DerivativesSwitch{PS, VPS}}} where {TF, PS, VPS}","page":"Reference","title":"FastMultipole.L2B_velocity_gradient","text":"Eq 35-37 S&L\n\n\n\n\n\n","category":"method"},{"location":"reference/#FastMultipole.d2rdx2-Tuple{Any, Any, Any}","page":"Reference","title":"FastMultipole.d2rdx2","text":"drk/dxidx_j\n\n\n\n\n\n","category":"method"},{"location":"reference/#FastMultipole.direct!-Tuple{Any, Any}","page":"Reference","title":"FastMultipole.direct!","text":"direct!(target_system, source_system; derivatives_switches)\n\nApplies all interactions of source_system acting on target_system without multipole acceleration.\n\nArguments\n\ntarget_system: either\na system object for which compatibility functions have been overloaded, or\na tuple of system objects for which compatibility functions have been overloaded\nsource_system: either\na system object for which compatibility functions have been overloaded, or\na tuple of system objects for which compatibility functions have been overloaded\n\nOptional Arguments\n\nderivatives_switches::DerivativesSwitch: determines whether to include the scalar potential, vector potential, velocity, and/or velocity gradient for the target_system; either\n(if target_system is not a ::Tuple of systems) an instance of DerivativesSwitch\n(if target_system is a ::Tuple of systems) a ::Tuple of DerivativesSwitch of length length(target_systems)\n\n\n\n\n\n","category":"method"},{"location":"reference/#FastMultipole.direct!-Tuple{Tuple}","page":"Reference","title":"FastMultipole.direct!","text":"direct!(systems; derivatives_switches)\n\nApplies all interactions of systems acting on itself without multipole acceleration.\n\nArguments\n\nsystems: either\na system object for which compatibility functions have been overloaded, or\na tuple of system objects for which compatibility functions have been overloaded\n\nOptional Arguments\n\nderivatives_switches::DerivativesSwitch: determines whether to include the scalar potential, vector potential, velocity, and/or velocity gradient when solving the n-body problem; either\n(if systems is not a ::Tuple of systems) an instance of DerivativesSwitch\n(if systems is a ::Tuple of systems) a ::Tuple of DerivativesSwitch of length length(systems)\n\n\n\n\n\n","category":"method"},{"location":"reference/#FastMultipole.drdx-Tuple{Any, Any, Any}","page":"Reference","title":"FastMultipole.drdx","text":"drj/dxi\n\n\n\n\n\n","category":"method"},{"location":"reference/#FastMultipole.fmm!-Tuple{Any, Any}","page":"Reference","title":"FastMultipole.fmm!","text":"fmm!(target_systems, source_systems; kwargs...)\n\nApply all interactions of source_systems acting on target_systems using the fast multipole method. Assumes compatibility functions have been overloaded for both source and target systems.\n\nArguments\n\ntarget_systems: either\na system object for which compatibility functions have been overloaded, or\na tuple of system objects for which compatibility functions have been overloaded\nsource_systems: either\na system object for which compatibility functions have been overloaded, or\na tuple of system objects for which compatibility functions have been overloaded\n\nOptional Arguments\n\nexpansion_order::Int: the expansion order to be used\nn_per_branch_source::Int: maximum number of bodies from source_systems allowed in a leaf-level branch\nn_per_branch_target::Int: maximum number of bodies from target_systems allowed in a leaf-level branch\nmultipole_acceptance_criterion::Float64: number between 0 and 1 (often denoted theta in [0,1]) controls the accuracy by determining the non-dimensional distance after which multipoles are used; 0 means an infinite distance (no error, high cost), and 1 means barely convergent (high error, low cost)\nscalar_potential::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(target_systems) indicating whether each system should receive a scalar potential from source_systems\nvector_potential::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(target_systems) indicating whether each system should receive a vector potential from source_systems\nvelocity::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(target_systems) indicating whether each system should receive a velocity from source_systems\nvelocity_gradient::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(target_systems) indicating whether each system should receive a velocity gradient from source_systems\nnearfield::Bool: indicates whether near-field (comuted without multipoles) interactions should be included\nfarfield::Bool: indicates whether far-field (comuted with multipoles) interactions should be included\nself_induced::Bool: indicates whether to include the interactions of each leaf-level branch on itself\nunsort_source_bodies::Bool: indicates whether or not to undo the sort operation used to generate the octree for the source_systems\nunsort_target_bodies::Bool: indicates whether or not to undo the sort operation used to generate the octree for the target_systems\nsource_shink_recenter::Bool: indicates whether or not to resize branches for the source_systems octree after it is created to increase computational efficiency\ntarget_shink_recenter::Bool: indicates whether or not to resize branches for the target_systems octree after it is created to increase computational efficiency\nsave_tree::Bool: indicates whether or not to save a VTK file for visualizing the octree\nsave_name::String: name and path of the octree visualization if save_tree == true\n\n\n\n\n\n","category":"method"},{"location":"reference/#FastMultipole.fmm!-Tuple{Any}","page":"Reference","title":"FastMultipole.fmm!","text":"fmm!(systems; kwargs...)\n\nApply all interactions of systems acting on itself using the fast multipole method. Assumes compatibility functions have been overloaded for both source and target systems.\n\nArguments\n\nsystems: either\na system object for which compatibility functions have been overloaded, or\na tuple of system objects for which compatibility functions have been overloaded\n\nOptional Arguments\n\nexpansion_order::Int: the expansion order to be used\nn_per_branch::Int: maximum number of bodies from systems allowed in a leaf-level branch\nmultipole_acceptance_criterion::Float64: number between 0 and 1 (often denoted theta in [0,1]) controls the accuracy by determining the non-dimensional distance after which multipoles are used; 0 means an infinite distance (no error, high cost), and 1 means barely convergent (high error, low cost)\nscalar_potential::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(systems) indicating whether each system should receive a scalar potential from source_systems\nvector_potential::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(systems) indicating whether each system should receive a vector potential from source_systems\nvelocity::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(systems) indicating whether each system should receive a velocity from source_systems\nvelocity_gradient::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(systems) indicating whether each system should receive a velocity gradient from source_systems\nnearfield::Bool: indicates whether near-field (comuted without multipoles) interactions should be included\nfarfield::Bool: indicates whether far-field (comuted with multipoles) interactions should be included\nself_induced::Bool: indicates whether to include the interactions of each leaf-level branch on itself\nunsort_bodies::Bool: indicates whether or not to undo the sort operation used to generate the octree for systems\nshink_recenter::Bool: indicates whether or not to resize branches for the octree after it is created to increase computational efficiency\nsave_tree::Bool: indicates whether or not to save a VTK file for visualizing the octree\nsave_name::String: name and path of the octree visualization if save_tree == true\n\n\n\n\n\n","category":"method"},{"location":"reference/#FastMultipole.fmm!-Tuple{Tree, Any, Tree, Any}","page":"Reference","title":"FastMultipole.fmm!","text":"fmm!(target_tree, target_systems, source_tree, source_systems; kwargs...)\n\nDispatches fmm! using existing ::Tree objects.\n\nArguments\n\ntarget_tree::Tree: a <:Tree object (see Tree)\ntarget_systems: either\na system object for which compatibility functions have been overloaded, or\na tuple of system objects for which compatibility functions have been overloaded\nsource_tree::Tree: a <:Tree object (see Tree)\nsource_systems: either\na system object for which compatibility functions have been overloaded, or\na tuple of system objects for which compatibility functions have been overloaded\n\nOptional Arguments\n\nmultipole_acceptance_criterion::Float64: number between 0 and 1 (often denoted theta in [0,1]) controls the accuracy by determining the non-dimensional distance after which multipoles are used; 0 means an infinite distance (no error, high cost), and 1 means barely convergent (high error, low cost)\nscalar_potential::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(target_systems) indicating whether each system should receive a scalar potential from source_systems\nvector_potential::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(target_systems) indicating whether each system should receive a vector potential from source_systems\nvelocity::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(target_systems) indicating whether each system should receive a velocity from source_systems\nvelocity_gradient::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(target_systems) indicating whether each system should receive a velocity gradient from source_systems\nnearfield::Bool: indicates whether near-field (comuted without multipoles) interactions should be included\nfarfield::Bool: indicates whether far-field (comuted with multipoles) interactions should be included\nself_induced::Bool: indicates whether to include the interactions of each leaf-level branch on itself\nunsort_source_bodies::Bool: indicates whether or not to undo the sort operation used to generate the octree for source_systems\nunsort_target_bodies::Bool: indicates whether or not to undo the sort operation used to generate the octree for target_systems\n\n\n\n\n\n","category":"method"},{"location":"reference/#FastMultipole.fmm!-Tuple{Tree, Any}","page":"Reference","title":"FastMultipole.fmm!","text":"fmm!(tree, systems; kwargs...)\n\nDispatches fmm! using an existing ::Tree.\n\nArguments\n\ntree::Tree: a <:Tree object (see Tree)\nsystems: either\na system object for which compatibility functions have been overloaded, or\na tuple of system objects for which compatibility functions have been overloaded\n\nOptional Arguments\n\nmultipole_acceptance_criterion::Float64: number between 0 and 1 (often denoted theta in [0,1]) controls the accuracy by determining the non-dimensional distance after which multipoles are used; 0 means an infinite distance (no error, high cost), and 1 means barely convergent (high error, low cost)\nscalar_potential::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(systems) indicating whether each system should receive a scalar potential from source_systems\nvector_potential::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(systems) indicating whether each system should receive a vector potential from source_systems\nvelocity::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(systems) indicating whether each system should receive a velocity from source_systems\nvelocity_gradient::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(systems) indicating whether each system should receive a velocity gradient from source_systems\nnearfield::Bool: indicates whether near-field (comuted without multipoles) interactions should be included\nfarfield::Bool: indicates whether far-field (comuted with multipoles) interactions should be included\nself_induced::Bool: indicates whether to include the interactions of each leaf-level branch on itself\nunsort_bodies::Bool: indicates whether or not to undo the sort operation used to generate the octree for systems\n\n\n\n\n\n","category":"method"},{"location":"reference/#FastMultipole.reset!-Tuple{ProbeSystem}","page":"Reference","title":"FastMultipole.reset!","text":"reset!(probes)\n\nZeroes all values (e.g. scalar/vector potential, velocity, and/or velocity gradient) of all probes.\n\nArguments\n\nprobes::ProbeSystem: a ::ProbeSystem object\n\n\n\n\n\n","category":"method"},{"location":"reference/#FastMultipole.unsort!-Tuple{Tuple, FastMultipole.MultiTree}","page":"Reference","title":"FastMultipole.unsort!","text":"Undoes the sort operation performed by the tree.\n\n\n\n\n\n","category":"method"},{"location":"#FastMultipole","page":"Introduction","title":"FastMultipole","text":"","category":"section"},{"location":"","page":"Introduction","title":"Introduction","text":"FastMultipole is a highly performant, CPU parallelized fast multipole code suitable for accelerating large N-body problems in scalar and or vector potentials with a wide range of applications, including astronomy, electro-magnetism, and fluid-dynamics. Typical use cases include boundary element problems, such as 3-dimensional panel methods. The code is compatible with ForwardDiff and ReverseDiff algorithmic differentiation for gradient-based design optimization. Its elegant interface makes it extremely easy to incorporate into existing Julia code with minimal modification. Convenience functions are provided for generating the expansions of source and vortex points and constant source and doublet panels, with more support planned for the future. It currently supports only the Laplace kernel, though this may change soon.","category":"page"}] +[{"location":"guided_examples/#Guided-Examples","page":"Guided Examples","title":"Guided Examples","text":"","category":"section"},{"location":"guided_examples/","page":"Guided Examples","title":"Guided Examples","text":"This section a work in progress.","category":"page"},{"location":"theory/#Theory","page":"Theory","title":"Theory","text":"","category":"section"},{"location":"theory/","page":"Theory","title":"Theory","text":"An explanation of the theory can be found here.","category":"page"},{"location":"quickstart/#Quick-Start","page":"Quick Start","title":"Quick Start","text":"","category":"section"},{"location":"quickstart/","page":"Quick Start","title":"Quick Start","text":"The tutorial for FastMultipole is a work in progress. While we work on creating a tutorial, see the example file scripts/simple_gravitational.jl.","category":"page"},{"location":"reference/#Reference","page":"Reference","title":"Reference","text":"","category":"section"},{"location":"reference/","page":"Reference","title":"Reference","text":"CurrentModule = FastMultipole","category":"page"},{"location":"reference/","page":"Reference","title":"Reference","text":"Modules = [FastMultipole]\nOrder = [:constant, :type, :function]\n# Pages = [\"fmm.jl\"]","category":"page"},{"location":"reference/","page":"Reference","title":"Reference","text":"Modules = [FastMultipole]\nOrder = [:constant, :type, :function]\n# Pages = [\"fmm.jl\"]","category":"page"},{"location":"reference/#FastMultipole.DerivativesSwitch","page":"Reference","title":"FastMultipole.DerivativesSwitch","text":"DerivativesSwitch\n\nSwitch indicating whether the scalar potential, vector potential, velocity, and/or velocity gradient should be computed for a target system. Information is stored as type parameters, allowing the compiler to compile away if statements.\n\n\n\n\n\n","category":"type"},{"location":"reference/#FastMultipole.DerivativesSwitch-NTuple{4, Any}","page":"Reference","title":"FastMultipole.DerivativesSwitch","text":"DerivativesSwitch(scalar_potential, vector_potential, velocity, velocity_gradient)\n\nConstructs a tuple of DerivativesSwitch objects.\n\nArguments\n\nscalar_potential::Vector{Bool}: a vector of ::Bool indicating whether the scalar potential should be computed for each target system\nvector_potential::Vector{Bool}: a vector of ::Bool indicating whether the vector potential should be computed for each target system\nvelocity::Vector{Bool}: a vector of ::Bool indicating whether the velocity should be computed for each target system\nvelocity_gradient::Vector{Bool}: a vector of ::Bool indicating whether the velocity gradient should be computed for each target system\n\n\n\n\n\n","category":"method"},{"location":"reference/#FastMultipole.DerivativesSwitch-NTuple{4, Bool}","page":"Reference","title":"FastMultipole.DerivativesSwitch","text":"DerivativesSwitch(scalar_potential, vector_potential, velocity, velocity_gradient)\n\nConstructs a single DerivativesSwitch object.\n\nArguments\n\nscalar_potential::Bool: a ::Bool indicating whether the scalar potential should be computed for the target system\nvector_potential::Bool: a ::Bool indicating whether the vector potential should be computed for the target system\nvelocity::Bool: a ::Bool indicating whether the velocity should be computed for the target system\nvelocity_gradient::Bool: a ::Bool indicating whether the velocity gradient should be computed for the target system\n\n\n\n\n\n","category":"method"},{"location":"reference/#FastMultipole.DerivativesSwitch-Tuple{Bool, Bool, Bool, Bool, Tuple}","page":"Reference","title":"FastMultipole.DerivativesSwitch","text":"DerivativesSwitch(scalar_potential, vector_potential, velocity, velocity_gradient, target_systems)\n\nConstructs a ::Tuple of indentical DerivativesSwitch objects of the same length as target_systems (if it is a ::Tuple), or a single DerivativesSwitch (if target_system is not a ::Tuple)\n\nArguments\n\nscalar_potential::Bool: a ::Bool indicating whether the scalar potential should be computed for each target system\nvector_potential::Bool: a ::Bool indicating whether the vector potential should be computed for each target system\nvelocity::Bool: a ::Bool indicating whether the velocity should be computed for each target system\nvelocity_gradient::Bool: a ::Bool indicating whether the velocity gradient should be computed for each target system\n\n\n\n\n\n","category":"method"},{"location":"reference/#FastMultipole.MultiTree","page":"Reference","title":"FastMultipole.MultiTree","text":"bodies[indexlist] is the same sort operation as performed by the tree sortedbodies[inverseindexlist] undoes the sort operation performed by the tree\n\n\n\n\n\n","category":"type"},{"location":"reference/#FastMultipole.ProbeSystem","page":"Reference","title":"FastMultipole.ProbeSystem","text":"ProbeSystem\n\nConvenience system for defining locations at which the potential, velocity, or velocity gradient may be desired.\n\n\n\n\n\n","category":"type"},{"location":"reference/#FastMultipole.ProbeSystem-Union{Tuple{Array{StaticArraysCore.SVector{3, TF}, 1}}, Tuple{TF}} where TF","page":"Reference","title":"FastMultipole.ProbeSystem","text":"ProbeSystem(positions; kwargs...)\n\nA convenience system constructor for calculating the influence of source systems at locations not already described by a system object. It behaves like a system whose elements induce a null potential field.\n\nArguments\n\npositions::Vector{SVector{3,Float64}}: a vector of position vectors of each probe\n\nOptional Arguments\n\nscalar_potential::Bool: whether or not to compute the scalar potential at each probe location\nvector_potential::Bool: whether or not to compute the vector potential at each probe location\nvelocity::Bool: whether or not to compute the velocity at each probe location\nvelocity_gradient::Bool: whether or not to compute the velocity gradient at each probe location\n\n\n\n\n\n","category":"method"},{"location":"reference/#FastMultipole.ProbeSystem-Union{Tuple{Matrix{TF}}, Tuple{TF}} where TF","page":"Reference","title":"FastMultipole.ProbeSystem","text":"ProbeSystem(positions; kwargs...)\n\nDispatch of ProbeSystem accepting a matrix of horizontally concatenated column vectors describing the position of each probe. Optional arguments are identical.\n\n\n\n\n\n","category":"method"},{"location":"reference/#FastMultipole.SortWrapper-Tuple{Any}","page":"Reference","title":"FastMultipole.SortWrapper","text":"SortWrapper(system)\n\nConvenience wrapper for systems whose elements cannot be sorted in-place (e.g. structured grids). The resulting object is treated like any other system.\n\n\n\n\n\n","category":"method"},{"location":"reference/#FastMultipole.Tree","page":"Reference","title":"FastMultipole.Tree","text":"abstract type Tree{TF,P} end\n\nSupertype of all octree structures with TF the floating point type and P the expansion order.\n\n\n\n\n\n","category":"type"},{"location":"reference/#FastMultipole.L2B_velocity-Union{Tuple{VPS}, Tuple{PS}, Tuple{TF2}, Tuple{TF1}, Tuple{TF1, Any, Any, Any, Any, Any, Any, Any, TF2, Any, Any, Any, Any, Any, Any, Any, Any, Any, DerivativesSwitch{PS, VPS}}} where {TF1, TF2, PS, VPS}","page":"Reference","title":"FastMultipole.L2B_velocity","text":"Does not include the rotation matrix R yet. Eq 28 in S&L\n\n\n\n\n\n","category":"method"},{"location":"reference/#FastMultipole.L2B_velocity_gradient-Union{Tuple{VPS}, Tuple{PS}, Tuple{TF}, Tuple{TF, Any, Any, Any, Any, Any, Any, Any, Any, Any, Any, Any, Any, Any, Any, Any, Any, Any, Any, Any, Any, Any, Any, Any, Any, DerivativesSwitch{PS, VPS}}} where {TF, PS, VPS}","page":"Reference","title":"FastMultipole.L2B_velocity_gradient","text":"Eq 35-37 S&L\n\n\n\n\n\n","category":"method"},{"location":"reference/#FastMultipole.add_line!-Tuple{ProbeSystem, Vararg{Any, 4}}","page":"Reference","title":"FastMultipole.add_line!","text":"add_line!(probes::ProbeSystem, x1, x2, n_probes, i_last)\n\nAdds n_probes probes in a line between x1 and x2. Specifically, they are added at the midpoint of equally partiti oned segments of the line.\n\nArguments\n\nprobes::ProbeSystem: the probe system whose .position field is to be updated\nx1::Vector{Float64}: the first point defining the line along which probes are to be added\nx2::Vector{Float64}: the second point defining the line along which probes are to be added\nn_probes::Int: number of probes to be added\ni_last::Int: index of the last probe in probes\n\nOutput\n\ni_last::Int: updated index of the last probe in probes\n\n\n\n\n\n","category":"method"},{"location":"reference/#FastMultipole.d2rdx2-Tuple{Any, Any, Any}","page":"Reference","title":"FastMultipole.d2rdx2","text":"drk/dxidx_j\n\n\n\n\n\n","category":"method"},{"location":"reference/#FastMultipole.direct!-Tuple{Any, Any}","page":"Reference","title":"FastMultipole.direct!","text":"direct!(target_system, source_system; derivatives_switches)\n\nApplies all interactions of source_system acting on target_system without multipole acceleration.\n\nArguments\n\ntarget_system: either\na system object for which compatibility functions have been overloaded, or\na tuple of system objects for which compatibility functions have been overloaded\nsource_system: either\na system object for which compatibility functions have been overloaded, or\na tuple of system objects for which compatibility functions have been overloaded\n\nOptional Arguments\n\nderivatives_switches::DerivativesSwitch: determines whether to include the scalar potential, vector potential, velocity, and/or velocity gradient for the target_system; either\n(if target_system is not a ::Tuple of systems) an instance of DerivativesSwitch\n(if target_system is a ::Tuple of systems) a ::Tuple of DerivativesSwitch of length length(target_systems)\n\n\n\n\n\n","category":"method"},{"location":"reference/#FastMultipole.direct!-Tuple{Tuple}","page":"Reference","title":"FastMultipole.direct!","text":"direct!(systems; derivatives_switches)\n\nApplies all interactions of systems acting on itself without multipole acceleration.\n\nArguments\n\nsystems: either\na system object for which compatibility functions have been overloaded, or\na tuple of system objects for which compatibility functions have been overloaded\n\nOptional Arguments\n\nderivatives_switches::DerivativesSwitch: determines whether to include the scalar potential, vector potential, velocity, and/or velocity gradient when solving the n-body problem; either\n(if systems is not a ::Tuple of systems) an instance of DerivativesSwitch\n(if systems is a ::Tuple of systems) a ::Tuple of DerivativesSwitch of length length(systems)\n\n\n\n\n\n","category":"method"},{"location":"reference/#FastMultipole.drdx-Tuple{Any, Any, Any}","page":"Reference","title":"FastMultipole.drdx","text":"drj/dxi\n\n\n\n\n\n","category":"method"},{"location":"reference/#FastMultipole.fmm!-Tuple{Any, Any}","page":"Reference","title":"FastMultipole.fmm!","text":"fmm!(target_systems, source_systems; kwargs...)\n\nApply all interactions of source_systems acting on target_systems using the fast multipole method. Assumes compatibility functions have been overloaded for both source and target systems.\n\nArguments\n\ntarget_systems: either\na system object for which compatibility functions have been overloaded, or\na tuple of system objects for which compatibility functions have been overloaded\nsource_systems: either\na system object for which compatibility functions have been overloaded, or\na tuple of system objects for which compatibility functions have been overloaded\n\nOptional Arguments\n\nexpansion_order::Int: the expansion order to be used\nn_per_branch_source::Int: maximum number of bodies from source_systems allowed in a leaf-level branch\nn_per_branch_target::Int: maximum number of bodies from target_systems allowed in a leaf-level branch\nmultipole_acceptance_criterion::Float64: number between 0 and 1 (often denoted theta in [0,1]) controls the accuracy by determining the non-dimensional distance after which multipoles are used; 0 means an infinite distance (no error, high cost), and 1 means barely convergent (high error, low cost)\nscalar_potential::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(target_systems) indicating whether each system should receive a scalar potential from source_systems\nvector_potential::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(target_systems) indicating whether each system should receive a vector potential from source_systems\nvelocity::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(target_systems) indicating whether each system should receive a velocity from source_systems\nvelocity_gradient::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(target_systems) indicating whether each system should receive a velocity gradient from source_systems\nnearfield::Bool: indicates whether near-field (comuted without multipoles) interactions should be included\nfarfield::Bool: indicates whether far-field (comuted with multipoles) interactions should be included\nself_induced::Bool: indicates whether to include the interactions of each leaf-level branch on itself\nunsort_source_bodies::Bool: indicates whether or not to undo the sort operation used to generate the octree for the source_systems\nunsort_target_bodies::Bool: indicates whether or not to undo the sort operation used to generate the octree for the target_systems\nsource_shink_recenter::Bool: indicates whether or not to resize branches for the source_systems octree after it is created to increase computational efficiency\ntarget_shink_recenter::Bool: indicates whether or not to resize branches for the target_systems octree after it is created to increase computational efficiency\nsave_tree::Bool: indicates whether or not to save a VTK file for visualizing the octree\nsave_name::String: name and path of the octree visualization if save_tree == true\n\n\n\n\n\n","category":"method"},{"location":"reference/#FastMultipole.fmm!-Tuple{Any}","page":"Reference","title":"FastMultipole.fmm!","text":"fmm!(systems; kwargs...)\n\nApply all interactions of systems acting on itself using the fast multipole method. Assumes compatibility functions have been overloaded for both source and target systems.\n\nArguments\n\nsystems: either\na system object for which compatibility functions have been overloaded, or\na tuple of system objects for which compatibility functions have been overloaded\n\nOptional Arguments\n\nexpansion_order::Int: the expansion order to be used\nn_per_branch::Int: maximum number of bodies from systems allowed in a leaf-level branch\nmultipole_acceptance_criterion::Float64: number between 0 and 1 (often denoted theta in [0,1]) controls the accuracy by determining the non-dimensional distance after which multipoles are used; 0 means an infinite distance (no error, high cost), and 1 means barely convergent (high error, low cost)\nscalar_potential::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(systems) indicating whether each system should receive a scalar potential from source_systems\nvector_potential::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(systems) indicating whether each system should receive a vector potential from source_systems\nvelocity::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(systems) indicating whether each system should receive a velocity from source_systems\nvelocity_gradient::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(systems) indicating whether each system should receive a velocity gradient from source_systems\nnearfield::Bool: indicates whether near-field (comuted without multipoles) interactions should be included\nfarfield::Bool: indicates whether far-field (comuted with multipoles) interactions should be included\nself_induced::Bool: indicates whether to include the interactions of each leaf-level branch on itself\nunsort_bodies::Bool: indicates whether or not to undo the sort operation used to generate the octree for systems\nshink_recenter::Bool: indicates whether or not to resize branches for the octree after it is created to increase computational efficiency\nsave_tree::Bool: indicates whether or not to save a VTK file for visualizing the octree\nsave_name::String: name and path of the octree visualization if save_tree == true\n\n\n\n\n\n","category":"method"},{"location":"reference/#FastMultipole.fmm!-Tuple{Tree, Any, Tree, Any}","page":"Reference","title":"FastMultipole.fmm!","text":"fmm!(target_tree, target_systems, source_tree, source_systems; kwargs...)\n\nDispatches fmm! using existing ::Tree objects.\n\nArguments\n\ntarget_tree::Tree: a <:Tree object (see Tree)\ntarget_systems: either\na system object for which compatibility functions have been overloaded, or\na tuple of system objects for which compatibility functions have been overloaded\nsource_tree::Tree: a <:Tree object (see Tree)\nsource_systems: either\na system object for which compatibility functions have been overloaded, or\na tuple of system objects for which compatibility functions have been overloaded\n\nOptional Arguments\n\nmultipole_acceptance_criterion::Float64: number between 0 and 1 (often denoted theta in [0,1]) controls the accuracy by determining the non-dimensional distance after which multipoles are used; 0 means an infinite distance (no error, high cost), and 1 means barely convergent (high error, low cost)\nscalar_potential::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(target_systems) indicating whether each system should receive a scalar potential from source_systems\nvector_potential::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(target_systems) indicating whether each system should receive a vector potential from source_systems\nvelocity::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(target_systems) indicating whether each system should receive a velocity from source_systems\nvelocity_gradient::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(target_systems) indicating whether each system should receive a velocity gradient from source_systems\nnearfield::Bool: indicates whether near-field (comuted without multipoles) interactions should be included\nfarfield::Bool: indicates whether far-field (comuted with multipoles) interactions should be included\nself_induced::Bool: indicates whether to include the interactions of each leaf-level branch on itself\nunsort_source_bodies::Bool: indicates whether or not to undo the sort operation used to generate the octree for source_systems\nunsort_target_bodies::Bool: indicates whether or not to undo the sort operation used to generate the octree for target_systems\n\n\n\n\n\n","category":"method"},{"location":"reference/#FastMultipole.fmm!-Tuple{Tree, Any}","page":"Reference","title":"FastMultipole.fmm!","text":"fmm!(tree, systems; kwargs...)\n\nDispatches fmm! using an existing ::Tree.\n\nArguments\n\ntree::Tree: a <:Tree object (see Tree)\nsystems: either\na system object for which compatibility functions have been overloaded, or\na tuple of system objects for which compatibility functions have been overloaded\n\nOptional Arguments\n\nmultipole_acceptance_criterion::Float64: number between 0 and 1 (often denoted theta in [0,1]) controls the accuracy by determining the non-dimensional distance after which multipoles are used; 0 means an infinite distance (no error, high cost), and 1 means barely convergent (high error, low cost)\nscalar_potential::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(systems) indicating whether each system should receive a scalar potential from source_systems\nvector_potential::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(systems) indicating whether each system should receive a vector potential from source_systems\nvelocity::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(systems) indicating whether each system should receive a velocity from source_systems\nvelocity_gradient::Bool: either a ::Bool or a ::AbstractVector{Bool} of length length(systems) indicating whether each system should receive a velocity gradient from source_systems\nnearfield::Bool: indicates whether near-field (comuted without multipoles) interactions should be included\nfarfield::Bool: indicates whether far-field (comuted with multipoles) interactions should be included\nself_induced::Bool: indicates whether to include the interactions of each leaf-level branch on itself\nunsort_bodies::Bool: indicates whether or not to undo the sort operation used to generate the octree for systems\n\n\n\n\n\n","category":"method"},{"location":"reference/#FastMultipole.reset!-Tuple{ProbeSystem}","page":"Reference","title":"FastMultipole.reset!","text":"reset!(probes)\n\nZeroes all values (e.g. scalar/vector potential, velocity, and/or velocity gradient) of all probes.\n\nArguments\n\nprobes::ProbeSystem: a ::ProbeSystem object\n\n\n\n\n\n","category":"method"},{"location":"reference/#FastMultipole.unsort!-Tuple{Tuple, FastMultipole.MultiTree}","page":"Reference","title":"FastMultipole.unsort!","text":"Undoes the sort operation performed by the tree.\n\n\n\n\n\n","category":"method"},{"location":"#FastMultipole","page":"Introduction","title":"FastMultipole","text":"","category":"section"},{"location":"","page":"Introduction","title":"Introduction","text":"FastMultipole is a highly performant, CPU parallelized fast multipole code suitable for accelerating large N-body problems in scalar and or vector potentials with a wide range of applications, including astronomy, electro-magnetism, and fluid-dynamics. Typical use cases include boundary element problems, such as 3-dimensional panel methods. The code is compatible with ForwardDiff and ReverseDiff algorithmic differentiation for gradient-based design optimization. Its elegant interface makes it extremely easy to incorporate into existing Julia code with minimal modification. Convenience functions are provided for generating the expansions of source and vortex points and constant source and doublet panels, with more support planned for the future. It currently supports only the Laplace kernel, though this may change soon.","category":"page"}] } diff --git a/dev/theory/index.html b/dev/theory/index.html index be5472e..a45e4b2 100644 --- a/dev/theory/index.html +++ b/dev/theory/index.html @@ -1,2 +1,2 @@ -Theory · FastMultipole.jl

Theory

An explanation of the theory can be found here.

+Theory · FastMultipole.jl

Theory

An explanation of the theory can be found here.