找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 2188|回复: 0
打印 上一主题 下一主题
收起左侧

语音信号的时频认知(噪音为1/20的高斯白噪音)GUI界面和MATLAB代码

[复制链接]
跳转到指定楼层
楼主
设计基于MATLAB,添加的噪音为1/20的高斯白噪音


MATLAB源程序如下:
  1. function varargout = untitled(varargin)
  2. gui_Singleton = 1;
  3. gui_State = struct('gui_Name',       mfilename, ...
  4.                    'gui_Singleton',  gui_Singleton, ...
  5.                    'gui_OpeningFcn', @untitled_OpeningFcn, ...
  6.                    'gui_OutputFcn',  @untitled_OutputFcn, ...
  7.                    'gui_LayoutFcn',  [] , ...
  8.                    'gui_Callback',   []);
  9. if nargin && ischar(varargin{1})
  10.     gui_State.gui_Callback = str2func(varargin{1});
  11. end

  12. if nargout
  13.     [varargout{1:nargout}] = gui_mainfcn(gui_State, varargin{:});
  14. else
  15.     gui_mainfcn(gui_State, varargin{:});
  16. end
  17. function untitled_OpeningFcn(hObject, ~, handles, varargin)
  18. handles.output = hObject;
  19. guidata(hObject, handles);
  20. function varargout = untitled_OutputFcn(~, ~, handles)
  21. varargout{1} = handles.output;
  22. function pushbutton1_Callback(~, ~, handles)
  23. global bit SingleC Number_of_Wave_Data_Point SingleCn;
  24. [file,path]=uigetfile('*.m4a;*.mp3;*.wav;*.flac');
  25. set(handles.text3,'String',[path,file]);   % 将路径及文件名显示在文本框中
  26. [y,Fs] = audioread([path,file]);
  27. bit=Fs;
  28. SingleC=y(:,1); % 抽取第 1 声道  即抽取其中一维数组
  29. SingleCn=SingleC;
  30. Single_Channel_Max = max(abs(SingleC));  %幅值数据归一化
  31. Single_Channel_Wave = SingleC/Single_Channel_Max;   %幅值重构
  32. Number_of_Wave_Data_Point = length(Single_Channel_Wave);   
  33. Time_Single_Channel_Wave=(0:Number_of_Wave_Data_Point-1)/bit;  %计算数据点时刻 , 需要将横轴的纯数字点转化为时间(秒)
  34. axes(handles.axes1);                                                                        
  35. plot(Time_Single_Channel_Wave,Single_Channel_Wave);                  %调取数据点,绘制图像
  36. xlabel('时间/s','FontSize',10,'FontWeight','bold');
  37. ylabel('幅值','FontSize',10,'FontWeight','bold');
  38. axes(handles.axes2);
  39. Single_Channel_Wave_Fft = fft(SingleC);                    
  40. Fft_Xabel=(0 : Number_of_Wave_Data_Point/2)*bit / Number_of_Wave_Data_Point;     %提取一般数据,以绘制单边谱波形
  41. Single_Channel_Wave_Fft_Max = max(abs(Single_Channel_Wave_Fft));  %幅值数据归一化
  42. Single_Channel_Wave_Fft = Single_Channel_Wave_Fft/Single_Channel_Wave_Fft_Max;   %幅值重构
  43. plot(Fft_Xabel,abs(Single_Channel_Wave_Fft (1 : Number_of_Wave_Data_Point / 2 +1)));%调用数据,绘制图像,以Fft_Xabel的数据为横轴数据,
  44. xlabel('频率/Hz','FontSize',10,'FontWeight','bold');
  45. ylabel('频率幅值','FontSize',10,'FontWeight','bold');
  46. function nc_Callback(~, ~, handles)
  47. global bit SingleC Number_of_Wave_Data_Point SingleCn;
  48. noise=wgn(Number_of_Wave_Data_Point,1,1);
  49. SingleCn=SingleC+0.05*noise;  %加入高斯白噪声
  50. Single_Channel_Max = max(abs(SingleCn));  %幅值数据归一化
  51. Single_Channel_Wave = SingleCn/Single_Channel_Max;   %幅值重构   
  52. Time_Single_Channel_Wave=(0:Number_of_Wave_Data_Point-1)/bit;  %计算数据点时刻 , 需要将横轴的纯数字点转化为时间(秒)
  53. axes(handles.axes1);                                                                        
  54. plot(Time_Single_Channel_Wave,Single_Channel_Wave);                  %调取数据点,绘制图像
  55. xlabel('时间/s','FontSize',10,'FontWeight','bold');
  56. ylabel('幅值','FontSize',10,'FontWeight','bold');
  57. axes(handles.axes2);
  58. Single_Channel_Wave_Fft = fft(SingleCn);                    
  59. Fft_Xabel=(0 : Number_of_Wave_Data_Point/2)*bit / Number_of_Wave_Data_Point;     %提取一般数据,以绘制单边谱波形
  60. Single_Channel_Wave_Fft_Max = max(abs(Single_Channel_Wave_Fft));  %幅值数据归一化
  61. Single_Channel_Wave_Fft = Single_Channel_Wave_Fft/Single_Channel_Wave_Fft_Max;   %幅值重构
  62. plot(Fft_Xabel,abs(Single_Channel_Wave_Fft (1 : Number_of_Wave_Data_Point / 2 +1)));%调用数据,绘制图像,以Fft_Xabel的数据为横轴数据,
  63. xlabel('频率/Hz','FontSize',10,'FontWeight','bold');
  64. ylabel('频率幅值','FontSize',10,'FontWeight','bold');
  65. set(handles.uipanel2,'Title','加噪后的时域波形和频谱图');
  66. Time_Noise=(0:Number_of_Wave_Data_Point-1)/bit;  %计算数据点时刻
  67. Noise_Max = max(abs(SingleCn));  %幅值数据归一化
  68. SingleCn = SingleCn/Noise_Max;   %幅值重构
  69. axes(handles.axes3);
  70. plot(Time_Noise,0.05*noise,'r');
  71. xlabel('时间/s');
  72. ylabel('幅值');
  73. function stp_Callback(~, ~, ~)
  74. clear sound;
  75. function pushbutton11_Callback(~, ~, handles)
  76. global bit SingleC Number_of_Wave_Data_Point SingleCn;
  77. SingleCn=SingleC;
  78. Single_Channel_Max = max(abs(SingleCn));  %幅值数据归一化
  79. Single_Channel_Wave = SingleCn/Single_Channel_Max;   %幅值重构   
  80. Time_Single_Channel_Wave=(0:Number_of_Wave_Data_Point-1)/bit;  %计算数据点时刻 , 需要将横轴的纯数字点转化为时间(秒)
  81. axes(handles.axes1);                                                                        
  82. plot(Time_Single_Channel_Wave,Single_Channel_Wave);                  %调取数据点,绘制图像
  83. xlabel('时间/s','FontSize',10,'FontWeight','bold');
  84. ylabel('幅值','FontSize',10,'FontWeight','bold');
  85. axes(handles.axes2);
  86. Single_Channel_Wave_Fft = fft(SingleCn);                    
  87. Fft_Xabel=(0 : Number_of_Wave_Data_Point/2)*bit / Number_of_Wave_Data_Point;     %提取一般数据,以绘制单边谱波形
  88. Single_Channel_Wave_Fft_Max = max(abs(Single_Channel_Wave_Fft));  %幅值数据归一化
  89. Single_Channel_Wave_Fft = Single_Channel_Wave_Fft/Single_Channel_Wave_Fft_Max;   %幅值重构
  90. plot(Fft_Xabel,abs(Single_Channel_Wave_Fft (1 : Number_of_Wave_Data_Point / 2 +1)));%调用数据,绘制图像,以Fft_Xabel的数据为横轴数据,
  91. xlabel('频率/Hz','FontSize',10,'FontWeight','bold');
  92. ylabel('频率幅值','FontSize',10,'FontWeight','bold');
  93. set(handles.uipanel2,'Title','原始信号的时域波形和频谱图');
  94. axes(handles.axes3);
  95. plot(0);
  96. xlabel('时间/s');
  97. ylabel('幅值');
  98. function pc_Callback(~, ~, handles)
  99. global SingleCn bit
  100. sound(SingleCn,0.5*get(handles.spd,'value')*bit);
复制代码

所有资料51hei提供下载:
信号大作业.rar (62.34 KB, 下载次数: 19)


评分

参与人数 1黑币 +50 收起 理由
admin + 50 共享资料的黑币奖励!

查看全部评分

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖 顶 踩
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表