matlab频谱分析仪

合集下载

基于MATLAB的频谱分析仪设计

基于MATLAB的频谱分析仪设计

基于MATLAB的频谱分析仪设计
频谱分析仪是一种用于测量信号频谱以及分析信号频谱特征的仪器。

频谱分析仪在许多领域具有广泛的应用,例如通信系统、音频处理、机械振动等。

在这篇文章中,我们将基于MATLAB来设计一个频谱分析仪。

首先,我们需要了解频谱是什么。

频谱是信号在不同频率上的能量分布情况。

在频谱分析中,常用的频谱表示方法有幅度谱和相位谱。

在MATLAB中,可以使用fft函数对信号进行频谱分析。

该函数将信号从时域转换为频域,并返回信号的幅度谱和相位谱。

接下来,我们需要设计一个用户界面,用于输入和显示信号数据。

可以使用MATLAB的图形用户界面(GUI)工具箱来实现。

首先,创建一个GUI窗口,包括信号输入框、频谱显示框和按钮。

用户可以在信号输入框中输入信号数据,然后点击按钮来进行频谱分析。

在按钮的回调函数中,我们可以获取用户输入的信号数据,并使用fft函数对信号进行频谱分析。

然后,我们将频谱数据显示在频谱显示框中。

在频谱显示框中,我们可以使用MATLAB的plot函数来绘制频谱图。

可以将频率作为X轴,幅度谱作为Y轴进行绘制。

此外,我们还可以为频谱分析仪添加一些额外的功能,例如窗函数选择、功率谱密度估计、频谱平滑等。

这些功能可以使用MATLAB提供的函数来实现。

总结起来,基于MATLAB的频谱分析仪设计主要包括信号输入、频谱分析、频谱显示以及额外功能的添加。

通过MATLAB的函数和工具箱,我们可以方便地实现一个功能完善的频谱分析仪。

matlab频谱分析仪

matlab频谱分析仪

%
%
GUOJING('CALLBACK',hObject,eventData,handles,...) calls the
local
%
function named CALLBACK in GUOJING.M with the given input
arguments.
%
%
GUOJING('Property','Value',...) creates a new GUOJING or
% --- Outputs from this function are returned to the command line. function varargout = guojing_OutputFcn(hObject, eventdata, handles) % varargout cell array for returning output args (see VARARGOUT); % hObject handle to figure % eventdata reserved - to be defined in a future version of MATLAB % handles structure with handles and user data (see GUIDATA)
% Get default command line output from handles structure varargout{1} = handles.output;
2
% --- Executes on button press in soundcard. function soundcard_Callback(hObject, eventdata, handles) % hObject handle to soundcard (see GCBO) % eventdata reserved - to be defined in a future version of MATLAB % handles structure with handles and user data (see GUIDATA)

利用Matlab进行频谱分析的方法

利用Matlab进行频谱分析的方法

利用Matlab进行频谱分析的方法引言频谱分析是信号处理和电子工程领域中一项重要的技术,用于分析信号在频率域上的特征和频率成分。

在实际应用中,频谱分析广泛应用于音频处理、图像处理、通信系统等领域。

Matlab是一种强大的工具,可以提供许多功能用于频谱分析。

本文将介绍利用Matlab进行频谱分析的方法和一些常用的工具。

一、Matlab中的FFT函数Matlab中的FFT(快速傅里叶变换)函数是一种常用的频谱分析工具。

通过使用FFT函数,我们可以将时域信号转换为频域信号,并得到信号的频谱特征。

FFT 函数的使用方法如下:```Y = fft(X);```其中,X是输入信号,Y是输出的频域信号。

通过该函数,我们可以得到输入信号的幅度谱和相位谱。

二、频谱图的绘制在进行频谱分析时,频谱图是一种直观和易于理解的展示形式。

Matlab中可以使用plot函数绘制频谱图。

首先,我们需要获取频域信号的幅度谱。

然后,使用plot函数将频率与幅度谱进行绘制。

下面是一个示例:```X = 1:1000; % 时间序列Y = sin(2*pi*10*X) + sin(2*pi*50*X); % 输入信号Fs = 1000; % 采样率N = length(Y); % 信号长度Y_FFT = abs(fft(Y)); % 计算频域信号的幅度谱f = (0:N-1)*(Fs/N); % 频率坐标plot(f, Y_FFT);```通过上述代码,我们可以得到输入信号在频谱上的特征,并将其可视化为频谱图。

