Supongamos que tiene n matrices cuadradas A1, ..., An. ¿Hay alguna forma de multiplicar estas matrices de una manera ordenada? Por lo que sé, dot in numpy solo acepta dos argumentos. Una forma obvia es definir una función para llamarse a sí misma y obtener el resultado. ¿Hay alguna forma mejor de hacerlo?Multiplica varias matrices en numpy
Respuesta
Esta podría ser una característica relativamente reciente, pero me gusta:
A.dot(B).dot(C)
o si ha tenido una larga cadena que podía hacer:
reduce(numpy.dot, [A1, A2, ..., An])
Actualización:
Hay más información acerca de reducir here. Aquí hay un ejemplo que podría ayudar.
>>> A = [np.random.random((5, 5)) for i in xrange(4)]
>>> product1 = A[0].dot(A[1]).dot(A[2]).dot(A[3])
>>> product2 = reduce(numpy.dot, A)
>>> numpy.all(product1 == product2)
True
Actualización 2016: A partir de Python 3.5, existe un nuevo símbolo matrix_multiply, @
:
R = A @ B @ C
Si calcula todas las matrices a priori, entonces debe usar un esquema de optimización para la multiplicación de la cadena de matrices. Ver this Wikipedia article.
Gracias por su comentario; pero no creo que para matrices cuadradas sea importante. ¿Derecha? – NNsr
@Nikandish: Correcto. Me perdí esa parte en tu respuesta original. –
A_list = [np.random.randn(100, 100) for i in xrange(10)]
B = np.eye(A_list[0].shape[0])
for A in A_list:
B = np.dot(B, A)
C = reduce(np.dot, A_list)
assert(B == C)
Resurrecting una vieja pregunta con una actualización:
A partir de November 13, 2014 ahora existe una función np.linalg.multi_dot
que hace exactamente lo que usted desea. También tiene la ventaja de optimizar el orden de las llamadas, aunque eso no es necesario en su caso.
Tenga en cuenta que esto está disponible comenzando con la versión numpy 1.10.
Otra forma de lograr esto sería usando einsum
, que implementa el Einstein summation convention para NumPy.
Para explicar muy brevemente esta convención con respecto a este problema: Al escribir su producto de matriz múltiple como una gran cantidad de productos, se obtiene algo así como:
P_im = sum_j sum_k sum_l A1_ij A2_jk A3_kl A4_lm
donde P
es el resultado de su producto y A1
, A2
, A3
y A4
son las matrices de entrada. Tenga en cuenta que suma exactamente los índices que aparecen dos veces en el summand, es decir, j
, k
y l
. Como una suma con esta propiedad aparece a menudo en física, cálculo vectorial y probablemente en otros campos, existe una herramienta NumPy para él, es decir, einsum
.
En el ejemplo anterior, se puede usar para calcular su producto matricial de la siguiente manera:
P = np.einsum("ij,jk,kl,lm", A1, A2, A3, A4)
Aquí, el primer argumento indica a la función que los índices de aplicar a las matrices de argumentos y luego todos los índices doblemente aparecen se suman, produciendo el resultado deseado.
Tenga en cuenta que la eficiencia computacional depende de varios factores (por lo que es probablemente el mejor fuera con sólo probarlo):
- 1. Generando Matrices Simétricas en Numpy
- 2. uniendo dos matrices numpy
- 3. Confusión de índice en matrices numpy
- 4. Multiplica TimeSpan en .NET
- 5. numpy: ndenumerate para matrices enmascaradas?
- 6. Distancia entre matrices numpy, columna
- 7. Numpy, problema con matrices largas
- 8. Combinación de matrices de NumPy
- 9. numpy - 2d indexación de matrices
- 10. matrices de rebanado en numpy/SciPy
- 11. ¿Cómo creo matrices de caracteres en numpy?
- 12. NumPy: Comparación de elementos en dos matrices
- 13. Escribir múltiples matrices numpy en el archivo
- 14. matrices por columnas crecientes en NumPy
- 15. ¿Ventana giratoria para matrices 1D en Numpy?
- 16. Indexación con matrices enmascaradas en numpy
- 17. problema de asignación de matrices numpy
- 18. ¿Cómo puedo "ordenar zip" matrices numpy paralelas?
- 19. matrices de estilo NumPy para C++?
- 20. Comparando dos matrices numpy entre sí
- 21. Matrices muy grandes usando Python y NumPy
- 22. ¿Las matrices numpy se pasan por referencia?
- 23. Funciones de mapeo de matrices numpy 2D
- 24. comparando matrices numpy que contienen NaN
- 25. Ignorando -Inf valores en matrices utilizando numpy/scipy en Python
- 26. Timedelta se multiplica con flotador en python
- 27. ¿Cómo hago esta indexación de matrices en numpy
- 28. Concatenar dos matrices numpy en la 4ta dimensión
- 29. encuentra el producto escalar de las sub-matrices en numpy
- 30. "Conversión" de matrices Numpy en Matlab y viceversa
Gracias por la respuesta. La primera opción funciona bien; pero el segundo no; o al menos no pude hacer que funcione. ¿Puedes por favor elaborarlo un poco más o quizás dar un ejemplo? Muchas gracias – NNsr
Me encuentro con esto todo el tiempo y terminé escribiendo una función de ayuda. Desearía que esto fuera parte de NumPy: 'def xdot (* args): return reduce (np.dot, args)' – rd11
Simplemente añadiendo un comentario que esto funciona cuando A, B y C son de tipo numpy.ndarray. Esto puede funcionar para otros tipos, pero no lo he comprobado. – OfLettersAndNumbers