Code for Base Matrix

3 visualizaciones (últimos 30 días)
Fayyaz
Fayyaz el 4 de Jul. de 2014
Editada: Andrei Bobrov el 4 de Jul. de 2014
Hello All.
I've a matrix, A=61312*3
1st column: from 1 to 246 (survey no, total 61312 surveys at 246 location, for a vehicle from origin to destination) 2nd column: from 1 to 81 (Origin) 3rd column: from 1 to 81 (Destination)
I need to create a base matrix (81*81) which shows the no. of vehicles among these origins and destinations.
Kindly help me out.

Respuesta aceptada

Andrei Bobrov
Andrei Bobrov el 4 de Jul. de 2014
Editada: Andrei Bobrov el 4 de Jul. de 2014
[a,~,ii] = unique(A(:,2));
[b,~,jj] = unique(A(:,3));
out1 = accumarray([ii,jj],A(:,1),[max(ii), max(jj)],@(x){x});
out = [[{nan};num2cell(a(:))],[num2cell(b(:)');out1]];
ADD
out1 = accumarray([ii,jj],1);
out = [[nan;a(:)],[b(:)';out1]];
  2 comentarios
Fayyaz
Fayyaz el 4 de Jul. de 2014
Thanks for this. Actually I need the total sum for each 1 to 81 origin and destination. Your code was OK for my previous link question, but unfortunately not for this. Can you check it again? or let me know if you didn't understand my question well.
Andrei Bobrov
Andrei Bobrov el 4 de Jul. de 2014
Hi Muhammad! Please try code after word ADD in this answer.

Iniciar sesión para comentar.

Más respuestas (0)

Categorías

Más información sobre Resizing and Reshaping 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