I have a dataset of accelerometric data that is affected by electical spikes.
I'm looking for a good method to filter out or reduce these spikes as need to calculate on these data a rolling window of FFT and other statistical indicators such as kurtosis and skewness. I can't simply delete these outliers or replace them with NaN. Sampling 2000[hz]
Until now I've tried on MATLAB 2012b:
- Wavelet denoising (Haar wavelet)
- Median Filter
- Despike and iterpolate approach
Can you suggest a proper approach to deal with these data?
A moderator merged this question with this question - that's why it looks a little messy here. This answer considers additional issues in the second question!
The following is not an entirely clean solution, the code is adopted from my previous answer, but I added an exception for your case, so you don't need to delete values at the beginning and/or end of your data manually. It discards only these invalid values, that shouldn't cause problems.
For determining the threshold you could use somethink like this, but it's also quite brute-force:
For others that may need this here's what I ended up using. Here's the data file data file link
Thanks goes to @thewaywewalk
Matlab filter electical spikes in accelerometric data
Here are the images of before and after.
I would suggest some local smoothing. By defining thresholds and averaging all values below and above.
The problem with this approach is that your outliners sometimes consist of up to 6 samples. So you need to smooth in multiple steps using a while loop:
after 6 iterations you get the following result:
I have used the file
despiking
from the matlab central file exchange with very good effect for similar problems, though I see you've tried that as well.Another approach I've taken is to treat the spikes as statistical outliers and removed them using this function which uses Rosner's many outlier test. (NIST site is down for obvious reasons, so here is the Google cached version)
Edited to add: I was mistaken. My despiking algorithm did not come from the file exchange function I linked to above. It was actually pulled out of a journal article (the code is listed in the supplementary information to the paper, but they didn't publish the code to the file exchange). The paper was:
Practical Methods for Noise Removal: Applications to Spikes, Nonstationary Quasi-Periodic Noise, and Baseline Drift
Delphine Feuerstein , Kim H. Parker and Martyn G. Boutelle
Anal. Chem., 2009, 81 (12), pp 4987–4994
Since the copyright is held by the American Chemical Society and the authors, I can't copy the code here, but if you have access to a university library account, you can download a copy. If you don't, I left the link to the file exchange version, but I haven't used it so I can't vouch for its efficacy.