WIP: added example

This commit is contained in:
Andrey Gumirov
2024-01-08 02:42:59 +07:00
parent 606ce553ac
commit 8780822f95
2 changed files with 63 additions and 46 deletions

View File

@ -193,56 +193,56 @@ using namespace std;
//// Huffman coding algorithm
int main(int argc, char **argv)
{
// buildHuffmanTree(cin);
// 10111010 11110101
stringstream ss("\xba\xf5");
ibitstream ibs(ss);
// // buildHuffmanTree(cin);
// // 10111010 11110101
// stringstream ss("\xba\xf5");
// ibitstream ibs(ss);
// 10111010 11110101
// ^^
int a = ibs.getbits(2);
cout << bitset<2>(a) << endl;
// // 10111010 11110101
// // ^^
// int a = ibs.getbits(2);
// cout << bitset<2>(a) << endl;
// 10111010 11110101
// ^^^^
int b = ibs.getbits(4);
cout << bitset<4>(b) << endl;
// // 10111010 11110101
// // ^^^^
// int b = ibs.getbits(4);
// cout << bitset<4>(b) << endl;
// 10111010 11110101
// ^^ ^^^^^^^
b = ibs.getbits(9);
cout << bitset<9>(b) << endl;
// // 10111010 11110101
// // ^^ ^^^^^^^
// b = ibs.getbits(9);
// cout << bitset<9>(b) << endl;
// 10111010 11110101
// ^ + overflow
try {
b = ibs.getbits(10);
cout << b << endl;
} catch (std::runtime_error &e) {
cout << "Got runtime error: " << e.what() << endl;
}
// // 10111010 11110101
// // ^ + overflow
// try {
// b = ibs.getbits(10);
// cout << b << endl;
// } catch (std::runtime_error &e) {
// cout << "Got runtime error: " << e.what() << endl;
// }
ostringstream so("bits: ");
obitstream obs(so);
// ostringstream so("bits: ");
// obitstream obs(so);
obs.writebits(0xf, 3);
cout << "After 3 bits: " << so.str() << endl;
// cache here: 00000111
// obs.writebits(0xf, 3);
// cout << "After 3 bits: " << so.str() << endl;
// // cache here: 00000111
obs.writebits(0xf5, 7);
// here: Flush: 10101111
cout << "After 7 bits: " << so.str() << endl;
obs.flush();
// here: Flush: 00000011
cout << "After flush: " << so.str() << endl;
// obs.writebits(0xf5, 7);
// // here: Flush: 10101111
// cout << "After 7 bits: " << so.str() << endl;
// obs.flush();
// // here: Flush: 00000011
// cout << "After flush: " << so.str() << endl;
obs.writebits(0xbeef, 16);
cout << "After 0xbeef: " << so.str() << endl;
obs.flush();
// here: Flush: 0xEFBE - reversed!
cout << "After flush: " << so.str() << endl;
// obs.writebits(0xbeef, 16);
// cout << "After 0xbeef: " << so.str() << endl;
// obs.flush();
// // here: Flush: 0xEFBE - reversed!
// cout << "After flush: " << so.str() << endl;
string s = "Some long text!!!!\x01\x02\x03\x04";
@ -252,10 +252,10 @@ int main(int argc, char **argv)
HuffmanTable ht(ss1);
uint8_t *header = ht.to_header();
for (size_t i = 0; i < 128; i++)
{
cout << "Code for " << 2 * i << " and " << 2 * i + 1 << ": " << bitset<8>(header[i]) << endl;
}
// for (size_t i = 0; i < 128; i++)
// {
// cout << "Code for " << 2 * i << " and " << 2 * i + 1 << ": " << bitset<8>(header[i]) << endl;
// }
ostringstream test;
@ -272,7 +272,7 @@ int main(int argc, char **argv)
}
some_stream.flush();
std::cout << "Coding result: " << test.str() << endl;
std::cout << test.str();
return 0;
}