Problem with intersect function?
6 visualizaciones (últimos 30 días)
Mostrar comentarios más antiguos
Nicolson
el 4 de Oct. de 2017
Comentada: Nicolson
el 4 de Oct. de 2017
I am writing a matlab programm to import xls files from local and do some calculations. These xls files alwasys have four cloummns but different number of rows, each colummn from left to right is considered as a, b,c and d. And my code need to compare two adjacent rows, when they meet some conditions, put results in a matrix. I am using a nested loop to compare rows, and use intesect command to keep the order of the matrix and suppress repeated rows. But here is the problem, because intersect function will suppress repeated rows for each matrix before compare the value, so if there are repeated rows in the original data, my code will fail. Any advice? Thanks.
[vert,horz]=size(data);
for ii=1:vert-1;
for jj=ii+1:vert;
if data(ii,1)+data(jj,1)-data(ii,2)-data(jj,2)+data(ii,3)+data(jj,3)-data(ii,4)-data(jj,4)<10;
result=[data(ii,1),data(ii,2),data(ii,3),data(ii,4);data(jj,1),data(jj,2),data(jj,3),data(jj,4);result]
end
end
end
result=intersect(data,result,'stable','rows');
1 comentario
Jan
el 4 de Oct. de 2017
Editada: Jan
el 4 de Oct. de 2017
I have edited you code to format the code. Please use the "{} Code" button the next time - thank you.
As far as I understand, it does not matter, that the data are coming from an Excel file and the pre-sorting in the nested loop is not a problem also. So all you are asking for is using intersect with keeping repeated rows of the inputs? But what do you expect as output then? This is not uniquely defined.
Respuesta aceptada
Jan
el 4 de Oct. de 2017
Editada: Jan
el 4 de Oct. de 2017
Perhaps you want:
index = ismember(data, result, 'stable', 'rows');
result = data(index, :); % [EDITED, Typo fixed]
This keeps the repetitions in the matrix data. Or do you want to keep the repetitions in the first version of result? Or both?
Perhaps it helps to post a short example.
4 comentarios
Jan
el 4 de Oct. de 2017
There was a typo in my code. You need data(index, :), not data(ismember, :). I should drink a coffee before answering.
Again: A short example would help to understand, what you want. Follo9wing your description, the two parts of the result:
p1 = result(:, 1:2)
p2 = result(:, 3:4)
would be identical. Is this really wanted and useful? If so:
index = ismember(data, result, 'stable', 'rows');
result = [data(index, :), data(index, :)];
Or do you want to keep all rows, which appear in the other matrix? But then it is not guaranteed, that the number of rows is the same:
data = [1,2,3; 2,3,4; 1,2,3];
result = [1,2,3; 1,2,3; 1,2,3; 4,5,6];
What is the wanted result now?
Más respuestas (0)
Ver también
Categorías
Más información sobre Creating and Concatenating Matrices 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!