首页 > 解决方案 > Python - 使用 sympy 和 lambdify 时,矩阵的点积似乎不起作用

问题描述

我正在python中实现数据处理流程。我正在尝试尽可能多地使用符号计算 (sympynumpy) 以获得与代码一致的清晰文档。因此,当我尝试获取点积并将其用于真实矩阵时(通过lambdify),我得到了其他东西:

import numpy as np
from sympy import *
init_printing()

A = Matrix([[1, 2], [1, 100]])
B = Matrix([[3, 4], [10, 1000]])
AA = MatrixSymbol('A',2,2)
BB = MatrixSymbol('B',2,2)
mulab = lambdify([AA,BB],AA*BB)
print(mulab(A,B))
print(A*B)

[7, 1010, 406, 100020]
Matrix([[23, 2004], [1003, 100004]])

链接到代码的实时版本

有没有人遇到过类似的问题?是否有已知的解决方法?

先感谢您。

标签: pythonnumpysympylambdify

解决方案


lambdify创建一个应该在 NumPy 数组上使用的函数。如果将 SymPy 对象传递给此函数,则结果行为是未定义的。如果要在 SymPy 表达式上评估 SymPy 表达式,只需使用 SymPy 表达式,使用subs来替换表达式。

>>> (AA*BB).subs({AA: A, BB: B}).doit()
⎡ 23    2004 ⎤
⎢            ⎥
⎣1003  100004⎦

如果你有 NumPy 数组,那就是你想使用lambdify的时候:

>>> mulab(np.array([[1,2],[1,100]]), np.array([[3,4],[10,1000]]))
 [[    23   2004]
 [  1003 100004]]

推荐阅读