How to Interpolated data outliers
3 visualizzazioni (ultimi 30 giorni)
Mostra commenti meno recenti
Matheus Brito
il 2 Mar 2020
Commentato: Matheus Brito
il 9 Mar 2020
I have a data column that has 3630 rows of data. I used the method: [A, B] = rmoutliers (C, 'movmedian', window); to remove the data outliers.
These data were removed and I need them to be interpolated by the average of the entire column of data. How can I do this?
0 Commenti
Risposta accettata
Turlough Hughes
il 2 Mar 2020
Modificato: Turlough Hughes
il 2 Mar 2020
Generate some sample data:
C = (1:3630).';
idxout = randperm(3630,500); % random index for outliers
C(idxout) = C(idxout)+2000*(1-2*rand(numel(idxout),1));
Using rmoutliers some of the values are removed:
window = 50;
[A, B] = rmoutliers(C, 'movmedian', window);
Seeing as you've indicated that you only have a column vector of data I assume you want to interpolate using index position as your input for x, you could try the following:
idx = find(~B); % C(idx) is the same as A
D = interp1(idx,A,1:size(C,1)); % Interpolated using index position as x values.
Let me know.
1 Commento
Turlough Hughes
il 3 Mar 2020
Did this work for you? If not I suggest uploadibg the variable C as a .mat
Più risposte (1)
Vedere anche
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!