Concatenating cells according an external vector

3 visualizaciones (últimos 30 días)
Milos
Milos el 4 de Mzo. de 2023
Comentada: Milos el 4 de Mzo. de 2023
I am trying to do some work on simulating particles. We label the particles say 1 to n. In each time frame there is a chance that particle i undergoes more than one collision and I'd like to capture this data in an easy way. I have two vectors A and B, where B is in ascending order. The rule is that the particle whose number is given by B(i) collides with particle A(i).
Typicall example might be
A = [7;3;4;13;20;3;1]
B = [11;11;11;15;15;24;24]
I'd like to find an easy way of being able to draw in the data that tells me which particle hit particle B(i) for each unque B(i). My idea is to creat a cell that concactenates entries of A accoriding to the corrresponding entry of B. But I can't seem to do this.
What I hope to get would be a cell
E = {[7,3,4];[13,20];[3,1]}.
I tried the follwing code but I keep getting that "Index exceeds the number of array elements." error.
m = length(unique(B))
E = cell(1,m)
C = unique(B)
for i=1:m %C(i) is the ith unique entry of B
while B(j) == C(i)
E{i} = cat(2,E{i},A(j));
end
end

Respuesta aceptada

Matt J
Matt J el 4 de Mzo. de 2023
Editada: Matt J el 4 de Mzo. de 2023
A = [7;3;4;13;20;3;1];
B = [11;11;11;15;15;24;24];
E=splitapply(@(x) {x}, A, findgroups(B));
E{:}
ans = 3×1
7 3 4
ans = 2×1
13 20
ans = 2×1
3 1
  6 comentarios
Dyuman Joshi
Dyuman Joshi el 4 de Mzo. de 2023
Editada: Dyuman Joshi el 4 de Mzo. de 2023
You mentioned in your question -
"What I hope to get would be a cell"
E = {[7,3,4];[13,20];[3,1]}
E = 3×1 cell array
{[7 3 4]} {[13 20]} {[ 3 1]}
Here each cell elements are row vectors not column vectors as they should be as A is a column vector. (which could have been a typo)
Milos
Milos el 4 de Mzo. de 2023
Ahh yes I see now. I am quite new to coding and didn't notice this subtlety. I happens that it didn't make a difference to my proceeding code. Thank you for your help!

Iniciar sesión para comentar.

Más respuestas (0)

Categorías

Más información sobre Creating and Concatenating Matrices en Help Center y File Exchange.

Etiquetas

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by