Auf jeden Fall ist es ein Fehler in der Rodrigues-Funktion ...
Wenn Sie das entsprechende Dokument lesen , sehen Sie möglicherweise, dass cv2.Rodrigues
es zwei verschiedene Schnittstellen hat:
Eine, die die C ++ - Schnittstelle nachahmt, bei der der Rotationsvektor (und optional der Jacobi) als Referenz übergeben und von der Funktion geändert werden
cv2.Rodrigues(src, dst[, jacobian]) --> None
und eine (mehr Pythonic), bei der der Rotationsvektor und der Jacobi als Tupel zurückgegeben werden
cv2.Rodrigues(src) --> dst, jacobian
Wenn Sie die erste Schnittstelle verwenden, verschwindet die pb ...
import numpy as np
import cv2
def changes():
rmat=np.eye(4)
tvec=np.zeros(3)
#(rvec, jacobian)=cv2.Rodrigues(rmat)
cv2.Rodrigues(rmat, tvec)
print(tvec)
for i in range(2):
changes()
Ergebnis:
[0. 0. 0.]
[0. 0. 0.]
BEARBEITEN nach weiterer Untersuchung:
Die Funktion ist erwartungsgemäß noch fehlerhafter : Bei Verwendung der ersten Schnittstelle werden die Parameter dst
und jacobian
nicht geändert, was in völligem Widerspruch zur Dokumentzeichenfolge steht:
>>> help(cv2.Rodrigues)
Help on built-in function Rodrigues:
Rodrigues(...)
Rodrigues(src[, dst[, jacobian]]) -> dst, jacobian
. @brief Converts a rotation matrix to a rotation vector or vice versa.
.
. @param src Input rotation vector (3x1 or 1x3) or rotation matrix (3x3).
. @param dst Output rotation matrix (3x3) or rotation vector (3x1 or 1x3), respectively.
. @param jacobian Optional output Jacobian matrix, 3x9 or 9x3, which is a matrix of partial
. derivatives of the output array components with respect to the input array components.
Mit anderen Worten, dies erfordert eindeutig einen Fehlerbericht ...