The SciML common interface ties together the numerical solvers of the Julia package ecosystem into a single unified interface. It is designed for maximal efficiency and parallelism, while incorporating essential features for large-scale scientific machine learning such as differentiability, composability, and sparsity.
This documentation is made to pool together the docs of the various SciML libraries to paint the overarching picture, establish development norms, and document the shared/common functionality.
The SciML common interface covers the following domains:
Linear systems (LinearProblem
)
- Direct methods for dense and sparse
- Iterative solvers with preconditioning
Nonlinear Systems (NonlinearProblem
)
- Rootfinding for systems of nonlinear equations
Interval Nonlinear Systems
- Bracketing rootfinders for nonlinear equations with interval bounds
Integrals (quadrature) (IntegralProblem
)
Differential Equations
- Discrete equations (function maps, discrete stochastic (Gillespie/Markov) simulations) (
DiscreteProblem
) - Ordinary differential equations (ODEs) (
ODEProblem
) - Split and Partitioned ODEs (Symplectic integrators, IMEX Methods) (
SplitODEProblem
) - Stochastic ordinary differential equations (SODEs or SDEs) (
SDEProblem
) - Stochastic differential-algebraic equations (SDAEs) (
SDEProblem
with mass matrices) - Random differential equations (RODEs or RDEs) (
RODEProblem
) - Differential algebraic equations (DAEs) (
DAEProblem
and ODEProblem
with mass matrices) - Delay differential equations (DDEs) (
DDEProblem
) - Neutral, retarded, and algebraic delay differential equations (NDDEs, RDDEs, and DDAEs)
- Stochastic delay differential equations (SDDEs) (
SDDEProblem
) - Experimental support for stochastic neutral, retarded, and algebraic delay differential equations (SNDDEs, SRDDEs, and SDDAEs)
- Mixed discrete and continuous equations (Hybrid Equations, Jump Diffusions) (
AbstractDEProblem
s with callbacks)
Optimization (OptimizationProblem
)
- Nonlinear (constrained) optimization
(Stochastic/Delay/Differential-Algebraic) Partial Differential Equations (PDESystem
)
- Finite difference and finite volume methods
- Interfaces to finite element methods
- Physics-Informed Neural Networks (PINNs)
- Integro-Differential Equations
- Fractional Differential Equations
The SciML common interface also includes ModelingToolkit.jl for defining such systems symbolically, allowing for optimizations like automated generation of parallel code, symbolic simplification, and generation of sparsity patterns.
In addition to the purely numerical representations of mathematical objects, there are also sets of problem types associated with common mathematical algorithms. These are:
We note that parameter estimation and inverse problems are solved directly on their constituent problem types using tools like DiffEqFlux.jl. Thus for example, there is no ODEInverseProblem
, and instead ODEProblem
is used to find the parameters p
that solve the inverse problem.
The SciML interface is common as the usage of arguments is standardized across all of the problem domains. Underlying high level ideas include:
- All domains use the same interface of defining a
AbstractSciMLProblem
which is then solved via solve(prob,alg;kwargs)
, where alg
is a AbstractSciMLAlgorithm
. The keyword argument namings are standardized across the organization. AbstractSciMLProblem
s are generally defined by a SciMLFunction
which can define extra details about a model function, such as its analytical Jacobian, its sparsity patterns and so on.- There is an organization-wide method for defining linear and nonlinear solvers used within other solvers, giving maximum control of performance to the user.
- Types used within the packages are defined by the input types. For example, packages attempt to internally use the type of the initial condition as the type for the state within differential equation solvers.
solve
calls should be thread-safe and parallel-safe.init(prob,alg;kwargs)
returns an iterator which allows for directly iterating over the solution process- High performance is key. Any performance that is not at the top level is considered a bug and should be reported as such.
- All functions have an in-place and out-of-place form, where the in-place form is made to utilize mutation for high performance on large-scale problems and the out-of-place form is for compatibility with tooling like static arrays and some reverse-mode automatic differentiation systems.
DifferentialEquations.jl
- Multi-package interface of high performance numerical solvers of differential equations
ModelingToolkit.jl
- The symbolic modeling package which implements the SciML symbolic common interface.
LinearSolve.jl
- Multi-package interface for specifying linear solvers (direct, sparse, and iterative), along with tools for caching and preconditioners for use in large-scale modeling.
NonlinearSolve.jl
- High performance numerical solving of nonlinear systems.
Integrals.jl
- Multi-package interface for high performance, batched, and parallelized numerical quadrature.
Optimization.jl
- Multi-package interface for numerical solving of optimization problems.
NeuralPDE.jl
- Physics-Informed Neural Network (PINN) package for transforming partial differential equations into optimization problems.
DiffEqOperators.jl
- Automated finite difference method (FDM) package for transforming partial differential equations into nonlinear problems and ordinary differential equations.
DiffEqFlux.jl
- High level package for scientific machine learning applications, such as neural and universal differential equations, solving of inverse problems, parameter estimation, nonlinear optimal control, and more.
DataDrivenDiffEq.jl
- Multi-package interface for data-driven modeling, Koopman dynamic mode decomposition, symbolic regression/sparsification, and automated model discovery.
SciMLExpectations.jl
- Extension to the dynamical modeling tools for calculating expectations.
SciMLBase.jl
- The core package defining the interface which is consumed by the modeling and solver packages.
DiffEqBase.jl
- The core package defining the extended interface which is consumed by the differential equation solver packages.
SciMLSensitivity.jl
- A package which pools together the definition of derivative overloads to define the common
sensealg
automatic differentiation interface.
DiffEqNoiseProcess.jl
- A package which defines the stochastic
AbstractNoiseProcess
interface for the SciML ecosystem.
RecursiveArrayTools.jl
- A package which defines the underlying
AbstractVectorOfArray
structure used as the output for all time series results.
ArrayInterface.jl
- The package which defines the extended
AbstractArray
interface employed throughout the SciML ecosystem.
There are too many to name here and this will be populated when there is time!
The following example showcases how the pieces of the common interface connect to solve a problem that mixes inference, symbolics, and numerics.
diffeqr
- Solving differential equations in R using DifferentialEquations.jl with ModelingToolkit for JIT compilation and GPU-acceleration
diffeqpy
- Solving differential equations in Python using DifferentialEquations.jl
There are too many to name here. Check out the SciML Organization Github Page for details.
The documentation of this SciML package was built using these direct dependencies,
Status `~/work/SciMLBase.jl/SciMLBase.jl/docs/Project.toml`
[e30172f5] Documenter v1.4.0
[961ee093] ModelingToolkit v9.12.1
- [0bca4576] SciMLBase v2.35.0 `~/work/SciMLBase.jl/SciMLBase.jl`
and using this machine and Julia version.
Julia Version 1.10.2
-Commit bd47eca2c8a (2024-03-01 10:14 UTC)
+ [0bca4576] SciMLBase v2.35.0 `~/work/SciMLBase.jl/SciMLBase.jl`
and using this machine and Julia version.
Julia Version 1.10.3
+Commit 0b4590a5507 (2024-04-30 10:59 UTC)
Build Info:
Official https://julialang.org/ release
Platform Info:
@@ -45,13 +45,13 @@
[864edb3b] DataStructures v0.18.20
[e2d170a0] DataValueInterfaces v1.0.0
[2b5f629d] DiffEqBase v6.149.1
- [459566f4] DiffEqCallbacks v3.6.1
+ [459566f4] DiffEqCallbacks v3.6.2
[163ba53b] DiffResults v1.1.0
[b552c78f] DiffRules v1.15.1
[31c24e10] Distributions v0.25.108
[ffbed154] DocStringExtensions v0.9.3
[e30172f5] Documenter v1.4.0
- [5b8099bc] DomainSets v0.7.12
+ [5b8099bc] DomainSets v0.7.13
[fa6b7ba4] DualNumbers v0.6.8
[7c1d4256] DynamicPolynomials v0.5.6
[06fc5a27] DynamicQuantities v0.13.2
@@ -89,9 +89,9 @@
[98e50ef6] JuliaFormatter v1.0.56
[ccbc3e58] JumpProcesses v9.11.1
[ef3ab10e] KLU v0.6.0
- [ba0b0d4f] Krylov v0.9.5
+ [ba0b0d4f] Krylov v0.9.6
[b964fa9f] LaTeXStrings v1.3.1
- [2ee39098] LabelledArrays v1.15.1
+ [2ee39098] LabelledArrays v1.16.0
[984bce1d] LambertW v0.4.6
[23fbe1c1] Latexify v0.16.3
[10f19ff3] LayoutPointers v0.1.15
@@ -100,7 +100,7 @@
[d3d80556] LineSearches v7.2.0
[7ed4a6bd] LinearSolve v2.29.1
[2ab3a3ac] LogExpFunctions v0.3.27
- [bdcacae8] LoopVectorization v0.12.169
+ [bdcacae8] LoopVectorization v0.12.170
[d8e11817] MLStyle v0.4.17
[1914dd2f] MacroTools v0.5.13
[d125e4d3] ManualMemory v0.1.8
@@ -131,7 +131,7 @@
[1fd47b50] QuadGK v2.9.4
[e6cf234a] RandomNumbers v1.5.3
[3cdcf5f2] RecipesBase v1.3.4
- [731186ca] RecursiveArrayTools v3.13.0
+⌃ [731186ca] RecursiveArrayTools v3.13.0
[f2c3362d] RecursiveFactorization v0.2.23
[189a3867] Reexport v1.2.2
[2792f1a3] RegistryInstances v0.1.0
@@ -176,9 +176,9 @@
[3a884ed6] UnPack v1.0.2
[1986cc42] Unitful v1.19.0
[a7c27f48] Unityper v0.1.6
- [3d5dd08c] VectorizationBase v0.21.66
+ [3d5dd08c] VectorizationBase v0.21.67
[19fa3120] VertexSafeGraphs v0.2.0
- [2e619515] Expat_jll v2.5.0+0
+ [2e619515] Expat_jll v2.6.2+0
[f8c6e375] Git_jll v2.44.0+2
[1d5cc7b8] IntelOpenMP_jll v2024.1.0+0
[94ce4f54] Libiconv_jll v1.17.0+0
@@ -221,7 +221,7 @@
[8dfed614] Test
[cf7118a7] UUIDs
[4ec0a83e] Unicode
- [e66e0078] CompilerSupportLibraries_jll v1.1.0+0
+ [e66e0078] CompilerSupportLibraries_jll v1.1.1+0
[deac9b47] LibCURL_jll v8.4.0+0
[e37daf67] LibGit2_jll v1.6.4+0
[29816b5a] LibSSH2_jll v1.11.0+1
@@ -235,4 +235,4 @@
[8e850b90] libblastrampoline_jll v5.8.0+1
[8e850ede] nghttp2_jll v1.52.0+1
[3f19e933] p7zip_jll v17.4.0+2
-Info Packages marked with ⌃ and ⌅ have new versions available. Those with ⌃ may be upgradable, but those with ⌅ are restricted by compatibility constraints from upgrading. To see why use `status --outdated -m`
You can also download the manifest file and the project file.