三、频谱分析的应用举例频谱分析可以应用于许多实际问题中。

下面将介绍两个常见的应用举例:语音信号分析和图像处理。

1. 语音信号分析语音信号分析是频谱分析的一个重要应用领域。

通过对语音信号进行频谱分析,我们可以探索声波的频率特性和信号的频率成分。

在Matlab中,可以使用wavread 函数读取音频文件,并进行频谱分析。

下面是一个示例:```[waveform, Fs] = wavread('speech.wav'); % 读取音频文件N = length(waveform); % 信号长度waveform_FFT = abs(fft(waveform)); % 计算频域信号的幅度谱f = (0:N-1)*(Fs/N); % 频率坐标plot(f, waveform_FFT);```通过上述代码,我们可以获取语音信号的频谱特征,并将其可视化为频谱图。

matlab gui 频谱分析仪

matlab gui 频谱分析仪

频谱分析仪实验报告一:频谱分析仪的功能:(1) 音频信号信号输入。

输入的途径包括从声卡、从WAV文件输入、从信号发生器输入;(2) 信号波形分析。

包括幅值、频率、周期、相位的估计,并计算统计量的峰值、均值、均方值和方差等信息;GUI界面见附页(3) 信号频谱分析。

频率、周期的估计,图形显示幅值谱、相位谱和功率谱等信息的曲线。

二:实验原理1. 时域抽样时域抽样定理给出了连续信号抽样过程中信号不失真的约束条件:对于基带信号,信号抽样频率大于等于2倍的信号最高频率。

时域抽样是把连续信号变成适于数字系统处理的离散信号。

2.快速傅里叶变换(FFT)对有限长序列可以利用离散傅立叶变换(DFT)进行分析。

DFT不但可以很好的反映序列的频谱特性,而且易于用快速算法(FFT)在计算机上进行分析。

MATLAB为计算数据的离散快速傅立叶变换,提供了一系列丰富的数学函数,本设计用的为FFT3.波形分析原理(1)频率(周期)检测对周期信号来说,可以用时域波形分析来确定信号的周期,也就是计算相邻的两个信号波峰的时间差、或过零点的时间差。

这里采用过零点(ti)的时间差T(周期)。

频率即为f = 1/T,由于能够求得多个T值(ti有多个),故采用它们的平均值作为周期的估计值。

(2)幅值检测在一个周期内,求出信号最大值ymax与最小值ymin的差的一半,即A = (ymax - ymin)/2,同样,也会求出多个A值,但第1个A值对应的ymax和ymin不是在一个周期内搜索得到的,故以除第1个以外的A值的平均作为幅值的估计值。

(3)相位检测采用过零法,即通过判断与同频零相位信号过零点时刻,计算其时间差,然后换成相应的相位差。

φ=2π(1-ti/T),{x}表示x的小数部分,同样,以φ的平均值作为相位的估计值。

(4)峰值P的估计在样本数据x中找出最大值与最小值,其差值为双峰值,双峰值的一半即为峰值。

P=[max(yi)-min(yi)]/2(5)均值,均方值,方差,均有计算所得4,频谱图为了直观地表示信号的频率特性,工程上常常将Fourier变换的结果用图形的方式表示,即频谱图三:程序设计1、三种信号的输入方式(1)声卡的输入这里声卡输入是指由麦克风录音得到的声音信号的输入,MATLAB提供了wavrecord函数,该函数能够实现读取麦克风录音信号。

基于LabVIEW和MATLAB的频谱分析仪设计

基于LabVIEW和MATLAB的频谱分析仪设计

固《计量与洲斌桂术)2007牟第34卷第9期基于LabVIEW和MATLAB的频谱分析仪设计DesignontheVirtualSpectrumAnalysisInstrumentBasedonLabVIEWandMATIAB陈华丽(武汉科技大学,湖北武汉430081)摘要:介绍丁基于LaJ)VIEW和MATLAB的虚拟频藩分析仪的设计过程。

重点阐述了基于LabVIEW的前赍用户界面设计、基于MATLAB的后台信号分析算法研制两部分。

该仪器充分发挥了MATL^_B的数值运算功能、LabVIEW的动态显示和虚拟仪器特睦,以极小的成本实现了传统频谱分析仪的功能,且具有鏖好的扩展性和人机界面。

