for loops for two variables (not nested loop)

I've a .dat file with 73280 length. i'm trying to find mean of first 100 values, then mean of 101 to 200 values, then 201 to 300 and so on until last 100 values. 1st error i got was "Index exceeds matrix dimensions." I rounded off the length to 73200 and got rid of this problem.
x = [];
y = rms (a1,100); %a1 is original data
b= length(y);
c= b/100;
for i =1:100:b
x= [mean(y(i:i+99))]
end
subplot (2,2,1); plot (t1, a1)
subplot (2,2,2); plot (x)
subplot (2,2,3); plot (t1,y)
the value of "x" is updating in every iteration. what i want is to store the every value of "x" and then plot it.

1 Comment

when I try to apply another for loop,
x = [];
y = rms (a1, 100);
b= length(y);
c= b/100;
for i =1:100:b, j=1:c;
x= [mean(y(i:i+99))]
end
subplot (2,2,1); plot (t1, a1)
subplot (2,2,2); plot (x)
subplot (2,2,3); plot (t1,y)
it actually becomes nested loop, which i dont want

Sign in to comment.

 Accepted Answer

A loop is not required. Just use reshape. Then you can plot them all at one too!
>> N = 100;
>> V = rand(1,73280); % your data vector
>> Z = N*fix(numel(V)/N);
>> M = mean(reshape(V(1:Z),N,[]),1);
>> plot(M)

1 Comment

Hi Stephen...... thanks for reply... what if i dont know the size of a file (n above case "73280")????? actually i have over over 225 files hence cannot look at each file everytime i'm going to process it.

Sign in to comment.

More Answers (1)

You can use
x=[x mean(y(i:i+99))];

1 Comment

i'm using the same thing, Sir.... but cant get the desired result

Sign in to comment.

Categories

Find more on Programming in Help Center and File Exchange

Asked:

on 30 Nov 2017

Edited:

on 18 Jan 2018

Community Treasure Hunt

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

Start Hunting!