Sum all negative values in a matrix

8 views (last 30 days)
I have a matrix that is 400x95. I would like to sum all the negative values in each column and divide this by the sum of all the positive values in the same column to yield a new vector that is essentially 1x95. Any help is much appreciated!

Accepted Answer

John D'Errico
John D'Errico on 1 Jun 2015
Edited: John D'Errico on 1 Jun 2015
Too trivial?
sum(A.*(A < 0),1)./sum(A.*(A > 0),1)
The point is, to learn to start to think in terms of matrices and vectors, and operations on those objects.
Of course, be careful if there are no positive elements in a column of the array. In that case, you will get either an Inf or NaN result, depending on if there are any negative values in that column.
  2 Comments
Joseph Cheng
Joseph Cheng on 1 Jun 2015
2nd method would used the 2nd input parameter in max() and min().
x = magic(10)-50;
rat = sum(min(x,0))./sum(max(x,0))
John D'Errico
John D'Errico on 1 Jun 2015
Another good way. There are always so many ways to solve a problem like this, once you start thinking in terms of arrays.

Sign in to comment.

More Answers (0)

Community Treasure Hunt

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

Start Hunting!