关键词:囝彤化编程;频谱分析仪;虚拟仪器1引言信号处理几乎涉及到所有的工程技术领域,面频谱分析又是信号处理中一个非常重要的分析手段。

一般的频学分析都依靠传统频谱分析仪来完成,价格昂贵,体积庞大,不便于工程技术人员的携带。

虚拟频谱分析仪改变了原有频谱分析仪的整体设计思路,用软件代替了硬件,使工程技术人员可以用一部笔记本电脑到现场就可轻松完成信号的采集、处理及频谱分析。

在工程领域中,LabVIEW和MATLAB是倍受程序开发人员青睐的两种语言,剐于一些需要做大量数据运算处理的复杂应用以及某些复杂的频谱分析算法LabVIEW显得有些力不从心。

而MATLAB不能实现端口操作和实时控制,在界面方面也稍逊一筹。

在实际工程应用中将二者结合起来取长补短,具有非常实用的价值。

本文将重点介绍基于LabVIEW和MAT—LAB的虚拟频谱分析仪的设计。

2基于LabVIEW和MATLAB的虚拟频谱分析仪的设计2.1基于LabVIEW的前台用户界面设计信号分析模块的前面板设置了一个WaveformGraph控件进行波形显示,显示对信号进行各种分析的结果。

分析仪能够同时进行时域分析和频域分析,时域分析包括微分、积分、卷积、自相关和互相关,频域分析包括F丌、Hilbert变换、小波变换、Hartley变换和IFFT变换,时域分析和频域分析可根据实际需要进行扩展。

基于matlab的频谱分析仪设计

基于matlab的频谱分析仪设计

