Nektar++
Python/MeshGraph.cpp
Go to the documentation of this file.
1////////////////////////////////////////////////////////////////////////////////
2//
3// File: MeshGraph.cpp
4//
5// For more information, please see: http://www.nektar.info/
6//
7// The MIT License
8//
9// Copyright (c) 2006 Division of Applied Mathematics, Brown University (USA),
10// Department of Aeronautics, Imperial College London (UK), and Scientific
11// Computing and Imaging Institute, University of Utah (USA).
12//
13// Permission is hereby granted, free of charge, to any person obtaining a
14// copy of this software and associated documentation files (the "Software"),
15// to deal in the Software without restriction, including without limitation
16// the rights to use, copy, modify, merge, publish, distribute, sublicense,
17// and/or sell copies of the Software, and to permit persons to whom the
18// Software is furnished to do so, subject to the following conditions:
19//
20// The above copyright notice and this permission notice shall be included
21// in all copies or substantial portions of the Software.
22//
23// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
24// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
25// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
26// THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
27// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
28// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
29// DEALINGS IN THE SOFTWARE.
30//
31// Description: Python wrapper for MeshGraph.
32//
33////////////////////////////////////////////////////////////////////////////////
34
37#include <boost/python/suite/indexing/map_indexing_suite.hpp>
38
39using namespace Nektar;
40using namespace Nektar::SpatialDomains;
41
42/*
43 * @brief Lightweight wrapper around MeshGraph::Read to avoid wrapping
44 * DomainRange struct.
45 */
48{
49 return MeshGraph::Read(session);
50}
51
52/**
53 * @brief MeshGraph exports.
54 */
56{
57 py::class_<PointGeomMap>("PointGeomMap")
58 .def(py::map_indexing_suite<PointGeomMap, true>());
59 py::class_<SegGeomMap>("SegGeomMap")
60 .def(py::map_indexing_suite<SegGeomMap, true>());
61 py::class_<QuadGeomMap>("QuadGeomMap")
62 .def(py::map_indexing_suite<QuadGeomMap, true>());
63 py::class_<TriGeomMap>("TriGeomMap")
64 .def(py::map_indexing_suite<TriGeomMap, true>());
65 py::class_<TetGeomMap>("TetGeomMap")
66 .def(py::map_indexing_suite<TetGeomMap, true>());
67 py::class_<PrismGeomMap>("PrismGeomMap")
68 .def(py::map_indexing_suite<PrismGeomMap, true>());
69 py::class_<PyrGeomMap>("PyrGeomMap")
70 .def(py::map_indexing_suite<PyrGeomMap, true>());
71 py::class_<HexGeomMap>("HexGeomMap")
72 .def(py::map_indexing_suite<HexGeomMap, true>());
73 py::class_<CurveMap>("CurveMap")
74 .def(py::map_indexing_suite<CurveMap, true>());
75
76 py::class_<MeshGraph, std::shared_ptr<MeshGraph>, boost::noncopyable>(
77 "MeshGraph", py::no_init)
78
79 .def("Read", MeshGraph_Read)
80 .staticmethod("Read")
81
82 .def("GetMeshDimension", &MeshGraph::GetMeshDimension)
83 .def("GetAllPointGeoms", &MeshGraph::GetAllPointGeoms,
84 py::return_internal_reference<>())
85 .def("GetAllSegGeoms", &MeshGraph::GetAllSegGeoms,
86 py::return_internal_reference<>())
87 .def("GetAllQuadGeoms", &MeshGraph::GetAllQuadGeoms,
88 py::return_internal_reference<>())
89 .def("GetAllTriGeoms", &MeshGraph::GetAllTriGeoms,
90 py::return_internal_reference<>())
91 .def("GetAllTetGeoms", &MeshGraph::GetAllTetGeoms,
92 py::return_internal_reference<>())
93 .def("GetAllPrismGeoms", &MeshGraph::GetAllPrismGeoms,
94 py::return_internal_reference<>())
95 .def("GetAllPyrGeoms", &MeshGraph::GetAllPyrGeoms,
96 py::return_internal_reference<>())
97 .def("GetAllHexGeoms", &MeshGraph::GetAllHexGeoms,
98 py::return_internal_reference<>())
99 .def("GetCurvedEdges", &MeshGraph::GetCurvedEdges,
100 py::return_internal_reference<>())
101 .def("GetCurvedFaces", &MeshGraph::GetCurvedFaces,
102 py::return_internal_reference<>())
103
104 .def("GetNumElements", &MeshGraph::GetNumElements)
105
106 .def("SetExpansionInfosToEvenlySpacedPoints",
107 &MeshGraph::SetExpansionInfoToEvenlySpacedPoints)
108 .def("SetExpansionInfosToPolyOrder",
109 &MeshGraph::SetExpansionInfoToNumModes)
110 .def("SetExpansionInfosToPointOrder",
111 &MeshGraph::SetExpansionInfoToPointOrder);
112}
void export_MeshGraph()
MeshGraph exports.
MeshGraphSharedPtr MeshGraph_Read(const LibUtilities::SessionReaderSharedPtr &session)
std::shared_ptr< SessionReader > SessionReaderSharedPtr
std::shared_ptr< MeshGraph > MeshGraphSharedPtr
Definition: MeshGraph.h:176
The above copyright notice and this permission notice shall be included.
Definition: CoupledSolver.h:2