My question is:
I have an array with values ranging from 0 to 200 something, and I need to find the average value for a set range of the data i.e. I need to find the average value for 0 to 1, the average value of the data for 1-2, and so on until it hits the end. I would like to save that information in a new matrix that I can look up later on.
Any help is appreciated.

2 Kommentare

James Tursa
James Tursa am 23 Mär. 2016
What about the boundary points? E.g., if a value is exactly 1, do you want it to be part of the 0-1 average and also the 1-2 average? Or do you want these averages to be mutually exclusive?
KK
KK am 23 Mär. 2016
I suppose the range should be greater than the lower bound, less than or equal to the upper bound. I'll have to try out your method.

Melden Sie sich an, um zu kommentieren.

 Akzeptierte Antwort

Image Analyst
Image Analyst am 24 Mär. 2016

0 Stimmen

If you have the Statistics and Machine Learning Toolbox, you can use grpstats(). It's a single line of code:
% Create sample data
r = 200 * rand(100000, 1);
% Now find means in every integer range.
means = grpstats(r, floor(r))

4 Kommentare

KK
KK am 24 Mär. 2016
That may have worked like a charm, thank you very much. That was simple too!
Image Analyst
Image Analyst am 24 Mär. 2016
Bearbeitet: Image Analyst am 26 Mär. 2016
One point to note is that if there are absolutely no means in some range, then that element will be missing from means. So just be aware of that.
KK
KK am 26 Mär. 2016
Is there a way to save the values used for each mean in an array so that I may apply further operations to that information?
Image Analyst
Image Analyst am 26 Mär. 2016
In my code above, means is already an array. Do you mean like an array of those arrays? Like you want a 2D array or an array of structures?

Melden Sie sich an, um zu kommentieren.

Weitere Antworten (1)

James Tursa
James Tursa am 23 Mär. 2016
Bearbeitet: James Tursa am 23 Mär. 2016

0 Stimmen

Does something like this do what you want?
n = ceil(max(values));
x = bsxfun(@ge,values(:),0:n-1) & bsxfun(@le,values(:),1:n);
averages = sum(bsxfun(@times,values(:),x)) ./ sum(x);
averages(isnan(averages)) = 0;

1 Kommentar

KK
KK am 24 Mär. 2016
The ceil function is pretty cool. I like the idea of using the bsxfun, but how would I be able to calculate the average for the data with a value between 0 and 1, or 1 to 2 (and so on), using this function, for all the values in the array?

Melden Sie sich an, um zu kommentieren.

Gefragt:

KK
am 23 Mär. 2016

Kommentiert:

am 26 Mär. 2016

Community Treasure Hunt

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

Start Hunting!

Translated by