Labfans是一个针对大学生、工程师和科研工作者的技术社区。 | 论坛首页 | 联系我们(Contact Us) |
![]() |
![]() |
#1 |
高级会员
注册日期: 2019-11-21
帖子: 3,006
声望力: 66 ![]() |
![]()
我有一个结构数组,其中包含字段作为长度可变的结构数组。例如:
's'是结构'data'是's'中的字段,也是结构数组本身和 length(s(n).data) ~= length(s(m).data) 我想预分配一个从每个字段s.data.timestamp获取时间戳的数组。有没有一种方法可以不用两次使用for循环?这是我到目前为止的内容: % find the total length count=0; for x=1:length(s) count=count+length(s(x).data); end % preallocate timestamp array timestamp=zeros(1,count); % populate timestamp array index=1; for x=1:length(s) for y=1:length(s(x).data) timestamp(index)=s(x).data(y).timestamp; index=index+1; end end 我考虑过仅根据“ s”的长度和“数据”的平均长度高估我需要的长度,但是每个“数据”字段/子结构的实际长度差异很大。我会更好地只是高估了一下,然后修剪结果数组吗?我正在使用的数据集不可能有零时间戳,所以这不应该成为问题。 回答: 如果每个结构数组data都具有相同的字段并且是行向量(即1-by-N ),则将起作用: allData = [s.data]; %# Concatenate all data arrays into one timestamp = [allData.timestamp]; %# Collect all the time stamps 如果data结构数组是列向量(即N-by-1 ),则需要使用vertcat : allData = vertcat(s.data); %# Concatenate all data arrays into one timestamp = [allData.timestamp]; %# Collect all the time stamps 上面的解决方案之所以有效,是因为访问结构数组的单个字段会返回一个逗号分隔的list 。 更多&回答... |
![]() |
![]() |