Azzera filtri
Azzera filtri

How to calculate the mean from cell when each cell is a different double.

1 visualizzazione (ultimi 30 giorni)
Hi Im reading excel files and storing them into data{k} so my data is 1x34 cell and each cell is a double, with variable column number and fixed row 13, now i want to calculate mean of 34 files for column and row 1 and do the same for the rest.I tried cell2mat but this doesnt work as i have different values for columns.
folder='E:\Engine image\E100 cycles\All Excel Files';
filetype='*.xlsx';
f=fullfile(folder,filetype);
d=dir(f);
for k=1:numel(d);
data{k}=xlsread(fullfile(folder,d(k).name));
end

Risposta accettata

Andrei Bobrov
Andrei Bobrov il 22 Ago 2016
Modificato: Andrei Bobrov il 22 Ago 2016
EDIT
m = numel(data);
[ii,~]= cellfun(@size,data);
a = nan(max(ii),size(data{1},2),m);
for jj = 1:m
a(1:ii(jj),:,jj) = data{jj};
end
out = nanmean(a,3);
  1 Commento
mohsen moslemin
mohsen moslemin il 22 Ago 2016
i think this makes it easier to explain i have 34 excel like this what i want is to read them all, what ive done so far now i want to average each value from 34 data, eventually i should have same matrix but each value is the average of 34 values.

Accedi per commentare.

Più risposte (1)

Azzi Abdelmalek
Azzi Abdelmalek il 22 Ago 2016
cellfun(@(x) mean(x,2),data,'un',0)
  5 Commenti
Azzi Abdelmalek
Azzi Abdelmalek il 22 Ago 2016
Modificato: Azzi Abdelmalek il 22 Ago 2016
This is not clear, to make your problem clear, you can post a short example, and also post the expected result, you haven't specified clearly what mean we have to calculate. You said also, that your matrices are not the same sizes
mohsen moslemin
mohsen moslemin il 22 Ago 2016
Azzi abdelmalek, thanks for your comments sorry this is actually m first time in here so i apologize if something wasn't clear enough.

Accedi per commentare.

Prodotti

Community Treasure Hunt

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

Start Hunting!

Translated by