Mercurial > repos > public > sbplib_julia
diff src/LazyTensors/LazyTensors.jl @ 1049:3bb94ce74697 feature/variable_derivatives
Merge default
author | Jonatan Werpers <jonatan@werpers.com> |
---|---|
date | Wed, 23 Mar 2022 12:54:45 +0100 |
parents | 9e76bf19904c |
children | 93f87d5d9fbb |
line wrap: on
line diff
--- a/src/LazyTensors/LazyTensors.jl Mon Mar 21 13:21:48 2022 +0100 +++ b/src/LazyTensors/LazyTensors.jl Wed Mar 23 12:54:45 2022 +0100 @@ -1,17 +1,36 @@ module LazyTensors -export LazyTensorMappingApplication -export LazyTensorMappingTranspose -export TensorMappingComposition -export LazyLinearMap -export IdentityMapping -export InflatedTensorMapping +export TensorApplication +export TensorTranspose +export TensorComposition +export DenseTensor +export IdentityTensor +export ScalingTensor +export InflatedTensor export LazyOuterProduct export ⊗ -export SizeMismatch +export DomainSizeMismatch +export RangeSizeMismatch -include("tensor_mapping.jl") +include("lazy_tensor.jl") +include("tensor_types.jl") include("lazy_array.jl") include("lazy_tensor_operations.jl") +include("tuple_manipulation.jl") + +# Applying lazy tensors to vectors +Base.:*(a::LazyTensor, v::AbstractArray) = TensorApplication(a,v) +Base.:*(a::LazyTensor, b::LazyTensor) = throw(MethodError(Base.:*,(a,b))) +Base.:*(a::LazyTensor, args::Union{LazyTensor, AbstractArray}...) = foldr(*,(a,args...)) + +# Addition and subtraction of lazy tensors +Base.:+(s::LazyTensor, t::LazyTensor) = ElementwiseTensorOperation{:+}(s,t) +Base.:-(s::LazyTensor, t::LazyTensor) = ElementwiseTensorOperation{:-}(s,t) + +# Composing lazy tensors +Base.:∘(s::LazyTensor, t::LazyTensor) = TensorComposition(s,t) + +# Outer products of tensors +⊗(a::LazyTensor, b::LazyTensor) = LazyOuterProduct(a,b) end # module