Filter löschen
Filter löschen

How to create a loop generating bins for the group of data in cell array

2 Ansichten (letzte 30 Tage)
Hi everyone,
I am a newby to MathLab and I need some help from the community.
I am trying to figure out how to loop a simple histcounts function.
I have a data set which I separtated into cell arrays with accumarrays
So now I have a cell array GC{121:1} which contain 121 separate matrixes (double values). Each of those matrixes has 2 columns and diferent numer of rows (2 x n matrix ).The first colunm is the number of slice indicating were data were extracted from.
I would like to split each matrix into 10 equal bins by the second column. So far I got to this:
But the loop I wrote dose not work
GC = accumarray(data(:,1),(1:size(data,1)),[],@(x){data(x,:)});
% Distribute x_point column into 6 equally spaced bins..
for i=1:121
[N,edges] = histcounts(GC{i,1},10);
end
  3 Kommentare
Iuliia Myrgorodska
Iuliia Myrgorodska am 25 Apr. 2020
Yes,
that's exactly the problem I have. Do you know how can I fiix this?
Iuliia Myrgorodska
Iuliia Myrgorodska am 25 Apr. 2020
How can I save the result in another set of cel arrys? so that I get the results from all iteration as one set?

Melden Sie sich an, um zu kommentieren.

Akzeptierte Antwort

Sriram Tadavarty
Sriram Tadavarty am 25 Apr. 2020
Hi Luliia,
The problem here is that the variables N and edges are overwritten with the latest value each time in the for loop.
You can try the following:
GC = accumarray(data(:,1),(1:size(data,1)),[],@(x){data(x,:)});
% Distribute x_point column into 6 equally spaced bins..
N = cell(1,121);
edges = cell(1,121);
for i=1:121
[N{i},edges{i}] = histcounts(GC{i,1},10);
end
% To access the first value in N, it can be done through N{1}
Hope this helps.
Regards,
Sriram

Weitere Antworten (0)

Kategorien

Mehr zu Creating and Concatenating Matrices finden Sie in Help Center und File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by