Nothing
#'@title FFT Filter
#'@description FFT Filter
#'@return a `ts_fil_fft` object.
#'@examples
#'# time series with noise
#'library(daltoolbox)
#'data(tsd)
#'tsd$y[9] <- 2*tsd$y[9]
#'
#'# filter
#'filter <- ts_fil_fft()
#'filter <- fit(filter, tsd$y)
#'y <- transform(filter, tsd$y)
#'
#'# plot
#'plot_ts_pred(y=tsd$y, yadj=y)
#'@importFrom daltoolbox dal_transform
#'@importFrom daltoolbox fit
#'@importFrom daltoolbox transform
#'@export
ts_fil_fft <- function() {
obj <- dal_transform()
class(obj) <- append("ts_fil_fft", class(obj))
return(obj)
}
compute_cut_index <- function(freqs) {
cutindex <- which.max(freqs)
if (min(freqs) != max(freqs)) {
threshold <- mean(freqs) + 2.968 * sd(freqs)
freqs[freqs < threshold] <- min(freqs) + max(freqs)
cutindex <- which.min(freqs)
}
return(cutindex)
}
#'@importFrom daltoolbox transform
#'@importFrom stats fft
#'@importFrom stats sd
#'@exportS3Method transform ts_fil_fft
transform.ts_fil_fft <- function(obj, data, ...) {
fft_signal <- stats::fft(data)
spectrum <- base::Mod(fft_signal) ^ 2
half_spectrum <- spectrum[1:(length(obj$serie) / 2 + 1)]
cutindex <- compute_cut_index(half_spectrum)
n <- length(fft_signal)
fft_signal[1:cutindex] <- 0
fft_signal[(n - cutindex):n] <- 0
noise <- base::Re(stats::fft(fft_signal, inverse = TRUE) / n)
result <- data - noise
return(result)
}
Any scripts or data that you put into this service are public.
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.