python 实现矩阵相乘

来源:互联网 发布:路由器编程器 编辑:程序博客网 时间:2024/04/30 08:32

优势在于,矩阵的数据组织方式适合分布式计算


# coding:utf-8__author__ = 'taohao'import randomclass Matrix(object):    def build_matrix_a(self, row, col):        """        matrix:            1  0  2            -1 3  1        turn to ->Matrix name,rowNum,colNum,elementNum        for example:            A,1,1,1            A,1,2,1            A,1,3,2            A,2,1,-1            A,2,2,3            A,2,3,1        save the matrix to file for hadoop to read data from file        :return:        """        fd = open('MatrixA.txt', 'w')        num = ''        for i in range(row):            for j in range(col):                num += ',' + str(i+1) + ',' + str(j+1) + ','                num += str(random.randint(1, 10))                fd.write('A' + num + '\n')                num = ''        fd.close()    def build_matrix_b(self, row, col):        """        the same as def build_matrix_a        :param row:        :param col:        :return:        """        fd = open('MatrixB.txt', 'w')        num = ''        for i in range(row):            for j in range(col):                num += ',' + str(i+1) + ',' + str(j+1) + ','                num += str(random.randint(1, 10))                fd.write('B' + num + '\n')                num = ''        fd.close()    def matrix_multify(self, row, col):        result = {}        matrix_a = {}        matrix_b = {}        fd_a = open("MatrixA.txt", 'r')        fd_b = open('MatrixB.txt', 'r')        for line_a in fd_a:            line_item = line_a.rstrip('\n').split(r',')            if line_item[1] not in matrix_a:                matrix_a[line_item[1]] = []            matrix_a[line_item[1]].append(line_item[3])        for line_b in fd_b:            line_item_b = line_b.rstrip('\n').split(r',')            if line_item_b[2] not in matrix_b:                matrix_b[line_item_b[2]] = []            matrix_b[line_item_b[2]].append(line_item_b[3])        fd_a.close()        fd_b.close()        # print matrix_a        # print matrix_b        for i in range(row):            row_num = matrix_a.get(str(i+1))            # print 'row', row_num            for j in range(col):                col_num = matrix_b.get(str(j+1))                # print 'col', col_num                k = 0                while k < len(row_num):                    if str(i+1)+str(j+1) not in result:                        result[str(i+1)+str(j+1)] = 0                    result[str(i+1)+str(j+1)] += int(row_num[k]) * int(col_num[k])                    k += 1        print result    # output the resultif __name__ == '__main__':    rowA = 4    colA = 2    rowB = 2    colB = 3    matrix = Matrix()    matrix.build_matrix_a(rowA, colA)    matrix.build_matrix_b(rowB, colB)    matrix.matrix_multify(rowA, colB)




0 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 摩托车被收了怎么办 摩托车的手续都怎么办 摩托车罚单掉了怎么办 行人遇到黄灯该怎么办 长辈借钱不还怎么办 不绣刚电梯轿壁有凹槽怎么办 电梯下限位故障怎么办 卫生间夏天太热怎么办 07大檐帽变形了怎么办 税务局不批发票怎么办 进项发票太多了怎么办 发票报销联丢失怎么办 发票领用簿没有怎么办 发票购买本遗失怎么办 销售方遗失发票怎么办 增值税发票发票联丢失怎么办 苹果购买发票丢失怎么办 空白增值税发票发票丢失怎么办 网购发票 领购簿怎么办 购物发票丢了怎么办 饭店客人买单要少钱怎么办 发票备注栏写错怎么办 卖房子发票丢失怎么办 发票二维码蓝票怎么办 车祸伤者出院怎么办 微信付款失败怎么办 增值税电子发票没打税号怎么办 买假出租车发票怎么办 纳税号错了怎么办 发票抬头写错怎么办 增值税发票打错顺序怎么办 发票打错了怎么办 电子发票错了怎么办 税率开高了怎么办 增值发票折叠了怎么办 播放器格式不对怎么办 发票弄上油了怎么办 快手视频快进了怎么办? 三星手机没声音怎么办 mp4不是标准格式怎么办 苹果七充电慢怎么办