热门标签 | HotTags
当前位置:  开发笔记 > 开发工具 > 正文

从3D数组中的多个页面访问不同的行

如何解决《从3D数组中的多个页面访问不同的行》经验,为你挑选了1个好方法。

如何避免在3D数组中从多个页面访问不同的行,同时避免for-loop?

假设我有一个10x5x3矩阵(mat1),我想将三个页面(例如第一,第二和第三页的第四,第二和第五行)中不同的单独行复制到另一个10x5x3矩阵的第一行(mat2)。

我的解决方案使用for-loop。矢量化呢?

mat1 = randi(100, 10, 5, 3)
mat2 = nan(size(mat1))

rows_to_copy = [4, 2, 5]

for i = 1 : 3
    mat2(1, :, i) = mat1(rows_to_copy(i), :, i)
end

gnovice.. 5

任何矢量化解决方案都不会像for循环解决方案那样简单,并且实际上效率可能更低(编辑:请参见下面的时序测试)。但是,如果您好奇,对这样的索引操作进行向量化通常会涉及将所需的索引从下标转换为线性索引。通常,您可以使用来执行此操作sub2ind,但是由于您要选择整行,因此自己计算索引可能会更有效。

这是一个在较新版本的MATLAB(R2016b及更高版本)中利用隐式扩展的解决方案:

[R, C, D] = size(mat1);
index = rows_to_copy+R.*(0:(C-1)).'+R*C.*(0:(D-1));
mat2(1, :, :) = reshape(mat1(index), 1, C, D);

请注意,如果您实际上并不需要所有多余的空间来填充NaNmat2,则可以通过将所有行串联到二维矩阵中来使结果更紧凑:

>> mat2 = mat1(index).'

mat2 =

    95    41     2    19    44
    38    31    93    27    27
    49    10    72    91    49

而且,如果您仍在使用旧版本的MATLAB而没有进行隐式扩展,则可以bsxfun改用:

