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

27 Ansichten (letzte 30 Tage)
Daniel
Daniel am 4 Dez. 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.

Akzeptierte Antwort

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

Melden Sie sich an, um zu kommentieren.

Weitere Antworten (2)

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

Melden Sie sich an, um zu kommentieren.


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

Melden Sie sich an, um zu kommentieren.

Kategorien

Mehr zu Matrices and Arrays finden Sie in Help Center und File Exchange

Produkte

Community Treasure Hunt

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

Start Hunting!

Translated by