#include <stdio.h>
#include "blosc2.h"
#define SIZE (100 * 1000)
#define BLOCKSIZE (40000)
#define NBLOCKS (SIZE / BLOCKSIZE)
#define NTHREADS 2
int main(void) {
blosc2_init();
float *data = malloc(SIZE * sizeof(float));
float *data_out = malloc(SIZE * sizeof(float));
float *data_dest = malloc(SIZE * sizeof(float));
int isize = SIZE * sizeof(float), osize = SIZE * sizeof(float);
int dsize = SIZE * sizeof(float), csize;
int i;
blosc2_cparams cparams = BLOSC2_CPARAMS_DEFAULTS;
blosc2_dparams dparams = BLOSC2_DPARAMS_DEFAULTS;
blosc2_context *cctx, *dctx;
for (i = 0; i < SIZE; i++) {
data[i] = (float)i;
}
printf("Blosc version info: %s (%s)\n",
BLOSC2_VERSION_STRING, BLOSC2_VERSION_DATE);
cparams.typesize = sizeof(float);
cparams.compcode = BLOSC_BLOSCLZ;
cparams.splitmode = BLOSC_NEVER_SPLIT;
cparams.filters[BLOSC2_MAX_FILTERS - 1] = BLOSC_SHUFFLE;
cparams.clevel = 5;
cparams.nthreads = NTHREADS;
cparams.instr_codec = true;
cparams.blocksize = BLOCKSIZE;
cctx = blosc2_create_cctx(cparams);
csize = blosc2_compress_ctx(cctx, data, isize, data_out, osize);
blosc2_free_ctx(cctx);
if (csize == 0) {
printf("Buffer is incompressible. Giving up.\n");
return 1;
}
else if (csize < 0) {
printf("Compression error. Error code: %d\n", csize);
return csize;
}
printf("Compression: %d -> %d (%.1fx)\n", isize, csize, (1. * isize) / csize);
dparams.nthreads = NTHREADS;
dctx = blosc2_create_dctx(dparams);
dsize = blosc2_decompress_ctx(dctx, data_out, csize, data_dest, dsize);
blosc2_free_ctx(dctx);
if (dsize < 0) {
printf("Decompression error. Error code: %d\n", dsize);
return dsize;
}
printf("Decompression successful!\n");
blosc2_instr *datai = (blosc2_instr *)data_dest;
for (i = 0; i < dsize / (int) sizeof(blosc2_instr); i++) {
printf("%.3g - ", datai->cratio);
printf("%.3g - ", datai->cspeed);
printf("%.3g - ", datai->filter_speed);
printf("%d ", datai->flags[0]);
printf("\n");
datai++;
}
free(data);
free(data_out);
free(data_dest);
blosc2_destroy();
return 0;
}