Mercurial > repos > public > sbplib_julia
comparison src/SbpOperators/volumeops/derivatives/first_derivative.jl @ 989:7bf3121c6864 feature/stencil_set_type
Add type StencilSet
author | Vidar Stiernström <vidar.stiernstrom@it.uu.se> |
---|---|
date | Thu, 17 Mar 2022 21:31:20 +0100 |
parents | ba023fc09961 |
children | b6238afd3bb0 |
comparison
equal
deleted
inserted
replaced
988:83046af6143a | 989:7bf3121c6864 |
---|---|
16 h_inv = inverse_spacing(grid)[direction] | 16 h_inv = inverse_spacing(grid)[direction] |
17 return SbpOperators.volume_operator(grid, scale(inner_stencil,h_inv), scale.(closure_stencils,h_inv), odd, direction) | 17 return SbpOperators.volume_operator(grid, scale(inner_stencil,h_inv), scale.(closure_stencils,h_inv), odd, direction) |
18 end | 18 end |
19 first_derivative(grid::EquidistantGrid{1}, inner_stencil::Stencil, closure_stencils) = first_derivative(grid,inner_stencil,closure_stencils,1) | 19 first_derivative(grid::EquidistantGrid{1}, inner_stencil::Stencil, closure_stencils) = first_derivative(grid,inner_stencil,closure_stencils,1) |
20 | 20 |
21 | |
21 """ | 22 """ |
22 first_derivative(grid, stencil_set, direction) | 23 first_derivative(grid, stencil_set, direction) |
23 | 24 |
24 Creates a `first_derivative` operator on `grid` along coordinate dimension `direction` given a parsed TOML | 25 Creates a `first_derivative` operator on `grid` along coordinate dimension `direction` given a `stencil_set`. |
25 `stencil_set`. | |
26 """ | 26 """ |
27 function first_derivative(grid::EquidistantGrid, stencil_set, direction) | 27 function first_derivative(grid::EquidistantGrid, stencil_set::StencilSet, direction) |
28 inner_stencil = parse_stencil(stencil_set["D1"]["inner_stencil"]) | 28 inner_stencil = parse_stencil(stencil_set["D1"]["inner_stencil"]) |
29 closure_stencils = parse_stencil.(stencil_set["D1"]["closure_stencils"]) | 29 closure_stencils = parse_stencil.(stencil_set["D1"]["closure_stencils"]) |
30 first_derivative(grid,inner_stencil,closure_stencils,direction); | 30 first_derivative(grid,inner_stencil,closure_stencils,direction); |
31 end | 31 end |
32 | |
33 # TODO: Not possible to remove ::Stencil from first_derivative(grid::EquidistantGrid{1},...) due to type deduction failing. | |
34 # Is this due to the type ambuguity of StencilSet? Possible to address in some other way? | |
35 # If not, should we drop ::StencilSet from the method above (it is not required)? |