Code to solve determinant using Python without using scipy.linalg.det(在不使用scipy.linalg.det的情况下使用Python求解行列式的代码)
本文介绍了在不使用scipy.linalg.det的情况下使用Python求解行列式的代码的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
描述(这是人力资源部的问题):
我不确定从哪里开始。我计划使用拉普拉斯展开,但我不确定如何对nxn矩阵实现它。任何帮助都将不胜感激。
注意:我已经有一个函数可以为n×n矩阵生成随机矩阵。此外,计算的时间也不是问题。我唯一的问题是如何计算行列式。我不得不删除我的班级策略的问题描述b/c。
推荐答案
下面是用于查找矩阵行列式的Adjucate方法的递归Python代码。
def getMatrixMinor(m,i,j):
return [row[:j] + row[j+1:] for row in (m[:i]+m[i+1:])]
def getMatrixDeternminant(m):
#base case for 2x2 matrix
if len(m) == 2:
return m[0][0]*m[1][1]-m[0][1]*m[1][0]
determinant = 0
for c in range(len(m)):
determinant += ((-1)**c)*m[0][c]*getMatrixDeternminant(getMatrixMinor(m,0,c))
return determinant
请注意,输入是表示nxn矩阵的数组
这篇关于在不使用scipy.linalg.det的情况下使用Python求解行列式的代码的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:在不使用scipy.linalg.det的情况下使用Python求解行列式的代码
猜你喜欢
- YouTube API v3 返回截断的观看记录 2022-01-01
- 检查具有纬度和经度的地理点是否在 shapefile 中 2022-01-01
- 我如何卸载 PyTorch? 2022-01-01
- 使用公司代理使Python3.x Slack(松弛客户端) 2022-01-01
- ";find_element_by_name(';name';)";和&QOOT;FIND_ELEMENT(BY NAME,';NAME';)";之间有什么区别? 2022-01-01
- 使用 Cython 将 Python 链接到共享库 2022-01-01
- 我如何透明地重定向一个Python导入? 2022-01-01
- 如何使用PYSPARK从Spark获得批次行 2022-01-01
- CTR 中的 AES 如何用于 Python 和 PyCrypto? 2022-01-01
- 计算测试数量的Python单元测试 2022-01-01