首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Matlab:当同一天发生多个计数时,我想对计数数据求和

Matlab:当同一天发生多个计数时,我想对计数数据求和
EN

Stack Overflow用户
提问于 2013-05-01 23:06:28
回答 2查看 229关注 0票数 0

我有一个生物体完成发育的天数的向量,以及每天完成发育的有机体的相应数量。这些生物都是在不同的日期开始发育的,但是不同年龄的生物可以在同一个day.eg上完成发育。

Completion_day

22

23

23

23

24

已完成的数量

124

12

345

7

231

我的问题是如何计算在同一天完成的所有有机体的总和。当只有两个连续的完成日期相同时,这不是问题:我只需添加'numbers_completed(i) to numbers_completed(i-1)‘。然而,如果三组有机体在同一天完成(例如,第23天),则第二天和第三天的总和将覆盖前两天的总和。有没有人对如何做到这一点有什么建议?

EN

回答 2

Stack Overflow用户

发布于 2013-05-02 04:08:31

假设您想要添加对应于第23天的“完成的数字”(因此是第2、3和4个条目),您可以使用find函数来索引它们在“完成日”矢量中的位置,然后告诉MATLAB添加那些“完成的数字”矢量的条目。

我将其实现为:

completion_day = [ 22 23 23 23 24]; % defining your variables

numbers_completed = [ 124 12 345 7 231]; % defining your variables

idx = find(completion_day == 23); % find the location of completion day 23

sum(numbers_completed(idx)) % return the sum of those 3 numbers

票数 0
EN

Stack Overflow用户

发布于 2013-05-02 04:34:23

只要向量大小相同,您就可以跳过find,只使用逻辑索引。这是更短的代码,而且可能更快。

completionDay = [22 23 23 23 24];

numbersCompleted = [124 12 345 7 231];

sumCompleted = sum(numbersCompleted(completionDay == 23));

您可以使用以下代码遍历唯一的完成天数,并获得每天创建的总天数

uniqueDays = unique(completionDays);

for i=1:length(uniqueDays)

sumCompleted(i) = sum(numbersCompleted(completionDay == uniqueDays(i)));

end

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/16320718

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档