Python实现矩阵相乘的三种方法小结


Posted in Python onJuly 26, 2018

问题描述

分别实现矩阵相乘的3种算法,比较三种算法在矩阵大小分别为22∗2222∗22, 23∗2323∗23, 24∗2424∗24, 25∗2525∗25, 26∗2626∗26, 27∗2727∗27, 28∗2828∗28, 29∗2929∗29时的运行时间与MATLAB自带的矩阵相乘的运行时间,绘制时间对比图。

解题方法

本文采用了以下方法进行求值:矩阵计算法、定义法、分治法和Strassen方法。这里我们使用Matlab以及Python对这个问题进行处理,比较两种语言在一样的条件下,运算速度的差别。

编程语言

Python

具体代码

#-*- coding: utf-8 -*-
from matplotlib.font_manager import FontProperties
import numpy as np
import time
import random
import math
import copy
import matplotlib.pyplot as plt

#n = [2**2, 2**3, 2**4, 2**5, 2**6, 2**7, 2**8, 2**9, 2**10, 2**11, 2**12]
n = [2**2, 2**3, 2**4, 2**5, 2**6, 2**7, 2**8, 2**9, 2**10, 2**11]
Sum_time1 = []
Sum_time2 = []
Sum_time3 = []
Sum_time4 = []
for m in n:
 A = np.random.randint(0, 2, [m, m])
 B = np.random.randint(0, 2, [m, m])
 A1 = np.mat(A)
 B1 = np.mat(B)
 time_start = time.time()
 C1 = A1*B1
 time_end = time.time()
 Sum_time1.append(time_end - time_start)

 C2 = np.zeros([m, m], dtype = np.int)
 time_start = time.time()
 for i in range(m):
  for k in range(m):
   for j in range(m):
    C2[i, j] = C2[i, j] + A[i, k] * B[k, j]
 time_end = time.time()
 Sum_time2.append(time_end - time_start)
 A11 = np.mat(A[0:m//2, 0:m//2])
 A12 = np.mat(A[0:m//2, m//2:m])
 A21 = np.mat(A[m//2:m, 0:m//2])
 A22 = np.mat(A[m//2:m, m//2:m])
 B11 = np.mat(B[0:m//2, 0:m//2])
 B12 = np.mat(B[0:m//2, m//2:m])
 B21 = np.mat(B[m//2:m, 0:m//2])
 B22 = np.mat(B[m//2:m, m//2:m])
 time_start = time.time()
 C11 = A11 * B11 + A12 * B21
 C12 = A11 * B12 + A12 * B22
 C21 = A21 * B11 + A22 * B21
 C22 = A21 * B12 + A22 * B22
 C3 = np.vstack((np.hstack((C11, C12)), np.hstack((C21, C22))))
 time_end = time.time()
 Sum_time3.append(time_end - time_start)
 time_start = time.time()
 M1 = A11 * (B12 - B22)
 M2 = (A11 + A12) * B22
 M3 = (A21 + A22) * B11
 M4 = A22 * (B21 - B11)
 M5 = (A11 + A22) * (B11 + B22)
 M6 = (A12 - A22) * (B21 + B22)
 M7 = (A11 - A21) * (B11 + B12)
 C11 = M5 + M4 - M2 + M6
 C12 = M1 + M2
 C21 = M3 + M4
 C22 = M5 + M1 - M3 - M7
 C4 = np.vstack((np.hstack((C11, C12)), np.hstack((C21, C22))))
 time_end = time.time()
 Sum_time4.append(time_end - time_start)

f1 = open('python_time1.txt', 'w')
for ele in Sum_time1:
 f1.writelines(str(ele) + '\n')
f1.close()

f2 = open('python_time2.txt', 'w')
for ele in Sum_time2:
 f2.writelines(str(ele) + '\n')
f2.close()

f3 = open('python_time3.txt', 'w')
for ele in Sum_time3:
 f3.writelines(str(ele) + '\n')
f3.close()

f4 = open('python_time4.txt', 'w')
for ele in Sum_time4:
 f4.writelines(str(ele) + '\n')
f4.close()

font = FontProperties(fname=r"c:\windows\fonts\simsun.ttc", size=8)
plt.figure(1)
plt.subplot(221)
plt.semilogx(n, Sum_time1, 'r-*')
plt.ylabel(u"时间(s)", fontproperties=font)
plt.xlabel(u"矩阵的维度n", fontproperties=font)
plt.title(u'python自带的方法', fontproperties=font)
plt.subplot(222)
plt.semilogx(n, Sum_time2, 'b-*')
plt.ylabel(u"时间(s)", fontproperties=font)
plt.xlabel(u"矩阵的维度n", fontproperties=font)
plt.title(u'定义法', fontproperties=font)
plt.subplot(223)
plt.semilogx(n, Sum_time3, 'y-*')
plt.ylabel(u"时间(s)", fontproperties=font)
plt.xlabel(u"矩阵的维度n", fontproperties=font)
plt.title( u'分治法', fontproperties=font)
plt.subplot(224)
plt.semilogx(n, Sum_time4, 'g-*')
plt.ylabel(u"时间(s)", fontproperties=font)
plt.xlabel(u"矩阵的维度n", fontproperties=font)
plt.title( u'Strasses法', fontproperties=font)
plt.figure(2)
plt.semilogx(n, Sum_time1, 'r-*', n, Sum_time2, 'b-+', n, Sum_time3, 'y-o', n, Sum_time4, 'g-^')
#plt.legend(u'python自带的方法', u'定义法', u'分治法', u'Strasses法', fontproperties=font)
plt.show()

以上这篇Python实现矩阵相乘的三种方法小结就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python实现统计英文单词个数及字符串分割代码
May 28 Python
利用python将xml文件解析成html文件的实现方法
Dec 22 Python
python中itertools模块zip_longest函数详解
Jun 12 Python
在scrapy中使用phantomJS实现异步爬取的方法
Dec 17 Python
Python3中列表list合并的四种方法
Apr 19 Python
Python实现FTP文件传输的实例
Jul 07 Python
使用python快速在局域网内搭建http传输文件服务的方法
Nov 14 Python
python实现从wind导入数据
Dec 03 Python
解决python-docx打包之后找不到default.docx的问题
Feb 13 Python
使用OpenCV获取图片连通域数量,并用不同颜色标记函
Jun 04 Python
如何用python实现一个HTTP连接池
Jan 14 Python
解决pycharm下载库时出现Failed to install package的问题
Sep 04 Python
python实现泊松图像融合
Jul 26 #Python
python中的decorator的作用详解
Jul 26 #Python
python opencv实现旋转矩形框裁减功能
Jul 25 #Python
Python3匿名函数用法示例
Jul 25 #Python
Python实现动态添加属性和方法操作示例
Jul 25 #Python
利用pandas读取中文数据集的方法
Jul 25 #Python
利用pandas进行大文件计数处理的方法
Jul 25 #Python
You might like
用 PHP5 轻松解析 XML
2006/12/04 PHP
PHP动态生成指定大小随机图片的方法
2016/03/25 PHP
PHP使用标准库spl实现的观察者模式示例
2018/08/04 PHP
javascript 当前日期加(天、周、月、年)
2009/08/09 Javascript
Javacript实现颜色梯度变化和渐变的效果代码
2013/05/31 Javascript
AngularJS HTML编译器介绍
2014/12/06 Javascript
node.js中的dns.getServers方法使用说明
2014/12/08 Javascript
JS实现仿雅虎首页快捷登录入口及导航模块效果
2015/09/19 Javascript
jquery判断复选框是否选中进行答题提示特效
2015/12/10 Javascript
详解JavaScript中|单竖杠运算符的使用方法
2016/05/23 Javascript
React创建组件的三种方式及其区别
2017/01/12 Javascript
JS给按钮添加跳转功能类似a标签
2017/05/30 Javascript
Vue.js实现可编辑的表格
2019/12/11 Javascript
Node.js API详解之 readline模块用法详解
2020/05/22 Javascript
Python的类实例属性访问规则探讨
2015/01/30 Python
Python中的进程分支fork和exec详解
2015/04/11 Python
在Python的gevent框架下执行异步的Solr查询的教程
2015/04/16 Python
Python实现对比不同字体中的同一字符的显示效果
2015/04/23 Python
利用Python+Java调用Shell脚本时的死锁陷阱详解
2018/01/24 Python
解决新版Pycharm中Matplotlib图像不在弹出独立的显示窗口问题
2019/01/15 Python
Python 3 判断2个字典相同
2019/08/06 Python
python基于socket实现的UDP及TCP通讯功能示例
2019/11/01 Python
Java Spring项目国际化(i18n)详细方法与实例
2020/03/20 Python
python Socket网络编程实现C/S模式和P2P
2020/06/22 Python
Python类成员继承重写的实现
2020/09/16 Python
Python内存泄漏和内存溢出的解决方案
2020/09/26 Python
GE设备配件:GE Appliance Parts(家电零件、配件和滤水器)
2018/11/28 全球购物
娱乐地球:Entertainment Earth
2020/01/08 全球购物
澳大利亚一站式数码相机商店:CameraPro
2020/03/09 全球购物
经典婚礼主持词
2014/03/13 职场文书
2015元旦主持词开场白和结束语
2014/12/14 职场文书
锅炉工岗位职责
2015/02/13 职场文书
保险公司反洗钱宣传活动总结
2015/05/08 职场文书
2015年学校精神文明工作总结
2015/05/27 职场文书
《学会生存》读后感3篇
2019/12/09 职场文书
解析redis hash应用场景和常用命令
2021/08/04 Redis