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

26 次查看(过去 30 天)
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

采纳的回答

Walter Roberson
Walter Roberson 2019-8-19
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 个评论
BN
BN 2021-3-10
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.

请先登录,再进行评论。

更多回答(0 个)

类别

Help CenterFile Exchange 中查找有关 Creating and Concatenating Matrices 的更多信息

Community Treasure Hunt

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

Start Hunting!

Translated by