📜  R 中的傅立叶 (1)

📅  最后修改于: 2023-12-03 15:34:35.656000             🧑  作者: Mango

R中的傅立叶

傅立叶变换是一个重要的数学工具,可以将一个时间域内的信号转换为频域内的信号,在信号分析、滤波器设计等领域广泛应用。R语言在处理信号处理和傅立叶变换方面也有很强的功能。

傅立叶变换

R中,可以使用 fft() 函数进行傅立叶变换,参数中的 x 是输入的一维数列。如下是一个简单的示例:

# 生成一个原始信号
Fs <- 1000   # Sampling rate
dt <- 1/Fs   # Time interval between samples
t <- seq(0,1,dt)
x <- sin(2*pi*60*t) + sin(2*pi*120*t) + rnorm(length(t), 0, 0.1)

# 对信号进行傅立叶变换
n <- length(x)
y <- fft(x)
freq <- (0:(n-1))*Fs/n

# 绘制频谱图
plot(freq, Mod(y))

这段代码生成了一个模拟的信号,将其进行傅立叶变换,并绘制出其频谱图。Mod(y) 表示获得傅立叶变换的幅度谱图。

可以看出,该信号在60Hz和120Hz处有明显的幅度峰值。

傅立叶反变换

除了进行傅立叶变换,R中还可以执行傅立叶反变换(ifft()),将频域中的信号转换回时间域。以下是一个示例:

# 进行傅立叶反变换
recon <- ifft(y)

# 绘制原始信号和通过反变换恢复的信号
par(mfrow=c(2,1))
plot(t, x, type='l', main='Original Signal')
plot(t, Re(recon), type='l', main='Recovered Signal')

这个示例中,我们将使用上述代码块生成的原始信号的傅立叶变换结果 y 作为输入进行反变换,并与原始信号进行比较。可以看出,经过反变换后的信号与原始信号非常接近。

实例:信号滤波

滤波器可以将某些频率范围的信号滤掉,用于降噪、频率分析等应用中。在R中,可以轻松地使用傅立叶变换来实现滤波。

以下是一个例子,使用一个低通滤波器将一个包含高频噪声的信号滤波:

# 生成原始信号
Fs <- 1000   # Sampling rate
dt <- 1/Fs   # Time interval between samples
t <- seq(0,1,dt)
x <- cos(2*pi*80*t) + cos(2*pi*150*t) + rnorm(length(t), 0, 0.1)

# 对原始信号进行傅立叶变换
n <- length(x)
y <- fft(x)

# 设计低通滤波器
fc <- 100   # Cutoff frequency
nyq <- Fs/2   # Nyquist frequncy
p <- 0.95   # Filter power
h <- hanning(n)
filt <- c(h[1:n/2], rep(0, n/2), h[n/2:1])

# 将低通滤波器应用到傅立叶变换结果上
filtY <- y * filt^p

# 对滤波后的信号进行傅立叶反变换
recon <- ifft(filtY)

# 绘制原始信号和滤波后的信号
plot(t, x, type='l', main="Original Signal")
lines(t, Re(recon), col='red')
legend("topright", c("Original", "Filtered"), lty=1, col=c("black", "red"))

可以看出,经过低通滤波器处理后,高频部分的噪声已经被滤除。这个例子主要使用了 hanning() 函数来生成一个汉宁窗,这个窗口是在傅立叶变换上进行的加窗,用于去除频谱泄漏。同时,还使用了一个幂操作来调整滤波器的阈值,用于控制滤波的程度。

总的来说,R语言提供了一套方便的信号处理和傅立叶变换的工具,能够帮助程序员轻松地在数据分析和科学研究中使用傅立叶变换等数学工具。