编程语言
首页 > 编程语言> > python-在Matlab中优化“遮罩”功能

python-在Matlab中优化“遮罩”功能

作者:互联网

为了进行基准比较,我考虑简单的功能:

function dealiasing2d(where_dealiased, data)
[n1, n0, nk] = size(data);
for i0=1:n0 
    for i1=1:n1
        if where_dealiased(i1, i0)
            data(i1, i0, :) = 0.;
        end
    end
end

它在伪光谱模拟(数据是一个3d复数数组)中很有用,但基本上它将掩码应用于一组图像,将其中where_dealiased为true的元素置零.

我将在这种简单情况下比较不同语言(以及实现,编译器等)的性能.对于Matlab,我将函数的计时时间定为timeit.由于我不想在Matlab中对我的无知进行基准测试,因此我想用这种语言真正优化此函数.在Matlab中最快的方法是什么?

我现在使用的简单解决方案是:

function dealiasing2d(where_dealiased, data)
[n1, n0, nk] = size(data);
N = n0*n1;
ind_zeros = find(reshape(where_dealiased, 1, []));
for ik=1:nk
    data(ind_zeros + N*(ik-1)) = 0;
end

我怀疑这不是正确的方法,因为等效的Numpy解决方案的速度大约快10倍.

import numpy as np

def dealiasing(where, data):
    nk = data.shape[0]
    N = reduce(lambda x, y: x*y, data.shape[1:])
    inds, = np.nonzero(where.flat)
    for ik in xrange(nk):
        data.flat[inds + N*ik] = 0.

最后,如果有人告诉我“当您想在Matlab中使用某个特定功能非常快时,应该像这样编译它:[…]”,那么我将在基准测试中包含这样的解决方案.

编辑:

经过2个回答,我已经对这些命题进行了基准测试,并且似乎并没有明显的性能改进.这很奇怪,因为简单的Python-Numpy解决方案的速度实际上快了一个数量级,因此我仍在寻找Matlab更好的解决方案…

解决方法:

如果我理解正确,可以使用bsxfun轻松快速地完成此操作:

data = bsxfun(@times, data, ~where_dealiased);

这会将where_dealiased为true(将它们乘以0)的条目的所有第三维分量设置为0,而其余部分保持不变(将它们乘以1).

当然,这假设[size(data,1)size(data,2] == size(where_dealiased).

您使用linear indexing的解决方案也可能非常快.为了节省时间,您可以删除整形,因为find已经返回线性索引:

ind_zeros = find(where_dealiased);

标签:optimization,benchmarking,matlab,python,numpy
来源: https://codeday.me/bug/20191028/1953953.html