我正在VS2010中手动执行以下操作。1.读入两个波形文件,比如"1.wav"one_answers"2.wav"。2.在1.wav的中间插入2.wav。3.将结果波形流写入输出文件"out.wav".
我现在可以使用以下结构成功读取波形文件
typedef struct {
char ChunkID[4]; /* RIFF Header */ //Magic header
unsigned long ChunkSize; /* RIFF Chunk Size */
char Format[4]; /* WAVE Header */
char Subchunk1ID[4]; /* FMT header */
unsigned long Subchunk1Size; /* Size of the fmt chunk */
unsigned short AudioFormat; /* Audio format 1=PCM,6=mulaw,7=alaw, 257=IBM Mu-Law, 258=IBM A-Law, 259=ADPCM */
unsigned short NumChannels; /* Number of channels 1=Mono 2=Sterio */
unsigned long SampleRate; /* Sampling Frequency in Hz */
unsigned long ByteRate; /* bytes per second */
unsigned short BlockAlign; /* 2=16-bit mono, 4=16-bit stereo */
unsigned short BitsPerSample; /* Number of bits per sample */
char Subchunk2ID[4]; /* "data" string */
unsigned long Subchunk2Size; /* Sampled data length */
BYTE Data[18000];
} WavFile;
但两个波形文件的某些参数不相同。例如,如果1.wav的SampleRate为8000,2.wav的采样器速率为44100,out.wav的采样器速率是多少?
out.wav的采样率是必须明确定义的。在您的示例中,您可以将out.wav选择为44100,两者中较好的一个,但您需要通过插值或在两者之间添加零来对1.wav进行上采样。或者,您可以将其保持在8000,并通过低通滤波器将其降采样2.wav,以过滤掉超过奈奎斯特(新采样率的一半)的频率,然后将采样从在中间丢弃。否则,你必须明确决定你想做什么
更多信息-https://ccrma.stanford.edu/~jos/resample/