久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 3000|回復: 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 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 一区二区三区国产 | 岛国毛片在线观看 | 亚洲欧美中文日韩在线v日本 | 欧美大片一区 | 免费一级欧美在线观看视频 | 中文字幕日韩欧美一区二区三区 | 国产九九精品视频 | 日韩精品区 | 国产精品一区二 | 久久精品无码一区二区三区 | 成人免费一区二区三区视频网站 | 精品久久亚洲 | 国产区在线视频 | 久久精品国产一区二区电影 | 国内精品视频 | 久久99蜜桃综合影院免费观看 | 日韩久久久久久 | 亚洲综合天堂网 | 国产视频第一页 | 亚洲成人福利在线观看 | 中文字幕一区二区三区在线观看 | 九九热久久免费视频 | 欧美成人精品一区二区男人看 | 国产精品国产成人国产三级 | 国产精品a久久久久 | 国产一区二区三区精品久久久 | 国产精品污www一区二区三区 | 一区二区在线免费播放 | 欧美日韩在线一区二区 | 亚洲综合一区二区三区 | 羞羞的视频在线 | 日韩中文字幕在线免费 | 成人免费在线 | 99只有精品 | 精产国产伦理一二三区 | 中文天堂网 | 日韩精品极品视频在线观看免费 | 99视频在线免费观看 | 96国产精品久久久久aⅴ四区 | 一本一道久久a久久精品蜜桃 | 久久精品视频在线观看 |