number of values greater than zero in a large matrix
6 views (last 30 days)
Show older comments
I have a 900X25 matrix The matrix has rows of zeros with one or two numeric values. Some rows have all zeros. What I want to do is have Matlab go through each row of zeros and find the lowest numeric value in that row, or if there is all zeros in that row, then the code will just skip that row. I want the code to return a 1X25 or a 25X1 array which will let me know the number of times there was a numeric value in each column. And not counting the larger numbers if there were more than one number in a given row. Example of data:
Grandmatrix = 23 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 87 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 93 12 0 0 0 0 0 0 0 0 0 0 0 0 0
Reducedmatrix = 1 0 0 0 0 0 0 0 0 0 0 1 0 0 1 0 0 0 0 0 0 0 0 0 0
4 Comments
Sean de Wolski
on 18 Jun 2012
Andrei and I are clearly missing the point. ZCould you give us a small example (3x3 maybe) and explain.
Answers (3)
Andrei Bobrov
on 18 Jun 2012
Reducedmatrix = any(Grandmatrix);
or?
Reducedmatrix = sum(Grandmatrix~=0);
0 Comments
Walter Roberson
on 18 Jun 2012
sum(GrandMatrix == repmat( min(GrandMatrix,2), 1, size(GrandMatrix,2) ))
2 Comments
Walter Roberson
on 19 Jun 2012
Dang, I keep forgetting about the other argument to min()
sum(GrandMatrix == repmat( min(GrandMatrix,[],2), 1, size(GrandMatrix,2) ))
See Also
Categories
Find more on Resizing and Reshaping Matrices in Help Center and File Exchange
Products
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!