-
-
Notifications
You must be signed in to change notification settings - Fork 30
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
1 changed file
with
61 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,3 +1,63 @@ | ||
# Frequently Asked Questions | ||
|
||
Ask more questions. | ||
## How should I use the in-place interface? | ||
|
||
The in-place interface allows evaluating vector-valued integrands without | ||
allocating an output array. This can be beneficial for reducing allocations when | ||
integrating many functions simultaneously or to make use of existing in-place | ||
code. However, note that not all algorithms use in-place operations under the | ||
hood, i.e. `HCubatureJL()`, and may still allocate. | ||
|
||
You can construct an `IntegralFunction(f, prototype)`, where `f` is of the form | ||
`f(y, u, p)` where `prototype` is of the desired type and shape of `y`. | ||
|
||
For small array outputs of a known size, consider using StaticArrays.jl for the | ||
return value of your integrand. | ||
|
||
## How should I use the batch interface? | ||
|
||
The batch interface allows evaluating one (or more) integrals simultaneously at | ||
different points, which maximizes the parallelism for a given algorithm. | ||
|
||
You can construct an out-of-place `BatchIntegralFunction(bf)` where `bf` is of | ||
the form `bf(u, p) = stack(x -> f(x, p), eachslice(u; dims=ndims(u)))`, where | ||
`f` is the (unbatched) integrand. | ||
|
||
You can construct an in-place `BatchIntegralFunction(bf, prototype)`, where `bf` | ||
is of the form `bf(y, u, p) = foreach((y,x) -> f(y,x,p), eachslice(y, dims=ndims(y)), eachslice(x, dims=ndims(x)))`. | ||
|
||
Note that not all algorithms use in-place batched operations under the hood, | ||
i.e. `QuadGKJL()`. | ||
|
||
## What should I do if my solution is not converged? | ||
|
||
Certain algorithms, such as `QuadratureRule` used a fixed number of points to | ||
calculate an integral and cannot provide an error estimate. In this case, you | ||
have to increase the number of points and check the convergence yourself, which | ||
will depend on the accuracy of the rule you choose. | ||
|
||
For badly-behaved integrands, such as (nearly) singular and highly oscillatory | ||
functions, most algorithms will fail to converge and either throw an error or | ||
silently return the incorrect result. In some cases Integrals.jl can provide an | ||
error code when things go wrong, but otherwise you can always check if the error | ||
estimate for the integral is less than the requested tolerance, e.g. `sol.resid | ||
< max(abstol, reltol*norm(sol.u))`. Sometimes using a larger tolerance or higher | ||
precision arithmetic may help. | ||
|
||
## How can I integrate arbitrarily-spaced data? | ||
|
||
See `SampledIntegralProblem`. | ||
|
||
## How can I integrate on arbitrary geometries? | ||
|
||
You can't, since Integrals.jl currently supports integration on hypercubes | ||
because that is what lower-level packages implement. | ||
|
||
## I don't see algorithm X or quadrature scheme Y ? | ||
|
||
Fixed quadrature rules from other packages can be used with `QuadratureRule`. | ||
Otherwise, feel free to open an issue or pull request. | ||
|
||
## Can I take derivatives with respect to the limits of integration? | ||
|
||
Currently this is not implemented. |