Perform processing over each row of table starting from first non-zero element in that row

조회 수: 2 (최근 30일)
Hello is there a way to perform mean and movmean of each row of the table starting from its first non zero element?

답변 (1개)

Matt J
Matt J 2020년 7월 6일
Your question implies that all elements of the table are numeric., e.g.,
T =
5×3 table
Var1 Var2 Var3
_______ _______ _______
0 0 0.66783
0.95769 0 0
0 0 0
0.67612 0.25479 0
0 0 0.67533
If so, you may as well pre-convert it to a numeric array because...what is the benefit of holding it as a table anyway if they are all numbers?
>> T=table2array(T)
T =
0 0 0.6678
0.9577 0 0
0 0 0
0.6761 0.2548 0
0 0 0.6753
At this point, I would convert all initial zeros to NaN:
[~,first]=max(logical(T));
nanmap=(1:size(T,1)).'<first;
T(nanmap)=nan;
>> T
T =
NaN NaN 0.6678
0.9577 NaN 0
0 NaN 0
0.6761 0.2548 0
0 0 0.6753
and now you can simply use any of the column-wise mean functions with nanflag='omitnan'. For example,
>> result=movmean(T,3,1,'omitnan');
>> result(nanmap)=0
result =
0 0 0.3339
0.4788 0 0.2226
0.5446 0 0
0.2254 0.1274 0.2251
0.3381 0.1274 0.3377
  댓글 수: 1
Matt J
Matt J 2020년 7월 6일
If you truly must have the result in table form, it is simple enough to convert it:
>> result=array2table(result,'VariableNames',{'Var1','Var2','Var3'})
result =
5×3 table
Var1 Var2 Var3
_______ _______ _______
0.95769 NaN 0.33392
0.47885 NaN 0.22261
0.54461 0.25479 0
0.22537 0.1274 0.22511
0.33806 0.1274 0.33767

댓글을 달려면 로그인하십시오.

카테고리

Help CenterFile Exchange에서 Tables에 대해 자세히 알아보기

Community Treasure Hunt

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

Start Hunting!

Translated by