Problem 904. Unique: Faster 'rows' for large array of uint8
Challenge: Execute unique(a,'rows') Faster for 'a' being uint8.
The "unique" function for the 'rows' options may be performed 10X more quickly for arrays of large rows, few columns, and of type uint8 (or values <256).
Input: c=randi(4,6000000,16,'uint8')-1;
Output: unique(c,'rows') or equivalent
Scoring: Time in milli-seconds
Hints:
- unique can sort a single column >10X faster than an array of rows
- 10X improvement is applicable to arrays where rows can be represented as a uint32 value
- 5X improvement occurs where arrays require uint64 representation
Solution Stats
Problem Comments
-
1 Comment
If your purpose is to compare the efficiency, I recommend you to use tic/toc or timeit instead of clock/etime. The clock function measures the operating system time which is less reliable as compared to tic/toc measurements.
Solution Comments
Show commentsProblem Recent Solvers22
Suggested Problems
-
Find state names that end with the letter A
1185 Solvers
-
Check to see if a Sudoku Puzzle is Solved
322 Solvers
-
All your base are belong to us
543 Solvers
-
Back to basics 8 - Matrix Diagonals
926 Solvers
-
Set the array elements whose value is 13 to 0
1373 Solvers
More from this Author308
Problem Tags
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!