3.6-git
DUNE for Multi-{Phase, Component, Scale, Physics, ...} flow and transport in porous media
python/common/boundarytypes.hh
Go to the documentation of this file.
1// -*- mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*-
2// vi: set et ts=4 sw=4 sts=4:
3/****************************************************************************
4 * See the file COPYING for full copying permissions. *
5 * *
6 * This program is free software: you can redistribute it and/or modify *
7 * it under the terms of the GNU General Public License as published by *
8 * the Free Software Foundation, either version 3 of the License, or *
9 * (at your option) any later version. *
10 * *
11 * This program is distributed in the hope that it will be useful, *
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
14 * GNU General Public License for more details. *
15 * *
16 * You should have received a copy of the GNU General Public License *
17 * along with this program. If not, see <http://www.gnu.org/licenses/>. *
18 *****************************************************************************/
24#ifndef DUMUX_PYTHON_COMMON_BOUNDARYTYPES_HH
25#define DUMUX_PYTHON_COMMON_BOUNDARYTYPES_HH
26
27#include <dune/common/classname.hh>
28#include <dune/python/pybind11/pybind11.h>
29#include <dune/python/common/typeregistry.hh>
30
32
33namespace Dumux::Python {
34
35template <class BoundaryTypes, class... Options>
36void registerBoundaryTypes(pybind11::handle scope, pybind11::class_<BoundaryTypes, Options...> cls)
37{
38 using pybind11::operator""_a;
39
40 cls.def(pybind11::init());
41 cls.def("__copy__", [](const BoundaryTypes& self) {
42 return BoundaryTypes(self);
43 });
44 cls.def("__deepcopy__", [](const BoundaryTypes& self, pybind11::dict) {
45 return BoundaryTypes(self);
46 }, "memo"_a);
47 cls.def("reset", &BoundaryTypes::reset);
48 cls.def("setNeumann", &BoundaryTypes::setAllNeumann);
49 cls.def("setDirichlet", &BoundaryTypes::setAllDirichlet);
50 cls.def_property_readonly("isDirichlet", &BoundaryTypes::hasDirichlet);
51 cls.def_property_readonly("isNeumann", &BoundaryTypes::hasNeumann);
52}
53
54template <class BoundaryTypes>
55void registerBoundaryTypes(pybind11::handle scope)
56{
57 using namespace Dune::Python;
58
59 auto [cls, addedToRegistry] = insertClass<BoundaryTypes>(
60 scope, "BoundaryTypes",
61 GenerateTypeName(Dune::className<BoundaryTypes>()),
62 IncludeFiles{"dumux/python/common/boundarytypes.hh"}
63 );
64
65 if (addedToRegistry)
66 registerBoundaryTypes(scope, cls);
67}
68
69} // namespace Dumux::Python
70
71#endif
Definition: python/assembly/fvassembler.hh:30
void registerBoundaryTypes(pybind11::handle scope, pybind11::class_< BoundaryTypes, Options... > cls)
Definition: python/common/boundarytypes.hh:36
Class to specify the type of a boundary.
Definition: common/boundarytypes.hh:38
void setAllNeumann()
Set all boundary conditions to Neumann.
Definition: common/boundarytypes.hh:102
void setAllDirichlet()
Set all boundary conditions to Dirichlet.
Definition: common/boundarytypes.hh:111
void reset()
Reset the boundary types for all equations.
Definition: common/boundarytypes.hh:54
bool hasNeumann() const
Returns true if some equation is used to specify a Neumann condition.
Definition: common/boundarytypes.hh:272
bool hasDirichlet() const
Returns true if some equation is used to specify a Dirichlet condition.
Definition: common/boundarytypes.hh:234
Class to specify the type of a boundary.