tsid 1.9.0
Efficient Task Space Inverse Dynamics for Multi-body Systems based on Pinocchio
Loading...
Searching...
No Matches
constraint-inequality.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#ifndef __tsid_python_constriant_inequality_hpp__
18#define __tsid_python_constriant_inequality_hpp__
19
21
23
24namespace tsid {
25namespace python {
26namespace bp = boost::python;
27
28template <typename ConstraintInequality>
30 : public boost::python::def_visitor<
31 ConstraintIneqPythonVisitor<ConstraintInequality> > {
32 template <class PyClass>
33
34 void visit(PyClass& cl) const {
35 cl.def(bp::init<std::string>((bp::arg("name")),
36 "Default constructor with name."))
37 .def(bp::init<std::string, unsigned int, unsigned int>(
38 (bp::arg("name"), bp::arg("row"), bp::arg("col")),
39 "Default constructor with name and size."))
40 .def(bp::init<std::string, Eigen::MatrixXd, Eigen::VectorXd,
41 Eigen::VectorXd>(
42 (bp::arg("name"), bp::arg("A"), bp::arg("lb"), bp::arg("ub")),
43 "Default constructor with name and constraint."))
44
45 .add_property("rows", &ConstraintInequality::rows)
46 .add_property("cols", &ConstraintInequality::cols)
47 .def("resize", &ConstraintInequality::resize,
48 (bp::arg("r"), bp::arg("c")), "Resize constraint size.")
49
50 .add_property("isEquality", &ConstraintInequality::isEquality)
51 .add_property("isInequality", &ConstraintInequality::isInequality)
52 .add_property("isBound", &ConstraintInequality::isBound)
53
54 .add_property("matrix", &ConstraintIneqPythonVisitor::matrix)
55 .add_property("vector", &ConstraintIneqPythonVisitor::vector)
56 .add_property("lowerBound", &ConstraintIneqPythonVisitor::lowerBound)
57 .add_property("upperBound", &ConstraintIneqPythonVisitor::upperBound)
58
59 .def("setMatrix",
60 (bool (ConstraintInequality::*)(
61 const Eigen::Ref<
62 const Eigen::MatrixXd>))&ConstraintInequality::setMatrix,
63 bp::args("matrix"), "Set Matrix")
64 .def("setVector",
65 (bool (ConstraintInequality::*)(
66 const Eigen::Ref<
67 const Eigen::VectorXd>))&ConstraintInequality::setVector,
68 bp::args("vector"), "Set Vector")
69 .def(
70 "setLowerBound",
71 (bool (ConstraintInequality::*)(
72 const Eigen::Ref<const Eigen::VectorXd>))&ConstraintInequality::
73 setLowerBound,
74 bp::args("lb"), "Set LowerBound")
75 .def(
76 "setUpperBound",
77 (bool (ConstraintInequality::*)(
78 const Eigen::Ref<const Eigen::VectorXd>))&ConstraintInequality::
79 setUpperBound,
80 bp::args("ub"), "Set UpperBound");
81 }
82 static Eigen::MatrixXd matrix(const ConstraintInequality& self) {
83 return self.matrix();
84 }
85 static Eigen::VectorXd vector(const ConstraintInequality& self) {
86 return self.vector();
87 }
88 static Eigen::VectorXd lowerBound(const ConstraintInequality& self) {
89 return self.lowerBound();
90 }
91 static Eigen::VectorXd upperBound(const ConstraintInequality& self) {
92 return self.upperBound();
93 }
94
95 static void expose(const std::string& class_name) {
96 std::string doc = "Constraint Inequality info.";
97 bp::class_<ConstraintInequality>(class_name.c_str(), doc.c_str(),
98 bp::no_init)
100 }
101};
102} // namespace python
103} // namespace tsid
104
105#endif // ifndef __tsid_python_constriant_inequality_hpp__
Definition constraint-bound.hpp:26
Definition constraint-bound.hpp:25
Definition constraint-inequality.hpp:31
static Eigen::MatrixXd matrix(const ConstraintInequality &self)
Definition constraint-inequality.hpp:82
static Eigen::VectorXd upperBound(const ConstraintInequality &self)
Definition constraint-inequality.hpp:91
static Eigen::VectorXd vector(const ConstraintInequality &self)
Definition constraint-inequality.hpp:85
void visit(PyClass &cl) const
Definition constraint-inequality.hpp:34
static Eigen::VectorXd lowerBound(const ConstraintInequality &self)
Definition constraint-inequality.hpp:88
static void expose(const std::string &class_name)
Definition constraint-inequality.hpp:95