Python 如何解决稀疏矩阵运算

作者:Thole Lee 时间:2022-02-13 21:59:01 

用Python求解微分线性方程

因为之前用matlab也编写过,所以前不久试着用python写,感觉之间互通点也蛮多的,易理解。

题目:稀疏线性方程组的求解方法

简单的方程如: AX=b

其中

Python 如何解决稀疏矩阵运算

python有很多功能库,这些库对于编程很有帮助,可以在pycharm的Project Interpreter导入库,例如numpy、os、scipy等比较基础的库,

下面是用来求解的代码:


import numpy as np
from scipy import linalg
import os
#输入矩阵维数
print("你好,这里是计算稀疏矩阵线性方程组的地方,非诚勿扰!")
dism_num = input("你的A矩阵维数是:")
dism_num = int(dism_num)
print("接下来请你依次输入矩阵的行向量(注意只能输入英文逗号,):")
A =[]
#X =[]
for i in range(1,dism_num+1):
   a=input("第"+str(i)+"行向量是:")
   alist = a.split(",")
   alist = [int(alist[j]) for j in range(len(alist))]
   A.append(alist)
print("你所输入的矩阵行向量是:")
print(A)
#记录输入的X矩阵

#输入向量b
print("输入b向量")
b = input("b向量是:")
b_list = b.split(",")
b_list = [int(b_list[j]) for j in range(len(b_list))]
print("你输入的b向量是:")
print(b_list)
#记录b向量

#询问是否计算单个答案(单元素)
ask = input("是否只需求解单个值:(是或否)")
while(True):
   if ask == '是':
       ask_a = 'T'
       ask_num = input("请继续输入你所需要的答案序号:")
       ask_num = int(ask_num)
       if ask_num<=dism_num and ask_num>0:
           print("OK,马上帮你计算")
           break
       else:
           print("输入的值超出矩阵维数,请重新输入:")
   if ask == '否':
       ask_a = 'F'
       break
#询问完成,只有当用户输入正确的序号才可以进行计算,否则重新询问

#开始计算x向量了
A = np.array(A)
b = np.array(b_list)
x = linalg.solve(A,b)
print("计算的结果的:")
if ask_a == 'F':
   print(x)
if ask_a =='T':
   print(x[ask_num-1])
#计算完x向量了

os.system("pause")
#用于py文件结束玩暂停显示结果

其基本流程如图:

Python 如何解决稀疏矩阵运算

运行结果如下:

Python 如何解决稀疏矩阵运算

补充:python 多线程稀疏矩阵乘法

Python 如何解决稀疏矩阵运算

看代码吧~


import threading, time
import numpy as np
res = []
class MyThread(threading.Thread):
   def __init__(self,i,j,m1,m2):
       threading.Thread.__init__(self)
       self.x, self.y = i,j
       self.m1, self.m2 = m1, m2
   def run(self):
       global res, lock
       if lock.acquire():
           m1 = self.m1[self.m1[:,0]==self.x]
           m2 = self.m2[self.m2[:,1]==self.y]
           value = 0.
           for item1 in m1:
               for item2 in m2:
                   if item1[1] == item2[0]:
                       value += item1[2]*item2[2]
           res.append([self.x,self.y,value])
           lock.release()
if "__main__" == __name__:
   m1 = [[2,2],[0,0,1],[0,1,2],[1,0,3],[1,1,4]]
   m2 = [[2,3],[0,0,2],[0,2,1],[1,2,3],[1,1,4]]
   s1, s2 = m1[0], m2[0]
   assert s1[1]==s2[0], 'mismatch'
   m1_value = np.array(m1[1:])
   m2_value = np.array(m2[1:])
   rows, cols = s1[0], s2[1]
   res.append([rows, cols])
   ThreadList = []
   lock = threading.Lock()
   for i in range(rows):
       for j in range(cols):
           t = MyThread(i,j,m1_value,m2_value)
           ThreadList.append(t)
   for t in ThreadList:
       t.start()
   for t in ThreadList:
       t.join()
   print (res)

来源:https://blog.csdn.net/weixin_42312037/article/details/111828624

标签:Python,稀疏矩阵,运算
0
投稿

猜你喜欢

  • python开启debug模式的方法

    2023-05-10 02:58:31
  • Python定义一个跨越多行的字符串的多种方法小结

    2022-08-04 03:34:27
  • Ubuntu中更改MySQL数据库文件目录的方法

    2024-01-15 06:39:18
  • python3实现表白神器

    2023-07-27 03:54:01
  • 10分钟学会Google Map API (一)

    2009-06-07 18:17:00
  • Oracle如何获取数据库系统的当前时间

    2024-01-21 22:20:55
  • Javascript中判断变量是数组还是对象(array还是object)

    2024-04-17 09:51:28
  • php设置编码格式的方法

    2023-11-14 12:01:22
  • python解决字符串倒序输出的问题

    2022-06-08 14:12:34
  • vue 请求后台数据的实例代码

    2024-05-05 09:23:47
  • 使用模板实现ASP代码与页面分离

    2008-09-12 16:07:00
  • 如何调用Oracle存储过程?

    2009-11-15 20:13:00
  • Oracle 中文字段进行排序的sql语句

    2024-01-22 13:26:43
  • php防止sql注入之过滤分页参数实例

    2023-07-21 10:02:40
  • itchat-python搭建微信机器人(附示例)

    2022-05-04 00:00:54
  • Vuex中actions的使用教程详解

    2024-04-30 08:45:29
  • 如何做一个文本书写器?

    2010-07-12 18:58:00
  • python打印9宫格、25宫格等奇数格 满足横竖斜相加和相等

    2023-08-27 07:55:11
  • Python爬取qq空间说说的实例代码

    2021-04-28 01:29:50
  • MySQL中where 1=1方法的使用及改进

    2024-01-17 22:00:59
  • asp之家 网络编程 m.aspxhome.com