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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 密室大逃脱第六季大神版在线观看 | 国产日本精品视频 | 亚洲aⅴ | 国产伦一区二区三区视频 | 最新伦理片| 色综合欧美 | 中文字幕一区在线观看视频 | 亚洲精品一区二区三区 | 狠狠色综合久久丁香婷婷 | h片在线免费观看 | 欧美日一区二区 | 日韩成人在线网站 | 狠狠干影院 | 色婷婷综合久久久中字幕精品久久 | 精品国产三级 | 久久精品中文 | 亚洲国产精品久久 | 日韩在线观看中文字幕 | 九九热在线免费视频 | 国产精品久久7777777 | 亚洲欧美日韩系列 | 免费成人在线网 | 狠狠做深爱婷婷综合一区 | 日日夜精品视频 | 在线只有精品 | 欧美日韩中文在线 | 日本黄色大片免费看 | 中国人pornoxxx麻豆 | 成人黄色电影在线观看 | 一级毛片黄片 | 国产激情视频网站 | 日本在线免费看最新的电影 | 亚洲欧美激情网 | 米奇7777狠狠狠狠视频 | 99爱免费 | 欧美涩 | 久久在视频 | 国产成人99久久亚洲综合精品 | 天天爽天天操 | 久草在线中文888 | 日本一道本 |