How do I get the sum of the averages for a specific time step?

I am using: mean_time = sum(mean(mean(mean(total)))); to get the sum of the averages of a 4D matrix. How do I change this to get the sum for a specific timestep? For example, if I wanted timestep 5 or 8 specifically rather than the sum of the entire thing (which is what the above does).

2 Commenti

In which of the 4 dimensions are the time steps?
When you calculate mean(total) you are taking the mean across the first dimension. So when you calculate mean(mean(total)), you are calculating the first dimension of the mean(total) array. To demonstrate that, see how the size of each dimension changes after each mean:
K>> size(total)
ans =
4 4 4 4
K>> size(mean(total))
ans =
1 4 4 4
K>> size(mean(mean(total)))
ans =
1 1 4 4
K>> size(mean(mean(mean(total))))
ans =
1 1 1 4
If you were to use squeeze() in each of the steps above you'd see the number of dimensions decrease at each step.
If you want to take the mean over a dimension other than the first, use the second input to mean(). To answer your question, it depends upon which dimension describes the time steps.
The time steps are the 4th dimension. So if I want the sum average of the last timestep (# 588) I would use squeeze(sum(mean(mean(mean(total))))? How do I limit it to just the 588th time step?

Accedi per commentare.

Risposte (2)

In your 4D array, if the 4th dim is time and you'd like to isolate all data from the 588th time step,
time588 = total(:,:,:,588);
which is now a 3D array of size
size(time588)
I'm not sure of your averaging methods but if you're executing
mean(mean(time588))
Then you're averaging across the 1st dimension, then averaging the averages across the 1st dimension again; all for data from time step 588.

4 Commenti

So this is the sum for the 588th timestep over all other dimensions then?:
time588 = total(:,:,:,588); sumof=sum(squeeze(mean(mean(time588)))));
If
No, the sum of the 588th timestep over all other dims is
sum588 = sum(time588(:));
What you're doing is the sum of the means of the means over the first dimension of all data pertaining to time step 588.
And you've got one too many ')' at the end.
Thanks!! If I wanted the last full year rather than just the last month (so time step 168-180) is there a way to do this within that single line?
time588 = total(:,:,:,168:188);

Accedi per commentare.

Richiesto:

il 29 Giu 2018

Risposto:

il 4 Lug 2018

Community Treasure Hunt

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

Start Hunting!

Translated by