SciMLOperators.jl: Unified operator interface for Julia and SciML
SciMLOperators
is a package for managing linear, nonlinear, time-dependent, and parameter dependent operators acting on vectors, (or column-vectors of matrices). We provide wrappers for matrix-free operators, fast tensor-product evaluations, pre-cached mutating evaluations, as well as Zygote
-compatible non-mutating evaluations.
The lazily implemented operator algebra allows the user to update the operator state by passing in an update function that accepts arbitrary parameter objects. Further, our operators behave like AbstractMatrix
types thanks to overloads defined for methods in Base
, and LinearAlgebra
.
Therefore, an AbstractSciMLOperator
can be passed to LinearSolve.jl
, or NonlinearSolve.jl
as a linear or nonlinear operator, or to OrdinaryDiffEq.jl
as an ODEFunction
. Examples of usage within the SciML
ecosystem are provided in the documentation.
Installation
To install SciMLOperators.jl, use the Julia package manager:
using Pkg
Pkg.add("SciMLOperators")
Why SciMLOperators
?
Many functions, from linear solvers to differential equations, require the use of matrix-free operators to achieve maximum performance in many scenarios. SciMLOperators.jl
defines the abstract interface for how operators in the SciML ecosystem are supposed to be defined. It gives the common set of functions and traits that solvers can rely on for properly performing their tasks. Along with that, SciMLOperators.jl
provides definitions for the basic standard operators that are used as building blocks for most tasks, simplifying the use of operators while also demonstrating to users how such operators can be built and used in practice.
SciMLOperators.jl
has the design that is required to be used in all scenarios of equation solvers. For example, Magnus integrators for differential equations require defining an operator $u' = A(t) u$, while Munthe-Kaas methods require defining operators of the form $u' = A(u) u$. Thus, the operators need some form of time and state dependence, which the solvers can update and query when they are non-constant (update_coefficients!
). Additionally, the operators need the ability to act like “normal” functions for equation solvers. For example, if A(v,u,p,t)
has the same operation as update_coefficients(A, u, p, t); A * v
, then A
can be used in any place where a differential equation definition (u,p,t) -> A(u, u, p, t)
is used without requiring the user or solver to do any extra work.
Another example is state-dependent mass matrices. M(u,p,t)*u' = f(u,p,t)
. When solving such an equation, the solver must understand how to "update M" during operations, and thus the ability to update the state of M
is a required function in the interface. This is also required for the definition of Jacobians J(u,p,t)
in order to be properly used with Krylov methods inside of ODE solves without reconstructing the matrix-free operator at each step.
Thus while previous good efforts for matrix-free operators have existed in the Julia ecosystem, such as LinearMaps.jl, those operator interfaces lack these aspects to actually be fully seamless with downstream equation solvers. This necessitates the definition and use of an extended operator interface with all of these properties, hence the AbstractSciMLOperator
interface.
This means that LinearMaps.jl is fundamentally lacking and is incompatible with many of the tools in the SciML ecosystem, except for the specific cases where the matrix-free operator is a constant!
Features
- Matrix-free operators with
FunctionOperator
- Fast tensor product evaluation with
TensorProductOperator
- Lazy algebra: addition, subtraction, multiplication, inverse, adjoint, and transpose
- Couple fast methods for operator evaluation with inversion via
InvertibleOperator
- One-line API to update operator state depending on arbitrary parameters.
- Mutating and nonmutating update behavior (Zygote compatible)
- One-line API for pre-caching operators for in-place operator evaluations
Contributing
Please refer to the SciML ColPrac: Contributor's Guide on Collaborative Practices for Community Packages for guidance on PRs, issues, and other matters relating to contributing to SciML.
See the SciML Style Guide for common coding practices and other style decisions.
There are a few community forums:
- The #diffeq-bridged and #sciml-bridged channels in the Julia Slack
- The #diffeq-bridged and #sciml-bridged channels in the Julia Zulip
- On the Julia Discourse forums
- See also SciML Community page
Reproducibility
The documentation of this SciML package was built using these direct dependencies,
Status `~/work/SciMLOperators.jl/SciMLOperators.jl/docs/Project.toml`
[e30172f5] Documenter v1.13.0
[7a1cc6ca] FFTW v1.9.0
[c0aeaf25] SciMLOperators v1.3.1 `~/work/SciMLOperators.jl/SciMLOperators.jl`
and using this machine and Julia version.
Julia Version 1.11.5
Commit 760b2e5b739 (2025-04-14 06:53 UTC)
Build Info:
Official https://julialang.org/ release
Platform Info:
OS: Linux (x86_64-linux-gnu)
CPU: 4 × AMD EPYC 7763 64-Core Processor
WORD_SIZE: 64
LLVM: libLLVM-16.0.6 (ORCJIT, znver3)
Threads: 1 default, 0 interactive, 1 GC (on 4 virtual cores)
A more complete overview of all dependencies and their versions is also provided.
Status `~/work/SciMLOperators.jl/SciMLOperators.jl/docs/Manifest.toml`
[a4c015fc] ANSIColoredPrinters v0.0.1
[621f4979] AbstractFFTs v1.5.0
[1520ce14] AbstractTrees v0.4.5
[7d9f7c33] Accessors v0.1.42
[79e6a3ab] Adapt v4.3.0
[4fba245c] ArrayInterface v7.19.0
[944b1d66] CodecZlib v0.7.8
[a33af91c] CompositionsBase v0.1.2
[187b0558] ConstructionBase v1.6.0
[ffbed154] DocStringExtensions v0.9.5
[e30172f5] Documenter v1.13.0
[7a1cc6ca] FFTW v1.9.0
[d7ba0133] Git v1.4.0
[b5f81e59] IOCapture v0.2.5
[3587e190] InverseFunctions v0.1.17
[692b3bcd] JLLWrappers v1.7.0
[682c06a0] JSON v0.21.4
[0e77f7df] LazilyInitializedFields v1.3.0
[1914dd2f] MacroTools v0.5.16
[d0879d2d] MarkdownAST v0.1.2
[69de0a69] Parsers v2.8.3
⌅ [aea7be01] PrecompileTools v1.2.1
[21216c6a] Preferences v1.4.3
[189a3867] Reexport v1.2.2
[2792f1a3] RegistryInstances v0.1.0
[ae029012] Requires v1.3.1
[c0aeaf25] SciMLOperators v1.3.1 `~/work/SciMLOperators.jl/SciMLOperators.jl`
[3bb67fe8] TranscodingStreams v0.11.3
[2e619515] Expat_jll v2.6.5+0
[f5851436] FFTW_jll v3.3.11+0
[f8c6e375] Git_jll v2.49.0+0
[1d5cc7b8] IntelOpenMP_jll v2025.0.4+0
[94ce4f54] Libiconv_jll v1.18.0+0
[856f044c] MKL_jll v2025.0.1+1
[9bd350c2] OpenSSH_jll v10.0.1+0
[458c3c95] OpenSSL_jll v3.5.0+0
[1317d2d5] oneTBB_jll v2022.0.0+0
[0dad84c5] ArgTools v1.1.2
[56f22d72] Artifacts v1.11.0
[2a0f44e3] Base64 v1.11.0
[ade2ca70] Dates v1.11.0
[f43a241f] Downloads v1.6.0
[7b1f6079] FileWatching v1.11.0
[b77e0a4c] InteractiveUtils v1.11.0
[4af54fe1] LazyArtifacts v1.11.0
[b27032c2] LibCURL v0.6.4
[76f85450] LibGit2 v1.11.0
[8f399da3] Libdl v1.11.0
[37e2e46d] LinearAlgebra v1.11.0
[56ddb016] Logging v1.11.0
[d6f4376e] Markdown v1.11.0
[a63ad114] Mmap v1.11.0
[ca575930] NetworkOptions v1.2.0
[44cfe95a] Pkg v1.11.0
[de0858da] Printf v1.11.0
[3fa0cd96] REPL v1.11.0
[9a3f8284] Random v1.11.0
[ea8e919c] SHA v0.7.0
[9e88b42a] Serialization v1.11.0
[6462fe0b] Sockets v1.11.0
[f489334b] StyledStrings v1.11.0
[fa267f1f] TOML v1.0.3
[a4e569a6] Tar v1.10.0
[8dfed614] Test v1.11.0
[cf7118a7] UUIDs v1.11.0
[4ec0a83e] Unicode v1.11.0
[e66e0078] CompilerSupportLibraries_jll v1.1.1+0
[deac9b47] LibCURL_jll v8.6.0+0
[e37daf67] LibGit2_jll v1.7.2+0
[29816b5a] LibSSH2_jll v1.11.0+1
[c8ffd9c3] MbedTLS_jll v2.28.6+0
[14a3606d] MozillaCACerts_jll v2023.12.12
[4536629a] OpenBLAS_jll v0.3.27+1
[efcefdf7] PCRE2_jll v10.42.0+1
[83775a58] Zlib_jll v1.2.13+1
[8e850b90] libblastrampoline_jll v5.11.0+0
[8e850ede] nghttp2_jll v1.59.0+0
[3f19e933] p7zip_jll v17.4.0+2
Info Packages marked with ⌅ have new versions available but compatibility constraints restrict them from upgrading. To see why use `status --outdated -m`
You can also download the manifest file and the project file.