Sum through an array until a value is reached, then continue

10 views (last 30 days)
Assume you have 2 arrays x = linspace(0.001,0.005,1000); y = linspace(0,1,1000);
I want to start at the beginning of x, and sum consecutive columns until the sum = 0.1, then take the average of y across that range.... then continue doing this until the end of x
  6 Comments
Bruno Luong
Bruno Luong on 2 Nov 2018
Edited: Bruno Luong on 2 Nov 2018
"With the values given, the first 100 columns would sum to 0.1"
No body know where the 100 comes from. Anyone is guessing and people just wastes theirs times for you.
Not give example is better than give one that doesn't make sense.

Sign in to comment.

Accepted Answer

Matt J
Matt J on 2 Nov 2018
Edited: Matt J on 2 Nov 2018
c=cumsum(x);
G=discretize(c, 0:0.1:c(end));
result = splitapply(@mean, y, G),

More Answers (2)

madhan ravi
madhan ravi on 2 Nov 2018
Edited: madhan ravi on 2 Nov 2018
mean(y(cumsum(x)<=0.1))
  8 Comments

Sign in to comment.


Guillaume
Guillaume on 2 Nov 2018
sumx = cumsum(x);
meanybelowthreshold = mean(y(sumx <= 0.1));
meanyabovethreshold = mean(y(sumx > 0.1));

Categories

Find more on Resizing and Reshaping Matrices in Help Center and File Exchange

Tags

Community Treasure Hunt

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

Start Hunting!