Frequency AnalyzerYangXiao M2013705103HuaZhong University of Science and TechnologySchool of Mechanical Science and Engineering Abstract: Matlab Is a numerical analysis, matrix calculation, scientific data visualization and nonlinear dynamic state system modeling and simulation, and other functions of practical software engineering.It’s easy to use the windows environment and cast off a tradition on the interactive programming language (such as C, Fortran) Edit mode In large range.In this report,The task is to design a frequency analyzer by using matlab.Keyword:frequency analyzer;Matlab;time-domainanalysis;frequency-domain analysis;1.PrefaceMATLAB is called Matrix Laboratory,which is designed by the United States MathWorks company.It’s a commercial mathematical software. Matlab can be use for Matrix operations, mapping functions and data, algorithm, creating the user interface, connect to other programming languages procedures, mainly used in engineering calculations, control design, signal processing and communications, image processing, signal detection, design and financial modeling analysis and other fields. GUI (Graphical User Interface, referred to as GUI, known Graphical User Interface) is displayed using the graphical user interface of computer operations.. Matlab has a powerful GUl tool. In this report, by using matlab GUI tool we could design a frequency analyzer.Frequency analyzer is the instrument which could be used to study the structure of the electrical signal spectrum, and used to measure the signal parameters of signal distortion, modulation, frequency stability and spectral purity.Frequency analyzer could be used to measure some parameters of amplifier and filter circuit system , and it is a kind of multipurpose electronic measuring instrument.FFT (Fast Fourier Transformation) is the fast algorithm of DFT(discrete Fourier transformtion), which is based on discrete Fourier transform.By using FFT we could get the answer faster than DFT.2.IntroduceThe frequency analyzer which is designed by using matlab have three models:record,play wav file and generator some waves .Every model could make three kinds of waveforms:the time domain figure,the frequency spectrum domain figure and the power spectrum figure.We could get the message we want from the frequency analyzer.The interface is that:2.1 Interface3. Design PrinciplesThe task is to design the frequency analyzer which can record,open wav file and play it,generator some kinds of waveforms . Each waveform could do FFT analysis and draw its frequency spectrum figure and power spectrum figure.3.1 signal input3.1.1 choose signal inputWhen we start using the frequency analyzer,we should first set the sampling frequency,sampling numbers and the model of inputting signal.The frequency analyzer has three model of inputting:it’s the record,open and play wav file,signal generator.The program is(just the record):val=get(handles.model,'Value');switch valcase 1h=findobj('Tag','recordtime');set(h,'enable','on');h=findobj('Tag','startrecord');set(h,'enable','on');h=findobj('Tag','filename');set(h,'enable','off');h=findobj('Tag','openfile');set(h,'enable','off');h=findobj('Tag','wave');set(h,'enable','off');h=findobj('Tag','amplitude');set(h,'enable','off');h=findobj('Tag','frequency');set(h,'enable','off');h=findobj('Tag','phase');set(h,'enable','off');h=findobj('Tag','add');set(h,'enable','off');h=findobj('Tag','generatorwave');set(h,'enable','off');When we choose one model ,the others couldn’t work.3.1.2 The recordWe could input the sound signal by using the microphone.Matlab provides the wavecord function,which can be used to get the signal of microphone.The program of record is :Fs=str2double(get(handles.samplefrequency,'String'));N=str2double(get(handles.recordtime,'String'))*Fs;handles.y=wavrecord(N, Fs,'double');handles.inputtype=1;guidata(hObject,handles);plot(handles.axes1,handles.y);ysize=size(handles.y);set(handles.samplenumber,'String',num2str(ysize(1)));3.1.3 Read the wav fileWe use the function of wavread to open the wav file and play it. Theprogram is:[fname,filepath]=uigetfile('*.wav','wav');set(handles.filename,'string',fname);[handles.y,Fs,bit]=wavread(fname);temp = wavread(get(findobj('Tag','filename'),'String'));handles.inputtype=2;guidata(hObject,handles);plot(handles.axes1,(1:length(handles.y))/Fs,handles.y);ysize=size(handles.y);set(handles.samplenumber,'String',num2str(ysize(1)));set(handles.samplefrequency,'string',Fs);wavplay(temp,Fs);3.1.4 Signal generatorMatlab has the general functions which can generator the general waveform directly.We judge the signals should add or not.The program is:Fs=str2double(get(handles.samplefrequency,'String'));N=str2double(get(handles.samplenumber,'String'));x=linspace(0,N/Fs,N);t=get(handles.wave,'Value');f=str2double(get(handles.frequency,'String'));a=str2double(get(handles.amplitude,'String'));p=str2double(get(handles.phase,'String')); switch tcase 1y=a*sin(2*pi*x*f+p);case 2y=a*square(sin(2*pi*x*f+p));case 3y=a*sawtooth(2*pi*x*f+p,0.5);case 4y=a*sawtooth(2*pi*x*f+p);case 5y=a*(2*rand(size(x))-1);endif get(handles.add,'Value')==0.0handles.y=y;elsehandles.y=handles.y+y;endhandles.inputtype=3;guidata(hObject,handles);plot(handles.axes1,handles.y);xlim([0 200]);3.2 Time domain analysisMatlab provides the functions of mean and std,which can easily calculate the mean and variance.The program is :Fs=str2double(get(handles.samplefrequency,'String'));N=str2double(get(handles.samplenumber,'String'));set(handles.vpp,'String',(max(handles.y)-min(handles.y)));set(handles.average,'String',mean(handles.y));set(handles.variance,'String',std(handles.y)^2);3.3 Frequency domain analysisMatlab provide the function of FFT,which can easily achieve the fast Fourier transform algorithm.The program is:Fs=str2double(get(handles.samplefrequency,'String'));N=str2double(get(handles.samplenumber,'String'));temple=handles.y;f=linspace(0,Fs/2,N/2);P=2*fft(temple,N)/N;Pyy=sqrt(P.* conj(P));plot(handles.axes2,f,Pyy(1:N/2));plot(handles.axes3,f,abs(P(1:N/2)).^2);3.4 Simulation3.4.1 The recordWe select the record ,set the record time and sampling frequency,pushthe start record button to begin recording.We can get the waveform of the sound in the graphic area axes1.If we push the time analysis button ,we could get the parameter of vpp,average variance.If we push the fft button,we could get the frequency spectrum figure and power spectrum figure in the graphic area axes2 and axes3.The result is shown:3.1 Image of record3.4.2 Read the wav fileThe result is shown:3.2 wav file amplitude-frequency characteristic3.4.3 Signal generatorWe set the waveform, amplitude, frequency, phase and other information to generate the waveform.The time domain analysis and frequency domain analysis is shown:3.3 amplitude-frequency characteristic of sin wave3.4 amplitude-frequency characteristic of square waveWe can add some waves and analysis3.5 phase frequency characteristics of Superposition signalOther waveform analysis:3.6 amplitude-frequency characteristic of noise4 .Exist problemWhen using the signal generator to generator the wave,the picture ofaxes3 (power spectrum)would change.I can’t solve this problem.And Ifail to build the window function.5.ConclusionIn the future study, I will learn MATLAB this powerful engineering software more harder and try to solve some common engineering problems.References[1] 薛山. MATLAB基础教程. [M] 北京:清华大学出版社,2011.3。

