傅里叶变换及其实现(MATLAB)

傅里叶变换及其实现(MATLAB)傅立叶变换傅立叶变换是一种常见的分析方法,傅立叶变换将满足一定条件的函数表示为一些函数的加权和(或者积分)。可以分为四个类别:1.非周期连续性信号对应于傅里叶变换,频域连续非周期2.周期性连续性信号对应于傅立叶级数,频域离散非周期3.非周期离散信号对应于DTFT(离散时间傅立叶变换),频域连续周期4.周期性离散信号对应于D

大家好,又见面了,我是你们的朋友全栈君。

傅立叶变换

傅立叶变换是一种常见的分析方法,傅立叶变换将满足一定条件的函数表示为一些函数的加权和(或者积分)。可以分为四个类别:
1. 非周期连续性信号
对应于傅里叶变换,频域连续非周期
2. 周期性连续性信号
对应于傅立叶级数,频域离散非周期
3. 非周期离散信号
对应于DTFT(离散时间傅立叶变换),频域连续周期
4. 周期性离散信号
对应于DFT(离散时间傅立叶变换),频域离散周期

傅立叶级数

首先从傅立叶级数开始分析,傅立叶级数是将一个信号在一组正交基上进行分解的体现。

x(t)=k=+akejkω0t x ( t ) = ∑ k = − ∞ + ∞ a k e j k ω 0 t




ak=1TT/2T/2x(t)ejkω0tdt a k = 1 T ∫ − T / 2 T / 2 x ( t ) e − j k ω 0 t d t

连续时间傅立叶变换

ω0=2πT ω 0 = 2 π T ,当 T T → ∞ 时, ω00 ω 0 → 0
X(jω) X ( j ω ) Tak T a k 的包络,用 kω0ω k ω 0 → ω ,推出:
正变换

X(jω)=+x(t)ejkω0tdt X ( j ω ) = ∫ − ∞ + ∞ x ( t ) e − j k ω 0 t d t



其中

ak a k


X(jω) X ( j ω )
的等距离采样,

ak=1TX(jkω0) a k = 1 T X ( j k ω 0 )


所以当

T T → ∞
时,

ω00 ω 0 → 0
,可以推出:



x(t)=akejkω0t=1TX(jkω0)ejkω0t=12πX(jkω0)ejkω0tω0 x ( t ) = ∑ a k e j k ω 0 t = ∑ 1 T X ( j k ω 0 ) e j k ω 0 t = ∑ 1 2 π X ( j k ω 0 ) e j k ω 0 t ω 0


极限时转变为积分:


逆变换


x(t)=12π+X(jω)ejωtdω x ( t ) = 1 2 π ∫ − ∞ + ∞ X ( j ω ) e j ω t d ω

离散时间傅立叶变换

离散时间傅立叶变换在频域上是连续的,但由于计算机无法表示无限长的时间片段,已经无法表示全部频率,一般取一定频域的分量。
正变换

X(ejω)=n=+x[n]ejωn X ( e j ω ) = ∑ n = − ∞ + ∞ x [ n ] e − j ω n




逆变换


x[n]=12π2πX(ejω)ejωndω x [ n ] = 1 2 π ∫ 2 π X ( e j ω ) e j ω n d ω

离散傅立叶变换

只有离散傅立叶变换在频域和时域都是离散的,即计算机可以处理的,因此DFT是可以实际进行编程并实用的。DFT的信号首先要进行截断,因为能处理的信号必须是有限的;然后对信号进行采样,对频谱进行离散化。
正变换

X(k)=n=0N1x(n)ej2πNnk X ( k ) = ∑ n = 0 N − 1 x ( n ) e − j 2 π N n k




逆变换


x(n)=1Nk=0N1X(k)ej2πNnk x ( n ) = 1 N ∑ k = 0 N − 1 X ( k ) e j 2 π N n k

二维傅立叶变换

F(u,v)=x=0M1y=0N1f(x,y)ej2π(ux/M+vy/N) F ( u , v ) = ∑ x = 0 M − 1 ∑ y = 0 N − 1 f ( x , y ) e − j 2 π ( u x / M + v y / N )




f(x,y)=1MNx=0M1y=0N1F(u,v)ej2π(ux/M+vy/N) f ( x , y ) = 1 M N ∑ x = 0 M − 1 ∑ y = 0 N − 1 F ( u , v ) e j 2 π ( u x / M + v y / N )

傅立叶变换实现

只有离散傅里叶变换才可以实现,在MATLAB中实现有fftfft2进行傅里叶变换,同样可以手动进行变换。

一维傅立叶变换

基于FFT

% xn是信号,n是坐标,N是点数
% N =8;
% n = [0:1:N-1];
% xn = 0.5.^n; % 指数信号
function [] = DFTusefft(xn,n,N)
    figure(1);
    Xk=fft(xn,N);      % 傅立叶变换
    subplot(211);
    stem(n,xn);
    title('原信号');

    subplot(212);
    stem(n,abs(Xk));
    title('FFT变换')
end

这里写图片描述

DFT公式

function [] = DFT(xn,n,N)
    Xk = zeros(1,N);    
    for k=1:N
        sn =0.0;
        for i=1:N
            sn = sn+xn(i)*exp(-j*2*pi*i*k/N);
        end
        Xk(k) = sn;
    end
    figure(2);
    subplot(211);
    stem(n,xn);
    title('原信号');

    subplot(212);
    stem(n,abs(Xk));
    title('DFT')
end

这里写图片描述

DTFT
由于DTFT的频域是连续的而且是无穷的,当我们选择的最高频域足够高时,可以基本代表信号特征,可以进行编程。

