File: __init__.py

package info (click to toggle)
libvbz-hdf-plugin 1.0.2-3.1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 8,384 kB
  • sloc: cpp: 28,289; python: 392; ansic: 40; sh: 21; makefile: 19; xml: 16
file content (79 lines) | stat: -rw-r--r-- 2,131 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
"""
Python bindings for libvbz
"""

__version__ = "0.9.3"


import numpy as np

from _vbz import lib, ffi


def compression_options(zigzag, size, zlevel=1, version=0):
    options = ffi.new("CompressionOptions *")
    options.integer_size = size
    options.perform_delta_zig_zag = zigzag
    options.zstd_compression_level = zlevel
    options.vbz_version = version
    return options


def compress(data, options=None):

    if options is None:
        zigzag = np.issubdtype(data.dtype, np.signedinteger)
        options = compression_options(zigzag, data.dtype.itemsize)

    output_size = lib.vbz_max_compressed_size(len(data) * options.integer_size, options)
    output = np.empty(output_size, dtype=np.uint8)

    if lib.vbz_is_error(output_size):
        raise Exception("Something unexpected went wrong")

    size = lib.vbz_compress_sized(
        ffi.cast("void const *", ffi.from_buffer(data)),
        len(data) * options.integer_size,
        ffi.cast("void *", ffi.from_buffer(output)),
        output_size,
        options
    )

    if lib.vbz_is_error(size):
        raise Exception("Something unexpected went wrong")

    return output[:size]


def decompress(data, dtype, options=None):

    if options is None:
        zigzag = np.issubdtype(dtype, np.signedinteger)
        try:
            options = compression_options(zigzag, dtype.itemsize)
        except TypeError:
            options = compression_options(zigzag, dtype().itemsize)

    uncompressed_size = lib.vbz_decompressed_size(
        ffi.cast("void const *", ffi.from_buffer(data)),
        len(data),
        options
    )

    if lib.vbz_is_error(uncompressed_size):
        raise Exception("Something unexpected went wrong")

    output = np.empty(uncompressed_size, dtype=dtype)

    size = lib.vbz_decompress_sized(
        ffi.cast("void const *", ffi.from_buffer(data)),
        len(data),
        ffi.cast("void *", ffi.from_buffer(output)),
        uncompressed_size,
        options
    )

    if lib.vbz_is_error(size):
        raise Exception("Something unexpected went wrong")

    return output[:int(size / options.integer_size)]