題目描述matlab編程小白一枚 請求各位大神給個思路 用matlab編程造一個過濾器過濾數據里的條目題目來源及自己的思路手頭上有一份原始數據 沒有標簽只有數字那種 其中的第二列是心跳現在需要把心跳檢測為0的條目過濾掉之前都是擼的別的語言 完全沒思路。。。老板給的思路是提取increment相關代碼// 請把代碼文本粘貼到下方(請勿用圖片代替代碼)部分數據:(沒有標簽 沒有標簽 只有數字 第二列是心跳)0.00 0 -1 -1 -127 -1 -1 52 -10.25 0 -1 -1 -127 -1 -1 52 -10.50 0 -1 -1 -127 -1 -1 51 -10.75 0 -1 -1 -127 -1 -1 51 -11.00 0 -1 -1 -127 -1 -1 50 -11.25 0 -1 -1 -127 -1 -1 50 -11.50 0 -1 -1 -127 -1 -1 50 -11.75 0 -1 -1 -127 -1 -1 52 -12.00 0 -1 -1 -127 -1 -1 52 -12.25 0 -1 -1 -127 -1 -1 54 -12.50 0 -1 -1 -127 -1 -1 53 -12.75 133 -1 -1 -127 -1 -1 54 -13.00 133 -1 -1 -127 -1 -1 56 -13.25 130 -1 -1 -127 -1 -1 54 -13.50 130 -1 -1 -127 -1 -1 56 -13.75 126 -1 -1 -127 -1 -1 57 -14.00 126 -1 -1 -127 -1 -1 56 -14.25 121 -1 -1 -127 -1 -1 56 -14.50 121 -1 -1 -127 -1 -1 56 -14.75 120 -1 -1 -127 -1 -1 52 -1你期待的結果是什么?實際看到的錯誤信息又是什么?過濾條件:1.檢測到一條數據心跳為0時, 如果從這條開始計算,后續累計的0的條目數小于等于20, 批量刪除掉這些條目;2.如果后續累計的0的條目大于20小于80, 計算平均數:(起始0條目之前的非0條目+累計0條目結束后第一條非0條目)/2然后把算出的平均數安到這些條目里去有點復雜 求一個思路和相關命令關鍵詞 跪謝
1 回答

Helenr
TA貢獻1780條經驗 獲得超4個贊
如果你的數據庫是M
,即
M = [0.00 0 -1 -1 -127 -1 -1 52 -10.25 0 -1 -1 -127 -1 -1 52 -10.50 0 -1 -1 -127 -1 -1 51 -10.75 0 -1 -1 -127 -1 -1 51 -1....4.50 121 -1 -1 -127 -1 -1 56 -14.75 120 -1 -1 -127 -1 -1 52 -1];
最直接的思路是用一個簡單粗暴的for
循環:
MSub = M(:,2); % 先把第二列提出來,提高檢索效率skipCountCache = 0; % 數據為0,連續跳過計數暫存finalSkipCount = 0; % 最終需要略去的數據計數accumsum = 0; %累和for i = 1:numel(MSub) if M(i) == 0 skipCountCache = skipCountCache + 1; if skipCountCache > 80 % 若跳過計數超過80,退出循環計算平均數 break; end continue; end if skipCountCache > 20 skipCountCache = 0; % 若跳過計數超過20,重置計數 else finalSkipCount = finalSkipCount + skipCountCache; % 否則計入finalSkipCount skipCountCache = 0; % 重置計數 end accumsum = accumsum + MSub(i);endfinalSkipCount = finalSkipCount + skipCountCache; 把最后所有的0都計入finalSkipCount average = accumsum / (i - finalSkipCount);
for
循環很好理解,也很好寫,但是運行效率不高,特別是當你的數據量較大時。
這時候,我們可以用另一種方法,創建一個0和1組成的過濾器(實質上是一個logical array
),然后用find
和diff
對過濾器處理。
- 1 回答
- 0 關注
- 631 瀏覽
添加回答
舉報
0/150
提交
取消