- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
MATLAB 的内置函数 accumarray
接受函数 fun
作为第四个参数。
A = accumarray(subs,val,sz,fun);
这适用 fun
val
中元素的每个子集在 subs
中具有相同的下标.然而,文档指出:
If the subscripts in
subs
are not sorted with respect to their linear indices,fun
should not depend on the order of the values in its input data.
我们如何实现 accumarray
的稳定版本,它没有此限制,但会保证子集采用与 val
给定的相同顺序?
示例:
subs = [1:10,1:10];
val = 1:20;
accumarray(subs(:), val(:), [], @(x)x(end)).'
预期输出为 11:20
如果accumarray
稳定。实际上输出是:
ans =
11 12 13 14 5 6 7 18 19 20
我们的实现应该产生:
accumarrayStable(subs(:), val(:), [], @(x)x(end)).'`
ans =
11 12 13 14 15 16 17 18 19 20
最佳答案
我们可以使用sortrows
作为预处理步骤,首先对索引和相应的值进行排序,如其文档所述:
SORTROWS
uses a stable version of quicksort.
作为subs
中的下标应该根据它们的线性索引进行排序,我们需要按照字典序对它们进行排序。这可以通过在使用 sortrows
之前和之后翻转列顺序来实现。 .
这为我们提供了以下稳定版本的代码 accumarray
:
function A = accumarrayStable(subs, val, varargin)
[subs(:,end:-1:1), I] = sortrows(subs(:,end:-1:1));
A = accumarray(subs, val(I), varargin{:});
替代方案:
按照 Luis Mendo 的建议,而不是 sortrows
也可以从下标生成线性索引并使用 sort
相反。
function A = accumarrayStable(subs, val, varargin)
if numel(varargin)>0 && ~isempty(varargin{1})
sz = varargin{1};
else
sz = max(subs,[],1);
end
[~, I] = sort(subs*cumprod([1,sz(1:end-1)]).');
A = accumarray(subs(I,:), val(I), sz, varargin{:});
请注意,我们应该使用 1+(subs-1)*cumprod([1,sz(1:end-1)]).'
用于转换为线性索引。我们省略了 +1
和 -1
作为 sort
的结果还是一样;这为我们节省了几个周期。
上述解决方案中哪一个更快取决于您的机器和 MATLAB 版本。例如,您可以通过以下方式进行测试:
A = randi(10, 1e4, 5);
timeit(@()accumarrayStable(A(:,1:end-1), A(:,end), [], @(x)x(1))
关于matlab - MATLAB 中的稳定 accumarray,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28463433/
我有一个键值对列表,我想计算每个键出现的次数以及它出现的值,但是当我尝试时,我得到了堆栈溢出。这是我正在运行的代码的简化版本: import Array add (n, vals) val = n `
只要我理解了accumarray,它的意思就是“输出第n行:1)在sub中找到n。2)如果n在sub中的m1,m2,m3个元素中,3)将函数应用于m1,m2,m3 val 4) 的第一个元素,即输出的
我刚刚阅读了 accumarray 的文档,无法理解第二个示例。例子如下 val = 101:106'; subs = [1 1; 2 2; 3 2; 1 1; 2 2; 4 1] subs =
我想做的是:给定一个二维矩阵,获取每行中满足某些特定条件的元素的列索引。 例如,假设我的矩阵是 M = [16 2 3 13; 5 11 10 8; 9 7 6 12; 4 14 15 1] 我的条件
所以我目前正在使用“accumarray”来查找与匹配 ID 相对应的一系列数字的平均值。例如输入: ID----Value 1 215 1 336 1 123 2 1
简短版: 作为第四个参数传递给 accumarray 的函数有时被调用时使用的参数不一致与将第一个参数编码到 accumarray 的规范。 因此,用作 accumarray 参数的函数必须测试实际上
在accumarray()关于“subs”的第一个注释,首先出现在 MATLAB R14sp3 docs , 说: Note If the subscripts in subs are not sor
MATLAB 的 accumarray在许多应用程序中具有令人难以置信的强大功能。我的问题是,应用于输入的 accumarray 函数具有三个输出,而 accumarray 只能处理标量输出。例如,我
MATLAB 的内置函数 accumarray 接受函数 fun作为第四个参数。 A = accumarray(subs,val,sz,fun); 这适用 fun val 中元素的每个子集在 subs
accumarray 使用两行索引创建一个矩阵,其元素位于有效索引对的位置,并具有由指定函数分配的值,例如: A = [11:20]; B = flipud([11:20]); C = 1:10; d
我有两个数组: OTPCORorder = [61,62,62,62,62,62,62,62,62,62,62,62,65,65,...] AprefCOR = [1,3,1,1,1,1,1,1,1,
我对 Matlab 很陌生,但我对其他编程语言有一些经验。我在 Matlab 中有一个从 MySQL 导入的非常大的表。它作为元胞数组给出,看起来像这样: date key sales
我有一个向量和一个大小相同的元胞数组(带有重复字符串)。元胞数组定义组。我想在每个组的向量中找到最小/最大值。 例如: value = randperm(5) %# just an example,
我需要了解 accumarray 才能编写我真正需要的代码。 我试着去理解http://www.mathworks.co.kr/kr/help/matlab/ref/accumarray.html 大
accumarray()的 val 参数必须是向量。在我的例子中,我需要对矩阵的列进行求和(或平均)。是否有实现此目的的功能或方法? 我现在正在做的是在一个 for 循环中,我分别对列值求和: for
我正在寻找 MATLAB 的 accumarray 的快速解决方案在 NumPy 的。 accumarray 累积属于同一索引的数组元素。一个例子: a = np.arange(1,11) # arr
我有一个这样的矩阵: >>D=[1,0,10;3,1,12;3,1,12.5;6,1,6;6,2,11.1;] D = 1.0000 0 10.0000 3.0000 1.0
要明确的是,以下不是我的原始问题,它具有更大的数据,并且此代码位于更大的应用程序和代码库的上下文中。我已将我的工作缩减为最简单的示例,为了清晰和开发和单元测试,现在只是玩具或教学大小,因为这对这些目的
我们正在尝试理解 MATLAB 的 accumarray 函数,希望为我们的理解编写相同的 C/C++ 代码。有人可以帮助我们提供示例/伪代码吗? 最佳答案 根据 the documentation
让我调用函数 accumrArray。 accumrArray :: (e' -> e -> e) An accumulating function
我是一名优秀的程序员,十分优秀!