Mercurial > repos > public > sbplib_julia
view src/BoundaryConditions/boundary_condition.jl @ 1485:e96ee7d7ac9c feature/boundary_conditions
Test sat_tensors for Laplace w. Neumann conditions
author | Vidar Stiernström <vidar.stiernstrom@it.uu.se> |
---|---|
date | Mon, 25 Dec 2023 23:39:56 +0100 |
parents | ee242c3fe4af |
children | 37b05221beda |
line wrap: on
line source
""" BoundaryCondition A type for implementing data needed in order to impose a boundary condition. Subtypes refer to perticular types of boundary conditions, e.g. Neumann conditions. """ abstract type BoundaryCondition{T1,T2} end """ id(::BoundaryCondition) The boundary identifier of the BoundaryCondition. Must be implemented by subtypes. """ function id end """ data(::BoundaryCondition) If implemented, the data associated with the BoundaryCondition """ function data end """ discretize(grid, bc::BoundaryCondition) The grid function obtained from discretizing the `bc` data on the boundary grid specified the by bc `id`. """ function discretize_data(grid, bc::BoundaryCondition) return eval_on(boundary_grid(grid, id(bc)), data(bc)) end struct DirichletCondition{T1,T2} <: BoundaryCondition{T1,T2} data::T1 id::T2 end id(bc::DirichletCondition) = bc.id data(bc::DirichletCondition) = bc.data struct NeumannCondition{T1,T2} <: BoundaryCondition{T1,T2} data::T1 id::T2 end id(bc::NeumannCondition) = bc.id data(bc::NeumannCondition) = bc.data