index = bsxfun(@plus, rows_to_copy+R*C.*(0:(D-1)), R.*(0:(C-1)).');


定时

我使用timeit(R2018a,Windows 7 64位)运行了一些测试,以查看循环和索引解决方案的比较情况。我测试了3种不同的情况:增加行大小,增加列大小和增加页面大小(第三维)mat1。所述rows_to_copy随机选择并总是有相同数量的元素作为页面大小的mat1。以下是结果,显示了循环时间与索引时间的比率:

除了一些瞬态噪声外,还有一些清晰的图案。增加行数或列数(蓝线或红线)不会明显改变时间比例,时间比例徘徊在0.7到0.9之间,这意味着for循环的平均速度略快。增加页面数(黄线)意味着for循环必须迭代更多次,并且索引解决方案迅速开始获胜,当页面大小超过约150时达到8倍加速。



1> gnovice..:

任何矢量化解决方案都不会像for循环解决方案那样简单,并且实际上效率可能更低(编辑:请参见下面的时序测试)。但是,如果您好奇,对这样的索引操作进行向量化通常会涉及将所需的索引从下标转换为线性索引。通常,您可以使用来执行此操作sub2ind,但是由于您要选择整行,因此自己计算索引可能会更有效。

这是一个在较新版本的MATLAB(R2016b及更高版本)中利用隐式扩展的解决方案:

[R, C, D] = size(mat1);
index = rows_to_copy+R.*(0:(C-1)).'+R*C.*(0:(D-1));
mat2(1, :, :) = reshape(mat1(index), 1, C, D);

请注意,如果您实际上并不需要所有多余的空间来填充NaNmat2,则可以通过将所有行串联到二维矩阵中来使结果更紧凑:

>> mat2 = mat1(index).'

mat2 =

    95    41     2    19    44
    38    31    93    27    27
    49    10    72    91    49

而且,如果您仍在使用旧版本的MATLAB而没有进行隐式扩展,则可以bsxfun改用:

index = bsxfun(@plus, rows_to_copy+R*C.*(0:(D-1)), R.*(0:(C-1)).');


定时

我使用timeit(R2018a,Windows 7 64位)运行了一些测试,以查看循环和索引解决方案的比较情况。我测试了3种不同的情况:增加行大小,增加列大小和增加页面大小(第三维)mat1。所述rows_to_copy随机选择并总是有相同数量的元素作为页面大小的mat1。以下是结果,显示了循环时间与索引时间的比率:

除了一些瞬态噪声外,还有一些清晰的图案。增加行数或列数(蓝线或红线)不会明显改变时间比例,时间比例徘徊在0.7到0.9之间,这意味着for循环的平均速度略快。增加页面数(黄线)意味着for循环必须迭代更多次,并且索引解决方案迅速开始获胜,当页面大小超过约150时达到8倍加速。


推荐阅读
  • 优化联通光猫DNS服务器设置
    本文详细介绍了如何为联通光猫配置DNS服务器地址,以提高网络解析效率和访问体验。通过智能线路解析功能,域名解析可以根据访问者的IP来源和类型进行差异化处理,从而实现更优的网络性能。 ... [详细]
  • 国内BI工具迎战国际巨头Tableau,稳步崛起
    尽管商业智能(BI)工具在中国的普及程度尚不及国际市场,但近年来,随着本土企业的持续创新和市场推广,国内主流BI工具正逐渐崭露头角。面对国际品牌如Tableau的强大竞争,国内BI工具通过不断优化产品和技术,赢得了越来越多用户的认可。 ... [详细]
  • 本文总结了2018年的关键成就,包括职业变动、购车、考取驾照等重要事件,并分享了读书、工作、家庭和朋友方面的感悟。同时,展望2019年,制定了健康、软实力提升和技术学习的具体目标。 ... [详细]
  • 本文详细介绍如何使用Python进行配置文件的读写操作,涵盖常见的配置文件格式(如INI、JSON、TOML和YAML),并提供具体的代码示例。 ... [详细]
  • 在计算机技术的学习道路上,51CTO学院以其专业性和专注度给我留下了深刻印象。从2012年接触计算机到2014年开始系统学习网络技术和安全领域,51CTO学院始终是我信赖的学习平台。 ... [详细]
  • CSS 布局:液态三栏混合宽度布局
    本文介绍了如何使用 CSS 实现液态的三栏布局,其中各栏具有不同的宽度设置。通过调整容器和内容区域的属性,可以实现灵活且响应式的网页设计。 ... [详细]
  • Linux 系统启动故障排除指南:MBR 和 GRUB 问题
    本文详细介绍了 Linux 系统启动过程中常见的 MBR 扇区和 GRUB 引导程序故障及其解决方案,涵盖从备份、模拟故障到恢复的具体步骤。 ... [详细]
  • 本文介绍了如何使用jQuery根据元素的类型(如复选框)和标签名(如段落)来获取DOM对象。这有助于更高效地操作网页中的特定元素。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • 本文介绍如何在 Xcode 中使用快捷键和菜单命令对多行代码进行缩进,包括右缩进和左缩进的具体操作方法。 ... [详细]
  • 介绍一个提供正版Windows软件下载的权威网站,确保用户能够安全合法地获取所需软件。 ... [详细]
  • c# – UWP:BrightnessOverride StartOverride逻辑 ... [详细]
  • 优化版Windows 10 LTSC 21H2企业版:适用于低内存设备
    此版本为经过优化的Windows 10 LTSC 21H2企业版,特别适合低内存配置的计算机。它基于官方版本进行了精简和性能优化,确保在资源有限的情况下依然能够稳定运行。 ... [详细]
  • 解决Linux系统中pygraphviz安装问题
    本文探讨了在Linux环境下安装pygraphviz时遇到的常见问题,并提供了详细的解决方案和最佳实践。 ... [详细]
author-avatar
懓瑞巴蒂
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有