Matriz de transformación
En álgebra lineal, una aplicación lineal se puede representar mediante una matriz. Si es una transformación lineal que representa una aplicación de sobre y es un vector columna con componentes, entonces
para una matriz de dimensión , denominada matriz de transformación de . Debe tenerse en cuenta que tiene filas y columnas, mientras que la transformación es de a . Algunos autores emplean expresiones alternativas de matrices de transformación que utilizan vectores fila en lugar de vectores columna, pero se trata de una circunstancia meramente formal.
Utilización
Las matrices permiten mostrar aplicaciones lineales arbitrarias en un formato coherente, muy adecuado para el cálculo.[1] Además, presenta la ventaja de permitir concatenar fácilmente transformaciones sucesivas (multiplicando sus matrices).
Las transformaciones lineales no son las únicas que se pueden representar mediante matrices. Algunas transformaciones que no son lineales en un espacio euclídeo Rn de n dimensiones se pueden representar como transformaciones lineales en el espacio n+1 dimensional Rn+1, donde se incluyen tanto transformaciones afines (como por ejemplo las traslaciones) como homografías. Por esta razón, las matrices de transformación de 4×4 se utilizan ampliamente en gráficos 3D por computadora. Estas matrices de transformación n+1 dimensionales se denominan, según su aplicación, matrices de transformación afín, matrices de transformación proyectiva o, más generalmente, matrices de transformación no lineal. Con respecto a una matriz n dimensional, una matriz n+1 dimensional se puede describir como una matriz aumentada.
En las ciencias físicas, una transformación activa es aquella que realmente cambia la posición física de un sistema, y tiene sentido incluso en ausencia de un sistema de coordenadas, mientras que una transformación pasiva es un cambio en la descripción de coordenadas del sistema físico (cambio de bases). La distinción entre transformaciones activas y pasivas es importante. Por defecto, cuando en matemáticas se habla de transformación, normalmente se hace referencia a transformaciones activas, mientras que en física puede designar cualquiera de los dos tipos.
Dicho de otra manera, una transformación pasiva se refiere a la descripción del mismo objeto visto desde dos marcos de coordenadas diferentes.
Determinación de la matriz de una transformación
Si se dispone de una transformación lineal en su forma funcional, es fácil determinar la matriz de transformación A transformando cada uno de los vectores de su base canónica por T, y luego insertando el resultado en las columnas de una matriz. En otras palabras,
Por ejemplo, la función es una transformación lineal. La aplicación del proceso anterior (suponiendo que n=2 en este caso) revela que
La representación matricial de vectores y operadores depende de la base elegida; el resultado de tomar la base alternada (ordenada de otra manera) es una matriz semejante. Sin embargo, el método para encontrar los componentes sigue siendo el mismo.
Para operar, el vector v se representa como una combinación lineal respecto a los vectores de la base, con coordenadas :
Ahora, expresando el resultado de la matriz de transformación A sobre , en la base dada:
Los elementos de la matriz A se determinan para una base E dada aplicando A a cada , siendo el vector obtenido
Esta ecuación define los elementos buscados de la j-ésima columna de la matriz A.[2]
Base de vectores propios y matriz diagonal
Sin embargo, existe una base especial para una transformación, en la que sus componentes forman una matriz diagonal y, por lo tanto, la complejidad de la multiplicación se reduce a n. Ser diagonal significa que todos sus coeficientes (excepto los ) son ceros, dejando solo un término no nulo en la suma anterior . Los elementos diagonales no nulos, , se conocen como valores propios y se designan con en la ecuación de definición, que se reduce a . La ecuación resultante se conoce como ecuación de valores propios.[3] Los valores y vectores propios se calculan mediante el polinomio característico de la matriz.
Mediante la diagonalización de una matriz es posible obtener un cambio de bases hacia y desde bases de vectores propios.
Ejemplos en 2 dimensiones
Las transformaciones geométricas más comunes que mantienen el origen fijo son lineales, incluidas la rotación, el escalado, el cizallamiento, la reflexión y la proyección ortogonal. Si una transformación afín no es una traslación pura, mantiene algún punto fijo, y ese punto puede elegirse como origen para hacer que la transformación sea lineal. En dos dimensiones, las transformaciones lineales se pueden representar utilizando una matriz de transformación de 2×2.
Estiramiento
Un estiramiento en el plano xy es una transformación lineal que agranda todas las distancias en una dirección particular por un factor constante pero no afecta las distancias en la dirección perpendicular. Solo se van a considerar alargamientos respecto al eje x y al eje y. Un alargamiento en el eje x tiene la forma x' = kx; y' = y para alguna constante positiva k. Se debe tener en cuenta que si k es >1, entonces se produce realmente un estiramiento; y si k es <1, técnicamente es una compresión, aunque de forma genérica también se denomina estiramiento. Además, si k = 1 , entonces la transformación es una identidad, es decir, no tiene ningún efecto.
La matriz asociada con un estiramiento por un factor k en el eje x viene dada por:
De manera similar, un estiramiento por un factor k en el eje y tiene la forma x' = x; y' = ky, por lo que la matriz asociada con esta transformación es
Contracción
Si dos de los estiramientos anteriores se combinan con valores recíprocos, entonces la matriz de transformación representa una contracción:
Un cuadrado con lados paralelos a los ejes se transforma en un rectángulo que tiene la misma área que el cuadrado. El estiramiento y la compresión recíprocos no alteran el valor del área de la figura sobre la que se aplican.
Rotación
Para generar una rotación con un ángulo θ en el sentido de las agujas del reloj respecto al origen de coordenadas, la forma funcional es y . Escrito en forma de matriz, esto se convierte en:[4]
De manera similar, para una rotación en sentido antihorario respecto al origen, la forma funcional es y , y su forma matricial es:
Estas fórmulas asumen que el eje x apunta a la derecha y el eje y apunta hacia arriba.
Cizallamiento
Para generar un cizallamiento (visualmente similar a una inclinación), hay dos posibilidades.
Un cizallamiento paralelo al eje x tiene la expresión y . Escrito en forma de matriz, esto se convierte en:
Un cizallamiento paralelo al eje y tiene la expresión y , que tiene forma de matriz:
Reflexión
Para obtener la reflexión respecto a una recta que pasa por el origen, siendo un vector en la dirección de la recta. Entonces, basta con usar la matriz de transformación:
Proyección ortogonal
Para proyectar un vector ortogonalmente respecto a una recta que pasa por el origen, se toma primero , un vector en la dirección de la recta, y se usa la matriz de transformación siguiente:
Al igual que con las reflexiones, la proyección ortogonal sobre una recta que no pasa por el origen es una transformación afín, no lineal.
Las proyecciones paralelas también son transformaciones lineales y se pueden representar simplemente mediante una matriz. Sin embargo, las proyecciones en perspectiva no lo son, y para representarlas con una matriz, se deben utilizar coordenadas homogéneas.
Ejemplos en gráficos 3D por computadora
Rotación
La matriz para rotar un ángulo θ alrededor de cualquier eje definido por un vector unitario de componentes (l, m, n) es[5]
Reflexión
Para reflejar un punto a través de un plano (que pasa por el origen), se puede usar la expresión , donde es la matriz identidad 3x3 y es el vector unitario tridimensional para el vector normal del plano. Si el módulo de y es la unidad, la matriz de transformación se puede expresar como:
Se debe tener en cuenta que estos son casos particulares de una transformación de Householder en dos y tres dimensiones. Una reflexión sobre una línea o plano que no pasa por el origen no es una transformación lineal, es un transformación afín. Una matriz de transformación afín de 4x4, se puede expresar de la siguiente manera (asumiendo que la normal es un vector unitario):
donde para algún punto del plano.
Si la cuarta componente del vector es 0 en lugar de 1, entonces solo se refleja la dirección del vector y su longitud permanece sin cambios, como si se reflejara a través de un plano paralelo que pasa por el origen. Esta es una propiedad muy útil, ya que permite la transformación de vectores posicionales y vectores normales con la misma matriz. Consúltese coordenadas homogéneas y transformaciones afines a continuación para obtener más información sobre el tema.
Componer e invertir transformaciones
Una de las principales motivaciones para usar matrices para representar transformaciones lineales es que las transformaciones pueden componerse e invertirse fácilmente.
La composición se logra mediante la multiplicación de matrices. Los vectores (fila o columna) son operados por matrices, filas a la derecha y columnas a la izquierda. Dado que el texto se lee de izquierda a derecha, se prefieren los vectores fila cuando se componen las matrices de transformación:
Si A y B son las matrices de dos transformaciones lineales, entonces el efecto de aplicar primero A y luego B a un vector fila x viene dado por:
En otras palabras, la matriz de la transformación combinada A seguida de B es simplemente el producto de las dos matrices.
Cuando A es una matriz invertible, entonces existe una matriz A−1 que representa una transformación que deshace A, ya que su composición con A es la matriz identidad. En algunas aplicaciones prácticas, la inversión se puede calcular utilizando algoritmos de inversión generales o realizando operaciones inversas (que tienen una interpretación geométrica obvia, como rotar en dirección opuesta) y luego componerlas en orden inverso.
Otros tipos de transformaciones
Transformaciones afines
Para representar una transformación afín con matrices, se pueden usar coordenadas homogéneas. Esto significa representar un 2-vector (x, y) como un 3-vector (x, y, 1), y de manera similar para dimensiones más altas. Con este sistema, la traslación se puede expresar mediante una multiplicación de matrices. La forma funcional se convierte en:
Todas las transformaciones lineales ordinarias se incluyen en el conjunto de transformaciones afines y se pueden describir como una forma simplificada de transformaciones afines. Por lo tanto, cualquier transformación lineal también se puede representar mediante una matriz de transformación general. Esta última se obtiene expandiendo la matriz de transformación lineal correspondiente en una fila y en una columna, llenando el espacio extra con ceros excepto la esquina inferior derecha, cuyo valor debe ser 1. Por ejemplo, la matriz de rotación en sentido antihorario (vista la figura desde arriba) se convierte en:
Al utilizar matrices de transformación que contienen coordenadas homogéneas, las traslaciones se convierten en linealmente independientes y, por lo tanto, pueden ser similarmente combinadas con todos los demás tipos de transformaciones. La razón es que el plano real se puede hacer corresponder con el plano w=1 en el espacio proyectivo real, por lo que una traslación en el espacio euclídeo real se puede representar como un cizallamiento en el espacio proyectivo real. Aunque una traslación no es una transformación lineal en un espacio euclídeo 2-D o 3-D descrito por coordenadas cartesianas (es decir, no se puede combinar con otras transformaciones conservando la conmutatividad y otras propiedades), cuando se utiliza un espacio proyectivo descrito por coordenadas homogéneas con una componente adicional, puede asimilarse a una transformación lineal simple (un cizallamiento).
Pueden obtenerse más transformaciones afines mediante composición de dos o más transformaciones afines. Por ejemplo, dada una traslación T' con el vector una rotación R en un ángulo θ en sentido antihorario, un escalado S con factores y una traslación T según el vector el resultado M de T'RST es:[6]
Cuando se utilizan transformaciones afines, la componente homogénea de un vector de coordenadas (normalmente denominada w) nunca se modifica. Por lo tanto, se puede asumir con seguridad que siempre es 1 e ignorarlo. Sin embargo, esto no es cierto cuando se utilizan proyecciones en perspectiva.
Proyección en perspectiva
Otro tipo de transformación, de importancia en gráficos 3D por computadora, es la perspectiva. Mientras que las proyecciones paralelas se utilizan para proyectar puntos en el plano de la imagen mediante líneas paralelas, la proyección en perspectiva proyecta puntos en el plano de la imagen en líneas que irradian desde un punto determinado, llamado centro de proyección. Esto significa que un objeto tiene una proyección más pequeña cuando está lejos del centro de proyección y una proyección más grande cuando está más cerca (véase también función recíproca).
La proyección en perspectiva más simple utiliza el origen como centro de proyección y el plano en como plano de la imagen. La forma funcional de esta transformación es ; . Se puede expresar en coordenadas homogéneas como:
Tras realizar la multiplicación de matrices, la componente homogénea será igual al valor de y las otras tres no cambiarán. Por lo tanto, para volver al plano real se debe realizar la división homogénea o la división en perspectiva, dividiendo cada componente por :
Se pueden componer proyecciones en perspectiva más complicadas combinando este tipo de matrices con rotaciones, escalas, traslaciones y cizallamientos, con el fin de mover el plano de la imagen y el centro de proyección donde se desee.
Véase también
- Proyección tridimensional
- Cambio de bases
- Rectificación de imagen
- Transformación rígida
- Transformación (función)
- Geometría de las transformaciones
Referencias
- Gentle, James E. (2007). «Matrix Transformations and Factorizations». Matrix Algebra: Theory, Computations, and Applications in Statistics. Springer. ISBN 9780387708737.
- Nearing, James (2010). «Chapter 7.3 Examples of Operators». Mathematical Tools for Physics. ISBN 978-0486482125. Consultado el 1 de enero de 2012.
- Nearing, James (2010). «Chapter 7.9: Eigenvalues and Eigenvectors». Mathematical Tools for Physics. ISBN 978-0486482125. Consultado el 1 de enero de 2012.
- http://ocw.mit.edu/courses/aeronautics-and-astronautics/16-07-dynamics-fall-2009/lecture-notes/MIT16_07F09_Lec03.pdf
- Szymanski, John E. (1989). Basic Mathematics for Electronic Engineers:Models and Applications. Taylor & Francis. p. 154. ISBN 0278000681.
- Cédric Jules (25 de febrero de 2015). «2D transformation matrices baking».
Enlaces externos
- La página de Matrix Ejemplos prácticos en POV-Ray
- Página de referencia - Rotación de ejes
- Calculadora de transformación lineal
- Transformation Applet - Genera matrices a partir de transformaciones 2D y viceversa.
- Transformación de coordenadas en rotación en 2D
- graphics-spreadsheet / Excel Fun: crea gráficos en 3D a partir de una hoja de cálculo