tsid 1.9.0
Efficient Task Space Inverse Dynamics for Multi-body Systems based on Pinocchio
Loading...
Searching...
No Matches
constraint-equality.hpp
Go to the documentation of this file.
1//
2// Copyright (c) 2018 CNRS
3//
4// This file is part of tsid
5// tsid is free software: you can redistribute it
6// and/or modify it under the terms of the GNU Lesser General Public
7// License as published by the Free Software Foundation, either version
8// 3 of the License, or (at your option) any later version.
9// tsid is distributed in the hope that it will be
10// useful, but WITHOUT ANY WARRANTY; without even the implied warranty
11// of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12// General Lesser Public License for more details. You should have
13// received a copy of the GNU Lesser General Public License along with
14// tsid If not, see
15// <http://www.gnu.org/licenses/>.
16//
17
18#ifndef __tsid_python_constriant_equality_hpp__
19#define __tsid_python_constriant_equality_hpp__
20
22
24
25namespace tsid {
26namespace python {
27namespace bp = boost::python;
28
29template <typename ConstraintEquality>
31 : public boost::python::def_visitor<
32 ConstraintEqPythonVisitor<ConstraintEquality> > {
33 template <class PyClass>
34
35 void visit(PyClass& cl) const {
36 cl.def(bp::init<std::string>((bp::arg("name")),
37 "Default constructor with name."))
38 .def(bp::init<std::string, unsigned int, unsigned int>(
39 (bp::arg("name"), bp::arg("row"), bp::arg("col")),
40 "Default constructor with name and size."))
41 .def(bp::init<std::string, Eigen::MatrixXd, Eigen::VectorXd>(
42 (bp::arg("name"), bp::arg("A"), bp::arg("b")),
43 "Default constructor with name and constraint."))
44
45 .add_property("rows", &ConstraintEquality::rows)
46 .add_property("cols", &ConstraintEquality::cols)
47 .def("resize", &ConstraintEquality::resize,
48 (bp::arg("r"), bp::arg("c")), "Resize constraint size.")
49
50 .add_property("isEquality", &ConstraintEquality::isEquality)
51 .add_property("isInequality", &ConstraintEquality::isInequality)
52 .add_property("isBound", &ConstraintEquality::isBound)
53
54 .add_property("matrix", &ConstraintEqPythonVisitor::matrix)
55 .add_property("vector", &ConstraintEqPythonVisitor::vector)
56 .add_property("lowerBound", &ConstraintEqPythonVisitor::lowerBound)
57 .add_property("upperBound", &ConstraintEqPythonVisitor::upperBound)
58
59 .def("setMatrix",
60 (bool (ConstraintEquality::*)(
61 const Eigen::Ref<
62 const Eigen::MatrixXd>))&ConstraintEquality::setMatrix,
63 bp::args("matrix"), "Set Matrix")
64 .def("setVector",
65 (bool (ConstraintEquality::*)(
66 const Eigen::Ref<
67 const Eigen::VectorXd>))&ConstraintEquality::setVector,
68 bp::args("vector"), "Set Vector")
69 .def("setLowerBound",
70 (bool (ConstraintEquality::*)(
71 const Eigen::Ref<
72 const Eigen::VectorXd>))&ConstraintEquality::setLowerBound,
73 bp::args("lb"), "Set LowerBound")
74 .def("setUpperBound",
75 (bool (ConstraintEquality::*)(
76 const Eigen::Ref<
77 const Eigen::VectorXd>))&ConstraintEquality::setUpperBound,
78 bp::args("ub"), "Set UpperBound")
79
80 ;
81 }
82 static Eigen::MatrixXd matrix(const ConstraintEquality& self) {
83 return self.matrix();
84 }
85 static Eigen::VectorXd vector(const ConstraintEquality& self) {
86 return self.vector();
87 }
88 static Eigen::VectorXd lowerBound(const ConstraintEquality& self) {
89 return self.lowerBound();
90 }
91 static Eigen::VectorXd upperBound(const ConstraintEquality& self) {
92 return self.upperBound();
93 }
94
95 static void expose(const std::string& class_name) {
96 std::string doc = "Constraint Equality info.";
97 bp::class_<ConstraintEquality>(class_name.c_str(), doc.c_str(), bp::no_init)
99
100 eigenpy::enableEigenPySpecific<Eigen::MatrixXd>();
101 }
102};
103} // namespace python
104} // namespace tsid
105
106#endif // ifndef __tsid_python_constriant_equality_hpp__
Definition constraint-bound.hpp:26
Definition constraint-bound.hpp:25
Definition constraint-equality.hpp:32
static Eigen::VectorXd vector(const ConstraintEquality &self)
Definition constraint-equality.hpp:85
void visit(PyClass &cl) const
Definition constraint-equality.hpp:35
static void expose(const std::string &class_name)
Definition constraint-equality.hpp:95
static Eigen::VectorXd lowerBound(const ConstraintEquality &self)
Definition constraint-equality.hpp:88
static Eigen::VectorXd upperBound(const ConstraintEquality &self)
Definition constraint-equality.hpp:91
static Eigen::MatrixXd matrix(const ConstraintEquality &self)
Definition constraint-equality.hpp:82