そこで、オーディオ ファイルを取り、16000hz の 320 サンプルのフレームに分割するコードを書きました。
コードで示されているように、各フレームのハミング ウィンドウを取得しました。
fs=16000;
[x,fs] = audioread('01.wav');
%Pre-emphasis filter (Y[n]=X [n]-0.95x[n - 1])
b = [1 -0.95];
y = filter(b,1,x);
%windowing
numSamples = length(y);
frameLength = 320;
numFrames = floor(numSamples/frameLength);
for frame = 1:numFrames,
firstSample = (frame * frameLength) - (frameLength - 1);
lastSample = (frame * frameLength);
shortTimeFrame = y(firstSample:lastSample);
h = hamming(320);
hs = h.*shortTimeFrame;
plot(hs, 'r');
end
ハミング ウィンドウを 50% オーバーラップさせるにはどうすればよいでしょうか。SO に関する他の質問を見て、次のような回答を見ました。
y = buffer(h, 1, floor(64 * 0.5));
しかし、それで運がなかった