Reference
Base.:* — Method:*(F, m)Constructs F*m where F is a Jets linear (e.g. JopLn) or nonlinear (JopNl) operator.
Base.:+ — Method:+(A₂, A₁)Construct and return the linear combination of the two Jets operators A₁::Jop and A₂::Jop. Note that A₁ and A₂ must have consistent (same size and type) domains and ranges.
Example
A = 1.0*A₁ - 2.0*A₂ + 3.0*A₃Base.:- — Method:-(A₂, A₁)Construct and return the linear combination of the two Jets operators A₁::Jop and A₂::Jop. Note that A₁ and A₂ must have consistent (same size and type) domains and ranges.
Example
A = 1.0*A₁ - 2.0*A₂ + 3.0*A₃Base.:∘ — Method:∘(A₂, A₁)Construct the composition of the two Jets operators.  Note that when applying the composition operator, operators are applied in order from right to left: first A₁ and then A₂.
Example
using Jets
dg!(d,m;mₒ) = @. d = 2*m
A₁ = JopLn(Jet(;dom=JetSpace(Float64,2), rng=JetSpace(Float64,2), df! = dg!))
A₂ = JopLn(Jet(;dom=JetSpace(Float64,2), rng=JetSpace(Float64,2), df! = dg!))
C = A₂ ∘ A₁
m = rand(domain(C))
d = C * mBase.adjoint — Methodadjoint(A::Union{JopLn, JopAdjoint})Return the adjoint of A.
Base.convert — Methodconvert(Array, A::JopLn)Convert a linear Jets operator into its equivalent matrix.
Base.eltype — Methodeltype(A::Union{Jet,Jop,JopAdjoint})Return the element type of A.
Base.eltype — Methodeltype(R)Return the element type of the space R::JetAbstractSpace.
Base.iszero — Methodiszero(A::Union{Jet, Jop})Return true if A was constructed via JopZeroBlock.
Base.length — Methodlength(R)Return the dimension the space R::JetAbstractSpace
Base.ones — Functionones(R)Construct an array of the type and size defined by R::JetAbstractSpace{T} and filled with one(T).
Base.rand — Functionrand(R)Construct an array of the type and size defined by the R::JetAbstractSpace, and filled with random values.
Base.range — MethodR = range(A)Return R::JetAbstractSpace, which is the range of A::Union{Jet, Jop, AbstractMatrix}.
Base.reshape — Methodreshape(x, R)Returns an array that is consistent with the shape of the space R::JetAbstractSpace, and shares memory with x.
Base.size — Methodsize(R[,i])Return the shape of the array associated to the Jet space R::JetAbstractSpace. If i is specifid, then returns the length along the ith array dimension.
Base.size — Methodsize(A[, i])Return the size of the range and domain of A::Union{Jet,Jop}.  With no arguments, return (length(range(A)), length(domain(A))).  With i specified, return length(range(A)) for i = 1 and return length(domain(A)) otherwise.
Base.vec — MethodB = vec(A)B is equivelent to A except that its domain and range are "vectorized".  This is useful when calling algorithms that expect vectors in the domain and range of the operator.  One example of this is the lsqr method in the IterativeSolvers package.
Example
using Jets, JetPack, IterativeSolvers
A = JopDiagonal(rand(10,11))
d = rand(range(A))
m = lsqr(vec(A), vec(d))Base.zeros — Functionzeros(R)Construct an array of the type and size defined by R::JetAbstractSpace{T} and filled with zero(T).
Jets.JopZeroBlock — MethodJopZeroBlock(dom, rng)Construct a Jets operator that is equivalent to a matrix of zeros, and that maps from dom::JetAbstractSpace to rng::JetAbstractSpace.  This can be useful when forming block operators that contain zero blocks.
Jets.domain — MethodR = domain(A)Return R::JetAbstractSpace, which is the domain of A::Union{Jet, Jop, AbstractMatrix}.
Jets.dot_product_test — Methodlhs,rhs = dot_product_test(A, m, d; mmask, dmask)Compute and return the left and right hand sides of the dot product test:
<d,Am> ≈ <Aᴴd,m>
Here Aᴴ is the conjugate transpose or adjoint of A, and <x, y> denotes the inner product of vectors x and y. The left and right hand sides of the dot product test are expected to be equivalent close to machine precision for operator A. If the equality does not hold this can indicate a problem with the implementation of the operator A.
This function provides the optional named arguments mmask and dmask which are vectors in the domain and range of A that are applied via elementwise multiplication to mask the vectors m and d before applying of the operator, as shown below. Here we use ∘ to represent the Hadamard product (elementwise multiplication) of two vectors.
<dmask ∘ d, A (mmask ∘ m)> ≈ <Aᵀ (dmask ∘ d), mmask ∘ m>
You can test the relative accuracy of the operator with this relation for the left hand side lhs and right hand side rhs returned by this function: 
|lhs - rhs| / |lhs + rhs| < ϵ
Jets.getblock — Methodgetblock(A, i, j)Return the block of the Jets block operator A that corresponds to row block i and column block j.
Jets.indices — Methodindices(R, iblock)Return the linear indices associated with block iblock in the Jets block space R::JetBSpace.
Example
Consider a block operator with 2 row-blocks and 3 column-blocks.  We can use indices to determine the elements of the vector that are associatd with the first block of its domain:
using Pkg
pkg"add Jets JetPack"
using Jets, JetPack
A = @blockop [JopDiagonal(rand(10)) for irow=1:2, icol=1:3]
indices(domain(A), 1) # returns indices 1:10Jets.isblockop — Methodisblockop(A)Return true if A is a Jets block operator.
Jets.jacobian! — Methodjacobian!(F, mₒ)Return the jacobian of F::Union{Jet, Jop, AbstractMatrix} at the linearization point m₀. The jacobian shares the underlying Jet with F. This means that if the jacobian may mutate F.
Jets.jacobian — Methodjacobian(F, mₒ)Return the jacobian of F::Union{Jet, Jop, AbstractMatrix} at the point m₀. The linearization constructs a new underlying Jet.
Jets.jet — Methodjet(A)Return the Jet associated with A::Union{Jop, JopAdjoint}.
Jets.linearity_test — Functionlhs,rhs = linearity_test(A::Jop)test the the linear Jet operator A satisfies the following test for linearity: 
A(m_1+m_2)=Am_1 + A_m2
Jets.linearization_test — Methodμobs, μexp = linearization_test(F, mₒ; μ)Thest that the jacobian, J, of F satisfies the Taylor expansion:
F(m) = F(m_o) + F'(m_o)δm + O(δm^2)
Jets.nblocks — Methodnblocks(R)Return the number of blocks in the Jets block space R::JetBSpace.
Jets.nblocks — Methodnblocks(A[, i])Return the number of blocks in the range and domain of the Jets block operator A::Union{Jet, Jop}. With i specified, return nblocks(range(jet)) for i = 1 and return nblocks(domain(jet)) otherwise.
Jets.perfstat — Methodperfstat(A)Return a Dictionary with performance information for A::Union{Jet,Jop,JopAdjoint}. the perfstat(jet::Jet) method that can be implemented by the author of an operator to track performance metrics.
Jets.point! — Methodpoint!(F, mₒ)Update the linearization point (model vector) for F::Union{Jet, JopLn, JopAdjoint} to model vector mₒ.
Jets.point — Methodpoint(F)Return the linearization point (model vector) mₒ associated with F::Union{Jet, JopLn, JopAdjoint}.
Jets.shape — Methodshape(A[, i])Return the shape of the range and domain of A::Union{Jet, Jop, AbstractMatrix}. With no arguments, return (size(range(A)), size(domain(A))).  With i specified, return size(range(A)) for i = 1 and return size(domain(A)) otherwise.
Jets.space — Methodspace(R, iblock)Return the Jets sub-space associated with block iblock in the Jets block space R::JetBSpace.
Example
Consider a block operator with 2 row-blocks and 3 column-blocks.  We can use space to determine the sub-space associated with the first block of its domain:
using Pkg
pkg"add Jets JetPack"
using Jets, JetPack
A = @blockop [JopDiagonal(rand(10)) for irow=1:2, icol=1:3]
space(domain(A), 1) # JetSpace(Float64,10)Jets.state! — Methodstate!(A::Union{Jet,Jop,JopAdjoint}, s)Updates and merges the state of the A with s.
Jets.state — Methodstate(A::Union{Jet,Jop,JopAdjoint}[, key])If key::Symbol is specified, then return the state corresponding to key. Otherwise, return the state of A as a NamedTuple.
LinearAlgebra.mul! — Methodmul!(d, F, m)In place version of d=F*m where F is a Jets linear (e.g. JopLn) or nonlinear (JopNl) operator.
Random.randperm — Methodrandperm(R)Construct a list of random linear indices over the dimensions of R::JetAbstractSpace.  The list is useful for selecting a random subset of a multi-dimensional image.
Example
using Jets
R = JetSpace(Float64, 10, 2)
x = rand(R)
y = x[randperm(R)[1:10]] # get 10 elements at random from xCore.Array — TypeArray(R)Construct an uninitialized array of the type and size defined by R::JetsAbstractSpace.
Jets.Jet — MethodJet(;dom, rng, f!, df!, df′!, upstate!, s)Return a Jet with domain dom::JetAbstractSpace, range rng::JetSAbstractpace, with forward mapping  f!::Function, linearized forward mapping df!::Function, linearized adjoint mapping df′!::Function, Jacobian state modification function upstate!::Function, and state s::NamedTuple.
A jet describes a function f! and its linearization (forward df!, and adjointdf′!``) about a point.
If one of f! or df! is specified, and df′! is not, then we assume that f!=df!=df′!. This means that the operator is linear and self-adjoint.
If f! and df! are sepecified, bug df′! is not, then we assume that df′!=df!.  This means that the operator is nonlinear and self-adjoint.
Example
Consider a nonlinear mapping with a self-adjoint linearization $f(x)=x^2$
using Jets
g!(m) = m.^2
dg!(δm; mₒ) = @. 2*mₒ*δm
jet = Jet(;dom=JetSpace(Float64,2), rng=JetSpace(Float64,2), f! = g!, df! = dg!)Jets.JetSSpace — MethodJetSSpace(_T, n, M, map::F)Construct and return a symmetric space JetSSpace.
parameters
- _Tis the type, usually- Complex{Float32}or- Complex{Float64}.
- nis a tuple that defines the dimensionality of the space.
- Mis a tuple that defines which dimensions are symmetric. Note that currently only a single symmetric dimension is supported by the API.
- Fis a function that maps indices for the symmetric dimension, described below.
An example requiring a JetSSpace is the Fourier transform: the Fourier transform of a real vector is in a complex space with Hermittian symmetry. Only the positive frequencies are needed, and the spectrum at negative frequencies is the Hermittian conjugate of the spectrum at the corresponding positive frequencies: S(-f) = conj(S(f). For this example the map F is a function that returns the multi-dimensional index of f when given the multi-dimensional index of -f.
See also: JopFft in the JetPackTransforms package.
Jets.JetSpace — MethodJetSpace(T, n)Construct and return a JetSpace of type T and size n
Examples
Create a 100 dimension space with array elelment type Float64 and array size (100,)
R1 = JetSpace(Float64, 100)Create a 100 dimension space with array element type Float32 and array size (5, 20)
R2 = JetSpace(Float32, 5, 20)Jets.JopLn — MethodJopLn(; kwargs ...)Construct a JopLn with Jet constructed from keyword arguments kwargs. This is equivalent to JopLn(Jet(;kwargs...)).  Please see Jet for more information.
Jets.JopNl — MethodJopNl(; kwargs ...)Construct a JopNl with Jet constructed from keyword arguments kwargs. This is equivalent to JopNl(Jet(;kwargs...)).  Please see Jet for more information.
Index
- Core.Array
- Jets.Jet
- Jets.JetSSpace
- Jets.JetSpace
- Jets.JopLn
- Jets.JopNl
- Base.:*
- Base.:+
- Base.:-
- Base.:∘
- Base.adjoint
- Base.convert
- Base.eltype
- Base.eltype
- Base.iszero
- Base.length
- Base.ones
- Base.rand
- Base.range
- Base.reshape
- Base.size
- Base.size
- Base.vec
- Base.zeros
- Jets.JopZeroBlock
- Jets.domain
- Jets.dot_product_test
- Jets.getblock
- Jets.indices
- Jets.isblockop
- Jets.jacobian
- Jets.jacobian!
- Jets.jet
- Jets.linearity_test
- Jets.linearization_test
- Jets.nblocks
- Jets.nblocks
- Jets.perfstat
- Jets.point
- Jets.point!
- Jets.shape
- Jets.space
- Jets.state
- Jets.state!
- LinearAlgebra.mul!
- Random.randperm