- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我在 Matlab 脚本中有复杂的代码块,它们作用于大型非稀疏数组。该代码对数组中的随机元素执行许多写入操作,以及读取操作。相同的代码必须针对不同的(大)数组执行(即相同的代码块,除了不同的数组变量名称)。
我不希望只有数组名称不同的长而重复的代码块。
不幸的是,当我创建一个函数来执行这些操作时,代码块只出现一次,性能下降了 10 倍或更多(可能是由于数组的复制)。但是,我不需要复制数组。我宁愿“通过引用传递”,这样函数调用的目的只是为了避免重复的代码块。然而,似乎没有办法避免写时复制语义。
此外,不可能(据我所知)创建脚本(不是函数)来实现此目的,因为脚本必须包含与调用脚本相同的变量名称,因此我需要为每个脚本创建一个不同的脚本我希望在其上运行脚本的数组,它什么也得不到(我仍然会有重复的代码块)。
我研究过创建一个别名变量名来“替代”感兴趣的数组变量名,在这种情况下我可以调用脚本并避免重复代码。但是,我找不到任何方法在 Matlab 中创建别名。
最后,我尝试编写一个利用 evalin()
函数的函数,并将数组变量的 string 名称传递给该函数,但尽管这可行,性能也大大降低 - 与按值将数组传递给函数大致相同(性能至少下降 10 倍)。
我得出的结论是,在对非稀疏数组执行复杂操作时,在 Matlab 中不可能避免重复代码块,以努力避免 Matlab 似乎使用任何可能的避免重复技术出现的可怕开销代码块。
我觉得这难以置信,但我找不到解决方法。
有人知道在 Matlab 中对多个非稀疏数组执行相同的复杂操作时避免重复代码块的方法吗?
最佳答案
如 Loren on his blog 所述, MATLAB 确实支持对矩阵的内联 操作,这基本上涵盖了通过引用传递数组、在函数中修改它们以及返回结果。您似乎知道这一点,但您错误地陈述了这一点,因为脚本必须包含与调用脚本相同的变量名。这是显示这是错误的代码示例。测试时请逐字复制并另存为函数:
function inplace_test
y = zeros(1,1e8);
x = zeros(1,1e8);
tic; x = compute(x); toc
tic; y = compute(y); toc
tic; x = computeIP(x); toc
tic; y = computeIP(y); toc
tic; x = x+1; toc
end
function x=computeIP(x)
x = x+1;
end
function y=compute(x)
y = x+1;
end
我电脑上的时间结果:
Elapsed time is 0.243335 seconds.
Elapsed time is 0.251495 seconds.
Elapsed time is 0.090949 seconds.
Elapsed time is 0.088894 seconds.
Elapsed time is 0.090638 seconds.
如您所见,使用in-place 函数的最后两次调用对于输入数组x
和y
的速度同样快。此外,它们与不带函数运行 x = x+1
一样快。唯一重要的是函数内部输入和输出参数是相同的。还有一件事......
如果我猜出您的代码有什么问题,我会说您制作了您希望就地使用的嵌套 函数。他们不是。所以下面的代码将不起作用:
function inplace_test
y = zeros(1,1e8);
x = zeros(1,1e8);
tic; x = compute(x); toc
tic; y = compute(y); toc
tic; x = computeIP(x); toc
tic; y = computeIP(y); toc
tic; x = x+1; toc
function x=computeIP(x)
x = x+1;
end
function y=compute(x)
y = x+1;
end
end
Elapsed time is 0.247798 seconds.
Elapsed time is 0.257521 seconds.
Elapsed time is 0.229774 seconds.
Elapsed time is 0.237215 seconds.
Elapsed time is 0.090446 seconds.
底线 - 小心那些嵌套函数..
关于matlab - 传递数组,没有开销(最好是 "by reference"),以避免在 matlab 中复制复杂的代码块?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13078338/
我想知道,通过数据 channel 发送数据时 WebRTC 会产生多少开销。 我知道 Websockets 每帧有 2 - 14 字节的开销。 WebRTC 是否使用更多开销?我在网上找不到一些有用
我想知道与创建新类而不是该类的新对象相关的开销是小还是大。我正在使用 dojo,但我将提供纯 JS 的示例。我将在启动时创建 10 到 100 个对象,我认为这不会是一个严重的问题,但我想涵盖所有基础
我有一个如下所示的表设置。 Table comment_flags user_id comment_id 我允许用户标记评论,然后给他们取消标记的选项,因为他们可能犯了一个错误。 问题
这个问题已经有答案了: 已关闭10 年前。 Possible Duplicate: In MySQL what does “Overhead” mean, what is bad about it,
我正在制作一个非常简单的游戏,只是为了好玩/练习,但无论它现在有多简单,我仍然想很好地编写它,以防我想回到它并只是为了学习 因此,在这种情况下,我的问题是: 对象分配涉及多少开销?解释器对此的优化程度
我有一些资源敏感的东西要写。我想知道与仅将这些变量一起传递(例如作为函数参数)相比,在结构中将变量组合在一起是否真的会导致内存开销。 如果是这样,那么在不产生开销的情况下创建对惰性值进行操作的东西的好
我一直在开发一个实时应用程序,并注意到一些 OOP 设计模式在 Python 中引入了难以置信的开销(使用 2.7.5 进行了测试)。 直截了当,当字典被另一个对象封装时,为什么简单的字典值访问器方法
我正在从 ifstream 中读取随机 ascii 文本文件。我需要能够将整个消息放入字符串类型以进行字符解析。我当前的解决方案有效,但我认为我通过使用等效于此的方式来谋杀更冗长文件的处理时间: st
纯粹从软件工程的角度来看,getActivity() 有多少开销? 我在整个应用程序中经常多次使用此方法,并考虑使用一个引用 getActivity() 的全局变量。 如果为 Activity 设置一
我一直在研究 Riccardo Terrell 的 Akka.NET 分形演示 (https://github.com/rikace/akkafractal) 以尝试理解它。 (这很棒,顺便说一句)
我正在尝试使用高分辨率计时器查找我的代码运行时间,我注意到计时器的结果不一致,我想知道为什么会这样。 我找到了这篇文章 How do you test running time of VBA code
我正在学习WPF。我现在开始装订了。使用 INotifyPropertyChanged 时绑定(bind)是否依赖反射?是这样,价格是多少?我正在考虑使用 WPF 来显示通过 UDP 流式传输的数据,
我有某种模板化基类 template class Base { }; 并希望将其派生实例存储在列表中。为此,我使用 using derived_handle = std::unique_ptr v
使用GHC.TypeLits中的Sing有任何开销吗? ?以程序为例: {-# LANGUAGE DataKinds #-} module Test (test) where import GHC.T
我有某种模板化基类 template class Base { }; 并希望将其派生实例存储在列表中。为此,我使用 using derived_handle = std::unique_ptr v
我有一个 ORM sqlalchemy 模型,我需要构建一个查询(使用 ORM 类更容易构建),但这需要大量时间。当我直接像 SQL 一样向数据库执行相同的查询时,速度相当快。 使用 SQLAlche
我在 PHP 平台上有一家商店(开发不善),那里有很多不好的查询(没有索引的长查询、rand() 排序、动态计数,..) 我现在无法更改查询,但我必须调整服务器才能保持事件状态。 我尝试了我所知道的一
我有一个使用 JQuery mobile 构建的移动应用程序,响应时间对我来说非常重要,因为我希望为我的用户提供流畅的体验。 我刚刚将网站的安装移至本地服务器,以提高应用程序的性能,因为它连接到本地
关于数据库设计的问题。如果我有 28 个 bool 值并且能够将它们添加为每行 28 个 bool 值或一个整数,哪一个会更快?哪种方法将使磁盘上的表大小保持最低? 这是在假设我需要的可以通过查询中的
我有一个看起来像 Boost.Array 的简单类。有两个模板参数 T 和 N。Boost.Array 的一个缺点是,每个使用这种数组的方法都必须是带有参数 N 的模板(T 可以)。结果是整个程序往往
我是一名优秀的程序员,十分优秀!