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

3 ビュー (過去 30 日間)
Anthony
Anthony 2018 年 11 月 2 日
コメント済み: Anthony 2018 年 11 月 2 日
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 件のコメント
Bruno Luong
Bruno Luong 2018 年 11 月 2 日
編集済み: Bruno Luong 2018 年 11 月 2 日
"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.
Anthony
Anthony 2018 年 11 月 2 日
Thanks for trying Bruno, you're a peach!

サインインしてコメントする。

採用された回答

Matt J
Matt J 2018 年 11 月 2 日
編集済み: Matt J 2018 年 11 月 2 日
c=cumsum(x);
G=discretize(c, 0:0.1:c(end));
result = splitapply(@mean, y, G),
  1 件のコメント
Anthony
Anthony 2018 年 11 月 2 日
This looks like it working how I want... Thanks a lot!

サインインしてコメントする。

その他の回答 (2 件)

madhan ravi
madhan ravi 2018 年 11 月 2 日
編集済み: madhan ravi 2018 年 11 月 2 日
mean(y(cumsum(x)<=0.1))
  8 件のコメント
Bruno Luong
Bruno Luong 2018 年 11 月 2 日
Yes 1 over 4 people figures it out ...by chance.
Anthony
Anthony 2018 年 11 月 2 日
Thanks again Bruno, you're the best!

サインインしてコメントする。


Guillaume
Guillaume 2018 年 11 月 2 日
sumx = cumsum(x);
meanybelowthreshold = mean(y(sumx <= 0.1));
meanyabovethreshold = mean(y(sumx > 0.1));

カテゴリ

Help Center および File ExchangeResizing and Reshaping Matrices についてさらに検索

タグ

Community Treasure Hunt

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

Start Hunting!

Translated by