70 lines
3.0 KiB
C++
70 lines
3.0 KiB
C++
#include <pybind11/eigen.h>
|
|
#include <pybind11/stl_bind.h>
|
|
#include <pybind11/pybind11.h>
|
|
#include <pybind11/operators.h>
|
|
#include "gtsam/nonlinear/utilities.h" // for RedirectCout.
|
|
|
|
#include "path/to/ns1.h"
|
|
#include "path/to/ns1/ClassB.h"
|
|
#include "path/to/ns2.h"
|
|
#include "path/to/ns2/ClassA.h"
|
|
#include "path/to/ns3.h"
|
|
#include "gtsam/nonlinear/Values.h"
|
|
|
|
|
|
|
|
|
|
using namespace std;
|
|
|
|
namespace py = pybind11;
|
|
|
|
PYBIND11_MODULE(namespaces_py, m_) {
|
|
m_.doc() = "pybind11 wrapper of namespaces_py";
|
|
|
|
pybind11::module m_ns1 = m_.def_submodule("ns1", "ns1 submodule");
|
|
|
|
py::class_<ns1::ClassA, std::shared_ptr<ns1::ClassA>>(m_ns1, "ClassA")
|
|
.def(py::init<>());
|
|
|
|
py::class_<ns1::ClassB, std::shared_ptr<ns1::ClassB>>(m_ns1, "ClassB")
|
|
.def(py::init<>());
|
|
|
|
m_ns1.def("aGlobalFunction",[](){return ns1::aGlobalFunction();}); pybind11::module m_ns2 = m_.def_submodule("ns2", "ns2 submodule");
|
|
|
|
py::class_<ns2::ClassA, std::shared_ptr<ns2::ClassA>>(m_ns2, "ClassA")
|
|
.def(py::init<>())
|
|
.def("memberFunction",[](ns2::ClassA* self){return self->memberFunction();})
|
|
.def("nsArg",[](ns2::ClassA* self, const ns1::ClassB& arg){return self->nsArg(arg);}, py::arg("arg"))
|
|
.def("nsReturn",[](ns2::ClassA* self, double q){return self->nsReturn(q);}, py::arg("q"))
|
|
.def_static("afunction",[](){return ns2::ClassA::afunction();});
|
|
pybind11::module m_ns2_ns3 = m_ns2.def_submodule("ns3", "ns3 submodule");
|
|
|
|
py::class_<ns2::ns3::ClassB, std::shared_ptr<ns2::ns3::ClassB>>(m_ns2_ns3, "ClassB")
|
|
.def(py::init<>());
|
|
|
|
py::class_<ns2::ClassC, std::shared_ptr<ns2::ClassC>>(m_ns2, "ClassC")
|
|
.def(py::init<>());
|
|
|
|
m_ns2.attr("aNs2Var") = ns2::aNs2Var;
|
|
m_ns2.def("aGlobalFunction",[](){return ns2::aGlobalFunction();});
|
|
m_ns2.def("overloadedGlobalFunction",[](const ns1::ClassA& a){return ns2::overloadedGlobalFunction(a);}, py::arg("a"));
|
|
m_ns2.def("overloadedGlobalFunction",[](const ns1::ClassA& a, double b){return ns2::overloadedGlobalFunction(a, b);}, py::arg("a"), py::arg("b"));
|
|
py::class_<ClassD, std::shared_ptr<ClassD>>(m_, "ClassD")
|
|
.def(py::init<>());
|
|
|
|
m_.attr("aGlobalVar") = aGlobalVar; pybind11::module m_gtsam = m_.def_submodule("gtsam", "gtsam submodule");
|
|
|
|
py::class_<gtsam::Values, std::shared_ptr<gtsam::Values>>(m_gtsam, "Values")
|
|
.def(py::init<>())
|
|
.def(py::init<const gtsam::Values&>(), py::arg("other"))
|
|
.def("insert_vector",[](gtsam::Values* self, size_t j, const gtsam::Vector& vector){ self->insert(j, vector);}, py::arg("j"), py::arg("vector"))
|
|
.def("insert",[](gtsam::Values* self, size_t j, const gtsam::Vector& vector){ self->insert(j, vector);}, py::arg("j"), py::arg("vector"))
|
|
.def("insert_matrix",[](gtsam::Values* self, size_t j, const gtsam::Matrix& matrix){ self->insert(j, matrix);}, py::arg("j"), py::arg("matrix"))
|
|
.def("insert",[](gtsam::Values* self, size_t j, const gtsam::Matrix& matrix){ self->insert(j, matrix);}, py::arg("j"), py::arg("matrix"));
|
|
|
|
|
|
#include "python/specializations.h"
|
|
|
|
}
|
|
|