Skip to content
Snippets Groups Projects
Commit 5003e83e authored by Paul McCarthy's avatar Paul McCarthy :mountain_bicyclist:
Browse files

New convenience function transform.rotMatToAffine. Fixed scaleOffsetXform so

it accepts numpy arrays
parent 97136a3f
No related branches found
No related tags found
No related merge requests found
...@@ -16,6 +16,7 @@ spaces. The following functions are provided: ...@@ -16,6 +16,7 @@ spaces. The following functions are provided:
concat concat
compose compose
decompose decompose
rotMatToAffine
rotMatToAxisAngles rotMatToAxisAngles
axisAnglesToRotMat axisAnglesToRotMat
axisBounds axisBounds
...@@ -60,10 +61,12 @@ def scaleOffsetXform(scales, offsets): ...@@ -60,10 +61,12 @@ def scaleOffsetXform(scales, offsets):
:returns: A ``numpy.float32`` array of size :math:`4 \\times 4`. :returns: A ``numpy.float32`` array of size :math:`4 \\times 4`.
""" """
if not isinstance(scales, collections.Sequence): scales = [scales] oktypes = (collections.Sequence, np.ndarray)
if not isinstance(offsets, collections.Sequence): offsets = [offsets]
if not isinstance(scales, list): scales = list(scales) if not isinstance(scales, oktypes): scales = [scales]
if not isinstance(offsets, list): offsets = list(offsets) if not isinstance(offsets, oktypes): offsets = [offsets]
if not isinstance(scales, list): scales = list(scales)
if not isinstance(offsets, list): offsets = list(offsets)
lens = len(scales) lens = len(scales)
leno = len(offsets) leno = len(offsets)
...@@ -131,7 +134,7 @@ def compose(scales, offsets, rotations, origin=None): ...@@ -131,7 +134,7 @@ def compose(scales, offsets, rotations, origin=None):
return concat(offset, postRotate, rotate, preRotate, scale) return concat(offset, postRotate, rotate, preRotate, scale)
def decompose(xform): def decompose(xform, angles=True):
"""Decomposes the given transformation matrix into separate offsets, """Decomposes the given transformation matrix into separate offsets,
scales, and rotations, according to the algorithm described in: scales, and rotations, according to the algorithm described in:
...@@ -142,12 +145,17 @@ def decompose(xform): ...@@ -142,12 +145,17 @@ def decompose(xform):
It is assumed that the given transform has no perspective components. Any It is assumed that the given transform has no perspective components. Any
shears in the affine are discarded. shears in the affine are discarded.
:arg xform: A ``(4, 4)`` affine transformation matrix. :arg xform: A ``(4, 4)`` affine transformation matrix.
:arg angles: If ``True`` (the default), the rotations are returned
as axis-angles, in radians. Otherwise, the rotation matrix
is returned.
:returns: The following: :returns: The following:
- A sequence of three scales - A sequence of three scales
- A sequence of three translations - A sequence of three translations
- A sequence of three rotations, in radians - A sequence of three rotations, in radians. Or, if
``angles is False``, a rotation matrix.
""" """
# The inline comments in the code below are taken verbatim from # The inline comments in the code below are taken verbatim from
...@@ -216,9 +224,17 @@ def decompose(xform): ...@@ -216,9 +224,17 @@ def decompose(xform):
# Finally, we need to decompose the rotation matrix into a sequence # Finally, we need to decompose the rotation matrix into a sequence
# of rotations about the x, y, and z axes. [This is done in the # of rotations about the x, y, and z axes. [This is done in the
# rotMatToAxisAngles function] # rotMatToAxisAngles function]
rx, ry, rz = rotMatToAxisAngles(R.T) if angles: rotations = rotMatToAxisAngles(R.T)
else: rotations = R.T
return [sx, sy, sz], translations, rotations
return [sx, sy, sz], translations, [rx, ry, rz]
def rotMatToAffine(rotmat, origin=None):
"""Convenience function which encodes the given ``(3, 3)`` rotation
matrix into a ``(4, 4)`` affine.
"""
return compose([1, 1, 1], [0, 0, 0], rotmat, origin)
def rotMatToAxisAngles(rotmat): def rotMatToAxisAngles(rotmat):
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment