fourier transfrom 傅立叶变换代码实现(matlab语言)

2024-06-06 10:18

本文主要是介绍fourier transfrom 傅立叶变换代码实现(matlab语言),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

DFT的事情拖了很久了,上个学期就一直纠缠着,始终没有理解,去逸夫楼上课每次下课空教室的时候就喜欢一个人“过瘾”,在黑板上写DFT

的表达式,总想着程序实现。大概那样过了一个月,还是没有理解(智商是硬伤),这几天看了stanford的视频,老师挺逗的,感觉好像懂了,

于是重新写DFT。在matlab下实现了 。。。。




个人觉得<The Scientist and Engineer's Guide to Digital Signal Processing>这本书还是很好的。很值得一看,如果对DSP有兴趣的话。

好吧,开源,上代码:

%% ***************************************************************************************
% code writer ?EOF
% code date : 2014.03.11              2014.03.12 update
% e-mail : jasonleaster@gmail.com
% code purpose : 
%       This code is demo for DFT. I would like to share my code with
%       someone who is interesting in DSP. If there is something wrong with
%       my code, please touche me by e-mail. Thank you!
%
%% ***************************************************************************************TotalSample = 400;
%The number of all the signal that our sensor got
circle = TotalSample/2;
% circle = TotalSample;
%We assume that the preiod of the signal we generated is 'circle';
SignalInS = zeros(circle,1);
%This varible is used for recording the signal in frequency domain
SignalInT = zeros(TotalSample,1);
%This varible is used for recording the signal which were processed by inverse-DFT in time domain
OriginalSignal = zeros(TotalSample,1);
%This varible is used for recording the original signal that we got.%% initialize a square wave
for SampleNumber = -(TotalSample/2):(TotalSample/2)-1if (mod(abs(SampleNumber),circle) < (circle/2))&&(SampleNumber>0)OriginalSignal((TotalSample/2)+1+SampleNumber) = 5;elseif (mod(abs(SampleNumber),circle) >= (circle/2))&&(SampleNumber>0)OriginalSignal((TotalSample/2)+1+SampleNumber) = 0;elseif (mod(abs(SampleNumber),circle) < (circle/2))&&(SampleNumber<0)OriginalSignal((TotalSample/2)+1+SampleNumber) = 0;   elseif (mod(abs(SampleNumber),circle) >= (circle/2))&&(SampleNumber<0)OriginalSignal((TotalSample/2)+1+SampleNumber) = 5;end
end% %% initialize a delta wave
% for SampleNumber = -(TotalSample/2):(TotalSample/2)-1
%     if (SampleNumber == 0)
%         OriginalSignal((TotalSample/2)+1+SampleNumber) = 5;
%     end
% end%We show the original signal in time domain.
figure(1);
plot( -(TotalSample/2):(TotalSample/2)-1,OriginalSignal,'.-');
title('The original signal');%% forward-DFT
for frequency = -(circle/2):(circle/2)-1 % You must knew what is "Shannon sampling theorem" and you will knew that why frequency is from -(circle/2) to (circle/2)-1for SampleNumber = -(TotalSample/2):(TotalSample/2)-1%Nothingelse, just from 1 to TotalSampleSignalInS((circle/2)+1+frequency) = ...SignalInS((circle/2)+1+frequency) + ...OriginalSignal((TotalSample/2)+1+SampleNumber)*exp(-2*pi*(frequency/circle)*(SampleNumber)*i);end
end%We show the real part of processed signal in frequency domain.
figure(2);
plot(-(circle/2):(circle/2)-1,real(SignalInS),'-');
title('The real part of signal after processed');%We show the imagine part of processed signal in frequency domain.
figure(3);
plot(-(circle/2):(circle/2)-1,imag(SignalInS),'-');
title('The imagine part of signal after processed');%% inverse-DFT
for frequency = -(circle/2):(circle/2)-1for SampleNumber = -(TotalSample/2):(TotalSample/2)-1SignalInT((TotalSample/2)+1+SampleNumber) = ...SignalInT((TotalSample/2)+1+SampleNumber) + ...(1/TotalSample)*SignalInS((circle/2)+1+frequency)*exp(2*pi*(frequency/circle)*(SampleNumber)*i);end
end%Just show the signal that we rebuilt by inverse-DFT
figure(4);
plot(-(TotalSample/2):(TotalSample/2)-1,SignalInT,'-');
title('The  rebuilt signal after processed');





我们假设初始信号是方波信号



处理后的实数部分


处理后的虚数部分


逆变换合成的信号



可以看出逆变换的效果是很好的。

这里应该注意

circle = TotalSample/2;

信号周期不能太短,太短了就会出现aliasing引起的逆向变换误差很大。设置值的时候,根据shannon sampling定理来模拟相应的信号周期就可以了


It is hard and wonderful time when you are thinking about fourier transform.


2014.03.12更新:

原来的代码有点问题,对于delta函数的傅立叶变换显然不正确。现在对代码作出更正


The . L

于XTU



update: 2014.10.29

方波的初始化部分可以用以下算法,使得方波关于y轴对称

%% initialize a square wave
for SampleNumber = -(TotalSample/2):(TotalSample/2)-1if (mod(abs(SampleNumber),circle) <= (circle/4)) || (mod(abs(SampleNumber),circle) > (circle*3/4))OriginalSignal((TotalSample/2)+1+SampleNumber) = 5;elseOriginalSignal((TotalSample/2)+1+SampleNumber) = 0;end
end









这篇关于fourier transfrom 傅立叶变换代码实现(matlab语言)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1035822

相关文章

利用c++判断水仙花数并输出示例代码

《利用c++判断水仙花数并输出示例代码》水仙花数是指一个三位数,其各位数字的立方和恰好等于该数本身,:本文主要介绍利用c++判断水仙花数并输出的相关资料,文中通过代码介绍的非常详细,需要的朋友可以... 以下是使用C++实现的相同逻辑代码:#include <IOStream>#include <vec

基于C++的UDP网络通信系统设计与实现详解

《基于C++的UDP网络通信系统设计与实现详解》在网络编程领域,UDP作为一种无连接的传输层协议,以其高效、低延迟的特性在实时性要求高的应用场景中占据重要地位,下面我们就来看看如何从零开始构建一个完整... 目录前言一、UDP服务器UdpServer.hpp1.1 基本框架设计1.2 初始化函数Init详解

Java中Map的五种遍历方式实现与对比

《Java中Map的五种遍历方式实现与对比》其实Map遍历藏着多种玩法,有的优雅简洁,有的性能拉满,今天咱们盘一盘这些进阶偏基础的遍历方式,告别重复又臃肿的代码,感兴趣的小伙伴可以了解下... 目录一、先搞懂:Map遍历的核心目标二、几种遍历方式的对比1. 传统EntrySet遍历(最通用)2. Lambd

springboot+redis实现订单过期(超时取消)功能的方法详解

《springboot+redis实现订单过期(超时取消)功能的方法详解》在SpringBoot中使用Redis实现订单过期(超时取消)功能,有多种成熟方案,本文为大家整理了几个详细方法,文中的示例代... 目录一、Redis键过期回调方案(推荐)1. 配置Redis监听器2. 监听键过期事件3. Redi

SpringBoot全局异常拦截与自定义错误页面实现过程解读

《SpringBoot全局异常拦截与自定义错误页面实现过程解读》本文介绍了SpringBoot中全局异常拦截与自定义错误页面的实现方法,包括异常的分类、SpringBoot默认异常处理机制、全局异常拦... 目录一、引言二、Spring Boot异常处理基础2.1 异常的分类2.2 Spring Boot默

基于SpringBoot实现分布式锁的三种方法

《基于SpringBoot实现分布式锁的三种方法》这篇文章主要为大家详细介绍了基于SpringBoot实现分布式锁的三种方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、基于Redis原生命令实现分布式锁1. 基础版Redis分布式锁2. 可重入锁实现二、使用Redisso

SpringBoo WebFlux+MongoDB实现非阻塞API过程

《SpringBooWebFlux+MongoDB实现非阻塞API过程》本文介绍了如何使用SpringBootWebFlux和MongoDB实现非阻塞API,通过响应式编程提高系统的吞吐量和响应性能... 目录一、引言二、响应式编程基础2.1 响应式编程概念2.2 响应式编程的优势2.3 响应式编程相关技术

Java 接口定义变量的示例代码

《Java接口定义变量的示例代码》文章介绍了Java接口中的变量和方法,接口中的变量必须是publicstaticfinal的,用于定义常量,而方法默认是publicabstract的,必须由实现类... 在 Java 中,接口是一种抽象类型,用于定义类必须实现的方法。接口可以包含常量和方法,但不能包含实例

C#实现将XML数据自动化地写入Excel文件

《C#实现将XML数据自动化地写入Excel文件》在现代企业级应用中,数据处理与报表生成是核心环节,本文将深入探讨如何利用C#和一款优秀的库,将XML数据自动化地写入Excel文件,有需要的小伙伴可以... 目录理解XML数据结构与Excel的对应关系引入高效工具:使用Spire.XLS for .NETC

Nginx更新SSL证书的实现步骤

《Nginx更新SSL证书的实现步骤》本文主要介绍了Nginx更新SSL证书的实现步骤,包括下载新证书、备份旧证书、配置新证书、验证配置及遇到问题时的解决方法,感兴趣的了解一下... 目录1 下载最新的SSL证书文件2 备份旧的SSL证书文件3 配置新证书4 验证配置5 遇到的http://www.cppc