BitMagic-C++

#include <bmsparsevec_serial.h>

Inheritance diagram for bm::sparse_vector_serializer< SV >:
Collaboration diagram for bm::sparse_vector_serializer< SV >:

Public Types

typedef SV::bvector_type bvector_type
typedef const bvector_typebvector_type_const_ptr
typedef bvector_typebvector_type_ptr
typedef SV::value_type value_type
typedef SV::size_type size_type
typedef bvector_type::allocator_type alloc_type
typedef alloc_type::allocator_pool_type allocator_pool_type
typedef bm::serializer< bvector_type >::bv_ref_vector_type bv_ref_vector_type
typedef bm::serializer< bvector_type >::xor_sim_model_type xor_sim_model_type

Public Member Functions

 sparse_vector_serializer ()
Compression settings
void set_bookmarks (bool enable, unsigned bm_interval=256) BMNOEXCEPT
 Add skip-markers for faster range deserialization.
void enable_xor_compression () BMNOEXCEPT
 Enable XOR compression on vector serialization.
void disable_xor_compression () BMNOEXCEPT
 Disable XOR compression on serialization.
void set_xor_ref (bool is_enabled) BMNOEXCEPT
 Turn ON and OFF XOR compression of sparse vectors Enables XOR reference compression for the sparse vector.
