• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >编程问答 > C程序:如何优化矩阵幂运算

C程序:如何优化矩阵幂运算

作者:佚名 字体:[增加 减小] 来源:互联网 时间:2017-06-07

佚名通过本文主要向大家介绍了c语言程序优化,c程序性能优化,最优化c程序,c程序优化,如何用vc6编写c程序等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com
问题:C程序:如何优化矩阵幂运算
描述:

最近写了个C程序来计算矩阵的幂,代码如下:

    /*  矩阵幂运算,例如
        1 2        1 0
        3 4 ^ 0 => 0 1

        1 2        1 2
        3 4 ^ 1 => 3 4

        1 2        199 290
        3 4 ^ 4 => 435 634
    */
uint32_t* matrix_pow(const uint32_t* matrix, uint32_t exponent) {

    uint32_t* result = new_matrix();

    if (exponent == 0){
        result = identity_matrix();
    } else{
        result = cloned(matrix);
        for (int c = 1; c < exponent; c++){
            result = matrix_mul(result, matrix);
        }
    }

    return result;
}

其中, exponent是幂次,cloned()方法是复制矩阵,identity_matrix()返回一个单位矩阵,matrix_mul()用来计算两个计算的乘积。

不知有哪些优化的方法(可以完全改写上面的程序),可以使上面的函数效率更高,可以使用多线程,分治等。


解决方案1:

SIMD...

属于指令上的优化了...

你在哪个平台上运行,arm还是ia?

解决方案2:

主要还是优化时间复杂度吧,主要是使用快速幂

cppuint32_t* matrix_pow(const uint32_t* matrix, uint32_t exponent) {

    uint32_t* result = identity_matrix();
    while(exponent)
    {
        if(exponent&1) result=matrix_mul(result, matrix);
        matrix=matrix_mul(matrix , matrix);
        exponent>>=1;
    }
    return result;
}

这样只要进行log(exponent)次矩阵乘法即可;
另外不知道你的matrix_mul是怎么实现的,如果一般方法是O(n^3)的,改用Strassen算法则仅需O(n^2.81)复杂度即可;

进行如上改进之后,再考虑通用的优化方法,对于矩阵乘法常用的是SIMD指令集优化,矩阵乘法部分可以嵌入汇编优化


分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • C程序:如何优化矩阵幂运算

相关文章

  • 2017-06-07 (flask)Web程序中的全局变量,有些问题想不通
  • 2017-06-07 请问关于播放七牛m3u8音视频的问题
  • 2017-06-07 qrsync执行报错
  • 2017-06-07 七牛申请绑定自己的域名后,自己的域名可以直接访问,网站不显示内容,
  • 2017-06-07 七牛forWordPressV10非镜像直接上传
  • 2017-06-07 开始Python学习不归路
  • 2017-06-07 (python)Dataframe使用'<'运算符比较字符串,结果不正确
  • 2017-06-07 关于MemcachedCAS协议
  • 2017-06-07 获取七牛空间大小的接口
  • 2017-06-07 如何快速深入学习web开发?

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • wxpythonDLL替换失败
    • 如何把一个PHP中递归正则的语句替换为JavaScript非递归的语句?
    • 你们不能自定义max-age,请求次数又算钱。这
    • 这句正则表示的什么意思?
    • rubyruby图片处理
    • 外链淘宝图片和又拍云存储哪个快
    • 如何在android客户端直接获取token?
    • Flask的url_for引用静态文件,如何让http和https都能正常获取
    • (ruby)求一个MYSQL查询语句
    • 七牛pythonSDK兼容python35吗?

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有