How to reduce time of calculation? (code includes 'for' loop with cell function)

1 visualización (últimos 30 días)
Hallo ;), Thanks in advance
I have a data table 'P' (2772774x17) and generated another table 'aT' where the length is the unique elments from column 1 of 'P' and unique values from column 2 of 'P' as width(header). My purpose is to count the occurence of column 2 values of 'P' for each column 1 unqiue values of 'P' and save the occurences in 'aT'. This takes a very long time. Is there a possiblity to do it in a different way to save the time. Code given below:
for i=1:length(uniqueP)
count_string = cellfun(@(x) sum(ismember(P.Typ(ismember(P.ProjektID,...
uniqueP(i)),:),x)), aT.Properties.VariableNames(2:end));
% Replacing rows of a table
aT(i,2:end) = num2cell(count_string);
end
  2 comentarios
Sergey Kasyanov
Sergey Kasyanov el 6 de Mayo de 2021
What data types are stored in P.ProjektID and P.Typ columns?
Kazi Alam
Kazi Alam el 6 de Mayo de 2021
Editada: Kazi Alam el 7 de Mayo de 2021
P.ProjektID >> double
P.Typ >> Cell

Iniciar sesión para comentar.

Respuesta aceptada

Kazi Alam
Kazi Alam el 7 de Mayo de 2021
I changed the data search order. Earlier, the code was checking the uniqueness of the duble array then the string array. Now, the process is reveresed and it saved me hours.

Más respuestas (0)

Categorías

Más información sobre Logical 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!

Translated by