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

27 vues (au cours des 30 derniers jours)
Daniel
Daniel le 4 Déc 2011
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.

Réponse acceptée

bym
bym le 4 Déc 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 commentaires
Daniel
Daniel le 5 Déc 2011
Thank you! Worked like a charm. Can you explain what the code is doing though? I really appreciate it.
bym
bym le 5 Déc 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

Connectez-vous pour commenter.

Plus de réponses (2)

bym
bym le 4 Déc 2011
x=randi(100,20,1);
sx = sum(x(x<=55))
  2 commentaires
Daniel
Daniel le 4 Déc 2011
This didn't work. Should I mention that the list of numbers are in matrix form?
Walter Roberson
Walter Roberson le 4 Déc 2011
sx = sum(x(x(:) <= 55));

Connectez-vous pour commenter.


Walter Roberson
Walter Roberson le 4 Déc 2011
Alternatives:
sum(x .* (x <= 55))
or
sum(x(find(x<=55)))
  8 commentaires
Image Analyst
Image Analyst le 5 Déc 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 le 6 Déc 2011
@Walter: What about logical indexing? FIND is not useful here:
sum(x(x<=55))

Connectez-vous pour commenter.

Catégories

En savoir plus sur Matrices and Arrays dans Help Center et File Exchange

Produits

Community Treasure Hunt

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

Start Hunting!

Translated by