Transformation
- class compas.geometry.Transformation(matrix=None)[source]
Bases:
Data
Class representing a general 4x4 transformation matrix.
It is the base class for transformations like
Rotation
,Translation
,Scale
,Reflection
,Projection
andShear
.The class allows to concatenate Transformations by multiplication, to calculate the inverse transformation and to decompose a transformation into its components of rotation, translation, scale, shear, and perspective. The matrix follows the row-major order, such that translation components x, y, z are in the right column of the matrix, i.e.
M[0][3], M[1][3], M[2][3] = x, y, z
.- Parameters
matrix (list[list[float]], optional) – The 4x4 transformation matrix.
- Attributes
scale (
Scale
, read-only) – The scale component of the transformation matrix.shear (
Shear
, read-only) – The shear component of the transformation matrix.rotation (
Rotation
, read-only) – The rotation component of the transformation matrix.translation (
Translation
, read-only) – The translation component of the transformation matrix.projection (
Projection
, read-only) – The projection component of the transformation matrix.translation_vector (
Vector
, read-only) – The translation component of the transformation matrix as a translation vector.basis_vectors (tuple[
Vector
,Vector
], read-only) – The basis vectors from the rotation component of the transformation matrix.list (list[float], read-only) – Flattens the 4x4 transformation matrix into a list of 16 numbers.
determinant (float, read-only) – The determinant of the matrix of the transformation.
Examples
>>> from compas.geometry import Frame >>> f1 = Frame([1, 1, 1], [0.68, 0.68, 0.27], [-0.67, 0.73, -0.15]) >>> T = Transformation.from_frame(f1) >>> Sc, Sh, R, Tl, P = T.decomposed() >>> Tinv = T.inverse()
Methods
Concatenate another transformation to this transformation.
Concatenate two transformations into one Transformation.
Returns a copy of the transformation.
Decompose the Transformation into its components.
Construct a change of basis transformation between two frames.
Construct a transformation from a rotation represented by Euler angles.
Construct a transformation from world XY to frame.
Construct a transformation between two frames.
Creates a transformation from a list of 16 numbers.
Creates a transformation from a list[list[float]] object.
Returns the inverse transformation.
Invert this transformation.
Returns the inverse transformation.
Transpose the matrix of this transformation.
Create a transposed copy of this transformation.
Inherited Methods
Construct an object of this type from the provided data.
Construct an object from serialized data contained in a JSON file.
Construct an object from serialized data contained in a JSON string.
Convert an object to its native data representation.
Serialize the data representation of an object to a JSON file.
Serialize the data representation of an object to a JSON string.
Validate the object's data against its data schema.
Validate the object's data against its json schema.