library(alkahest)
## Simulate data
set.seed(12345)
x <- seq(-4, 4, length = 100)
y <- dnorm(x)
z <- y + rnorm(100, mean = 0, sd = 0.01) # Add some noise
## Plot raw data
plot(x, z, type = "l", xlab = "", ylab = "", las = 1)
lines(x, y, type = "l", lty = 2, col = "red")
data:image/s3,"s3://crabby-images/4e9c3/4e9c3b03cdbaead407e5039263dd60c300eeab45" alt="Simulated data."
1. Rectangular smoothing
unweighted <- smooth_rectangular(x, z, m = 3)
par(mar = c(3, 3, 1, 1) + 0.1, las = 1)
layout(matrix(c(1, 2), nrow = 2, ncol = 1), heights = c(2, 1))
plot(unweighted, type = "l", xlab = "", ylab = "")
lines(x, y, type = "l", lty = 2, col = "red")
plot(x, y - unweighted$y, ylim = c(-0.03, 0.03), type = "l", xlab = "", ylab = "")
abline(h = 0, lty = 2)
data:image/s3,"s3://crabby-images/d77f0/d77f0a90059cf9fc1b4f9f91bf3f80024462883c" alt="Rectangular smoothing."
2. Triangular smoothing
weighted <- smooth_triangular(x, z, m = 5)
par(mar = c(3, 3, 1, 1) + 0.1, las = 1)
layout(matrix(c(1, 2), nrow = 2, ncol = 1), heights = c(2, 1))
plot(weighted, type = "l", xlab = "", ylab = "")
lines(x, y, type = "l", lty = 2, col = "red")
plot(x, y - weighted$y, ylim = c(-0.03, 0.03), type = "l", xlab = "", ylab = "")
abline(h = 0, lty = 2)
data:image/s3,"s3://crabby-images/617b5/617b52c1df4510b5a1e16625e99f4a6d3e7298a3" alt="Triangular smoothing."
3. Loess smoothing
loess <- smooth_loess(x, z, span = 0.2)
par(mar = c(3, 3, 1, 1) + 0.1, las = 1)
layout(matrix(c(1, 2), nrow = 2, ncol = 1), heights = c(2, 1))
plot(loess, type = "l", xlab = "", ylab = "")
lines(x, y, type = "l", lty = 2, col = "red")
plot(x, y - loess$y, ylim = c(-0.03, 0.03), type = "l", xlab = "", ylab = "")
abline(h = 0, lty = 2)
data:image/s3,"s3://crabby-images/d0d18/d0d18f7238b28996b17c07da2de3f343d2003aaa" alt="Loess smoothing."
4. Savitzky-Golay filter
savitzky <- smooth_savitzky(x, z, m = 21, p = 2)
par(mar = c(3, 3, 1, 1) + 0.1, las = 1)
layout(matrix(c(1, 2), nrow = 2, ncol = 1), heights = c(2, 1))
plot(savitzky, type = "l", xlab = "", ylab = "")
lines(x, y, type = "l", lty = 2, col = "red")
plot(x, y - savitzky$y, ylim = c(-0.03, 0.03), type = "l", xlab = "", ylab = "")
abline(h = 0, lty = 2)
data:image/s3,"s3://crabby-images/bc1d8/bc1d8bc414e4d48aeab3e780ae83c233f2e60a02" alt="Savitzky–Golay filter."
5. Whittaker smoothing
whittaker <- smooth_whittaker(x, z, lambda = 1000, d = 3, sparse = TRUE)
par(mar = c(3, 3, 1, 1) + 0.1, las = 1)
layout(matrix(c(1, 2), nrow = 2, ncol = 1), heights = c(2, 1))
plot(whittaker, type = "l", xlab = "", ylab = "")
lines(x, y, type = "l", lty = 2, col = "red")
plot(x, y - whittaker$y, ylim = c(-0.03, 0.03), type = "l", xlab = "", ylab = "")
abline(h = 0, lty = 2)
data:image/s3,"s3://crabby-images/3587c/3587c6482e555844f1f6fce2ce0745850c8a490b" alt="Whittaker smoothing."