diff --git a/bindings/python/utils/conversions.cpp b/bindings/python/utils/conversions.cpp index 8b07ba2bc9..87800d2b85 100644 --- a/bindings/python/utils/conversions.cpp +++ b/bindings/python/utils/conversions.cpp @@ -2,6 +2,8 @@ // Copyright (c) 2019-2020 CNRS INRIA // +#include + #include "pinocchio/bindings/python/fwd.hpp" #include "pinocchio/bindings/python/spatial/se3.hpp" @@ -35,23 +37,33 @@ namespace pinocchio template SE3 XYZQUATToSE3_bp(const TupleOrList& v) { - //bp::extract to_double; + ssize_t size = bp::len(v); + if(size != 7) + { + throw std::invalid_argument( + "Wrong size: v(" + std::to_string(size) + ") should have 7 elements"); + } SE3::Quaternion q ( - (Scalar)bp::extract(v[6]), - (Scalar)bp::extract(v[3]), - (Scalar)bp::extract(v[4]), - (Scalar)bp::extract(v[5])); + static_cast(bp::extract(v[6])), + static_cast(bp::extract(v[3])), + static_cast(bp::extract(v[4])), + static_cast(bp::extract(v[5]))); SE3::Vector3 t ( - (Scalar)bp::extract(v[0]), - (Scalar)bp::extract(v[1]), - (Scalar)bp::extract(v[2])); + static_cast(bp::extract(v[0])), + static_cast(bp::extract(v[1])), + static_cast(bp::extract(v[2]))); return SE3 (q.matrix(), t); } template SE3 XYZQUATToSE3_ei(const Vector7Like& v) { - PINOCCHIO_ASSERT_MATRIX_SPECIFIC_SIZE(Vector7Like, v, 7, 1); + if(v.rows() != 7 || v.cols() != 1) + { + std::ostringstream shape; + shape << "(" << v.rows() << ", " << v.cols() << ")"; + throw std::invalid_argument("Wrong size: v" + shape.str() + " but should have the following shape (7, 1)"); + } QuatConstMap q (v.template tail<4>().data()); return SE3 (q.matrix(), v.template head<3>()); } diff --git a/unittest/python/utils.py b/unittest/python/utils.py index fe75f3527f..f40caf2920 100644 --- a/unittest/python/utils.py +++ b/unittest/python/utils.py @@ -14,6 +14,11 @@ def test_se3ToXYZQUAT_XYZQUATToSe3(self): m.rotation = np.array([[1., 0., 0.],[0., 0., -1.],[0., 1., 0.]]) # rotate('x', pi / 2) self.assertApprox(pin.SE3ToXYZQUAT(m).T, [1., 2., 3., sqrt(2) / 2, 0, 0, sqrt(2) / 2]) self.assertApprox(pin.XYZQUATToSE3([1., 2., 3., sqrt(2) / 2, 0, 0, sqrt(2) / 2]), m) + self.assertApprox(pin.XYZQUATToSE3(np.array([1., 2., 3., sqrt(2) / 2, 0, 0, sqrt(2) / 2])), m) + with self.assertRaisesRegex(ValueError, "Wrong size: .*"): + pin.XYZQUATToSE3([1., 2., 3.]) + with self.assertRaisesRegex(ValueError, "Wrong size: .*"): + pin.XYZQUATToSE3(np.array([1., 2., 3., sqrt(2) / 2])) def test_isapprox(self): self.assertFalse(isapprox(1, 2))