基于.MATLAB的声音信号频谱分析仪设计说明书

基于.MATLAB的声音信号频谱分析仪设计说明书

1.概述随着软硬件技术的发展.仪器的智能化与虚拟化已成为未来实验室及研究机构的发展方向[1]。

虚拟仪器技术的优势在于可由用户定义自己的专用仪器系统.且功能灵活.很容易构建.所以应用面极为广泛。

基于计算机软硬件平台的虚拟仪器可代替传统的测量仪器.如示波器、逻辑分析仪、信号发生器、频谱分析仪等[2]。

从发展史看.电子测量仪器经历了由模拟仪器、智能仪器到虚拟仪器.由于计算机性能的飞速发展.已把传统仪器远远抛到后面.并给虚拟仪器生产厂家不断带来连锅端的技术更新速率。

目前已经有许多较成熟的频谱分析软件.如SpectraLAB、RSAVu、dBFA等。

声卡是多媒体计算机最基本的配置硬件之一.价格便宜.使用方便。

MATLAB是一个数据分析和处理功能十分强大的工程实用软件.他的数据采集工具箱为实现数据的输入和输出提供了十分方便的函数和命令[3]。

本文将给出基于声卡与MATLAB的声音信号频谱分析仪的设计原理与实现方法.功能包括:<1> 音频信号信号输入.从声卡输入、从WAV文件输入、从标准信号发生器输入;<2> 信号波形分析.包括幅值、频率、周期、相位的估计.以及统计量峰值、均值、均方值和方差的计算;<3> 信号频谱分析.频率、周期的估计.图形显示幅值谱、相位谱、实频谱、虚频谱和功率谱的曲线。

2.设计原理2.1波形分析原理2.1.1 信号频率、幅值和相位估计<1>频率<周期>检测对周期信号来说.可以用时域波形分析来确定信号的周期.也就是计算相邻的两个信号波峰的时间差、或过零点的时间差。

这里采用过零点<ti>的时间差T<周期>。

频率即为f = 1/T.由于能够求得多个T值<ti有多个>.故采用它们的平均值作为周期的估计值。

<2>幅值检测在一个周期内.求出信号最大值y max与最小值y min的差的一半.即A = <y max - y min>/2.同样.也会求出多个A值.但第1个A值对应的y max和y min不是在一个周期内搜索得到的.故以除第1个以外的A值的平均作为幅值的估计值。

基于MATLAB的声音信号频谱分析仪设计

基于MATLAB的声音信号频谱分析仪设计

基于MATLAB的声音信号频谱分析仪设计1设计目的及要求1.1设计目的基于MATLAB设计一个简易声音信号频谱分析仪。

1.2设计要求(1)输入方式:①利用电脑声卡录音;②打开WAV文件;(2)时域分析:计算原始信号的幅值,频率,相位;(3)频域分析:利用快速傅里叶变换(FFT)得到信号的幅频特性和相频特性。

2设计原理分析2.1设计结构设计的结构图如下:2.2 声音输入方式(1) 声卡输入:利用MATLAB 中的函数wavrecord 函数获取声卡录制的声音,录制频率和时间可以设置。

默认双声道录制。

(2) 打开WA V 文件:通过MATLAB 中的uigetfile 函数获取声音文件。

如果获取的信号是单声道信号,则双声道分析不可选。

2.3 声道选择设置一个变量handles.sd,如果选择的是左声道,handles.sd =1;如果是右声道,handles.sd =2;如果是双声道,handles.sd =0;在时域和频域分析的时候,通过handles.sd 的值来判断声道。

2.4 时域分析(1) 幅值检测:在一个周期内,求出信号最大值max y 与最小值min y 的差的一半,即max min ()/2A y y =-,同样,也会求出多个A 值,但第1个A 值对应的max y 和min y 不是在一个周期内搜索得到的,故以除第1个以外的A 值的平均作为幅值的估计值。

(2) 频率检测:对周期信号来说,可以用时域波形分析来确定信号的周期,也就是计算相邻的两个信号波峰的时间差、或过零点的时间差。

