Sum of a list of numbers if they're a certain value or not

24 views (last 30 days)
I have a list of numbers, and I'm trying to determine the sum of all of the numbers that have a value less than 55. I know that this will involve some sort of logic set-up, but I'm not familiar with how to set it up exactly. Any help is really appreciated.

Accepted Answer

bym
bym on 4 Dec 2011
Or even (without using sum)
x.'*(x<55)
[edit]
for x being a matrix
x = randi(100,20,20);
sx = x(:).'*(x(:)<55);
  4 Comments
Daniel
Daniel on 5 Dec 2011
Thank you! Worked like a charm. Can you explain what the code is doing though? I really appreciate it.
bym
bym on 5 Dec 2011
reading from left to right the line x(:).'*(x(:)<55);
x(:) returns all elements of x in a column (see doc colon)
.' transposes x(:)from column to row
* is matrix multiply
(x(:)<55) returns a column of 1's & 0's (1 is true x(n),55)
in summary, you are transforming the matrix in to 1 row and matrix multiplying it by a column of boolean values generated by the logical test. The addition is implicit in the matrix multiply

Sign in to comment.

More Answers (2)

bym
bym on 4 Dec 2011
x=randi(100,20,1);
sx = sum(x(x<=55))

Walter Roberson
Walter Roberson on 4 Dec 2011
Alternatives:
sum(x .* (x <= 55))
or
sum(x(find(x<=55)))
  8 Comments
Image Analyst
Image Analyst on 5 Dec 2011
No, that's not it. It works just fine with <=. I just changed it to less than because that's what you said. But <= will also work fine - just try it. There must have been some other reason that you're not telling us and we don't know because you didn't share your code.
Jan
Jan on 6 Dec 2011
@Walter: What about logical indexing? FIND is not useful here:
sum(x(x<=55))

Sign in to comment.

Categories

Find more on Matrices and Arrays 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!