close all;clear all; % read speech waveform from a file [s, fs] = audioread('voice.wav'); % set analysis parameters, pre-emphasise and windowing N = 8192; Nfft = 8192; n0 = 1000; x = s(n0 : n0+N-1);r = zeros(2*N/2-1, 1); for k = 1 : N/2 x1 = x(k : N); x2 = x(1 : N+1-k); r(N/2+k-1) = x1'* x2 / N; r(N/2-k+1) = r(N/2+k-1); %r(-k) = r(k) end f = (0 : Nfft/2-1)*fs / Nfft / 1000; rx = r ; Sxz1 = fft(rx, Nfft); Sxdbz1 = 10*log10(abs(Sxz1(1 : Nfft/2))); subplot(4,1,1); plot(f, Sxdbz1); ylabel('强度 (dB)'); xlabel('频率 (kHz)'); title('相关图 (矩形窗)功率谱');这段代码存在错误:无法执行赋值,因为左侧和右侧的元素数目不同
时间: 2024-02-25 15:58:20 浏览: 47
这段代码存在错误,因为r的尺寸为(2*N/2-1,1),而Sxz1的尺寸为(Nfft,1)。在将rx进行FFT计算时,应该将其补零以匹配FFT的长度,而不是直接使用rx的长度。修改代码的方式如下:
```
rx = r;
rx = [rx; zeros(Nfft-2*N/2+1, 1)]; % 补零以匹配FFT的长度
Sxz1 = fft(rx, Nfft);
Sxdbz1 = 10*log10(abs(Sxz1(1 : Nfft/2)));
subplot(4,1,1); plot(f, Sxdbz1); ylabel('强度 (dB)');
xlabel('频率 (kHz)'); title('相关图 (矩形窗)功率谱');
```
这样,就能够正确地将rx进行FFT计算,并绘制出功率谱图。
相关问题
%录制信号 recObj = audiorecorder; disp('Start speaking.') recordblocking(recObj, 5); % 录制5秒钟的语音 disp('End of recording.'); y = getaudiodata(recObj); filename = 'myvoice.wav'; audiowrite(filename, y, recObj.SampleRate); [y,fs] = audioread('myvoice.wav'); t = 0:1/fs:(length(y)-1)/fs; subplot(2,1,1) plot(t,y); xlabel('Time (s)'); ylabel('Amplitude'); title('Time Domain Waveform');
这段代码是用于录制5秒钟的音频信号,并将其保存为WAV格式的文件。首先创建了一个名为`recObj`的录音器对象,然后使用`audiorecorder`函数进行初始化。接着使用`recordblocking`函数进行录制,录制时间为5秒钟。录制完成后,使用`getaudiodata`函数获取录制的音频数据,将其保存为名为`myvoice.wav`的WAV格式文件。最后使用`audioread`函数读取保存的音频文件,并使用`plot`函数将其在时间域上绘制出来。
function pushbutton1_Callback(hObject, eventdata, handles) % hObject handle to pushbutton1 (see GCBO) % eventdata reserved - to be defined in a future version of MATLAB % handles structure with handles and user data (see GUIDATA) [file, path] = uigetfile('*.wav', 'Select a .wav file'); % 打开文件选择对话框 if file ~= 0 % 如果用户选择了文件 handles.audio = audioread(fullfile(path, file)); % 读取音频文件 handles.fs = 8000; % 假设音频文件的采样率为44100Hz axes(handles.axes1); % 设置显示波形的坐标轴为axes1 plot(handles.audio); % 绘制波形图 title('Waveform'); % 设置波形图标题 axes(handles.axes2); % 设置显示频谱的坐标轴为axes2 spectrogram(handles.audio, 'yaxis'); % 绘制频谱图 title('Spectrogram'); % 设置频谱图标题 % 初始化滑块的值 handles.slider1_value = 1; handles.slider2_value = 1; handles.slider3_value = 1; handles.slider4_value = 1; % 更新滑块的初始值 set(handles.slider1, 'Value', handles.slider1_value); set(handles.slider2, 'Value', handles.slider2_value); set(handles.slider3, 'Value', handles.slider3_value); set(handles.slider4, 'Value', handles.slider4_value); guidata(hObject, handles); % 更新handles结构体 end
这段代码是按钮1的回调函数,用于选择并读取一个.wav音频文件。在这个回调函数中,`handles.audio`被赋值为读取的音频数据,`handles.fs`被设定为假设的采样率。
然后,代码继续绘制波形图和频谱图,并初始化滑块的值。最后,通过`guidata(hObject, handles)`来更新`handles`结构体。
如果你有任何问题或需要进一步的帮助,请随时提问。
阅读全文