Mercurial > repos > public > sbplib_julia
comparison src/SbpOperators/volumeops/volume_operator.jl @ 988:83046af6143a
Merge feature/tensormapping_application_promotion
author | Jonatan Werpers <jonatan@werpers.com> |
---|---|
date | Wed, 16 Mar 2022 18:39:00 +0100 |
parents | 469ed954b493 |
children | e79debd10f7d 1ba8a398af9c bbbc31953367 |
comparison
equal
deleted
inserted
replaced
985:1b4f31ae114f | 988:83046af6143a |
---|---|
41 closure_size(::VolumeOperator{T,N,M}) where {T,N,M} = M | 41 closure_size(::VolumeOperator{T,N,M}) where {T,N,M} = M |
42 | 42 |
43 LazyTensors.range_size(op::VolumeOperator) = op.size | 43 LazyTensors.range_size(op::VolumeOperator) = op.size |
44 LazyTensors.domain_size(op::VolumeOperator) = op.size | 44 LazyTensors.domain_size(op::VolumeOperator) = op.size |
45 | 45 |
46 function LazyTensors.apply(op::VolumeOperator{T}, v::AbstractVector{T}, i::Index{Lower}) where T | 46 function LazyTensors.apply(op::VolumeOperator, v::AbstractVector, i::Index{Lower}) |
47 return @inbounds apply_stencil(op.closure_stencils[Int(i)], v, Int(i)) | 47 return @inbounds apply_stencil(op.closure_stencils[Int(i)], v, Int(i)) |
48 end | 48 end |
49 | 49 |
50 function LazyTensors.apply(op::VolumeOperator{T}, v::AbstractVector{T}, i::Index{Interior}) where T | 50 function LazyTensors.apply(op::VolumeOperator, v::AbstractVector, i::Index{Interior}) |
51 return apply_stencil(op.inner_stencil, v, Int(i)) | 51 return apply_stencil(op.inner_stencil, v, Int(i)) |
52 end | 52 end |
53 | 53 |
54 function LazyTensors.apply(op::VolumeOperator{T}, v::AbstractVector{T}, i::Index{Upper}) where T | 54 function LazyTensors.apply(op::VolumeOperator, v::AbstractVector, i::Index{Upper}) |
55 return @inbounds Int(op.parity)*apply_stencil_backwards(op.closure_stencils[op.size[1]-Int(i)+1], v, Int(i)) | 55 return @inbounds Int(op.parity)*apply_stencil_backwards(op.closure_stencils[op.size[1]-Int(i)+1], v, Int(i)) |
56 end | 56 end |
57 | 57 |
58 function LazyTensors.apply(op::VolumeOperator{T}, v::AbstractVector{T}, i) where T | 58 function LazyTensors.apply(op::VolumeOperator, v::AbstractVector, i) |
59 r = getregion(i, closure_size(op), op.size[1]) | 59 r = getregion(i, closure_size(op), op.size[1]) |
60 return LazyTensors.apply(op, v, Index(i, r)) | 60 return LazyTensors.apply(op, v, Index(i, r)) |
61 end | 61 end |