apply function along dimension
23 visualizaciones (últimos 30 días)
Mostrar comentarios más antiguos
Daniele Rocchetta
el 6 de Jul. de 2016
Editada: Daniele Rocchetta
el 7 de Jul. de 2016
Hi,
I am trying to find a way to determine if all elements in a hyperplane of an n-dimensional array are NaNs. To exemplify, with a 4-D array of size (3,5,2,7), I would like to determine along dimension 2 which of the 5 sub-arrays (hyperplanes) of size (3,1,2,7) are filled with just NaNs. The result should be a 5 elems vector (the size of the original array along dimension 2) containing true or false depending on whether there are just NaNs or not in the corresponding sub-array. The for loop answer would be
% A = <3,5,2,7>
z = false(size(A,2),1);
for i = 1:size(A,2)
% turning each sub-array in a column vector and perform the check
z(i) = all(isnan(reshape(A(:,i,:,:),prod(size(A(:,i,:,:))),1)));
end
Since the arrays I work with are quite large this seems impractical, plus the dimension along which to perform the check is not given at the outset, but itself an argument of the function (i.e. A(:,i,:,:) would not work, because it should be A(:,:,i,:) if the check was performed along dimension 3). I think bsxfun and/or arrayfun could help in this regard, but their complex implementation doesn't help. Any suggestions on how this might be achieved?
Thanks in advance
Dan
0 comentarios
Respuesta aceptada
James Tursa
el 6 de Jul. de 2016
Editada: James Tursa
el 6 de Jul. de 2016
Does this do what you want?
% x = nD array, k = dimension to check for all NaN's per plane
function result = nanplane(x,k)
z = 1:numel(size(x));
X = permute(x,[z(k) z(1:k-1) z(k+1:end)]);
X = reshape(X,size(X,1),[]);
result = all(isnan(X),2);
end
3 comentarios
James Tursa
el 7 de Jul. de 2016
Editada: James Tursa
el 7 de Jul. de 2016
If you are working with very large arrays, it might be a bit faster to do the isnan part first. That way the permute would be working with 1-byte data instead of 8-byte data and the memory copies involved might be a bit quicker to accomplish. E.g. something like this (CAUTION: untested):
% x = nD array, k = dimension to check for all NaN's per plane
function result = nanplane(x,k)
N = isnan(x); % <-- do the isnan first
z = 1:numel(size(x));
N = permute(N,[z(k) z(1:k-1) z(k+1:end)]); % <-- permute the 1-byte data
N = reshape(N,size(N,1),[]);
result = all(N,2);
end
Más respuestas (1)
Daniele Rocchetta
el 6 de Jul. de 2016
Editada: Daniele Rocchetta
el 6 de Jul. de 2016
0 comentarios
Ver también
Categorías
Más información sobre Matrix Indexing en Help Center y File Exchange.
Productos
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!