Unique not working - may be due to different datatypes in array

27 Ansichten (letzte 30 Tage)
After smoothing out the data from one array I end up with one containing the values shown below. I want to get rid of the duplicate values 7 and 4.6 however unique will not get rid of them. Is this due to the fact that these values are different data types to each other? Any help would be appreciated.
Array
1.40000000000000
6.20000000000000
4.60000000000000
4.60000000000000
3.40000000000000
3.80000000000000
7.00000000000000
7
3.40000000000000
4
4.40000000000000
2.80000000000000
3.20000000000000

Akzeptierte Antwort

Walter Roberson
Walter Roberson am 19 Aug. 2019
Those are not different datatypes.
When you see the same array displaying 7.00000000000000 and 7 both, then what it tells you is that the 7 value is exactly the floating point representation of 7, but that the 7.00000000000000 value is slightly different from 7 exactly. If you were to take Array(7) - Array(8) you would see a very small difference, probably roughly 2E-15 . The value that is exactly 7.0000000000000017763568394002504646778106689453125 displays as 7.00000000000000 in some cases because the default formats do not display all of the digits.
  5 Kommentare
Stephen23
Stephen23 am 19 Aug. 2019
Bearbeitet: Stephen23 am 19 Aug. 2019
You could also try uniquetol, which was designed to handle this situation.
BN
BN am 10 Mär. 2021
If any NaN values exist in rows, the unique function does not work (not eliminate parallel rows). I have this problem, so I converted NaN values to -99 using fillmissing, I use unique value again, and it's work.

Melden Sie sich an, um zu kommentieren.

Weitere Antworten (0)

Kategorien

Mehr zu Creating and Concatenating Matrices finden Sie in Help Center und File Exchange

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by