Sort an Array with sortrows ( ) with two columns
이전 댓글 표시
Hey guys,
I'm sorting an 82x4 arraywith sortrows. I want it to be sorted in a descending way. First the second column shall be significant and for tiebreakers the third column.
My code is:
Knotenpaare=sortrows(Auswertung,[2 3],'descend')
where Auswertung is the array. The first 40 rows of the array are sorted beautifully. But at the moment the values in the second column switch from positive to negative the sorting changes.

Why are the values in the third column now ascending?
Is there a better way to sort these kinds of arrays ?
댓글 수: 7
Patrick Benz
2021년 2월 19일
dpb
2021년 2월 19일
Shouldn't matter, but try
Knotenpaare=sortrows(Auswertung,[2 3],{'descend','descend'})
just in case.
Attach the section of the data as a .mat file so folks can try to duplicate symptoms
Jan
2021년 2월 19일
@Patrick Benz: I assume also, that the equally looking numbers -1.0424 are not identical, if you consider all decimal places. Please post the data as MAT file. The 6 relevant rows are enough to finde the difference.
Stephen23
2021년 2월 19일
"The Values are exactly the same."
Until we test the actual data we have no reason to think that they are exactly the same values.
Please upload the data in a .mat file by clicking the paperclip button.
Patrick Benz
2021년 2월 24일
편집: Patrick Benz
2021년 2월 24일
dpb
2021년 2월 24일
"Is there an option to cut the number after 5 digits off? and not only visual."
node_Num=sign(node_Num).*floor(abs(node_Num)*1E5)/1E5;
채택된 답변
추가 답변 (1개)
the cyclist
2021년 2월 19일
1 개 추천
See my answer (and other comments) to this very similar question. (As with the comments above, the premise is that the displayed value is not sufficient to see a tiny difference between the numbers.)
카테고리
도움말 센터 및 File Exchange에서 Shifting and Sorting Matrices에 대해 자세히 알아보기
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!