1

我之前发布了一个类似的问题(认为最好重新开始,并希望获得更多的意见)。基本上,问题是我试图从 .wav 文件中读取数据,但是,输出与 MatLab 中的输出不同。

在 C++ 中,输出为:

-128

而在 Matlab 中:

0

输出完全不同,不仅仅是细微的差异,而是整个数据集都是错误的,我似乎不知道为什么。我认为这可能与字节顺序有关,但我不确定。以下是有关 .wav 文件的标头信息:

**** WAV FILE *****
Chunk IDRIFFN?
Chunk Size: 57934
Format: WAVEfmt 
Format: IDfmt 
FormatSize: 18
Format2: 1
Channel Num: 1
Sample Rate: 22050
Byte Rate: 22050
Align: 1
Bits Per Sample: 8

和代码:

file.read(this->chunkId,                                 4);
file.read(reinterpret_cast<char*>(&this->chunkSize),     4);
file.read(this->format,                                  4);

file.read(this->formatId,                                4);
file.read(reinterpret_cast<char*>(&this->formatSize),    4);
file.read(reinterpret_cast<char*>(&this->format2),       2);
file.read(reinterpret_cast<char*>(&this->numChannels),   2);
file.read(reinterpret_cast<char*>(&this->sampleRate),    4);
file.read(reinterpret_cast<char*>(&this->byteRate),      4);
file.read(reinterpret_cast<char*>(&this->align),         2);
file.read(reinterpret_cast<char*>(&this->bitsPerSample), 4);

char testing[4] = {0};
int testingSize = 0;

while(file.read(testing, 4) && (testing[0] != 'd' ||
                                testing[1] != 'a' ||
                                testing[2] != 't' ||
                                testing[3] != 'a'))
{

    file.read(reinterpret_cast<char*>(&testingSize), 4);
    file.seekg(testingSize, std::ios_base::cur);

}

this->dataId[0] = testing[0];
this->dataId[1] = testing[1];
this->dataId[2] = testing[2];
this->dataId[3] = testing[3];



file.read(reinterpret_cast<char*>(&this->dataSize),     4);

this->data = new char[this->dataSize];

file.read(data,this->dataSize);

cout << "**** WAV FILE *****" << endl;
cout << "Chunk ID" << this->chunkId << endl;
cout << "Chunk Size" << this->chunkSize << endl;
cout << "Format: " << this->format << endl;
cout << "Format ID" << this->formatId << endl;
cout << "FormatSize" << this->formatSize << endl;
cout << "Format2 " << this->format2 << endl;
cout << "Channel Num" << this->numChannels << endl;
cout << "Sample Rate" << this->sampleRate << endl;
cout << "Byte Rate" << this->byteRate << endl;
cout << "Align" << this->align << endl;
cout << "Bits Per Sample" << this->bitsPerSample << endl;
cout << "Size" << testingSize << endl;



for(unsigned i=0; (i < 20); i++){
    cout << (float) data[i] << endl;
}

return true;

谁能看到我哪里出错了?我试图调试它,但是没有乐趣(我正在使用 g++ 编译)。任何帮助将不胜感激:)对不起,我一直在问这个,现在真的很烦我!

谢谢

4

3 回答 3

0

我相信 WAV 文件中的块必须与最近的 WORD 边界对齐。如果在您解析的格式部分之后不是在下一个单词边界处,您将不会进入 while 循环,并且您的代码将假定您在数据部分。

同样,如果您的任何块的长度为奇数字节,您可能会遇到麻烦。

于 2012-09-08T17:52:19.740 回答
0

好的,看看代码,它看起来像一个转换错误。您显然正在尝试输出 20 个浮点数(每个由 4 个字节组成),但您实际输出的只是 20 个字节,每个单个字节都转换为一个浮点数。我想你可能想要这个

for(unsigned i=0; (i < 20); i++){
    cout << ((float*) data)[i] << endl;
}

换句话说,您将数据转换为浮点指针,然后应用索引。不要先应用索引,然后再转换为浮点数。

于 2012-09-08T19:41:49.703 回答
0

我认为在 matlab 中的值在 -1 到 1 之间进行归一化,因此为了在 c++ 中获得类似的输出,您需要对它们进行缩放。示例为 16 位在 -32768 到 32767 范围内的样本,您希​​望它们缩放到 -1.0 到 1.0。这样做的方法是除以 32768.0(-32768/32768.0 == -1,32767/32768.0 略小于 1)。

for(unsigned i=0; (i < 20); i++){
    cout << ((float) data[i])/32768.0 << endl;
}
于 2016-01-05T13:54:00.077 回答