【问题标题】:Exponent vectorization in OctaveOctave 中的指数矢量化
【发布时间】:2021-12-02 05:57:32
【问题描述】:

我正在尝试获取一个通用数组 A,将其提升到向量 p 的每个成员的(元素方面)幂,然后对结果求和,最好是在向量运算中,这样结果与A 的大小相同。理想情况下,应该允许A 的任何大小/维度的数组。例如,如果

A = [0 1 ; 2 3]
p = [2 3]

我想要结果A.^p(1) + A.^p(2),也就是[0 2 ; 12 36],更优雅,A 的任何大小和p 的长度,并避免循环。

我想出了以下内容,它扩展到 A 的下一个更高维度,然后沿该维度求和:

sum(repmat(A,[ones(1,ndims(A)) length(p)]) .^ repmat(reshape(p,[ones(1,ndims(A)) length(p)]),size(A)),ndims(A)+1)

这在技术上似乎可行,但是....呃。有没有更清洁的方法来做到这一点?

【问题讨论】:

  • 你不需要repmat,Octave 会隐式扩展单例维度以匹配数组。您只需要重塑p 矩阵:sum(A.^reshape(p,[ones(1,ndims(A)),numel(p)]),ndims(A)+1)。当然,下面rahnema1的回答就更好了……
  • @CrisLuengo 你的回答比我的更干净,我很感激!感谢您提供有关单例维度的课程,这对了解非常有用。

标签: vectorization octave


【解决方案1】:

假设p 是一个行向量:

result = reshape(sum(A(:) .^ p, 2), size(A));

【讨论】:

  • 完美,非常感谢。
猜你喜欢
  • 1970-01-01
  • 2011-07-08
  • 2012-05-19
  • 1970-01-01
  • 1970-01-01
  • 2023-04-06
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多