Mercurial > repos > public > sbplib_julia
annotate src/LazyTensors/lazy_tensor_operations.jl @ 460:acffa3a1395d feature/inflated_tensormapping
Move part of the documentation to the constructor
author | Jonatan Werpers <jonatan@werpers.com> |
---|---|
date | Wed, 21 Oct 2020 21:44:35 +0200 |
parents | 11e58c49fb46 |
children | a0e40d16ba0e |
rev | line source |
---|---|
196
b3c252280a19
Move LazyArray and make LazyTensorMappingApplication and LazyElementwiseOperation subtypes of it
Jonatan Werpers <jonatan@werpers.com>
parents:
195
diff
changeset
|
1 """ |
b3c252280a19
Move LazyArray and make LazyTensorMappingApplication and LazyElementwiseOperation subtypes of it
Jonatan Werpers <jonatan@werpers.com>
parents:
195
diff
changeset
|
2 LazyTensorMappingApplication{T,R,D} <: LazyArray{T,R} |
190
8964b3165097
Break LazyTensors.jl into several files
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
3 |
8964b3165097
Break LazyTensors.jl into several files
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
4 Struct for lazy application of a TensorMapping. Created using `*`. |
8964b3165097
Break LazyTensors.jl into several files
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
5 |
8964b3165097
Break LazyTensors.jl into several files
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
6 Allows the result of a `TensorMapping` applied to a vector to be treated as an `AbstractArray`. |
8964b3165097
Break LazyTensors.jl into several files
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
7 With a mapping `m` and a vector `v` the LazyTensorMappingApplication object can be created by `m*v`. |
8964b3165097
Break LazyTensors.jl into several files
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
8 The actual result will be calcualted when indexing into `m*v`. |
8964b3165097
Break LazyTensors.jl into several files
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
9 """ |
378
946516954c85
Use concrete types in LazyTensorApplication
Jonatan Werpers <jonatan@werpers.com>
parents:
359
diff
changeset
|
10 struct LazyTensorMappingApplication{T,R,D, TM<:TensorMapping{T,R,D}, AA<:AbstractArray{T,D}} <: LazyArray{T,R} |
946516954c85
Use concrete types in LazyTensorApplication
Jonatan Werpers <jonatan@werpers.com>
parents:
359
diff
changeset
|
11 t::TM |
946516954c85
Use concrete types in LazyTensorApplication
Jonatan Werpers <jonatan@werpers.com>
parents:
359
diff
changeset
|
12 o::AA |
190
8964b3165097
Break LazyTensors.jl into several files
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
13 end |
348
7fe43d902a27
Start trying to change LazyTensors
Jonatan Werpers <jonatan@werpers.com>
parents:
333
diff
changeset
|
14 # TODO: Do boundschecking on creation! |
190
8964b3165097
Break LazyTensors.jl into several files
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
15 export LazyTensorMappingApplication |
8964b3165097
Break LazyTensors.jl into several files
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
16 |
379
de4746d6d126
Add some notes and todos
Jonatan Werpers <jonatan@werpers.com>
parents:
378
diff
changeset
|
17 # TODO: Go through and remove unneccerary type parameters on functions |
de4746d6d126
Add some notes and todos
Jonatan Werpers <jonatan@werpers.com>
parents:
378
diff
changeset
|
18 |
310
ece3f6f8a1d4
Change all applys to dispatch on Vararg
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
279
diff
changeset
|
19 Base.getindex(ta::LazyTensorMappingApplication{T,R,D}, I::Vararg{Index,R}) where {T,R,D} = apply(ta.t, ta.o, I...) |
ece3f6f8a1d4
Change all applys to dispatch on Vararg
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
279
diff
changeset
|
20 Base.getindex(ta::LazyTensorMappingApplication{T,R,D}, I::Vararg{Int,R}) where {T,R,D} = apply(ta.t, ta.o, Index{Unknown}.(I)...) |
359
ba46a952a450
Remove unnecessary type parameters
Jonatan Werpers <jonatan@werpers.com>
parents:
348
diff
changeset
|
21 Base.size(ta::LazyTensorMappingApplication) = range_size(ta.t) |
190
8964b3165097
Break LazyTensors.jl into several files
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
22 # TODO: What else is needed to implement the AbstractArray interface? |
8964b3165097
Break LazyTensors.jl into several files
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
23 |
421
2808c41f5efa
Change defs of * for TensorApplication to fix bug
Jonatan Werpers <jonatan@werpers.com>
parents:
411
diff
changeset
|
24 Base.:*(a::TensorMapping, v::AbstractArray) = LazyTensorMappingApplication(a,v) |
2808c41f5efa
Change defs of * for TensorApplication to fix bug
Jonatan Werpers <jonatan@werpers.com>
parents:
411
diff
changeset
|
25 Base.:*(a::TensorMapping, b::TensorMapping) = throw(MethodError(Base.:*,(a,b))) |
2808c41f5efa
Change defs of * for TensorApplication to fix bug
Jonatan Werpers <jonatan@werpers.com>
parents:
411
diff
changeset
|
26 Base.:*(a::TensorMapping, args::Union{TensorMapping, AbstractArray}...) = foldr(*,(a,args...)) |
2808c41f5efa
Change defs of * for TensorApplication to fix bug
Jonatan Werpers <jonatan@werpers.com>
parents:
411
diff
changeset
|
27 |
190
8964b3165097
Break LazyTensors.jl into several files
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
28 # # We need the associativity to be a→b→c = a→(b→c), which is the case for '→' |
274
11010bb74260
Dispatch getindex for TensorMappingApplication on region indices. Dispatch apply
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
267
diff
changeset
|
29 # # Should we overload some other infix binary opesrator? |
190
8964b3165097
Break LazyTensors.jl into several files
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
30 # →(tm::TensorMapping{T,R,D}, o::AbstractArray{T,D}) where {T,R,D} = LazyTensorMappingApplication(tm,o) |
8964b3165097
Break LazyTensors.jl into several files
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
31 # TODO: We need to be really careful about good error messages. |
8964b3165097
Break LazyTensors.jl into several files
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
32 # For example what happens if you try to multiply LazyTensorMappingApplication with a TensorMapping(wrong order)? |
8964b3165097
Break LazyTensors.jl into several files
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
33 |
194
d30d42a11566
Move all Lazy operation into the same module
Jonatan Werpers <jonatan@werpers.com>
parents:
190
diff
changeset
|
34 """ |
197
a340fa91b1fc
Move transpose def to the bottom of the file
Jonatan Werpers <jonatan@werpers.com>
parents:
196
diff
changeset
|
35 LazyTensorMappingTranspose{T,R,D} <: TensorMapping{T,D,R} |
a340fa91b1fc
Move transpose def to the bottom of the file
Jonatan Werpers <jonatan@werpers.com>
parents:
196
diff
changeset
|
36 |
a340fa91b1fc
Move transpose def to the bottom of the file
Jonatan Werpers <jonatan@werpers.com>
parents:
196
diff
changeset
|
37 Struct for lazy transpose of a TensorMapping. |
a340fa91b1fc
Move transpose def to the bottom of the file
Jonatan Werpers <jonatan@werpers.com>
parents:
196
diff
changeset
|
38 |
a340fa91b1fc
Move transpose def to the bottom of the file
Jonatan Werpers <jonatan@werpers.com>
parents:
196
diff
changeset
|
39 If a mapping implements the the `apply_transpose` method this allows working with |
a340fa91b1fc
Move transpose def to the bottom of the file
Jonatan Werpers <jonatan@werpers.com>
parents:
196
diff
changeset
|
40 the transpose of mapping `m` by using `m'`. `m'` will work as a regular TensorMapping lazily calling |
a340fa91b1fc
Move transpose def to the bottom of the file
Jonatan Werpers <jonatan@werpers.com>
parents:
196
diff
changeset
|
41 the appropriate methods of `m`. |
a340fa91b1fc
Move transpose def to the bottom of the file
Jonatan Werpers <jonatan@werpers.com>
parents:
196
diff
changeset
|
42 """ |
438
907b0510699f
Change LazyTensorTranspose to have concrete fields
Jonatan Werpers <jonatan@werpers.com>
parents:
436
diff
changeset
|
43 struct LazyTensorMappingTranspose{T,R,D, TM<:TensorMapping{T,R,D}} <: TensorMapping{T,D,R} |
907b0510699f
Change LazyTensorTranspose to have concrete fields
Jonatan Werpers <jonatan@werpers.com>
parents:
436
diff
changeset
|
44 tm::TM |
197
a340fa91b1fc
Move transpose def to the bottom of the file
Jonatan Werpers <jonatan@werpers.com>
parents:
196
diff
changeset
|
45 end |
a340fa91b1fc
Move transpose def to the bottom of the file
Jonatan Werpers <jonatan@werpers.com>
parents:
196
diff
changeset
|
46 export LazyTensorMappingTranspose |
a340fa91b1fc
Move transpose def to the bottom of the file
Jonatan Werpers <jonatan@werpers.com>
parents:
196
diff
changeset
|
47 |
a340fa91b1fc
Move transpose def to the bottom of the file
Jonatan Werpers <jonatan@werpers.com>
parents:
196
diff
changeset
|
48 # # TBD: Should this be implemented on a type by type basis or through a trait to provide earlier errors? |
348
7fe43d902a27
Start trying to change LazyTensors
Jonatan Werpers <jonatan@werpers.com>
parents:
333
diff
changeset
|
49 # Jonatan 2020-09-25: Is the problem that you can take the transpose of any TensorMapping even if it doesn't implement `apply_transpose`? |
274
11010bb74260
Dispatch getindex for TensorMappingApplication on region indices. Dispatch apply
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
267
diff
changeset
|
50 Base.adjoint(tm::TensorMapping) = LazyTensorMappingTranspose(tm) |
11010bb74260
Dispatch getindex for TensorMappingApplication on region indices. Dispatch apply
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
267
diff
changeset
|
51 Base.adjoint(tmt::LazyTensorMappingTranspose) = tmt.tm |
197
a340fa91b1fc
Move transpose def to the bottom of the file
Jonatan Werpers <jonatan@werpers.com>
parents:
196
diff
changeset
|
52 |
310
ece3f6f8a1d4
Change all applys to dispatch on Vararg
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
279
diff
changeset
|
53 apply(tmt::LazyTensorMappingTranspose{T,R,D}, v::AbstractArray{T,R}, I::Vararg{Index,D}) where {T,R,D} = apply_transpose(tmt.tm, v, I...) |
ece3f6f8a1d4
Change all applys to dispatch on Vararg
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
279
diff
changeset
|
54 apply_transpose(tmt::LazyTensorMappingTranspose{T,R,D}, v::AbstractArray{T,D}, I::Vararg{Index,R}) where {T,R,D} = apply(tmt.tm, v, I...) |
197
a340fa91b1fc
Move transpose def to the bottom of the file
Jonatan Werpers <jonatan@werpers.com>
parents:
196
diff
changeset
|
55 |
359
ba46a952a450
Remove unnecessary type parameters
Jonatan Werpers <jonatan@werpers.com>
parents:
348
diff
changeset
|
56 range_size(tmt::LazyTensorMappingTranspose) = domain_size(tmt.tm) |
ba46a952a450
Remove unnecessary type parameters
Jonatan Werpers <jonatan@werpers.com>
parents:
348
diff
changeset
|
57 domain_size(tmt::LazyTensorMappingTranspose) = range_size(tmt.tm) |
197
a340fa91b1fc
Move transpose def to the bottom of the file
Jonatan Werpers <jonatan@werpers.com>
parents:
196
diff
changeset
|
58 |
210
2aa33d0eef90
Add ability to add and subtract TensorMappings
Jonatan Werpers <jonatan@werpers.com>
parents:
209
diff
changeset
|
59 |
2aa33d0eef90
Add ability to add and subtract TensorMappings
Jonatan Werpers <jonatan@werpers.com>
parents:
209
diff
changeset
|
60 struct LazyTensorMappingBinaryOperation{Op,T,R,D,T1<:TensorMapping{T,R,D},T2<:TensorMapping{T,R,D}} <: TensorMapping{T,D,R} |
274
11010bb74260
Dispatch getindex for TensorMappingApplication on region indices. Dispatch apply
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
267
diff
changeset
|
61 tm1::T1 |
11010bb74260
Dispatch getindex for TensorMappingApplication on region indices. Dispatch apply
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
267
diff
changeset
|
62 tm2::T2 |
210
2aa33d0eef90
Add ability to add and subtract TensorMappings
Jonatan Werpers <jonatan@werpers.com>
parents:
209
diff
changeset
|
63 |
274
11010bb74260
Dispatch getindex for TensorMappingApplication on region indices. Dispatch apply
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
267
diff
changeset
|
64 @inline function LazyTensorMappingBinaryOperation{Op,T,R,D}(tm1::T1,tm2::T2) where {Op,T,R,D, T1<:TensorMapping{T,R,D},T2<:TensorMapping{T,R,D}} |
11010bb74260
Dispatch getindex for TensorMappingApplication on region indices. Dispatch apply
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
267
diff
changeset
|
65 return new{Op,T,R,D,T1,T2}(tm1,tm2) |
210
2aa33d0eef90
Add ability to add and subtract TensorMappings
Jonatan Werpers <jonatan@werpers.com>
parents:
209
diff
changeset
|
66 end |
2aa33d0eef90
Add ability to add and subtract TensorMappings
Jonatan Werpers <jonatan@werpers.com>
parents:
209
diff
changeset
|
67 end |
348
7fe43d902a27
Start trying to change LazyTensors
Jonatan Werpers <jonatan@werpers.com>
parents:
333
diff
changeset
|
68 # TODO: Boundschecking in constructor. |
210
2aa33d0eef90
Add ability to add and subtract TensorMappings
Jonatan Werpers <jonatan@werpers.com>
parents:
209
diff
changeset
|
69 |
310
ece3f6f8a1d4
Change all applys to dispatch on Vararg
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
279
diff
changeset
|
70 apply(tmBinOp::LazyTensorMappingBinaryOperation{:+,T,R,D}, v::AbstractArray{T,D}, I::Vararg{Index,R}) where {T,R,D} = apply(tmBinOp.tm1, v, I...) + apply(tmBinOp.tm2, v, I...) |
ece3f6f8a1d4
Change all applys to dispatch on Vararg
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
279
diff
changeset
|
71 apply(tmBinOp::LazyTensorMappingBinaryOperation{:-,T,R,D}, v::AbstractArray{T,D}, I::Vararg{Index,R}) where {T,R,D} = apply(tmBinOp.tm1, v, I...) - apply(tmBinOp.tm2, v, I...) |
210
2aa33d0eef90
Add ability to add and subtract TensorMappings
Jonatan Werpers <jonatan@werpers.com>
parents:
209
diff
changeset
|
72 |
348
7fe43d902a27
Start trying to change LazyTensors
Jonatan Werpers <jonatan@werpers.com>
parents:
333
diff
changeset
|
73 range_size(tmBinOp::LazyTensorMappingBinaryOperation{Op,T,R,D}) where {Op,T,R,D} = range_size(tmBinOp.tm1) |
7fe43d902a27
Start trying to change LazyTensors
Jonatan Werpers <jonatan@werpers.com>
parents:
333
diff
changeset
|
74 domain_size(tmBinOp::LazyTensorMappingBinaryOperation{Op,T,R,D}) where {Op,T,R,D} = domain_size(tmBinOp.tm1) |
210
2aa33d0eef90
Add ability to add and subtract TensorMappings
Jonatan Werpers <jonatan@werpers.com>
parents:
209
diff
changeset
|
75 |
274
11010bb74260
Dispatch getindex for TensorMappingApplication on region indices. Dispatch apply
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
267
diff
changeset
|
76 Base.:+(tm1::TensorMapping{T,R,D}, tm2::TensorMapping{T,R,D}) where {T,R,D} = LazyTensorMappingBinaryOperation{:+,T,R,D}(tm1,tm2) |
11010bb74260
Dispatch getindex for TensorMappingApplication on region indices. Dispatch apply
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
267
diff
changeset
|
77 Base.:-(tm1::TensorMapping{T,R,D}, tm2::TensorMapping{T,R,D}) where {T,R,D} = LazyTensorMappingBinaryOperation{:-,T,R,D}(tm1,tm2) |
210
2aa33d0eef90
Add ability to add and subtract TensorMappings
Jonatan Werpers <jonatan@werpers.com>
parents:
209
diff
changeset
|
78 |
412
d94891b8dfca
Start implementing TensorComposition
Jonatan Werpers <jonatan@werpers.com>
parents:
402
diff
changeset
|
79 """ |
d94891b8dfca
Start implementing TensorComposition
Jonatan Werpers <jonatan@werpers.com>
parents:
402
diff
changeset
|
80 TensorMappingComposition{T,R,K,D} |
210
2aa33d0eef90
Add ability to add and subtract TensorMappings
Jonatan Werpers <jonatan@werpers.com>
parents:
209
diff
changeset
|
81 |
412
d94891b8dfca
Start implementing TensorComposition
Jonatan Werpers <jonatan@werpers.com>
parents:
402
diff
changeset
|
82 Lazily compose two TensorMappings, so that they can be handled as a single TensorMapping. |
d94891b8dfca
Start implementing TensorComposition
Jonatan Werpers <jonatan@werpers.com>
parents:
402
diff
changeset
|
83 """ |
d94891b8dfca
Start implementing TensorComposition
Jonatan Werpers <jonatan@werpers.com>
parents:
402
diff
changeset
|
84 struct TensorMappingComposition{T,R,K,D, TM1<:TensorMapping{T,R,K}, TM2<:TensorMapping{T,K,D}} <: TensorMapping{T,R,D} |
d94891b8dfca
Start implementing TensorComposition
Jonatan Werpers <jonatan@werpers.com>
parents:
402
diff
changeset
|
85 t1::TM1 |
d94891b8dfca
Start implementing TensorComposition
Jonatan Werpers <jonatan@werpers.com>
parents:
402
diff
changeset
|
86 t2::TM2 |
190
8964b3165097
Break LazyTensors.jl into several files
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
87 |
417
4c6604b7d990
Add dimension checking in the constructor
Jonatan Werpers <jonatan@werpers.com>
parents:
415
diff
changeset
|
88 @inline function TensorMappingComposition(t1::TensorMapping{T,R,K}, t2::TensorMapping{T,K,D}) where {T,R,K,D} |
4c6604b7d990
Add dimension checking in the constructor
Jonatan Werpers <jonatan@werpers.com>
parents:
415
diff
changeset
|
89 @boundscheck if domain_size(t1) != range_size(t2) |
419
2958b4ebd565
Change error message to fit guidelines
Jonatan Werpers <jonatan@werpers.com>
parents:
418
diff
changeset
|
90 throw(DimensionMismatch("the first argument has domain size $(domain_size(t1)) while the second has range size $(range_size(t2)) ")) |
417
4c6604b7d990
Add dimension checking in the constructor
Jonatan Werpers <jonatan@werpers.com>
parents:
415
diff
changeset
|
91 end |
4c6604b7d990
Add dimension checking in the constructor
Jonatan Werpers <jonatan@werpers.com>
parents:
415
diff
changeset
|
92 return new{T,R,K,D, typeof(t1), typeof(t2)}(t1,t2) |
4c6604b7d990
Add dimension checking in the constructor
Jonatan Werpers <jonatan@werpers.com>
parents:
415
diff
changeset
|
93 end |
412
d94891b8dfca
Start implementing TensorComposition
Jonatan Werpers <jonatan@werpers.com>
parents:
402
diff
changeset
|
94 # Add check for matching sizes as a boundscheck |
d94891b8dfca
Start implementing TensorComposition
Jonatan Werpers <jonatan@werpers.com>
parents:
402
diff
changeset
|
95 end |
d94891b8dfca
Start implementing TensorComposition
Jonatan Werpers <jonatan@werpers.com>
parents:
402
diff
changeset
|
96 export TensorMappingComposition |
190
8964b3165097
Break LazyTensors.jl into several files
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
97 |
412
d94891b8dfca
Start implementing TensorComposition
Jonatan Werpers <jonatan@werpers.com>
parents:
402
diff
changeset
|
98 range_size(tm::TensorMappingComposition) = range_size(tm.t1) |
d94891b8dfca
Start implementing TensorComposition
Jonatan Werpers <jonatan@werpers.com>
parents:
402
diff
changeset
|
99 domain_size(tm::TensorMappingComposition) = domain_size(tm.t2) |
190
8964b3165097
Break LazyTensors.jl into several files
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
100 |
412
d94891b8dfca
Start implementing TensorComposition
Jonatan Werpers <jonatan@werpers.com>
parents:
402
diff
changeset
|
101 function apply(c::TensorMappingComposition{T,R,K,D}, v::AbstractArray{T,D}, I::Vararg{S,R} where S) where {T,R,K,D} |
418
264af2bb646f
Switch to using * instead of calling the constructor
Jonatan Werpers <jonatan@werpers.com>
parents:
417
diff
changeset
|
102 apply(c.t1, c.t2*v, I...) |
412
d94891b8dfca
Start implementing TensorComposition
Jonatan Werpers <jonatan@werpers.com>
parents:
402
diff
changeset
|
103 end |
190
8964b3165097
Break LazyTensors.jl into several files
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
104 |
412
d94891b8dfca
Start implementing TensorComposition
Jonatan Werpers <jonatan@werpers.com>
parents:
402
diff
changeset
|
105 function apply_transpose(c::TensorMappingComposition{T,R,K,D}, v::AbstractArray{T,R}, I::Vararg{S,D} where S) where {T,R,K,D} |
418
264af2bb646f
Switch to using * instead of calling the constructor
Jonatan Werpers <jonatan@werpers.com>
parents:
417
diff
changeset
|
106 apply_transpose(c.t2, c.t1'*v, I...) |
412
d94891b8dfca
Start implementing TensorComposition
Jonatan Werpers <jonatan@werpers.com>
parents:
402
diff
changeset
|
107 end |
190
8964b3165097
Break LazyTensors.jl into several files
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
108 |
417
4c6604b7d990
Add dimension checking in the constructor
Jonatan Werpers <jonatan@werpers.com>
parents:
415
diff
changeset
|
109 Base.@propagate_inbounds Base.:∘(s::TensorMapping, t::TensorMapping) = TensorMappingComposition(s,t) |
190
8964b3165097
Break LazyTensors.jl into several files
Jonatan Werpers <jonatan@werpers.com>
parents:
diff
changeset
|
110 |
377
8414c2334393
Start implementing LazyLinearMap
Jonatan Werpers <jonatan@werpers.com>
parents:
359
diff
changeset
|
111 """ |
393
b14eacf823b6
Test applying LazyLinearMap to random vectors and matrices. Fix indentation
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
392
diff
changeset
|
112 LazyLinearMap{T,R,D,...}(A, range_indicies, domain_indicies) |
377
8414c2334393
Start implementing LazyLinearMap
Jonatan Werpers <jonatan@werpers.com>
parents:
359
diff
changeset
|
113 |
8414c2334393
Start implementing LazyLinearMap
Jonatan Werpers <jonatan@werpers.com>
parents:
359
diff
changeset
|
114 TensorMapping defined by the AbstractArray A. `range_indicies` and `domain_indicies` define which indicies of A should |
400
c640f37d1c74
Update documentation
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
399
diff
changeset
|
115 be considerd the range and domain of the TensorMapping. Each set of indices must be ordered in ascending order. |
394
7ad644d112de
Expand tests for LazyLinearMap and update its documentation
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
393
diff
changeset
|
116 |
400
c640f37d1c74
Update documentation
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
399
diff
changeset
|
117 For instance, if A is a m x n matrix, and range_size = (1,), domain_size = (2,), then the LazyLinearMap performs the |
c640f37d1c74
Update documentation
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
399
diff
changeset
|
118 standard matrix-vector product on vectors of size n. |
377
8414c2334393
Start implementing LazyLinearMap
Jonatan Werpers <jonatan@werpers.com>
parents:
359
diff
changeset
|
119 """ |
8414c2334393
Start implementing LazyLinearMap
Jonatan Werpers <jonatan@werpers.com>
parents:
359
diff
changeset
|
120 struct LazyLinearMap{T,R,D, RD, AA<:AbstractArray{T,RD}} <: TensorMapping{T,R,D} |
8414c2334393
Start implementing LazyLinearMap
Jonatan Werpers <jonatan@werpers.com>
parents:
359
diff
changeset
|
121 A::AA |
8414c2334393
Start implementing LazyLinearMap
Jonatan Werpers <jonatan@werpers.com>
parents:
359
diff
changeset
|
122 range_indicies::NTuple{R,Int} |
8414c2334393
Start implementing LazyLinearMap
Jonatan Werpers <jonatan@werpers.com>
parents:
359
diff
changeset
|
123 domain_indicies::NTuple{D,Int} |
399
3b4b1758a8ad
Add a check for permuted indecies.
Jonatan Werpers <jonatan@werpers.com>
parents:
394
diff
changeset
|
124 |
3b4b1758a8ad
Add a check for permuted indecies.
Jonatan Werpers <jonatan@werpers.com>
parents:
394
diff
changeset
|
125 function LazyLinearMap(A::AA, range_indicies::NTuple{R,Int}, domain_indicies::NTuple{D,Int}) where {T,R,D, RD, AA<:AbstractArray{T,RD}} |
3b4b1758a8ad
Add a check for permuted indecies.
Jonatan Werpers <jonatan@werpers.com>
parents:
394
diff
changeset
|
126 if !issorted(range_indicies) || !issorted(domain_indicies) |
3b4b1758a8ad
Add a check for permuted indecies.
Jonatan Werpers <jonatan@werpers.com>
parents:
394
diff
changeset
|
127 throw(DomainError("range_indicies and domain_indicies must be sorted in ascending order")) |
3b4b1758a8ad
Add a check for permuted indecies.
Jonatan Werpers <jonatan@werpers.com>
parents:
394
diff
changeset
|
128 end |
3b4b1758a8ad
Add a check for permuted indecies.
Jonatan Werpers <jonatan@werpers.com>
parents:
394
diff
changeset
|
129 |
3b4b1758a8ad
Add a check for permuted indecies.
Jonatan Werpers <jonatan@werpers.com>
parents:
394
diff
changeset
|
130 return new{T,R,D,RD,AA}(A,range_indicies,domain_indicies) |
3b4b1758a8ad
Add a check for permuted indecies.
Jonatan Werpers <jonatan@werpers.com>
parents:
394
diff
changeset
|
131 end |
377
8414c2334393
Start implementing LazyLinearMap
Jonatan Werpers <jonatan@werpers.com>
parents:
359
diff
changeset
|
132 end |
8414c2334393
Start implementing LazyLinearMap
Jonatan Werpers <jonatan@werpers.com>
parents:
359
diff
changeset
|
133 export LazyLinearMap |
8414c2334393
Start implementing LazyLinearMap
Jonatan Werpers <jonatan@werpers.com>
parents:
359
diff
changeset
|
134 |
392
418cfd945715
Fix bug in range_size and domain_size for LazyLinearMap and expand the test
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
377
diff
changeset
|
135 range_size(llm::LazyLinearMap) = size(llm.A)[[llm.range_indicies...]] |
418cfd945715
Fix bug in range_size and domain_size for LazyLinearMap and expand the test
Vidar Stiernström <vidar.stiernstrom@it.uu.se>
parents:
377
diff
changeset
|
136 domain_size(llm::LazyLinearMap) = size(llm.A)[[llm.domain_indicies...]] |
377
8414c2334393
Start implementing LazyLinearMap
Jonatan Werpers <jonatan@werpers.com>
parents:
359
diff
changeset
|
137 |
8414c2334393
Start implementing LazyLinearMap
Jonatan Werpers <jonatan@werpers.com>
parents:
359
diff
changeset
|
138 function apply(llm::LazyLinearMap{T,R,D}, v::AbstractArray{T,D}, I::Vararg{Index,R}) where {T,R,D} |
8414c2334393
Start implementing LazyLinearMap
Jonatan Werpers <jonatan@werpers.com>
parents:
359
diff
changeset
|
139 view_index = ntuple(i->:,ndims(llm.A)) |
8414c2334393
Start implementing LazyLinearMap
Jonatan Werpers <jonatan@werpers.com>
parents:
359
diff
changeset
|
140 for i ∈ 1:R |
8414c2334393
Start implementing LazyLinearMap
Jonatan Werpers <jonatan@werpers.com>
parents:
359
diff
changeset
|
141 view_index = Base.setindex(view_index, Int(I[i]), llm.range_indicies[i]) |
8414c2334393
Start implementing LazyLinearMap
Jonatan Werpers <jonatan@werpers.com>
parents:
359
diff
changeset
|
142 end |
8414c2334393
Start implementing LazyLinearMap
Jonatan Werpers <jonatan@werpers.com>
parents:
359
diff
changeset
|
143 A_view = @view llm.A[view_index...] |
8414c2334393
Start implementing LazyLinearMap
Jonatan Werpers <jonatan@werpers.com>
parents:
359
diff
changeset
|
144 return sum(A_view.*v) |
8414c2334393
Start implementing LazyLinearMap
Jonatan Werpers <jonatan@werpers.com>
parents:
359
diff
changeset
|
145 end |
411
4aa59af074ef
Add implementation of apply_transpose for LazyLinearMap
Jonatan Werpers <jonatan@werpers.com>
parents:
402
diff
changeset
|
146 |
4aa59af074ef
Add implementation of apply_transpose for LazyLinearMap
Jonatan Werpers <jonatan@werpers.com>
parents:
402
diff
changeset
|
147 function apply_transpose(llm::LazyLinearMap{T,R,D}, v::AbstractArray{T,R}, I::Vararg{Index,D}) where {T,R,D} |
4aa59af074ef
Add implementation of apply_transpose for LazyLinearMap
Jonatan Werpers <jonatan@werpers.com>
parents:
402
diff
changeset
|
148 apply(LazyLinearMap(llm.A, llm.domain_indicies, llm.range_indicies), v, I...) |
4aa59af074ef
Add implementation of apply_transpose for LazyLinearMap
Jonatan Werpers <jonatan@werpers.com>
parents:
402
diff
changeset
|
149 end |
429
46acb2560451
Start implementing LazyIdentity
Jonatan Werpers <jonatan@werpers.com>
parents:
411
diff
changeset
|
150 |
46acb2560451
Start implementing LazyIdentity
Jonatan Werpers <jonatan@werpers.com>
parents:
411
diff
changeset
|
151 |
46acb2560451
Start implementing LazyIdentity
Jonatan Werpers <jonatan@werpers.com>
parents:
411
diff
changeset
|
152 """ |
434
648a36ebac99
Change name from LazyIdentity to IdentityMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
433
diff
changeset
|
153 IdentityMapping{T,D} <: TensorMapping{T,D,D} |
429
46acb2560451
Start implementing LazyIdentity
Jonatan Werpers <jonatan@werpers.com>
parents:
411
diff
changeset
|
154 |
46acb2560451
Start implementing LazyIdentity
Jonatan Werpers <jonatan@werpers.com>
parents:
411
diff
changeset
|
155 The lazy identity TensorMapping for a given size. Usefull for building up higher dimensional tensor mappings from lower |
46acb2560451
Start implementing LazyIdentity
Jonatan Werpers <jonatan@werpers.com>
parents:
411
diff
changeset
|
156 dimensional ones through outer products. Also used in the Implementation for InflatedTensorMapping. |
46acb2560451
Start implementing LazyIdentity
Jonatan Werpers <jonatan@werpers.com>
parents:
411
diff
changeset
|
157 """ |
434
648a36ebac99
Change name from LazyIdentity to IdentityMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
433
diff
changeset
|
158 struct IdentityMapping{T,D} <: TensorMapping{T,D,D} |
429
46acb2560451
Start implementing LazyIdentity
Jonatan Werpers <jonatan@werpers.com>
parents:
411
diff
changeset
|
159 size::NTuple{D,Int} |
46acb2560451
Start implementing LazyIdentity
Jonatan Werpers <jonatan@werpers.com>
parents:
411
diff
changeset
|
160 end |
434
648a36ebac99
Change name from LazyIdentity to IdentityMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
433
diff
changeset
|
161 export IdentityMapping |
429
46acb2560451
Start implementing LazyIdentity
Jonatan Werpers <jonatan@werpers.com>
parents:
411
diff
changeset
|
162 |
434
648a36ebac99
Change name from LazyIdentity to IdentityMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
433
diff
changeset
|
163 IdentityMapping{T}(size::NTuple{D,Int}) where {T,D} = IdentityMapping{T,D}(size) |
441
552189707fbe
Add convenience constructor
Jonatan Werpers <jonatan@werpers.com>
parents:
439
diff
changeset
|
164 IdentityMapping{T}(size::Vararg{Int,D}) where {T,D} = IdentityMapping{T,D}(size) |
442
e70e47fbfa7c
Add another convenience constructor
Jonatan Werpers <jonatan@werpers.com>
parents:
441
diff
changeset
|
165 IdentityMapping(size::Vararg{Int,D}) where D = IdentityMapping{Float64,D}(size) |
429
46acb2560451
Start implementing LazyIdentity
Jonatan Werpers <jonatan@werpers.com>
parents:
411
diff
changeset
|
166 |
434
648a36ebac99
Change name from LazyIdentity to IdentityMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
433
diff
changeset
|
167 range_size(tmi::IdentityMapping) = tmi.size |
648a36ebac99
Change name from LazyIdentity to IdentityMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
433
diff
changeset
|
168 domain_size(tmi::IdentityMapping) = tmi.size |
429
46acb2560451
Start implementing LazyIdentity
Jonatan Werpers <jonatan@werpers.com>
parents:
411
diff
changeset
|
169 |
434
648a36ebac99
Change name from LazyIdentity to IdentityMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
433
diff
changeset
|
170 apply(tmi::IdentityMapping{T,D}, v::AbstractArray{T,D}, I::Vararg{Any,D}) where {T,D} = v[I...] |
648a36ebac99
Change name from LazyIdentity to IdentityMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
433
diff
changeset
|
171 apply_transpose(tmi::IdentityMapping{T,D}, v::AbstractArray{T,D}, I::Vararg{Any,D}) where {T,D} = v[I...] |
429
46acb2560451
Start implementing LazyIdentity
Jonatan Werpers <jonatan@werpers.com>
parents:
411
diff
changeset
|
172 |
460
acffa3a1395d
Move part of the documentation to the constructor
Jonatan Werpers <jonatan@werpers.com>
parents:
459
diff
changeset
|
173 |
459
11e58c49fb46
Add some documentation
Jonatan Werpers <jonatan@werpers.com>
parents:
458
diff
changeset
|
174 """ |
11e58c49fb46
Add some documentation
Jonatan Werpers <jonatan@werpers.com>
parents:
458
diff
changeset
|
175 InflatedTensorMapping{T,R,D} <: TensorMapping{T,R,D} |
11e58c49fb46
Add some documentation
Jonatan Werpers <jonatan@werpers.com>
parents:
458
diff
changeset
|
176 |
11e58c49fb46
Add some documentation
Jonatan Werpers <jonatan@werpers.com>
parents:
458
diff
changeset
|
177 An inflated `TensorMapping` with dimensions added before and afer its actual dimensions. |
11e58c49fb46
Add some documentation
Jonatan Werpers <jonatan@werpers.com>
parents:
458
diff
changeset
|
178 |
11e58c49fb46
Add some documentation
Jonatan Werpers <jonatan@werpers.com>
parents:
458
diff
changeset
|
179 """ |
449
14d60de71b72
Change to concrete fields in the type
Jonatan Werpers <jonatan@werpers.com>
parents:
448
diff
changeset
|
180 struct InflatedTensorMapping{T,R,D,D_before,R_middle,D_middle,D_after, TM<:TensorMapping{T,R_middle,D_middle}} <: TensorMapping{T,R,D} |
448
912ae510dec9
Use new name of IdentityMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
447
diff
changeset
|
181 before::IdentityMapping{T,D_before} |
449
14d60de71b72
Change to concrete fields in the type
Jonatan Werpers <jonatan@werpers.com>
parents:
448
diff
changeset
|
182 tm::TM |
448
912ae510dec9
Use new name of IdentityMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
447
diff
changeset
|
183 after::IdentityMapping{T,D_after} |
446
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
184 |
460
acffa3a1395d
Move part of the documentation to the constructor
Jonatan Werpers <jonatan@werpers.com>
parents:
459
diff
changeset
|
185 ``` |
acffa3a1395d
Move part of the documentation to the constructor
Jonatan Werpers <jonatan@werpers.com>
parents:
459
diff
changeset
|
186 InflatedTensorMapping(before, tm, after) |
acffa3a1395d
Move part of the documentation to the constructor
Jonatan Werpers <jonatan@werpers.com>
parents:
459
diff
changeset
|
187 |
acffa3a1395d
Move part of the documentation to the constructor
Jonatan Werpers <jonatan@werpers.com>
parents:
459
diff
changeset
|
188 The outer product of `before`, `tm` and `after`, where `before` and `after` are `IndentityMapping`s. |
acffa3a1395d
Move part of the documentation to the constructor
Jonatan Werpers <jonatan@werpers.com>
parents:
459
diff
changeset
|
189 ``` |
446
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
190 function InflatedTensorMapping(before, tm::TensorMapping{T}, after) where T |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
191 R_before = range_dim(before) |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
192 R_middle = range_dim(tm) |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
193 R_after = range_dim(after) |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
194 R = R_before+R_middle+R_after |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
195 |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
196 D_before = domain_dim(before) |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
197 D_middle = domain_dim(tm) |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
198 D_after = domain_dim(after) |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
199 D = D_before+D_middle+D_after |
449
14d60de71b72
Change to concrete fields in the type
Jonatan Werpers <jonatan@werpers.com>
parents:
448
diff
changeset
|
200 return new{T,R,D,D_before,R_middle,D_middle,D_after, typeof(tm)}(before, tm, after) |
448
912ae510dec9
Use new name of IdentityMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
447
diff
changeset
|
201 end |
446
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
202 end |
451
6cf234eef780
Add tests for constructors and size calculations
Jonatan Werpers <jonatan@werpers.com>
parents:
450
diff
changeset
|
203 export InflatedTensorMapping |
446
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
204 |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
205 # TODO: Implement constructors where one of `before` or `after` is missing |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
206 |
448
912ae510dec9
Use new name of IdentityMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
447
diff
changeset
|
207 # TODO: Implement syntax and constructors for products of different combinations of InflatedTensorMapping and IdentityMapping |
446
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
208 |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
209 # TODO: Implement some pretty printing in terms of ⊗. E.g InflatedTensorMapping(I(3),B,I(2)) -> I(3)⊗B⊗I(2) |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
210 |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
211 function range_size(itm::InflatedTensorMapping) |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
212 return flatten_tuple( |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
213 range_size(itm.before), |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
214 range_size(itm.tm), |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
215 range_size(itm.after), |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
216 ) |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
217 end |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
218 |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
219 function domain_size(itm::InflatedTensorMapping) |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
220 return flatten_tuple( |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
221 domain_size(itm.before), |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
222 domain_size(itm.tm), |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
223 domain_size(itm.after), |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
224 ) |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
225 end |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
226 |
452
aeda2698166d
Add tullio as a test dependency and add a test for apply
Jonatan Werpers <jonatan@werpers.com>
parents:
451
diff
changeset
|
227 function apply(itm::InflatedTensorMapping{T,R,D}, v::AbstractArray{T,D}, I::Vararg{Any,R}) where {T,R,D} |
aeda2698166d
Add tullio as a test dependency and add a test for apply
Jonatan Werpers <jonatan@werpers.com>
parents:
451
diff
changeset
|
228 view_index, inner_index = split_index(itm, I...) |
446
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
229 |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
230 v_inner = view(v, view_index...) |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
231 return apply(itm.tm, v_inner, inner_index...) |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
232 end |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
233 |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
234 |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
235 """ |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
236 split_index(...) |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
237 |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
238 Splits the multi-index into two parts. One part for the view that the inner TensorMapping acts on, and one part for indexing the result |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
239 Eg. |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
240 ``` |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
241 (1,2,3,4) -> (1,:,:,4), (2,3) |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
242 ``` |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
243 """ |
452
aeda2698166d
Add tullio as a test dependency and add a test for apply
Jonatan Werpers <jonatan@werpers.com>
parents:
451
diff
changeset
|
244 function split_index(itm::InflatedTensorMapping{T,R,D}, I::Vararg{Any,R}) where {T,R,D} |
458
41f9cb6ee5a7
Moar tests and moar type stableness
Jonatan Werpers <jonatan@werpers.com>
parents:
457
diff
changeset
|
245 I_before = slice_tuple(I, Val(1), Val(range_dim(itm.before))) |
41f9cb6ee5a7
Moar tests and moar type stableness
Jonatan Werpers <jonatan@werpers.com>
parents:
457
diff
changeset
|
246 I_after = slice_tuple(I, Val(R-range_dim(itm.after)+1), Val(R)) |
446
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
247 |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
248 view_index = (I_before..., ntuple((i)->:,domain_dim(itm.tm))..., I_after...) |
455
b86312d14873
Make split_index type stable
Jonatan Werpers <jonatan@werpers.com>
parents:
452
diff
changeset
|
249 inner_index = slice_tuple(I, Val(range_dim(itm.before)+1), Val(R-range_dim(itm.after))) |
446
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
250 |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
251 return (view_index, inner_index) |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
252 end |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
253 |
456
8f4c31e06689
Add docs and tests for slice_tuple
Jonatan Werpers <jonatan@werpers.com>
parents:
455
diff
changeset
|
254 # TODO: Can this be replaced by something more elegant while still being type stable? 2020-10-21 |
8f4c31e06689
Add docs and tests for slice_tuple
Jonatan Werpers <jonatan@werpers.com>
parents:
455
diff
changeset
|
255 # See: |
8f4c31e06689
Add docs and tests for slice_tuple
Jonatan Werpers <jonatan@werpers.com>
parents:
455
diff
changeset
|
256 # https://github.com/JuliaLang/julia/issues/34884 |
8f4c31e06689
Add docs and tests for slice_tuple
Jonatan Werpers <jonatan@werpers.com>
parents:
455
diff
changeset
|
257 # https://github.com/JuliaLang/julia/issues/30386 |
8f4c31e06689
Add docs and tests for slice_tuple
Jonatan Werpers <jonatan@werpers.com>
parents:
455
diff
changeset
|
258 """ |
8f4c31e06689
Add docs and tests for slice_tuple
Jonatan Werpers <jonatan@werpers.com>
parents:
455
diff
changeset
|
259 slice_tuple(t, Val(l), Val(u)) |
8f4c31e06689
Add docs and tests for slice_tuple
Jonatan Werpers <jonatan@werpers.com>
parents:
455
diff
changeset
|
260 |
8f4c31e06689
Add docs and tests for slice_tuple
Jonatan Werpers <jonatan@werpers.com>
parents:
455
diff
changeset
|
261 Get a slice of a tuple in a type stable way. |
8f4c31e06689
Add docs and tests for slice_tuple
Jonatan Werpers <jonatan@werpers.com>
parents:
455
diff
changeset
|
262 Equivalent to t[l:u] but type stable. |
8f4c31e06689
Add docs and tests for slice_tuple
Jonatan Werpers <jonatan@werpers.com>
parents:
455
diff
changeset
|
263 """ |
455
b86312d14873
Make split_index type stable
Jonatan Werpers <jonatan@werpers.com>
parents:
452
diff
changeset
|
264 function slice_tuple(t,::Val{L},::Val{U}) where {L,U} |
b86312d14873
Make split_index type stable
Jonatan Werpers <jonatan@werpers.com>
parents:
452
diff
changeset
|
265 return ntuple(i->t[i+L-1], U-L+1) |
b86312d14873
Make split_index type stable
Jonatan Werpers <jonatan@werpers.com>
parents:
452
diff
changeset
|
266 end |
b86312d14873
Make split_index type stable
Jonatan Werpers <jonatan@werpers.com>
parents:
452
diff
changeset
|
267 |
457
8fb6a5611c7a
Add tests and docs for flatten_tuple
Jonatan Werpers <jonatan@werpers.com>
parents:
456
diff
changeset
|
268 """ |
8fb6a5611c7a
Add tests and docs for flatten_tuple
Jonatan Werpers <jonatan@werpers.com>
parents:
456
diff
changeset
|
269 flatten_tuple(t) |
8fb6a5611c7a
Add tests and docs for flatten_tuple
Jonatan Werpers <jonatan@werpers.com>
parents:
456
diff
changeset
|
270 |
8fb6a5611c7a
Add tests and docs for flatten_tuple
Jonatan Werpers <jonatan@werpers.com>
parents:
456
diff
changeset
|
271 Takes a nested tuple and flattens the whole structure |
8fb6a5611c7a
Add tests and docs for flatten_tuple
Jonatan Werpers <jonatan@werpers.com>
parents:
456
diff
changeset
|
272 """ |
446
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
273 flatten_tuple(t::NTuple{N, Number} where N) = t |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
274 flatten_tuple(t::Tuple) = ((flatten_tuple.(t)...)...,) # simplify? |
904aae1899df
Start implementing InflatedTensorMapping
Jonatan Werpers <jonatan@werpers.com>
parents:
429
diff
changeset
|
275 flatten_tuple(ts::Vararg) = flatten_tuple(ts) |