这里采用过零点i t 的时间差T (周期)。

频率即为1/f T =,由于能够求得多个T 值(i t 有多个),故采用它们的平均值作为周期的估计值。

(3) 相位检测:采用过零法检测,通过判断与同频零相位信号过零点时刻,计算其时间差,然后换成相应的相位差。

2(1/)i t T φπ=-,同样,以φ的平均值作为相位的估计值。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

频谱分析仪摘要频谱分析仪是研究电信号频谱结构的仪器,用于信号失真度、调制度、谱纯度、频率稳定度和交调失真等信号参数的测量,是一种多用途的电子测量仪器。

随着软硬件技术的发展,仪器的智能化与虚拟化已成为未来实验室及研究机构的发展方向。

虚拟仪器技术的优势在于可由用户定义自己的专用仪器系统,且功能灵活,很容易构建,所以应用面极为广泛。

本文介绍了一种使用GUI工具箱用matlab实现的简易虚拟频谱分析仪的设计方法。

关键词matlab,频谱分析仪,时域分析,频域分析目录1概述 (3)2技术路线 (4)3实现方法 (5)3.1搭建GUI界面 (5)3.2信号输入 (6)3.2.1选择信号输入 (6)3.2.2声卡输入 (7)3.2.3读取wav文件 (7)3.2.4信号发生器输入 (7)3.3时域分析 (8)3.4频域分析 (9)3.5仿真 (10)3.5.1声卡输入 (10)3.5.2读取wav文件 (10)3.5.3信号发生器 (11)4存在的问题 (15)5致谢......................................................................................................... 错误!未定义书签。

参考文献 (15)1概述MATLAB是矩阵实验室(Matrix Laboratory)的简称,是美国MathWorks公司出品的商业数学软件。

可以进行矩阵运算、绘制函数和数据、实现算法、创建用户界面、连接其他编程语言的程序等,主要应用于工程计算、控制设计、信号处理与通讯、图像处理、信号检测、金融建模设计与分析等领域。

图形用户界面(Graphical User Interface,简称GUI,又称图形用户接口)是指采用图形方式显示的计算机操作用户界面。

与早期计算机使用的命令行界面相比,图形界面对于用户来说在视觉上更易于接受。

MATLAB自带了强大的GUl工具[1]。

在本文中,将利用MATLAB的GUI工具,设计出数字频谱分析仪。

频谱分析仪是研究电信号频谱结构的仪器,用于信号失真度、调制度、谱纯度、频率稳定度和交调失真等信号参数的测量,可用以测量放大器和滤波器等电路系统的某些参数,是一种多用途的电子测量仪器。

它又可称为频域示波器、跟踪示波器、分析示波器、谐波分析器、频率特性分析仪或傅里叶分析仪等。

现代频谱分析仪能以模拟方式或数字方式显示分析结果,能分析1赫兹以下的甚低频到亚毫米波段的全部无线电频段的电信号[2]。

目前已经有许多较成熟的频谱分析软件,如SpectraLAB、RSAVu、dBFA等[3]。

本文将给出的则是通过MATLAB软件实现的基于FFT的数字频谱分析仪。

FFT(Fast Fourier Transformation),即为快速傅氏变换,是离散傅氏变换的快速算法,它是根据离散傅氏变换的奇、偶、虚、实等特性,对离散傅立叶变换的算法进行改进获得的。

它对傅氏变换的理论并没有新的发现,但是对于在计算机系统或者说数字系统中应用离散傅立叶变换,可以说是进了一大步[4]。

通过此次设计,能进一步掌握MATLAB软件开发过程的基本理论、基本知识和基本技能,熟悉基于MATLAB平台的若干信号处理系统开发及调试方法,且成本低,易于实现,容易修改,并可以进行仿真。

该设计的进行可以为我们以后的学习工作奠定一定的基础。

2技术路线本次设计的频谱分析仪模块划分如图1所示:图1 频谱分析仪模块划分3实现方法3.1搭建GUI界面此次设计搭建的GUI见面如图2所示:图2 GUI界面最上方为标题区,用于显示软件标题等信息。

再往下是信号输入区,首先应输入采样频率和采样点。

信号有3种输入方式,包括声卡输入,读取WAV文件和信号发生器输入。

