Mercurial > repos > public > sbplib_julia
comparison src/SbpOperators/boundaryops/boundary_restriction.jl @ 1100:157a78959e5d refactor/sbpoperators/inflation
Bring up to date
author | Jonatan Werpers <jonatan@werpers.com> |
---|---|
date | Tue, 10 May 2022 20:34:20 +0200 |
parents | 05a25a5063bb 7fc8df5157a7 |
children | c0ab81e4c39c |
comparison
equal
deleted
inserted
replaced
1099:05a25a5063bb | 1100:157a78959e5d |
---|---|
1 # TODO: The type parameter closure_stencil::Stencil is required since there isnt any suitable type | |
2 # for stencil_set. We should consider adding type ::StencilSet and dispatch on that instead. | |
3 # The same goes for other operators | |
4 """ | 1 """ |
5 boundary_restriction(grid, closure_stencil::Stencil, boundary) | 2 boundary_restriction(grid, closure_stencil::Stencil, boundary) |
6 | 3 |
7 Creates boundary restriction operators `e` as `LazyTensor`s on `boundary` | 4 Creates boundary restriction operators `e` as `LazyTensor`s on `boundary` |
8 | 5 |
11 On a one-dimensional `grid`, `e` is a `BoundaryOperator`. On a multi-dimensional `grid`, `e` is the inflation of | 8 On a one-dimensional `grid`, `e` is a `BoundaryOperator`. On a multi-dimensional `grid`, `e` is the inflation of |
12 a `BoundaryOperator`. | 9 a `BoundaryOperator`. |
13 | 10 |
14 See also: [`boundary_operator`](@ref). | 11 See also: [`boundary_operator`](@ref). |
15 """ | 12 """ |
16 function boundary_restriction(grid, closure_stencil::Stencil, boundary) | 13 function boundary_restriction(grid, closure_stencil, boundary) |
17 converted_stencil = convert(Stencil{eltype(grid)}, closure_stencil) | 14 converted_stencil = convert(Stencil{eltype(grid)}, closure_stencil) |
18 | 15 |
19 op = BoundaryOperator(restrict(grid, dim(boundary)), converted_stencil, region(boundary)) | 16 op = BoundaryOperator(restrict(grid, dim(boundary)), converted_stencil, region(boundary)) |
20 return LazyTensors.inflate(op, size(grid), dim(boundary)) | 17 return LazyTensors.inflate(op, size(grid), dim(boundary)) |
21 end | 18 end |
22 | 19 |
23 """ | 20 """ |
24 boundary_restriction(grid, stencil_set, boundary) | 21 boundary_restriction(grid, stencil_set, boundary) |
25 | 22 |
26 Creates a `boundary_restriction` operator on `grid` given a parsed TOML | 23 Creates a `boundary_restriction` operator on `grid` given a `stencil_set`. |
27 `stencil_set`. | |
28 """ | 24 """ |
29 boundary_restriction(grid, stencil_set, boundary) = boundary_restriction(grid, parse_stencil(stencil_set["e"]["closure"]), boundary) | 25 boundary_restriction(grid, stencil_set::StencilSet, boundary) = boundary_restriction(grid, parse_stencil(stencil_set["e"]["closure"]), boundary) |