function [] = testDTFT(xn,n,N)
    figure(3);
    w=[-800:1:800]*4*pi/800;     %频域共-800----+800 的长度(本应是无穷,高频分量很少,故省去) 
    w = [-N/2:1:N/2]*4*pi*2/N;
    X=xn*exp(-j*(n'*w));         %求dtft变换,采用原始定义的方法,对复指数分量求和而得
    subplot(211)
    stem(n,xn);
    title('原始信号(指数信号)');
    subplot(212);
    plot(w/pi,abs(X));
    title('DTFT变换')
end

这里写图片描述

二维傅立叶变换

原始图像

这里写图片描述

使用fft2

function [] = imagefft()
    I=imread('lenna.jpg');
    I=rgb2gray(I);
    I=im2double(I);
    F=fft2(I);
    F=fftshift(F);
    F=abs(F);
    T=log(F+1);
    figure(4);
    imshow(T,[]);
end

这里写图片描述

使用二维傅立叶变换公式
速度很慢

function [] = imageDFT()
    I=imread('lenna_s.jpg');
    I=rgb2gray(I);
    I=im2double(I);
    [x,y] = size(I);
    ans = ones(x,y);
    com = 0+1i;
    for u =1:x
        for v= 1:y
            sn =0;
            for i=1:x                
                for j=1:y
                    sn = sn+I(i,j)*exp(-com*2*pi*(u*i/x+v*j/y));
                end
            end
            ans(u,v) = sn;
        end
    end
    F=fftshift(ans);
    F= abs(F);
    F=log(F+1);
    figure(5);
    imshow(F,[]);
end

这里写图片描述

优化二维傅立叶变换
先按列进行傅里叶变换,再对行进行傅立叶变换,简化计算。

function [] = imageDFT2()
    I=imread('lenna.jpg');
    I=rgb2gray(I);
    I=im2double(I);
    [x,y] = size(I);
    Ax = ones(x,y);
    ans = ones(x,y);
    com = 0+1i;
    % 对每一列进行DFT
    for k =1:x        
        for m=1:y
            sn =0;
            for n =1:x
                sn =sn + I(n,m)*exp(-com*2*pi*k*n/x);
            end
            Ax(k,m) = sn;
        end
    end
    % 对每一行进行DFT
    for l =1:y
        for k =1:x
            sn =0;
            for m=1:y
                sn = sn+Ax(k,m)*exp(-com*2*pi*l*m/y);
            end
            ans(k,l) = sn;
        end
    end    
    F=fftshift(ans);
    F= abs(F);
    F=log(F+1);
    figure(6);
    imshow(F,[]);
end

这里写图片描述

优化二维傅立叶变换
将按列进行傅里叶变换中使用DFT改为使用fft,速度提升很快。

function [] = imageDFT2fft()
    I=imread('lenna.jpg');
    I=rgb2gray(I);
    I=im2double(I);
    [x,y] = size(I);
    Ax = ones(x,y);
    ans = ones(x,y);
    com = 0+1i;
    % 对每一列进行DFT 
    for m=1:y
        Ax(:,m) = fft(I(:,m));
    end
    % 对每一行进行DFT 
    for k=1:x
        ans(k,:) = fft(Ax(k,:));
    end
    F=fftshift(ans);
    F= abs(F);
    F=log(F+1);
    figure(7);
    imshow(F,[]);
end

这里写图片描述

github地址

如有错误,欢迎指出~

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/160848.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • SpringMVC 上下文webApplicationContext

    SpringMVC 上下文webApplicationContext

  • 全国各地运营商dns列表(供查询)

    全国各地运营商dns列表(供查询)DNS列表 省份 城市 中国电信 中国联通 中国移动 教育网 云南 昭通 222.172.200.68 61.166.150.123 221.3.131.11 221.3.131.12 211.139.29.170 202.203.66.3

  • resize函数的作用「建议收藏」

    resize函数作用:修改有效字符个数resize(n)如果有效字符的个数增加,则新增的位置填充‘\0’resize(n,ch)如果有效的字符的个数增加,则新增的位置填充ch如果size减小,如下图。

  • 站内搜索 简单粗暴放代码

    站内搜索 简单粗暴放代码第一步:创建表单,放搜索框第二步:写JS第三步:在Web层创建Servlet,使用的gson转换的json格式,需要导包第四步:创建Service第五步:创建Dao,使用的C3P0和

  • cefsharp修改html元素,CefSharp网页元素点击

    cefsharp修改html元素,CefSharp网页元素点击我正在尝试简单地点击某个页面元素(如btn或链接)。我编写了两个函数,分别用于通过xpath和CSS选择器单击。这两个功能在浏览器的开发人员控制台中都能很好地工作,但在CEF中部分不能工作。从开发人员控制台和Cef的简单链接中编写完美的click代码代码完美地点击了开发人员控制台上的确切按钮,但没有点击CEF。只是出于某种原因忽略了它。。。怎么会这样?Js代码完全一样!…publicvoid…

  • React教程(详细版)

    React教程(详细版)一、简介(背景)1.1、概念它是一个将数据渲染为HTML视图的js库1.2、原生js痛点用dom的API去操作dom,繁琐且效率低用js直接操作dom,浏览器会进行大量的回流和重绘原生jjs没有组件化的编程方案,代码复用性低,哪怕有模块话的概念,但模块化也只能拆解一个个js,对样式和结构也没办法拆解,组件化就相当于3剑客整体拆解,成为一个个的小功能1.3、React特点采用组件化模式,声明式编码,提高开发效率和组件复用性在ReactNative中可以用react预发进行安卓、io

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号