loop to identify new particles
Mostrar comentarios más antiguos
I have the particle Id and y coordinates for every particle in my model over 3000s.
My loop currently tells me how many grains in each second have y coordinates <-0.13 and sums this in the variable 'grains'. This loop includes all the grains <-0.13, even if they have already been included in prevoius time steps.
I want the loop to only include new grains to get mass efflux per second that is not cumulative, and I want it to use the particle ID to do this. For example if particle 2 was included in time step 2, do not include in time step 2.
Can anybody help?
ymax = -0.13;
for b = 1:length(particledata)
%save all the rows in the 1st and 6th column (ID and y-coordinates) of each cell as a new variable y
y{b} = particledata{b}(:,[1 6]);
%use the function table2array to turn the format of the data from a table to an array
y_array{b} = table2array(y{b});
%sum the total number of grains with y coordinate <-0.13 in each cell, and save into a new variable 'grains'
grains{b} = sum(y_array{b}(:,2)<ymax);
fprintf('A total of %d grains left the rice pile\n',grains{b});
end
Respuestas (1)
Anmol Dhiman
el 28 de En. de 2021
Editada: Anmol Dhiman
el 28 de En. de 2021
Hi Chloe,
Assuming you have all the data in an array format. Follow the below instructions
% outside the loop
temp = [];
% Inside the loop after y_array{b} = table2array(y{b}); statement
temp2 = setdiff(y_Array{b}(:,2),temp);
grains{b} = sum(temp2<ymax);
temp = [temp temp2];
Hope it helps
5 comentarios
C.G.
el 28 de En. de 2021
Anmol Dhiman
el 29 de En. de 2021
Hi Chloe,
It doesnot matter, the error is coming in
temp = [temp temp2];
would you mind sharing the dimensions of the temp and temp2 variables in your case
C.G.
el 29 de En. de 2021
Anmol Dhiman
el 29 de En. de 2021
Use temp = [temp ; temp2]; It will work
Thanks
C.G.
el 29 de En. de 2021
Categorías
Más información sobre Particle & Nuclear Physics en Centro de ayuda y File Exchange.
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!