Unique concatenation of multi-dimensional cell arrays
3 visualizaciones (últimos 30 días)
Mostrar comentarios más antiguos
Milos
el 7 de Mzo. de 2023
Comentada: Stephen23
el 8 de Mzo. de 2023
I have 15, k x k x k cell arrays, stacked ontop of each other ,where each cell contians a row vector. I would like to concactenate each row vector living in the living the the same poisition cell for all 15 cell arrays such that each of the row vectors doesn't have any repetitions
For the sake of clarity, suppose we have only two cell arrays of size 3 x 3,
A(:,:,1) = {[1;2;3],[],[3];
[],[],[4];
[],[2;3],[]}
A(:,:,2) = {[2;3;4],[4],[3];
[],[],[4];
[],[2;4],[]}
%I'd like the output to be
C = {[1;2;3;4],[4],[3];
[],[],[4];
[],[2;3;4],[]}
%This is possible to do with a for loop where each step of the for loop
%looks like
C{i} = unique(cat(1,A{i},B{i}))
However, since k can be fairly large and vectors in each cell are very large this turns out to be very inefficent for me. I don't suppose anyone knows of a quick way to do this? Many Thanks.
Edit the uniqueness is no longer an issue since if say we are able to perform the concactenation to obtain;
D = {[1;2;3;1;2;3;4],[4],[3;3];
[],[],[4;4];
[],[2;2;3;4;4],[]}
C = cellfun(@(x)unique(x), D, 'UniformOutput', false);
What still remains unsolvable to me is how one could obtain D from A. I should add that I have tried
cat(1,A(:,:,1),A(:,:,2))
cat(2,A(:,:,1),A(:,:,2))
cat(3,A(:,:,1),A(:,:,2))
none of which yeild the desired result.
0 comentarios
Respuesta aceptada
Matt J
el 7 de Mzo. de 2023
A(:,:,1) = {[1;2;3],[],[3];
[],[],[4];
[],[2;3],[]};
A(:,:,2) = {[2;3;4],[4],[3];
[],[],[4];
[],[2;4],[]};
C = cellfun(@union,A(:,:,1),A(:,:,2),'UniformOutput',false)
Más respuestas (1)
Voss
el 7 de Mzo. de 2023
A(:,:,1) = {[1;2;3],[],[3];
[],[],[4];
[],[2;3],[]};
A(:,:,2) = {[2;3;4],[4],[3];
[],[],[4];
[],[2;4],[]};
C = cellfun(@(a,b)unique([a;b]),A(:,:,1),A(:,:,2),'UniformOutput',false)
2 comentarios
Stephen23
el 8 de Mzo. de 2023
"Do you have anysuggestions as to where I could read more about this?"
Ver también
Categorías
Más información sobre Loops and Conditional Statements en Help Center y File Exchange.
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!