# How to: sum up elements of a row vector into bins of a matrix

5 views (last 30 days)

Show older comments

Hello,

so I've got a matrix and bin index vectors from histcounts2; I've binned some data over a sphere.

[N,~,~,bx,by]=histcounts2(dataX, dataY, (0:5:180)', (0:5:355)' );

I have another row vector, power, that is equal in length with dataX, dataY, so the bx and by can be used to collect data from this power vector.

Question is, how do I use the bx and by, to generate a matrix out of the power vector, which equals N in size and in terms of the number of elements within bins, but the bin value should be the sum of the elements dedicated for this bin and collected from the power vector?

No loops please.

Thanks,

Tero

##### 0 Comments

### Accepted Answer

Cris LaPierre
on 15 Jan 2021

Edited: Cris LaPierre
on 15 Jan 2021

With a little creativity, you can use groupsummary. Since you haven't shared enough of your code to use that for an example, here's one modified from an example on the histcount2 documentation page.

% Set up the data

x = randn(100,1);

y = randn(100,1);

[N,~,~,bx,by] = histcounts2(x,y);

% create a 3rd vector, pwr

pwr = randn(100,1);

% Sum the data by grouping pwr by bin numbers by and bx.

% Sum data in the same group.

% Include data for all possible bins

[P,G,C] = groupsummary(pwr,[by,bx],'sum',"IncludeEmptyGroups",true,"IncludeMissingGroups",true);

% Reshape the data to be the same size an N

p = reshape(P,size(N))

N % compare to verify that when N==0, P==0.

##### 2 Comments

Cris LaPierre
on 18 Jan 2021

### More Answers (0)

### See Also

### Categories

### Community Treasure Hunt

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

Start Hunting!