26 #include "boost/filesystem.hpp"
31 using namespace pwiz::util;
33 using namespace pwiz::msdata;
34 namespace bfs = boost::filesystem;
42 200.00018816645022000000, 0.00000000000000000000,
43 200.00043034083151000000, 0.00000000000000000000,
44 200.00067251579924000000, 0.00000000000000000000,
45 200.00091469135347000000, 0.00000000000000000000,
46 201.10647068550810000000, 0.00000000000000000000,
47 201.10671554643099000000, 0.00000000000000000000,
48 201.10696040795017000000, 0.00000000000000000000,
49 201.10720527006566000000, 0.00000000000000000000,
50 201.10745013277739000000, 908.68475341796875000000,
51 201.10769499608537000000, 1266.26928710937500000000,
52 201.10793985998967000000, 1258.11450195312500000000,
53 201.10818472449023000000, 848.79339599609375000000,
54 201.10842958958708000000, 0.00000000000000000000,
55 201.10867445528024000000, 0.00000000000000000000,
56 201.10891932156963000000, 0.0000000000000000000,
69 const char*
sampleEncoded32Big_ =
"Q0gADAAAAABDSAAcAAAAAENIACwAAAAAQ0gAPAAAAABDSRtCAAAAAENJG1IAAAAAQ0kbYgAAAABDSRtyAAAAAENJG4JEYyvTQ0kbkkSeSJ5DSRuiRJ1DqkNJG7JEVDLHQ0kbwgAAAABDSRvSAAAAAENJG+IAAAAAQ0gAAAAAAABDlgAAP4AAAEPIAABBIAAAQ/oAAELIAABEFgAARHoAAA==";
70 const char*
sampleEncoded32Little_ =
"DABIQwAAAAAcAEhDAAAAACwASEMAAAAAPABIQwAAAABCG0lDAAAAAFIbSUMAAAAAYhtJQwAAAAByG0lDAAAAAIIbSUPTK2NEkhtJQ55InkSiG0lDqkOdRLIbSUPHMlREwhtJQwAAAADSG0lDAAAAAOIbSUMAAAAAAABIQwAAAAAAAJZDAACAPwAAyEMAACBBAAD6QwAAyEIAABZEAAB6RA==";
71 const char*
sampleEncoded64Little_ =
"/xedigEAaUAAAAAAAAAAAIV5fYYDAGlAAAAAAAAAAACkK16CBQBpQAAAAAAAAAAAXy4/fgcAaUAAAAAAAAAAAK4HNjVoI2lAAAAAAAAAAACrvLg2aiNpQAAAAAAAAAAAnMM7OGwjaUAAAAAAAAAAAIIcvzluI2lAAAAAAAAAAABax0I7cCNpQAAAAGB6ZYxAJcTGPHIjaUAAAADAE8mTQOUSSz50I2lAAAAAQHWok0CYs88/diNpQAAAAOBYhopAP6ZUQXgjaUAAAAAAAAAAANvq2UJ6I2lAAAAAAAAAAABpgV9EfCNpQAAAAAAAAAAAAAAAAAAAaUAAAAAAAAAAAAAAAAAAwHJAAAAAAAAA8D8AAAAAAAB5QAAAAAAAACRAAAAAAABAf0AAAAAAAABZQAAAAAAAwIJAAAAAAABAj0A=";
72 const char*
sampleEncoded64Big_ =
"QGkAAYqdF/8AAAAAAAAAAEBpAAOGfXmFAAAAAAAAAABAaQAFgl4rpAAAAAAAAAAAQGkAB34/Ll8AAAAAAAAAAEBpI2g1NgeuAAAAAAAAAABAaSNqNri8qwAAAAAAAAAAQGkjbDg7w5wAAAAAAAAAAEBpI245vxyCAAAAAAAAAABAaSNwO0LHWkCMZXpgAAAAQGkjcjzGxCVAk8kTwAAAAEBpI3Q+SxLlQJOodUAAAABAaSN2P8+zmECKhljgAAAAQGkjeEFUpj8AAAAAAAAAAEBpI3pC2erbAAAAAAAAAABAaSN8RF+BaQAAAAAAAAAAQGkAAAAAAAAAAAAAAAAAAEBywAAAAAAAP/AAAAAAAABAeQAAAAAAAEAkAAAAAAAAQH9AAAAAAABAWQAAAAAAAECCwAAAAAAAQI9AAAAAAAA=";
73 const char*
sampleEncoded32LittleZlib_ =
"eJzjYfBwZgACGSitA6VtoLSTtCeYDoLSSVC6CEo3AenL2skuk4D0PI95LouA9CrnuS6bgPRxoxCXQ1B1l6D0IyjNADWfgWEakG6wZ2A4AaQVHBkYfgHpE04MDGIuDAxVLgB7LB3q";
74 const char*
sampleEncoded32BigZlib_ =
"eJxz9mDgYQACZw8GGSitA6VtwLSntBOUDoLSSVC6CEo3uSRrXwbSk1zmecwD0otc5jqvAtKbXEKMjgPpQ1B1l6D0I6j5YOA8jYHBvgFIn2BgcFQA0r8YGJyAbBcxIK5iYAAAfLkd6g==";
75 const char*
sampleEncoded64LittleZlib_ =
"eJz7Lz63i5Eh04EBClora9uYkfhLtOOaWJH48Xr2dexI/HXsZqYZygj+6j07zLKQ+HMOW1vkIPGbZPZb5iHxo447WRdA+AlVqT0OqkeO2RRB+AeET052eCrkbVcC4TuUrpjsMGPzefsyCP9BRFuXg/2yEMcKJPNuv7rpVIXEz2yMd6lB4kNFUfkHiqD8D/YQuhLKV4HQDvVQfiSEPtAEFe93AACmsz1+";
76 const char*
sampleEncoded64BigZlib_ =
"eJxzyGRg7Jor/p8BChwyGZjbaitbkfisTXHaS5D47HX2evEIvnKGqRn7OiR+ltmOPauR+DkW1ofnIPHzLPfLNCHxC6ydjkc59KRWJUD4RTbHjqg6TD4pfADCL7HzFnrqMHlFqQOEX2Z/fvMMh662iAcQfoVjyDJ7JPOqnG6+uo3Er3GJb8xEcj8KcCg6AKbtP0D5lVBaBUrXO0DoSCi/CaLeoR8iDgC0Qj1+";
82 if (config.
precision == BinaryDataEncoder::Precision_32 &&
83 config.
byteOrder == BinaryDataEncoder::ByteOrder_LittleEndian &&
84 config.
compression == BinaryDataEncoder::Compression_None)
87 if (config.
precision == BinaryDataEncoder::Precision_32 &&
88 config.
byteOrder == BinaryDataEncoder::ByteOrder_BigEndian &&
89 config.
compression == BinaryDataEncoder::Compression_None)
92 if (config.
precision == BinaryDataEncoder::Precision_64 &&
93 config.
byteOrder == BinaryDataEncoder::ByteOrder_LittleEndian &&
94 config.
compression == BinaryDataEncoder::Compression_None)
97 if (config.
precision == BinaryDataEncoder::Precision_64 &&
98 config.
byteOrder == BinaryDataEncoder::ByteOrder_BigEndian &&
99 config.
compression == BinaryDataEncoder::Compression_None)
102 if (config.
precision == BinaryDataEncoder::Precision_32 &&
103 config.
byteOrder == BinaryDataEncoder::ByteOrder_LittleEndian &&
104 config.
compression == BinaryDataEncoder::Compression_Zlib)
107 if (config.
precision == BinaryDataEncoder::Precision_32 &&
108 config.
byteOrder == BinaryDataEncoder::ByteOrder_BigEndian &&
109 config.
compression == BinaryDataEncoder::Compression_Zlib)
112 if (config.
precision == BinaryDataEncoder::Precision_64 &&
113 config.
byteOrder == BinaryDataEncoder::ByteOrder_LittleEndian &&
114 config.
compression == BinaryDataEncoder::Compression_Zlib)
117 if (config.
precision == BinaryDataEncoder::Precision_64 &&
118 config.
byteOrder == BinaryDataEncoder::ByteOrder_BigEndian &&
119 config.
compression == BinaryDataEncoder::Compression_Zlib)
122 throw runtime_error(
"[BinaryDataEncoderTest::regressionTest()] Untested configuration.");
129 *
os_ <<
"testConfiguration: " << config << endl;
138 *
os_ <<
"original: " << binary.size() << endl;
139 *
os_ << setprecision(20) << fixed;
140 copy(binary.begin(), binary.end(), ostream_iterator<double>(*
os_,
"\n"));
150 encoder.
encode(binary, encoded);
153 *
os_ <<
"encoded: " << encoded.size() << endl << encoded << endl;
161 vector<double> decoded;
162 encoder.
decode(encoded, decoded);
166 *
os_ <<
"decoded: " << decoded.size() << endl;
167 copy(decoded.begin(), decoded.end(), ostream_iterator<double>(*
os_,
"\n"));
174 const double epsilon = config.
precision == BinaryDataEncoder::Precision_64 ? 1
e-14 : 1
e-5 ;
176 for (vector<double>::const_iterator it=binary.begin(), jt=decoded.begin();
177 it!=binary.end(); ++it, ++jt)
182 if (
os_) *
os_ <<
"validated with epsilon: " << fixed << setprecision(1) << scientific << epsilon <<
"\n\n";
190 config.
precision = BinaryDataEncoder::Precision_32;
191 config.
byteOrder = BinaryDataEncoder::ByteOrder_LittleEndian;
194 config.
precision = BinaryDataEncoder::Precision_32;
195 config.
byteOrder = BinaryDataEncoder::ByteOrder_BigEndian;
198 config.
precision = BinaryDataEncoder::Precision_64;
199 config.
byteOrder = BinaryDataEncoder::ByteOrder_LittleEndian;
202 config.
precision = BinaryDataEncoder::Precision_64;
203 config.
byteOrder = BinaryDataEncoder::ByteOrder_BigEndian;
206 config.
precision = BinaryDataEncoder::Precision_32;
207 config.
byteOrder = BinaryDataEncoder::ByteOrder_LittleEndian;
208 config.
compression = BinaryDataEncoder::Compression_Zlib;
211 config.
precision = BinaryDataEncoder::Precision_32;
212 config.
byteOrder = BinaryDataEncoder::ByteOrder_BigEndian;
213 config.
compression = BinaryDataEncoder::Compression_Zlib;
216 config.
precision = BinaryDataEncoder::Precision_64;
217 config.
byteOrder = BinaryDataEncoder::ByteOrder_LittleEndian;
218 config.
compression = BinaryDataEncoder::Compression_Zlib;
221 config.
precision = BinaryDataEncoder::Precision_64;
222 config.
byteOrder = BinaryDataEncoder::ByteOrder_BigEndian;
223 config.
compression = BinaryDataEncoder::Compression_Zlib;
230 if (
os_) *
os_ <<
"testBadFile: " << filename << flush;
236 filesize = (size_t) bfs::file_size(filename);
240 cerr <<
"\nUnable to find file " << filename << endl;
244 if (
os_) *
os_ <<
" (" << filesize <<
" bytes)\n";
250 vector<double> data(filesize/
sizeof(
double));
251 ifstream is(filename.c_str(), ios::binary);
252 is.read((
char*)&data[0], filesize);
258 if (filename.find(
"BinaryDataEncoderTest.bad.bin")!=string::npos)
261 config.
precision = BinaryDataEncoder::Precision_32;
262 config.
byteOrder = BinaryDataEncoder::ByteOrder_LittleEndian;
263 config.
compression = BinaryDataEncoder::Compression_Zlib;
270 encoder.
encode(data, encoded);
272 vector<double> decoded;
273 encoder.
decode(encoded, decoded);
278 for (
size_t i=0; i<decoded.size(); i++)
283 int main(
int argc,
char* argv[])
291 for (
int i=1; i<argc; i++)
293 if (!strcmp(argv[i],
"-v"))
os_ = &cout;
294 else if (bal::starts_with(argv[i],
"--"))
continue;
295 else filenames.push_back(argv[i]);
298 if (
os_) *
os_ <<
"BinaryDataEncoderTest\n\n";
300 for_each(filenames.begin(), filenames.end(),
testBadFile);