void set_xor_ref (const bv_ref_vector_type *bv_ref_ptr) BMNOEXCEPT
 Enable external XOR serialization via external reference vectors (data frame ref.
void compute_sim_model (xor_sim_model_type &sim_model, const bv_ref_vector_type &ref_vect, const bm::xor_sim_params &params)
 Calculate XOR similarity model for ref_vector refernece vector must be associated before.
void set_sim_model (const xor_sim_model_type *sim_model) BMNOEXCEPT
 Attach serizalizer to a pre-computed similarity model.
bool is_xor_ref () const BMNOEXCEPT
 Returns the XOR reference compression status (enabled/disabled).
Serialization
void serialize (const SV &sv, sparse_vector_serial_layout< SV > &sv_layout)
 Serialize sparse vector into a memory buffer(s) structure.
bm::serializer< bvector_type > & get_bv_serializer () BMNOEXCEPT
 Get access to the underlying bit-vector serializer This access can be used to fine tune compression settings.

Protected Types

typedef SV::remap_matrix_type remap_matrix_type
typedef bm::heap_vector< unsigned, alloc_type, true > u32_vector_type
typedef bm::serializer< bvector_typeserializer_type
typedef serializer_type::buffer buffer_type

Protected Member Functions

void build_xor_ref_vector (const SV &sv)
void encode_remap_matrix (bm::encoder &enc, const SV &sv)
 serialize the remap matrix used for SV encoding

Static Protected Member Functions

static void build_plane_digest (bvector_type &digest_bv, const SV &sv)

Protected Attributes

bm::serializer< bvector_typebvs_
bvector_type plane_digest_bv_
 bv.digest of bit-planes
buffer_type plane_digest_buf_
 serialization buf
u32_vector_type plane_off_vect_
u32_vector_type remap_rlen_vect_
bool is_xor_ref_
bv_ref_vector_type bv_ref_
xor_sim_model_type sim_model_
const bv_ref_vector_typebv_ref_ptr_
const xor_sim_model_typesim_model_ptr_

Detailed Description

template<typename SV>
class bm::sparse_vector_serializer< SV >
\brief Serialize sparse vector into a memory buffer(s) structure

Serialization format:

| HEADER | BIT-VECTORS ... | REMAP_MATRIX

Header structure:

BYTE+BYTE: Magic-signature 'BM' or 'BC' (c-compressed) BYTE : Byte order ( 0 - Big Endian, 1 - Little Endian) { BYTE : Number of Bit-vector planes (total) (non-zero when < 255 planes) | BYTE: zero - flag of large plane matrix INT64: Nnmber of bit-vector planes } INT64: Vector size INT64: Offset of plane 0 from the header start (value 0 means plane is empty) INT64: Offset of plane 1 from ... INT32: reserved

Bit-vectors:

Based on current bit-vector serialization

Remap Matrix: SubHeader | Matrix BLOB

sub-header: BYTE: 'R' (remapping) or 'N' (no remapping) N - means no other info is saved on the stream INT64: remap matrix size

Examples
rscsample02.cpp, rscsample05.cpp, strsvsample05.cpp, svsample02.cpp, and svsample08.cpp.

Definition at line 175 of file bmsparsevec_serial.h.

Member Typedef Documentation

◆ alloc_type

template<typename SV>
typedef bvector_type::allocator_type bm::sparse_vector_serializer< SV >::alloc_type

Definition at line 183 of file bmsparsevec_serial.h.

◆ allocator_pool_type

template<typename SV>
typedef alloc_type::allocator_pool_type bm::sparse_vector_serializer< SV >::allocator_pool_type

Definition at line 184 of file bmsparsevec_serial.h.

◆ buffer_type

template<typename SV>
typedef serializer_type::buffer bm::sparse_vector_serializer< SV >::buffer_type
protected

Definition at line 300 of file bmsparsevec_serial.h.

◆ bv_ref_vector_type

template<typename SV>
typedef bm::serializer<bvector_type>::bv_ref_vector_type bm::sparse_vector_serializer< SV >::bv_ref_vector_type

Definition at line 186 of file bmsparsevec_serial.h.

◆ bvector_type

template<typename SV>
typedef SV::bvector_type bm::sparse_vector_serializer< SV >::bvector_type

Definition at line 178 of file bmsparsevec_serial.h.

◆ bvector_type_const_ptr

template<typename SV>
typedef const bvector_type* bm::sparse_vector_serializer< SV >::bvector_type_const_ptr

Definition at line 179 of file bmsparsevec_serial.h.

◆ bvector_type_ptr

template<typename SV>
typedef bvector_type* bm::sparse_vector_serializer< SV >::bvector_type_ptr

Definition at line 180 of file bmsparsevec_serial.h.

◆ remap_matrix_type

template<typename SV>
typedef SV::remap_matrix_type bm::sparse_vector_serializer< SV >::remap_matrix_type
protected

Definition at line 293 of file bmsparsevec_serial.h.

◆ serializer_type

template<typename SV>
typedef bm::serializer<bvector_type> bm::sparse_vector_serializer< SV >::serializer_type
protected

Definition at line 299 of file bmsparsevec_serial.h.

◆ size_type

template<typename SV>
typedef SV::size_type bm::sparse_vector_serializer< SV >::size_type

Definition at line 182 of file bmsparsevec_serial.h.

◆ u32_vector_type

template<typename SV>
typedef bm::heap_vector<unsigned, alloc_type, true> bm::sparse_vector_serializer< SV >::u32_vector_type
protected

Definition at line 298 of file bmsparsevec_serial.h.

◆ value_type

template<typename SV>
typedef SV::value_type bm::sparse_vector_serializer< SV >::value_type

Definition at line 181 of file bmsparsevec_serial.h.

◆ xor_sim_model_type

template<typename SV>
typedef bm::serializer<bvector_type>::xor_sim_model_type bm::sparse_vector_serializer< SV >::xor_sim_model_type

Definition at line 188 of file bmsparsevec_serial.h.

Constructor & Destructor Documentation

◆ sparse_vector_serializer()

template<typename SV>
bm::sparse_vector_serializer< SV >::sparse_vector_serializer ( )

Definition at line 779 of file bmsparsevec_serial.h.

References bv_ref_ptr_, bvs_, and is_xor_ref_.

Member Function Documentation

◆ build_plane_digest()

template<typename SV>
void bm::sparse_vector_serializer< SV >::build_plane_digest ( bvector_type & digest_bv,
const SV & sv )
staticprotected

Definition at line 924 of file bmsparsevec_serial.h.

Referenced by serialize().

◆ build_xor_ref_vector()

template<typename SV>
void bm::sparse_vector_serializer< SV >::build_xor_ref_vector ( const SV & sv)
protected

Definition at line 833 of file bmsparsevec_serial.h.

References bv_ref_.

Referenced by serialize().

◆ compute_sim_model()

template<typename SV>
void bm::sparse_vector_serializer< SV >::compute_sim_model ( xor_sim_model_type & sim_model,
const bv_ref_vector_type & ref_vect,
const bm::xor_sim_params & params )

Calculate XOR similarity model for ref_vector refernece vector must be associated before.

See also
set_ref_vectors, set_sim_model

Definition at line 813 of file bmsparsevec_serial.h.

References bvs_.

Referenced by serialize_df2().

◆ disable_xor_compression()

template<typename SV>
void bm::sparse_vector_serializer< SV >::disable_xor_compression ( )
inline

Disable XOR compression on serialization.

Definition at line 221 of file bmsparsevec_serial.h.

Referenced by SDemo2().

◆ enable_xor_compression()

template<typename SV>
void bm::sparse_vector_serializer< SV >::enable_xor_compression ( )
inline

Enable XOR compression on vector serialization.

See also
set_xor_ref
disable_xor_compression

Definition at line 215 of file bmsparsevec_serial.h.

Referenced by SDemo2().

◆ encode_remap_matrix()

template<typename SV>
void bm::sparse_vector_serializer< SV >::encode_remap_matrix ( bm::encoder & enc,
const SV & sv )
protected

◆ get_bv_serializer()

template<typename SV>
bm::serializer< bvector_type > & bm::sparse_vector_serializer< SV >::get_bv_serializer ( )
inline

Get access to the underlying bit-vector serializer This access can be used to fine tune compression settings.

See also
bm::serializer::set_compression_level

Definition at line 281 of file bmsparsevec_serial.h.

◆ is_xor_ref()

template<typename SV>
bool bm::sparse_vector_serializer< SV >::is_xor_ref ( ) const
inline

Returns the XOR reference compression status (enabled/disabled).

Definition at line 260 of file bmsparsevec_serial.h.

Referenced by SDemo2(), and serialize().

◆ serialize()

◆ set_bookmarks()

template<typename SV>
void bm::sparse_vector_serializer< SV >::set_bookmarks ( bool enable,
unsigned bm_interval = 256 )
inline

Add skip-markers for faster range deserialization.

Parameters
enable- TRUE searilization will add bookmark codes
bm_interval- bookmark interval in (number of blocks) (suggested between 4 and 512) smaller interval means more bookmarks added to the skip list thus more increasing the BLOB size
Examples
rscsample02.cpp, strsvsample05.cpp, and svsample08.cpp.

Definition at line 207 of file bmsparsevec_serial.h.

Referenced by main().

◆ set_sim_model()

template<typename SV>
void bm::sparse_vector_serializer< SV >::set_sim_model ( const xor_sim_model_type * sim_model)

Attach serizalizer to a pre-computed similarity model.

Parameters
sim_model- pointer to external computed model

Definition at line 824 of file bmsparsevec_serial.h.

References BMNOEXCEPT, and sim_model_ptr_.

Referenced by serialize_df2().

◆ set_xor_ref() [1/2]

template<typename SV>
void bm::sparse_vector_serializer< SV >::set_xor_ref ( bool is_enabled)

Turn ON and OFF XOR compression of sparse vectors Enables XOR reference compression for the sparse vector.

Default: disabled Reference bit-vectors from the sparse vector itself

Definition at line 804 of file bmsparsevec_serial.h.

References BMNOEXCEPT, bv_ref_ptr_, and is_xor_ref_.

Referenced by bm::sparse_vector_serializer< sparse_vector_u32 >::disable_xor_compression(), bm::sparse_vector_serializer< sparse_vector_u32 >::enable_xor_compression(), serialize_df0(), and serialize_df2().

◆ set_xor_ref() [2/2]

template<typename SV>
void bm::sparse_vector_serializer< SV >::set_xor_ref ( const bv_ref_vector_type * bv_ref_ptr)

Enable external XOR serialization via external reference vectors (data frame ref.

vector). This method is useful when we serialize a group of related sparse vectors which benefits from the XOR referencial compression

Parameters
bv_ref_ptr- external reference vector if NULL - resets the use of reference vector

Definition at line 793 of file bmsparsevec_serial.h.

References BMNOEXCEPT, bv_ref_ptr_, is_xor_ref_, and sim_model_ptr_.

Field Documentation

◆ bv_ref_

template<typename SV>
bv_ref_vector_type bm::sparse_vector_serializer< SV >::bv_ref_
protected

Definition at line 315 of file bmsparsevec_serial.h.

Referenced by build_xor_ref_vector(), and serialize().

◆ bv_ref_ptr_

template<typename SV>
const bv_ref_vector_type* bm::sparse_vector_serializer< SV >::bv_ref_ptr_
protected

◆ bvs_

template<typename SV>
bm::serializer<bvector_type> bm::sparse_vector_serializer< SV >::bvs_
protected

Definition at line 306 of file bmsparsevec_serial.h.

Referenced by compute_sim_model(), serialize(), and sparse_vector_serializer().

◆ is_xor_ref_

template<typename SV>
bool bm::sparse_vector_serializer< SV >::is_xor_ref_
protected

Definition at line 314 of file bmsparsevec_serial.h.

Referenced by set_xor_ref(), set_xor_ref(), and sparse_vector_serializer().

◆ plane_digest_buf_

template<typename SV>
buffer_type bm::sparse_vector_serializer< SV >::plane_digest_buf_
protected

serialization buf

Definition at line 309 of file bmsparsevec_serial.h.

Referenced by serialize().

◆ plane_digest_bv_

template<typename SV>
bvector_type bm::sparse_vector_serializer< SV >::plane_digest_bv_
protected

bv.digest of bit-planes

Definition at line 308 of file bmsparsevec_serial.h.

Referenced by serialize().

◆ plane_off_vect_

template<typename SV>
u32_vector_type bm::sparse_vector_serializer< SV >::plane_off_vect_
protected

Definition at line 310 of file bmsparsevec_serial.h.

Referenced by serialize().

◆ remap_rlen_vect_

template<typename SV>
u32_vector_type bm::sparse_vector_serializer< SV >::remap_rlen_vect_
protected

Definition at line 312 of file bmsparsevec_serial.h.

Referenced by encode_remap_matrix().

◆ sim_model_

template<typename SV>
xor_sim_model_type bm::sparse_vector_serializer< SV >::sim_model_
protected

Definition at line 316 of file bmsparsevec_serial.h.

Referenced by serialize().

◆ sim_model_ptr_

template<typename SV>
const xor_sim_model_type* bm::sparse_vector_serializer< SV >::sim_model_ptr_
protected

Definition at line 318 of file bmsparsevec_serial.h.

Referenced by serialize(), set_sim_model(), and set_xor_ref().


The documentation for this class was generated from the following file: