Removing zeros that may be in columns or rows, in efficient fast way

3 views (last 30 days)
Greetings:
I have some matrices in a big computaion task. Some of these matrices will have zero rows or zero columns as part of them. I can't decide in priori.
We want an efficient way to remove any whole zero row or whole zero column from any matrix that may appear during the computation.
The methods I found, to my knowledge, are all:
1- require a priori knowledge of : Are there whole zero rows or whole zero columns?
2- require knowledge of the required dimensions of the output matrix after zeros removal.
These two pieces of information are not available.
Example:
If computations yield X = [ 0 0 0 ; 1 1 1; 2 2 2 ] , make it X = [1 1 1; 2 2 2]
If they yield Y = [0 1 2; 0 1 2 ; 0 1 2] make it [1 2; 1 2 ; 1 2] and so on..
We don't know if the zeros appear on rows or columns. We don't know the number of zero rows or columns.
Any ideas?

Accepted Answer

Voss
Voss on 10 Dec 2021
X(:,~any(X,1)) = []; % remove columns which are all 0
X(~any(X,2),:) = []; % remove rows which are all 0
or an equivalent but maybe more clear way:
X(:,all(X == 0,1)) = []; % remove columns which are all 0
X(all(X == 0,2),:) = []; % remove rows which are all 0

More Answers (1)

Image Analyst
Image Analyst on 10 Dec 2021
Try this (untested)
X = [ 0 0 0 ; 1 1 1; 2 2 2 ]
X = 3×3
0 0 0 1 1 1 2 2 2
rowsToRemove = all(X == 0, 2);
X(rowsToRemove, :) = [];
columnsToRemove = all(X == 0, 1);
X(:, columnsToRemove) = []
X = 2×3
1 1 1 2 2 2
Y = [0 1 2; 0 1 2 ; 0 1 2]
Y = 3×3
0 1 2 0 1 2 0 1 2
rowsToRemove = all(Y == 0, 2);
Y(rowsToRemove, :) = [];
columnsToRemove = all(Y == 0, 1);
Y(:, columnsToRemove) = []
Y = 3×2
1 2 1 2 1 2
  3 Comments
Image Analyst
Image Analyst on 11 Dec 2021
Yes, he posted his answer (essentially the same answer) just two minutes after mine. We were probably composing our answers at the same time. His second code sample is probably the more efficient one. Personally I think mine is less cryptic because I used well-named intermediate variables which will make it more maintainable should you pass the code on to others. Though he did use comments which will help make it less cryptic. Maybe you can at least "Vote" for mine.
I'm not sure what you're saying in your second paragraph. It takes however long as it takes, but it should be pretty fast, at least for matrices that are a few thousand rows or columns. How big are yours? Do they have millions of rows and columns?
Mohamed Abd El Raheem
Mohamed Abd El Raheem on 11 Dec 2021
Edited: Mohamed Abd El Raheem on 11 Dec 2021
No, my matrices are not that big. But the process of zeros deletion may repeat in nested loops, over matrices that may be thousands of rows or columns. That's why I care about time.
I accepted Benjamin answer, and tried to accept yours also. I thought it was possible to accept the two answers. Now I noticed the vote button and pressed it. Your answer is certainly appreciated.
Thank you!

Sign in to comment.

Categories

Find more on Loops and Conditional Statements in Help Center and File Exchange

Community Treasure Hunt

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

Start Hunting!