首页 > 编程问答 >NumPy 连续矩阵乘法向量化

NumPy 连续矩阵乘法向量化

时间:2024-07-22 06:20:45浏览次数:14  
标签:python numpy numpy-ndarray matrix-multiplication numpy-einsum

我有一个 NumPy 数组 ar 形状 (M, L, N, N)

我想连续乘以 L (N, N) 矩阵( multiplied_ar[m] = ar[m, 0, :, :] @ ar[m, 1, :, :] @ ... )以获得形状数组 (M, N, N)

是否有可能| ||向量化 以某种方式这样我就不必迭代 m l ?


是的,可以使用 NumPy 的 einsum 函数来实现。

import numpy as np

# 示例数据
M, L, N = 2, 3, 4
ar = np.random.rand(M, L, N, N)

# 使用 einsum 进行连续矩阵乘法
multiplied_ar = np.einsum('mijk,milj->mikj', ar, np.eye(N)[None, :, :, :].repeat(L, axis=0))

# 将结果简化为 (M, N, N)
multiplied_ar = np.einsum('m0jk->mjk', multiplied_ar)

print(multiplied_ar.shape)  # 输出: (2, 4, 4)

解释:

  1. 创建单位矩阵序列: np.eye(N)[None, :, :, :] 创建一个形状为 (1, N, N, N) 的单位矩阵。 repeat(L, axis=0) 将其沿第一个轴复制 L 次,从而得到形状为 (L, N, N, N) 的单位矩阵序列。
  2. 使用 einsum 进行连续乘法: einsum('mijk,milj->mikj', ar, ...) ar 和单位矩阵序列执行连续矩阵乘法。
    • mijk 表示 ar 的索引。
    • milj 表示单位矩阵序列的索引,其中 l 是沿着 L 维度的迭代器。
    • mikj 表示结果数组的索引。
    • einsum 会自动沿着匹配的 l 索引进行求和,从而实现连续乘法。
  3. 简化结果: np.einsum('m0jk->mjk', multiplied_ar) 将形状为 (M, L, N, N) 的结果数组简化为 (M, N, N) ,方法是将第一个索引 0 移除,因为它不包含任何有用信息。

这种方法避免了显式的 Python 循环,并且比使用循环进行迭代要快得多,尤其是在处理大型数组时。

标签:python,numpy,numpy-ndarray,matrix-multiplication,numpy-einsum
From: 78776454

相关文章

  • 我在 Windows 10 上运行 Python 代码后控制台立​​即关闭
    虽然我在代码末尾使用input(),但在Windows10(IDLE之外)的窗口中输入名称后,控制台仍然立即关闭,并且我看不到结果。我该怎么做才能阻止控制台关闭?#!python3name=input('Enteryourname:')print('Hello'+name)input('pressEntertoexit:')你在代码末尾......
  • 具有未定义嵌套列表深度的嵌套列表的Python注释类型
    [[1,2,3],3,[2,4],5]的类型是list[list[int]|int]但是,如果嵌套列表具有未定义的深度,例如[[[1,2]],2,[1,[3,[3]]]],3,[2,[2]]],那么它会具有什么类型?可以使用递归类型提示来表示任意深度嵌套的列表:fromtypingimportList,Union......
  • 在Spyder(Python 3.6)中导入cv2时出现导入错误
    我已经在Windows操作系统中安装了opencv3.0.0。我已运行该应用程序并已成功将其安装在C:\驱动器中,并且还将cv2.pyd文件复制到C:\Python27\Lib\site-packages中,正如我在几个教程视频中看到的那样在我的Python2.7.5Shell中,即当我键入>>>i......
  • Python + VS Code 调试器:可视化我的程序当前正在执行的源代码中的位置?
    当我使用VSCodePython调试器时:我可以执行我的程序,以便编辑器将我逐行带到源代码中的任何位置(跳转到相关文件/如果尚未打开则将其打开)目前的执行情况是?是的,VSCode的Python调试器可以让你逐行执行代码,并实时显示当前执行的位置。以下是操作方法:1.设置断点:......
  • 如何立即取消使用 Ollama Python 库生成答案的 Asyncio 任务?
    我正在使用Ollama通过OllamaPythonAPI从大型语言模型(LLM)生成答案。我想通过单击停止按钮取消响应生成。问题在于,只有当响应生成已经开始打印时,任务取消才会起作用。如果任务仍在处理并准备打印,则取消不起作用,并且无论如何都会打印响应。更具体地说,即使单击按钮后,此函数......
  • 使用 np.array 索引过滤 Python 列表
    谁能向我解释一下列表self.data如何使用numpy索引数组selec_idx进行索引/过滤?完整的课程可在https://github.com/kaidic/LDAM-DRW/blob/master/imbalance_cifar.pydefgen_imbalanced_data(self,img_num_per_cls):new_data=[]n......
  • 尝试在cmd(python)中安装turtle
    当我在cmd中编写pipinstallturtle后,这条消息出现在我面前。有人知道该怎么办吗?C:\>pipinstallturtleCollectingturtleUsingcachedturtle-0.0.2.tar.gz(11kB)ERROR:Commanderroredoutwithexitstatus1:command:'C:\Users\Bruger\App......
  • Python + Polars:如何有效地“fill_null”仅 DataFrame 的某些列?
    例如,假设我只想fill_null(strategy="zero")DataFrame的数字列。我当前的策略是这样做:final_df=df.select(cs.exclude(cs.numeric()))final_df.with_columns(df.select(cs.numeric()).fill_null(strategy="zero"))是否有替代的、更惯用或更有效的方法来实现我......
  • 如何找到 Windows 上 Python 的安装位置?
    我想找出我的Python在Windows上的安装路径。例如:C:\Python25如何找到Python的安装位置?在Windows上查找Python安装位置的方法有很多种:1.使用where命令(推荐方法):打开命令提示符(cmd)。输入以下命令并按回车键:wherepython......
  • Python Pandas:如何解析没有行结尾的 CSV
    如何解析没有行结尾的CSV文件?示例数据sep=;Id;Date;1;1980-02-29;2;1980-03-10;3;;可以使用lineterminator参数指定行终止符来解析没有行尾的CSV文件。在这种情况下,你可以将lineterminator设置为一个空字符串('')。以下是使用......