在 Matlab 中执行此矩阵运算是否更有效

Is there a more efficient to perform this matrix operation in Matlab

我想在 Matlab 中做以下事情:给定一个矩阵 H,我想构建一个相同大小的矩阵 H*,使得 H*(:,i) 是下一列的总和(即 i H 的 +1 -> n)。例如,如果 H 是

H =

 2     4     7    14
 3     5    11    -3

我希望 H* 是

25    21    14     0
13     8    -3     0

到目前为止,我已经完成了以下代码,但它涉及一个 for 循环,所以我不希望它非常有效(特别是,我的矩阵将有大量的列我将使用的实际应用程序)。

H_tilde=zeros(size(H));
for i=1:size(H,2)
    H_tilde(:,i)=sum(H(:,i+1:size(H,2)),2);
end

有没有办法让它变得更好?

使用cumsum沿第2维度和'reverse'选项,如下:

H_tilde = [cumsum(H(:, 2:end), 2, 'reverse') zeros(size(H,1), 1)];