2.5 Strassen矩阵乘法

news2025/7/18 15:13:25

矩阵乘法是线性代数中最常见的问题之一,在数值计算中有广泛的应用。设4和B是两

个nxn矩阵,它们的乘积 AB 同样是一个nxn矩阵。A和B的乘积矩阵 C中元素C定义为

C =2anw6o

=1

若依此定义来计算4 和B的乘积短阵C,则每计算 C的一个元素C,需要做n次乘法

和1-1 次加法。因此,求出矩阵C的八个元素所需的计算时间为 O((n)。

20 世纪 60年代末,Strassen 采用子类似于在大整数乘法中用过的分治技术,将计算 2

个n阶矩阵乘积所需的计算时间改进到 0(1083=0(n2.81。其基本思想还是使用分治法。

首先,仍假设n是2的幂。将矩阵4 、B和C中每个矩阵都分块成 4个大小相等的子矩

阵,每个子矩阵都是 n/2xn1/2 的方阵。由此可将方程C=4B 重写为

如果1=2,则2个2阶方阵的乘积可以直接计算出来,共需8次乘法和4 次加法。当子

矩阵的阶大于2时,为求2个子矩阵的积,可以继续将子矩阵分块,直到子矩阵的阶降为 2。

由此产生了分治降阶的递归算法。依此算法,计算2个n阶方阵的乘积转化为计算8个n/2

阶方阵的乘积和4个n/2阶方阵的加法。2个n/2xn/2矩阵的加法显然可以在 O(n时间内完

成。因此,上述分治法的计算时间耗费 T(n)应满足

这个递归方程的解仍然是 7n=0()。因此,该方法并不比用原始定义直接计算更有效。

究其原因,是由于该方法并没有减少矩阵的乘法次数。而矩阵乘法耗费的时间要比矩阵加

(减)法耗费的时间多得多,要想改进矩阵乘法的计算时问复杂性,必须减少乘法运算。

按照上达分治法的思想可以看出,要想减少乘法运算次数,关键在于计算2个2阶方阵

的乘积时,能否用少于8次的乘法运算。Strassen 提出了一种新的算法来计算2个2阶方阵

的乘积。该算法只用了 7次乘法运算,但增加了加减法的运算次数。这7次乘法是

019

以上计算的正确性容易验证。

Strassern 短阵乘法中用了7 次对于n/2 阶矩阵乘积的递归调用和 18 次11/2 阶矩阵的加

运算。由此可知,该算法所需的计算时间T(n满足如下递归方程:

O(1)

n=2

T(n) =

177(1/2)+0() n>2

解此递归方程得 70=0(11087~0(72.81)。由此可见, Strassen 矩阵乘法的计算时间复杂性

比普通矩阵乘法有较大改进。

有人曾列举了计算2个2×2阶矩阵乘法的36种方法。但所有的方法都至少做7 次乘法

除非能找到一种计算2阶方阵乘积的算法,使乘法的计算次数少于7次,计算矩阵乘积的计

算时间下界才有可能低于 0(n?.81。但是Hopcrof 和Kerr 己经证明(1971年),计算2个2x2

矩阵的乘积,7 次乘法是必要的。因此,要想进一步改进矩阵乘法的时间复杂性,就不能再

基于计算 2x2矩阵的7 次乘法这样的方法了,或许应当研究 3x3 或 5x5 矩阵的更好算法。在

Strassen 之后有许多算法改进了矩阵乘法的计算时间复杂性,目前最好的计算时间上界是

0(02-376),所知的矩阵乘法的最好下界仍是它的平凡下界2(n。因此,到目前为止还无法确

切知道矩阵乘法的时间复杂性。关于这一研究课题还有许多工作可做。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/395690.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

如何提高爬虫工作效率

单进程单线程爬取目标网站太过缓慢,这个只是针对新手来说非常友好,只适合爬取小规模项目,如果遇到大型项目就不得不考虑多线程、线程池、进程池以及协程等问题。那么我们该如何提升工作效率降低成本? 学习之前首先要对线程&#…

windows下一键启动vue项目,后台运行cmd命令

1、写好启动vue的bat echo off E: cd E:\project-html\study\vue-demo npm run serve 2、准备vbs脚本,指向bat Set hd CreateObject("Wscript.Shell")hd.run "cmd /c C:\Users\xxh\Desktop\vue-demo.bat",vbhide 3、双击vbs脚本就可以启动了…

java八股系列——SpringMVC从接受请求到完成响应的过程

Spring的MVC框架是围绕一个DispatcherServlet来设计的,这个Servlet会把请求分发给各个处理器,并支持可配置的处理器映射、视图渲染、本地化、时区与主题渲染等,甚至还能支持文件上传。 流程大致如下: 用户发起请求:用…

一般用哪些工具做大数据可视化分析?

做数据分析这些年来,从刚开始的死磕excel,到现在成为数据分析行业的偷懒大户,使用过的工具还真不少! 这篇分享一些我在可视化工具上的使用心得,由简单到复杂,按照可视化类型一共分为纯统计图表类、GIS地图…

C/C++每日一练(20230308)

目录 1. 最大间距 ★★★ 2. 被围绕的区域 ★★ 3. 天际线问题 ★★★ 🌟 每日一练刷题专栏 C/C 每日一练 ​专栏 Python 每日一练 ​专栏 1. 最大间距 给定一个无序的数组,找出数组在排序之后,相邻元素之间最大的差值。 如果数组…

Windows环境下nacos的下载与安装

一、nacos的下载地址:Releases alibaba/nacos GitHub根据自己项目配置的版本,下载对应的nacos客户端。windows下载上面的tar.gz的安装包,linux下载下面的zip包二、下载解压成功后,修改配置文件D:\nacos\bin下面的startup.cmd。把…

基于JavaEE社区物业管理系统开发与实现(附源码资料)

文章目录1. 适用人群2. 你将收获3.项目简介4.技术栈5.测试账号6.部分功能模块展示6.1.管理员6.2.业主1. 适用人群 本课程主要是针对计算机专业相关正在做毕业设计或者是需要实战项目的Java开发学习者。 2. 你将收获 提供:项目源码、项目文档、数据库脚本、软件工…

sealos 神奇功能 serverless kubernetes 之 cloud terminal

何为 serverless kubernetes 顾名思义,就是不需要安装直接打开网页就可以直接使用的 kubernetes,是一个多租户共享 kubernetes 的租户模型,这样做的好处是对于用户的使用成本极低,而且无需安装 kubernetes, 且天生对多租户的隔离…

C语言杂记(字符串)

字符串 字符串的定义方法 注意&#xff1a;char *data3 “hello3”;//字符串常量&#xff0c;不允许被修改 #include <stdio.h>int main() {char data[] {h,e,l,l,o};//字符数组char data2[] "hello2";//可修改char *data3 "hello3";//字符串常…

Ubuntu20.04 源码编译安装SRS-6流媒体服务器,开启GB28181支持

1. 下载SRS源码 直接从仓库clone git clone -b develop https://gitee.com/ossrs/srs.git 2. 编译源码 此处通过 --gb28181on 开启GB28181支持&#xff0c;默认是不开启的 cd srs/trunk && ./configure --gb28181on && make -j4 3. 编译过程中遇到的问题 …

【专项训练】前言:刻意练习,不断的过遍数才是王道

如何精通一个领域? 拆分知识点刻意练习:每个区域的基础动作分解训练和反复刻意练习反馈(主动反馈、被动反馈、及时反馈)任何知识体系都是一颗树,一定要梳理成思维导图,明确知识与知识之间的关系! 通过7-8周密集训练,练好基本功,彻底攻克LeetCode! 严格执行五毒神掌!…

Leetcode是什么

力扣&#xff08;LeetCode&#xff09;是领扣网络旗下专注于程序员技术成长和企业技术人才服务的品牌。源自美国硅谷&#xff0c;力扣为全球程序员提供了专业的IT 技术职业化提升平台&#xff0c;有效帮助程序员实现快速进步和长期成长。 此外&#xff0c;力扣&#xff08;Leet…

Verilog如何编写一个基础的Testbench

本文将讲述如何使用Verilog 编写一个基础的测试脚本&#xff08;testbench&#xff09;。在考虑一些关键概念之前&#xff0c;先来看看testbench的架构是什么样的。架构包括建模时间、initial块&#xff08;initial block&#xff09;和任务&#xff08;task&#xff09;。此文…

Stimulsoft Reports.WEB 23.1.8 完美Crack

Stimulsoft Reports.WEB 适用于 ASP.NET 和 .NET Core 的报告工具 Stimulsoft Reports.WEB 是一种跨平台报告工具&#xff0c;旨在在 Web 浏览器中创建、构建、显示、打印和导出报告。该产品包括将报告工具集成到基于 ASP.NET、ASP.NET MVC、.NET Core、Angular 和 Blazor 平台…

【算法设计-分治】递归与尾递归

文章目录1. 阶乘尾递归&#xff1a;递归的进一步优化2. 斐波那契数列3. 最大公约数&#xff08;GCD&#xff09;4. 上楼梯5. 汉诺塔&#xff08;1&#xff09;输出移动过程输出移动步数5. 汉诺塔&#xff08;2&#xff09;输出移动过程输出移动步数6. 杨辉三角形7. 完全二叉树1…

管理系统-学科列表-增删改查

查 1.布局2.定义api3.导入api4.进入页面就调用api5.获取数据6.存储并渲染7.与分页建立关联a.请求参数值要与分页组件绑定b.total值存储并绑定到分页组件c.页码改变与页容量改变都要请求api1.布局 <template><div><el-card><el-form :inline"true&q…

【Leetcode】反转链表 合并链表 相交链表 链表的回文结构

目录 一.【Leetcode206】反转链表 1.链接 2.题目再现 3.解法A&#xff1a;三指针法 二.【Leetcode21】合并两个有序链表 1.链接 2.题目再现 3.三指针尾插法 三.【Leetcode160】相交链表 1.链接 2.题目再现 3.解法 四.链表的回文结构 1.链接 2.题目再现 3.解法 一.…

【python爬虫】获取cookie和uid的方式

本文以微博网站为例。 一、获取cookie &#xff08;1&#xff09;在浏览器中输入“weibo.cn” &#xff08;2&#xff09;登录自己的账号。 &#xff08;3&#xff09;登录后&#xff0c;右键空白处点击【检查】 &#xff08;4&#xff09;点击【网络】或者【Network】 浏…

Sql执行流程与Redo log、 Undo log、 Bin log日志文件

文章目录Sql执行流程与日志文件Sql的执行流程Redo LogBin logUndo logSql执行流程与日志文件 Sql的执行流程 mysql的内部组件结构如下图所示 连接器 与客户端建立连接&#xff0c;检验登录密码&#xff0c;分配相应权限 查询缓存 执行sql语句时会先从这里找一下&#xff0c;…

雷电模拟器运行非常卡顿有效解决方法分享

雷电模拟器运行非常卡顿有效解决方法分享。有用户在电脑上开启雷电模拟器来使用的时候&#xff0c;遇到了软件使用非常卡顿的情况。那么这样的软件卡顿问题要怎么去进行处理呢&#xff1f;接下来我们一起来看看以下的解决方法教学吧。 雷电模拟器卡顿的解决方法 一、关闭360核晶…