pv2midifile.m
来自「自动语音识别源码对非特定人的孤立词语音识别算法 进行研究。考虑到语音识别技术在」· M 代码 · 共 31 行
M
31 行
function pv2midiFile(pitchVec, pitchRate, midiFile)
% pv2midiFile: Pitch vector to midi file conversion
% Usage: pv2midiFile(pitchVec, pitchRate, midiFile)
% pitchVec: pitch vector
% pitchRate: number of pitch points per second (which is equal to fs/(frameSize-overlap))
% midiFile: output midi file
noteVec = pv2note(pitchVec); % Note segmentation. The format of noteVec is [pitch, duration, pitch, duration...]
if noteVec(1)==0
noteVec = noteVec(3:end); % Get rid of leading rest
end
if noteVec(end-1) == 0
noteVec = noteVec(1:end-2); % Get rid of trailing rest
end
for i=1:2:length(noteVec)
k=(i+1)/2; % Note index
pVector(k)=noteVec(i); % pitch
durVector(k)=noteVec(i+1)*pitchRate; % duration
if k==1
onVector(k)=0; % onset begin at 0
else
onVector(k)=onVector(k-1)+durVector(k-1);
end
end
%pVector=noteVec(1:2:end);
%durVector=noteVec(2:2:end);
%onVector=[0, cumsum(durVector)];
beatUnit = 2*mean(durVector); %
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?