我之前发过了一个类似的问题(认为最好开始一个新鲜的,希望能得到更多的意见)。基本上,问题是我试图从.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 ++进行编译)。任何帮助将不胜感激:)抱歉,我一直在问这个,现在真的很讨厌我!
由于
答案 0 :(得分:0)
我认为WAV文件中的块必须与最近的WORD边界对齐。如果你在下一个单词边界解析了你的格式部分后,你不会进入while循环,你的代码将假设你在数据部分。
同样,如果你的任何一个块长度都是奇数个字节,你可能会遇到麻烦。
答案 1 :(得分:0)
好的查看代码看起来像是一个转换错误。您显然正在尝试输出20个浮点数(每个由4个字节组成),但实际输出的只是20个字节,每个字节转换为单个浮点数。我想你可能想要这个
for(unsigned i=0; (i < 20); i++){
cout << ((float*) data)[i] << endl;
}
换句话说,您将数据转换为浮点指针,然后应用索引。不首先应用索引然后转换为浮点数。
答案 2 :(得分: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;
}