version 0.4
python/basis/basis.hh
Go to the documentation of this file.
1// SPDX-FileCopyrightText: 2021-2024 The Ikarus Developers mueller@ibb.uni-stuttgart.de
2// SPDX-License-Identifier: LGPL-3.0-or-later
3
9#pragma once
10
11#include <dune/functions/functionspacebases/lagrangebasis.hh>
12#include <dune/functions/functionspacebases/powerbasis.hh>
13#include <dune/grid/yaspgrid.hh>
14#include <dune/python/common/typeregistry.hh>
15#include <dune/python/pybind11/eigen.h>
16#include <dune/python/pybind11/functional.h>
17#include <dune/python/pybind11/pybind11.h>
18#include <dune/python/pybind11/stl.h>
19
21#include <ikarus/utils/basis.hh>
22
23namespace Ikarus::Python {
24
36 template <class Basis, class... options>
37 void registerBasis(pybind11::handle scope, pybind11::class_<Basis, options...> cls) {
38 using pybind11::operator""_a;
39
40 using GridView = typename Basis::GridView;
41 using PreBasis = typename Basis::PreBasis;
42 using UntouchedBasis = typename Basis::UntouchedBasis;
43 using FlatBasis = typename Basis::FlatBasis;
44
45 cls.def(pybind11::init([](const UntouchedBasis& gb) { return new Basis(gb.preBasis()); }));
46
47 cls.def(
48 "flat", [](Basis& self) { return self.flat(); }, pybind11::return_value_policy::reference);
49
50 cls.def(
51 "untouched", [](Basis& self) { return self.untouched(); }, pybind11::return_value_policy::reference);
52 }
53
54} // namespace Ikarus::Python
Definition of the LinearElastic class for finite element mechanics computations.
void registerBasis(pybind11::handle scope, pybind11::class_< Basis, options... > cls)
Register a Python wrapper for an Ikarus basis class.
Definition: python/basis/basis.hh:37
void init(int argc, char **argv, bool enableFileLogger=true)
Initializes the Ikarus framework.
Definition: init.hh:81
Definition: flatassembler.hh:20
Wrapper class for a hierarchical basis constructed from a pre-basis.
Definition: utils/basis.hh:29
typename PreBasis::GridView GridView
The type of the grid view.
Definition: utils/basis.hh:32
auto & untouched()
Returns a reference to the untouched version of the basis.
Definition: utils/basis.hh:61
PreBasis_ PreBasis
The type of the untouched pre basis.
Definition: utils/basis.hh:31
decltype(Dune::Functions::DefaultGlobalBasis(Ikarus::flatPreBasis(std::declval< PreBasis >()))) FlatBasis
The type of the flattened basis.
Definition: utils/basis.hh:36
decltype(Dune::Functions::DefaultGlobalBasis(std::declval< PreBasis >())) UntouchedBasis
The type of the untouched basis.
Definition: utils/basis.hh:34
auto & flat()
Returns a reference to the flat version of the basis.
Definition: utils/basis.hh:54
Wrapper around Dune-functions global basis.