3.4
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("reset", &BoundaryTypes::reset);
42 cls.def("setNeumann", &BoundaryTypes::setAllNeumann);
43 cls.def("setDirichlet", &BoundaryTypes::setAllDirichlet);
44 cls.def("isDirichlet", &BoundaryTypes::hasDirichlet);
45 cls.def("isNeumann", &BoundaryTypes::hasNeumann);
46}
47
48template <class BoundaryTypes>
49void registerBoundaryTypes(pybind11::handle scope)
50{
51 using namespace Dune::Python;
52
53 auto [cls, addedToRegistry] = insertClass<BoundaryTypes>(
54 scope, "BoundaryTypes",
55 GenerateTypeName(Dune::className<BoundaryTypes>()),
56 IncludeFiles{"dumux/python/common/boundarytypes.hh"}
57 );
58
59 if (addedToRegistry)
60 registerBoundaryTypes(scope, cls);
61}
62
63} // namespace Dumux::Python
64
65#endif
Definition: python/common/boundarytypes.hh:33
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:296
bool hasDirichlet() const
Returns true if some equation is used to specify a Dirichlet condition.
Definition: common/boundarytypes.hh:258
Class to specify the type of a boundary.