在信号发生器中加入了信号叠加选项,从而可以将产生的信号与原有的信号进行混迭。

只有当某个单选框被选中时才允许使用对应的输入框、按钮等。

输入区右边为分析区,除了对wav文件进行播放外,还可以对信号进行时域分析和频域分析,该软件的核心代码都在这两个按钮的回调函数中。

再下方为分析结果区,用于显示波形基本参数与统计量的计算结果,Axes1为波形显示区,在录音结束、打开WAV文件成功或者信号发生器生成波形时会更新显示。

Axes2为频谱图显示区,用于显示各种频谱的谱线,在点击频域分析后会更新显示。

点击频谱类型可以显示不同的频谱图。

本次设计提供了幅频特性分析和相频特性分析。

3.2信号输入3.2.1选择信号输入开始使用频谱分析仪时,除了需要设定采样频率和采样点数外,还需要选择信号输入方式,本次设计提供三种输入,分别是:声卡录音,读取wav文件和信号发生器。

其代码如下(仅以选择声卡输入为例):function record_Callback(hObject, eventdata, handles)set(handles.record,'value',1);set(handles.wavfile,'value',0);set(handles.wave,'value',0);h=findobj('Tag','recordtime');set(h,'enable','on');h=findobj('Tag','startrecord');set(h,'enable','on');h=findobj('Tag','wavname');set(h,'enable','off');h=findobj('Tag','openfile');set(h,'enable','off');h=findobj('Tag','inwave');set(h,'enable','off');h=findobj('Tag','inamp');set(h,'enable','off');h=findobj('Tag','infre');set(h,'enable','off');h=findobj('Tag','inpha');set(h,'enable','off');h=findobj('Tag','mix');set(h,'enable','off');h=findobj('Tag','wavemake');set(h,'enable','off');当选择了一种输入方式之后,另外两种输入方式将不能使用。

3.2.2声卡输入这里声卡输入是指由麦克风录音得到的声音信号的输入,MATLAB提供了wavrecord函数,该函数能够实现读取麦克风录音信号。

声卡输入的主要代码如下所示[5]:function startrecord_Callback(hObject, eventdata, handles)Fs=str2double(get(handles.samplefre,'String'));N=str2double(get(handles.recordtime,'String'))*Fs;handles.y=wavrecord(N, Fs,'double');handles.inputtype=1;guidata(hObject,handles);plot(handles.axes1,handles.y);ysize=size(handles.y);set(handles.samplenum,'String',num2str(ysize(1)));3.2.3读取wav文件MATLAB提供了wavread函数,该函数能够方便的打开并读取WAV文件中的声音信息。

其代码如下:function openfile_Callback(hObject, eventdata, handles)[filename,filepath]=uigetfile('*.wav','wavfile');set(handles.wavname,'string',filename);[handles.y,Fs,bit]=wavread(filename);handles.inputtype=2;guidata(hObject,handles);plot(handles.axes1,(1:length(handles.y))/Fs,handles.y);ysize=size(handles.y);set(handles.samplenum,'String',num2str(ysize(1)));set(handles.samplefre,'string',Fs);3.2.4信号发生器输入MATLAB可以产生标准信号,如sin能够产生正弦波,首先利用get函数获得波形,频率f,幅值a和相位p,然后判断是否有信号叠加,若无叠加,则直接生成信号波形,如有叠加,则进行信号混叠。

function wavemake_Callback(hObject, eventdata, handles)Fs=str2double(get(handles.samplefre,'String'));N=str2double(get(handles.samplenum,'String'));x=linspace(0,N/Fs,N);t=get(handles.inwave,'Value');f=str2double(get(handles.infre,'String'));a=str2double(get(handles.inamp,'String'));p=str2double(get(handles.inpha,'String'));switch tcase 1y=a*sin(2*pi*x*f+p);case 2y=a*sign(sin(2*pi*x*f+p));case 3y=a*sawtooth(2*pi*x*f+p,0.5);case 4y=a*sawtooth(2*pi*x*f+p);case 5y=a*(2*rand(size(x))-1);endif get(handles.mix,'Value')==0.0handles.y=y;elsehandles.y=handles.y+y;endhandles.inputtype=3;guidata(hObject,handles);plot(handles.axes1,handles.y);xlim([0 200]);3.3时域分析时域分析直接在时间域内对系统动态过程进行研究的方法。

相关文档
最新文档