免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 5705 | 回复: 2
打印 上一主题 下一主题

在PYTHON中,不利用库,利用列表等的操作,如何求两个矩阵的乘积。 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2018-02-15 10:42 |只看该作者 |倒序浏览
我在一个矩阵类中的乘积方法部分的代码如下,测试时报错如下:IndexError: list index out of range
. . .
求指点,我是新手,代码写的很拙劣,望大家不要介意。
      


def __mul__(self, other):
        """
        Defines the behavior of * operator (matrix multiplication)
        """
        #   
        # TODO - your code here
        #
        def dot_product(vector_one,vector_two):
            result=0
            for i in range(len(vector_one)):
                result+=vector_one[i]*vector_two[i]
            return result
        def get_column(M, column_number):
            column = []
            for i in range(len(M[0])):
                column_i=M[i][column_number]
                column.append(column_i)
            return column
        product=[]
        for i in range(self.h):
            product_row=[]
            for j in range(len(other[0])):
                product_ij=dot_product(self.g[i],get_column(other,j))
                product_row.append(product_ij)
            product.append(product_row)
        return Matrix(product)

微信图片_20180215104055.png (57.94 KB, 下载次数: 68)

微信图片_20180215104055.png

论坛徽章:
145
技术图书徽章
日期:2013-10-01 15:32:13戌狗
日期:2013-10-25 13:31:35金牛座
日期:2013-11-04 16:22:07子鼠
日期:2013-11-18 18:48:57白羊座
日期:2013-11-29 10:09:11狮子座
日期:2013-12-12 09:57:42白羊座
日期:2013-12-24 16:24:46辰龙
日期:2014-01-08 15:26:12技术图书徽章
日期:2014-01-17 13:24:40巳蛇
日期:2014-02-18 14:32:59未羊
日期:2014-02-20 14:12:13白羊座
日期:2014-02-26 12:06:59
2 [报告]
发表于 2018-02-15 16:38 |只看该作者
回复 1# 晓晖映月

https://baike.baidu.com/item/%E7%9F%A9%E9%98%B5%E4%B9%98%E6%B3%95

矩阵相乘最重要的方法是一般矩阵乘积。它只有在第一个矩阵列数(column)第二个矩阵行数(row)相同时才有意义[1]。一般单指矩阵乘积时,指的便是一般矩阵乘积。一个m×n的矩阵就是m×n个数排成m行n列的一个数阵。由于它把许多数据紧凑的集中到了一起,所以有时候可以简便地表示一些复杂的模型。
...

论坛徽章:
0
3 [报告]
发表于 2018-03-11 12:12 |只看该作者
按照算法自己实现,不过速度比pynum慢很多
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP