加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Python > 正文

python – Numpy矩阵运算

发布时间:2020-12-20 12:37:15 所属栏目:Python 来源:网络整理
导读:我想为所有i和j计算以下值: M_ki = Sum[A_ij - A_ik - A_kj + A_kk,1 = j = n] 如何在没有显式循环的情况下使用Numpy(Python)来完成它? 谢谢! 解决方法 这是解决此类问题的一般策略. 首先,编写一个小脚本,将循环显式写入两个不同的函数,最后进行测试,确保
我想为所有i和j计算以下值:

M_ki = Sum[A_ij - A_ik - A_kj + A_kk,1 <= j <= n]

如何在没有显式循环的情况下使用Numpy(Python)来完成它?

谢谢!

解决方法

这是解决此类问题的一般策略.

首先,编写一个小脚本,将循环显式写入两个不同的函数,最后进行测试,确保两个函数完全相同:

import numpy as np
from numpy import newaxis

def explicit(a):
    n = a.shape[0]
    m = np.zeros_like(a)
    for k in range(n):
        for i in range(n):
            for j in range(n):
                m[k,i] += a[i,j] - a[i,k] - a[k,j] + a[k,k]
    return m

def implicit(a):
    n = a.shape[0]
    m = np.zeros_like(a)
    for k in range(n):
        for i in range(n):
            for j in range(n):
                m[k,k]
    return m

a = np.random.randn(10,10)
assert np.allclose(explicit(a),implicit(a),atol=1e-10,rtol=0.)

然后,通过编辑隐式来逐步向量化函数,在每一步运行脚本以确保它们继续保持不变:

步骤1

def implicit(a):
    n = a.shape[0]
    m = np.zeros_like(a)
    for k in range(n):
        for i in range(n):
            m[k,i] = (a[i,:] - a[k,:]).sum() - n*a[i,k] + n*a[k,k]
    return m

第2步

def implicit(a):
    n = a.shape[0]
    m = np.zeros_like(a)
    m = - n*a.T + n*np.diag(a)[:,newaxis]
    for k in range(n):
        for i in range(n):
            m[k,i] += (a[i,:]).sum()
    return m

第3步

def implicit(a):
    n = a.shape[0]
    m = np.zeros_like(a)
    m = - n*a.T + n*np.diag(a)[:,newaxis]
    m += (a.T[newaxis,...] - a[...,newaxis]).sum(1)
    return m

瞧瞧’!最后一个没有循环.为了矢量化这种方程,broadcasting就是要走的路!

警告:确保显式是您想要向量化的等式.我不确定是否也应该总结不依赖于j的术语.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读