Azzera filtri
Azzera filtri

mean without stable step

3 visualizzazioni (ultimi 30 giorni)
Fani
Fani il 25 Set 2014
Risposto: Fani il 25 Set 2014
Hi all! I need your help please!
my data are 3033 lines and 2005 columns. I want to find the mean for all columns separately but the step in lines is different. For example, i want to find the mean for the first 167 lines, then from 168 to 294, 295 to 428 and so on. what code can i write?
Thank you!

Risposta accettata

Fani
Fani il 25 Set 2014
This works perfect!!!
Thank you very much for your time!!!

Più risposte (3)

Mikhail
Mikhail il 25 Set 2014
You can write a=mean(M,2) - this will find mean of matrix M along each column. And then take only values you need. For 3033*2005 this is ok.
  2 Commenti
Mikhail
Mikhail il 25 Set 2014
Sorry, for columns use a=mean(M), or a=mean(M,1)
Mikhail
Mikhail il 25 Set 2014
Otherwise you can do it with for loop

Accedi per commentare.


Fani
Fani il 25 Set 2014
In the same column the step is different. For example, in the first column i want to find mean for the first 167 lines, then from 168 to 294,295 to 459 and so on. And this for all columns.
  1 Commento
Mikhail
Mikhail il 25 Set 2014
ok, so you create vector containing number of lines you want to take: a=[1:167,168...].
If you want to take into account only this lines for all columns, you can make new matrix: N=M(a,:). The new matrix contains only lines you need. And use mean.

Accedi per commentare.


Fani
Fani il 25 Set 2014
if i do this, i take mean for all these lines. I would like to take mean for 1:167, other mean for lines 168:294 and so on.

Categorie

Scopri di più su Creating and Concatenating Matrices in Help Center e File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by