Files
sf_daq_buffer/core-buffer/test/test_bitshuffle.cpp
T
2020-05-13 14:08:11 +02:00

41 lines
1.2 KiB
C++

#include "gtest/gtest.h"
#include "buffer_config.hpp"
#include "bitshuffle/bitshuffle.h"
using namespace std;
TEST(bitshuffle, simple_compression)
{
auto size = MODULE_N_PIXELS;
auto elem_size = 2; // uint16_t
auto block_size = MODULE_N_BYTES;
auto compress_buffer_size = bshuf_compress_lz4_bound(
size, elem_size, block_size);
auto frame_buffer = make_unique<uint16_t[]>(MODULE_N_PIXELS);
auto compress_buffer = make_unique<char[]>(compress_buffer_size);
for (size_t i=0; i<MODULE_N_PIXELS; i++) {
frame_buffer[i] = i%100;
}
auto compressed_size = bshuf_compress_lz4(
frame_buffer.get(), compress_buffer.get(),
size, elem_size, block_size);
ASSERT_TRUE(compressed_size > 0);
auto out_frame_buffer = make_unique<uint16_t[]>(MODULE_N_PIXELS);
auto consumed_bytes = bshuf_decompress_lz4(
compress_buffer.get(), out_frame_buffer.get(),
size, elem_size, block_size);
ASSERT_TRUE(consumed_bytes > 0);
ASSERT_EQ(compressed_size, consumed_bytes);
for (size_t i=0; i<MODULE_N_PIXELS; i++) {
ASSERT_EQ(out_frame_buffer[i], frame_buffer[i]);
}
}