From fd1f2a4eb5792821abdf0d1af5d0c4ae0dd4936a Mon Sep 17 00:00:00 2001 From: Joris Vaillant Date: Tue, 31 Oct 2023 15:23:12 +0100 Subject: [PATCH 1/2] python: Throw an exception in XYZQUATToSE3 if called with wrong size argument --- bindings/python/utils/conversions.cpp | 30 +++++++++++++++++++-------- unittest/python/utils.py | 5 +++++ 2 files changed, 26 insertions(+), 9 deletions(-) diff --git a/bindings/python/utils/conversions.cpp b/bindings/python/utils/conversions.cpp index 8b07ba2bc9..dd03ac62f2 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 at least 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)) From 1201d374c6d06b978a2bf0c886d1dfce1bdf48e1 Mon Sep 17 00:00:00 2001 From: Joris Vaillant Date: Tue, 31 Oct 2023 15:55:37 +0100 Subject: [PATCH 2/2] python: apply review --- bindings/python/utils/conversions.cpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/bindings/python/utils/conversions.cpp b/bindings/python/utils/conversions.cpp index dd03ac62f2..87800d2b85 100644 --- a/bindings/python/utils/conversions.cpp +++ b/bindings/python/utils/conversions.cpp @@ -38,10 +38,10 @@ namespace pinocchio SE3 XYZQUATToSE3_bp(const TupleOrList& v) { ssize_t size = bp::len(v); - if(size < 7) + if(size != 7) { throw std::invalid_argument( - "Wrong size: v(" + std::to_string(size) + ") should at least have 7 elements"); + "Wrong size: v(" + std::to_string(size) + ") should have 7 elements"); } SE3::Quaternion q ( static_cast(bp::extract(v[6])),