Mercurial > repos > public > sbplib_julia
view src/LazyTensors/tensor_mapping.jl @ 944:4a4ef4bf6cb9 feature/tensormapping_application_promotion
Move exports to the top of the files
author | Jonatan Werpers <jonatan@werpers.com> |
---|---|
date | Thu, 10 Mar 2022 16:59:43 +0100 |
parents | fb060e98ac0a |
children | 1f41cf9454f2 |
line wrap: on
line source
export TensorMapping export apply export apply_transpose export range_dim, domain_dim export range_size, domain_size """ TensorMapping{T,R,D} Describes a mapping of a `D` dimension tensor to an `R` dimension tensor. The action of the mapping is implemented through the method ```julia apply(t::TensorMapping{T,R,D}, v::AbstractArray{T,D}, I::Vararg) where {R,D,T} ``` The size of the range and domain that the operator works with should be returned by the functions ```julia range_size(::TensorMapping) domain_size(::TensorMapping) ``` to allow querying for one or the other. Optionally the action of the transpose may be defined through ```julia apply_transpose(t::TensorMapping{T,R,D}, v::AbstractArray{T,D}, I::Vararg) where {R,D,T} ``` """ abstract type TensorMapping{T,R,D} end """ apply(t::TensorMapping{T,R,D}, v::AbstractArray{<:Any,D}, I::Vararg) where {R,D,T} Return the result of the mapping for a given index. """ function apply end """ apply_transpose(t::TensorMapping{T,R,D}, v::AbstractArray{<:Any,R}, I::Vararg) where {R,D,T} Return the result of the transposed mapping for a given index. """ function apply_transpose end """ range_dim(::TensorMapping) Return the dimension of the range space of a given mapping """ range_dim(::TensorMapping{T,R,D}) where {T,R,D} = R """ domain_dim(::TensorMapping) Return the dimension of the domain space of a given mapping """ domain_dim(::TensorMapping{T,R,D}) where {T,R,D} = D """ range_size(M::TensorMapping) Return the range size for the mapping. """ function range_size end """ domain_size(M::TensorMapping) Return the domain size for the mapping. """ function domain_size end """ eltype(::TensorMapping{T}) The type of elements the TensorMapping acts on. """ Base.eltype(::TensorMapping{T}) where T = T # TODO: Think about boundschecking!