Classes | |
| class | bvector |
| bitvector with runtime compression of bits. More... | |
| struct | distance_metric_descriptor |
| Distance metric descriptor, holds metric code and result. More... | |
| class | block_allocator |
| Default malloc based bitblock allocator class. More... | |
| class | ptr_allocator |
| Default malloc based bitblock allocator class. More... | |
| class | mem_alloc |
| BM style allocator adapter. More... | |
| class | blocks_manager |
| bitvector blocks manager Embedded class managing bit-blocks on very low level. Includes number of functor classes used in different bitset algorithms. More... | |
| class | bit_block_guard |
| Bit block buffer guard. More... | |
| struct | DeBruijn_bit_position |
| struct | first_bit_table |
| Structure keeps index of first right 1 bit for every byte. More... | |
| struct | bit_count_table |
| Structure to aid in counting bits table contains count of bits in 0-255 diapason of numbers. More... | |
| struct | bv_statistics |
| Structure with statistical information about bitset's memory allocation details. More... | |
| struct | gap_len_table |
| Default GAP lengths table. More... | |
| struct | gap_len_table_min |
| Alternative GAP lengths table. Good for for memory saver mode and very sparse bitsets. More... | |
| struct | block_set_table |
| Structure keeps all-left/right ON bits masks. More... | |
| struct | all_set |
| Structure carries pointer on bit block with all bits 1. More... | |
| struct | _copyright |
| Internal structure. More... | |
| struct | globals |
| Internal structure. More... | |
| struct | d_copy_func |
| d-Gap copy functor More... | |
| class | copy_to_array_functor |
| Adaptor to copy 1 bits to array. More... | |
| class | copy_to_array_functor_inc |
| Adaptor to copy 1 bits to array with base increment. More... | |
| class | bitblock_get_adapter |
| Bit-block get adapter, takes bitblock and represents it as a get_32() accessor function /internal. More... | |
| class | bitblock_store_adapter |
| Bit-block store adapter, takes bitblock and saves results into it /internal. More... | |
| class | bitblock_sum_adapter |
| Bit-block sum adapter, takes values and sums it /internal. More... | |
| class | decoder_range_adapter |
| Adapter to get words from a range stream (see range serialized bit-block). More... | |
| struct | bit_AND |
| Bit AND functor. More... | |
| struct | bit_OR |
| Bit OR functor. More... | |
| struct | bit_SUB |
| Bit SUB functor. More... | |
| struct | bit_XOR |
| Bit XOR functor. More... | |
| struct | bit_ASSIGN |
| Bit ASSIGN functor. More... | |
| struct | bit_COUNT |
| Bit COUNT functor. More... | |
| struct | bit_COUNT_AND |
| Bit COUNT AND functor. More... | |
| struct | bit_COUNT_XOR |
| Bit COUNT XOR functor. More... | |
| struct | bit_COUNT_OR |
| Bit COUNT OR functor. More... | |
| struct | bit_COUNT_SUB_AB |
| Bit COUNT SUB AB functor. More... | |
| struct | bit_COUNT_SUB_BA |
| Bit SUB BA functor. More... | |
| struct | bit_COUNT_A |
| Bit COUNT A functor. More... | |
| struct | bit_COUNT_B |
| Bit COUNT B functor. More... | |
| struct | operation_functions |
| class | gamma_decoder |
| Elias Gamma decoder. More... | |
| class | serializer |
| Bit-vector serialization class. More... | |
| class | deseriaizer_base |
| Base deserialization class. More... | |
| class | deserializer |
| Class deserializer. More... | |
| class | iterator_deserializer |
| Iterator to walk forward the serialized stream. More... | |
| class | serial_stream_iterator |
| Serialization stream iterator. More... | |
| class | operation_deserializer |
| Class deserializer, can perform logical operation on bit-vector and serialized bit-vector. More... | |
| class | sse_empty_guard |
| SSE2 reinitialization guard class. More... | |
| struct | tmatrix |
| Mini-matrix for bit transposition purposes. More... | |
| struct | bit_grabber |
| struct | bit_grabber< unsigned, 32 > |
| struct | bit_grabber< unsigned short, 16 > |
| struct | bit_grabber< unsigned char, 8 > |
| struct | bit_trans_grabber |
| class | gap_transpose_engine |
| Bit-plain splicing of a GAP block. More... | |
| class | miniset |
| Template class implements memory saving set functionality. More... | |
| class | bvmini |
| Mini bitvector used in bvector template to keep block type flags. More... | |
| class | bvector_mini |
| Bitvector class with very limited functionality. More... | |
| class | encoder |
| Memory encoding. More... | |
| class | decoder_base |
| Base class for all decoding functionality. More... | |
| class | decoder |
| Class for decoding data from memory buffer. More... | |
| class | decoder_little_endian |
| Class for decoding data from memory buffer. More... | |
| class | bit_out |
| Byte based writer for un-aligned bit streaming. More... | |
| class | bit_in |
| Byte based reader for un-aligned bit streaming. More... | |
| class | gamma_encoder |
| Functor for Elias Gamma encoding. More... | |
Typedefs | |
| typedef bm::miniset< bm::block_allocator, bm::set_total_blocks > | mem_save_set |
| typedef mem_alloc< block_allocator, ptr_allocator > | standard_allocator |
| typedef unsigned long long | id64_t |
| typedef unsigned int | id_t |
| typedef unsigned int | word_t |
| typedef unsigned short | short_t |
| typedef unsigned short | gap_word_t |
| typedef word_t | wordop_t |
| typedef void(* | gap_operation_to_bitset_func_type )(unsigned *, const gap_word_t *) |
| typedef gap_word_t *(* | gap_operation_func_type )(const gap_word_t *, const gap_word_t *, gap_word_t *, unsigned &) |
| typedef bm::id_t(* | bit_operation_count_func_type )(const bm::word_t *, const bm::word_t *, const bm::word_t *) |
| typedef bm::bvmini< bm::set_total_blocks > | standard_miniset |
| typedef mem_alloc< block_allocator, ptr_allocator > | standard_allocator |
| typedef decoder | decoder_big_endian |
| Class for decoding data from memory buffer. | |
Enumerations | |
| enum | distance_metric { COUNT_AND = set_COUNT_AND, COUNT_XOR = set_COUNT_XOR, COUNT_OR = set_COUNT_OR, COUNT_SUB_AB = set_COUNT_SUB_AB, COUNT_SUB_BA = set_COUNT_SUB_BA, COUNT_A = set_COUNT_A, COUNT_B = set_COUNT_B } |
| Distance metrics codes defined for vectors A and B. More... | |
| enum | strategy { BM_BIT = 0, BM_GAP = 1 } |
| Block allocation strategies. More... | |
| enum | set_operation { set_AND = 0, set_OR = 1, set_SUB = 2, set_XOR = 3, set_ASSIGN = 4, set_COUNT = 5, set_COUNT_AND = 6, set_COUNT_XOR = 7, set_COUNT_OR = 8, set_COUNT_SUB_AB = 9, set_COUNT_SUB_BA = 10, set_COUNT_A = 11, set_COUNT_B = 12, set_END } |
| Nomenclature of set operations. More... | |
| enum | operation { BM_AND = set_AND, BM_OR = set_OR, BM_SUB = set_SUB, BM_XOR = set_XOR } |
| Bit operations enumeration. More... | |
| enum | ByteOrder { BigEndian = 0, LittleEndian = 1 } |
| Byte orders recognized by the library. More... | |
| enum | serialization_header_mask { BM_HM_DEFAULT = 1, BM_HM_RESIZE = (1 << 1), BM_HM_ID_LIST = (1 << 2), BM_HM_NO_BO = (1 << 3), BM_HM_NO_GAPL = (1 << 4) } |
| enum | serialization_flags { BM_NO_BYTE_ORDER = 1, BM_NO_GAP_LENGTH = (1 << 1) } |
| Bit mask flags for serialization algorithm. More... | |
Functions | |
| template<class Alloc, class MS> | |
| bvector< Alloc, MS > | operator & (const bvector< Alloc, MS > &v1, const bvector< Alloc, MS > &v2) |
| template<class Alloc, class MS> | |
| bvector< Alloc, MS > | operator| (const bvector< Alloc, MS > &v1, const bvector< Alloc > &v2) |
| template<class Alloc, class MS> | |
| bvector< Alloc, MS > | operator^ (const bvector< Alloc, MS > &v1, const bvector< Alloc, MS > &v2) |
| template<class Alloc, class MS> | |
| bvector< Alloc, MS > | operator- (const bvector< Alloc, MS > &v1, const bvector< Alloc, MS > &v2) |
| distance_metric | operation2metric (set_operation op) |
| Convert set operation into compatible distance metric. | |
| void | combine_count_operation_with_block (const bm::word_t *blk, unsigned gap, const bm::word_t *arg_blk, int arg_gap, bm::word_t *temp_blk, distance_metric_descriptor *dmit, distance_metric_descriptor *dmit_end) |
| Internal function computes different distance metrics. | |
| void | combine_any_operation_with_block (const bm::word_t *blk, unsigned gap, const bm::word_t *arg_blk, int arg_gap, bm::word_t *temp_blk, distance_metric_descriptor *dmit, distance_metric_descriptor *dmit_end) |
| Internal function computes different existense of distance metric. | |
| unsigned | combine_count_operation_with_block (const bm::word_t *blk, unsigned gap, const bm::word_t *arg_blk, int arg_gap, bm::word_t *temp_blk, distance_metric metric) |
| unsigned | combine_any_operation_with_block (const bm::word_t *blk, unsigned gap, const bm::word_t *arg_blk, int arg_gap, bm::word_t *temp_blk, distance_metric metric) |
| template<class BV> | |
| bm::word_t * | distance_stage (const BV &bv1, const distance_metric_descriptor *dmit, const distance_metric_descriptor *dmit_end, bool *is_all_and) |
| Staging function for distance operation. | |
| template<class BV> | |
| void | distance_operation (const BV &bv1, const BV &bv2, distance_metric_descriptor *dmit, distance_metric_descriptor *dmit_end) |
| Distance computing template function. | |
| template<class BV> | |
| void | distance_operation_any (const BV &bv1, const BV &bv2, distance_metric_descriptor *dmit, distance_metric_descriptor *dmit_end) |
| Distance screening template function. | |
| template<class BV> | |
| bm::id_t | count_and (const BV &bv1, const BV &bv2) |
| Computes bitcount of AND operation of two bitsets. | |
| template<class BV> | |
| bm::id_t | any_and (const BV &bv1, const BV &bv2) |
| Computes if there is any bit in AND operation of two bitsets. | |
| template<class BV> | |
| bm::id_t | count_xor (const BV &bv1, const BV &bv2) |
| Computes bitcount of XOR operation of two bitsets. | |
| template<class BV> | |
| bm::id_t | any_xor (const BV &bv1, const BV &bv2) |
| Computes if there is any bit in XOR operation of two bitsets. | |
| template<class BV> | |
| bm::id_t | count_sub (const BV &bv1, const BV &bv2) |
| Computes bitcount of SUB operation of two bitsets. | |
| template<class BV> | |
| bm::id_t | any_sub (const BV &bv1, const BV &bv2) |
| Computes if there is any bit in SUB operation of two bitsets. | |
| template<class BV> | |
| bm::id_t | count_or (const BV &bv1, const BV &bv2) |
| Computes bitcount of OR operation of two bitsets. | |
| template<class BV> | |
| bm::id_t | any_or (const BV &bv1, const BV &bv2) |
| Computes if there is any bit in OR operation of two bitsets. | |
| template<class It> | |
| It | block_range_scan (It first, It last, unsigned nblock, unsigned *max_id) |
| Internal algorithms scans the input for the block range limit. | |
| template<class BV, class It> | |
| void | combine_or (BV &bv, It first, It last) |
| OR Combine bitvector and the iterable sequence. | |
| template<class BV, class It> | |
| void | combine_xor (BV &bv, It first, It last) |
| XOR Combine bitvector and the iterable sequence. | |
| template<class BV, class It> | |
| void | combine_sub (BV &bv, It first, It last) |
| SUB Combine bitvector and the iterable sequence. | |
| template<class BV, class It> | |
| void | combine_and_sorted (BV &bv, It first, It last) |
| AND Combine bitvector and the iterable sequence. | |
| template<class BV, class It> | |
| void | combine_and (BV &bv, It first, It last) |
| AND Combine bitvector and the iterable sequence. | |
| template<class BV> | |
| bm::id_t | count_intervals (const BV &bv) |
| Compute number of bit intervals (GAPs) in the bitvector. | |
| template<class BV, class It> | |
| void | export_array (BV &bv, It first, It last) |
| Export bitset from an array of binary data representing the bit vector. | |
| bm::id_t | word_bitcount (bm::id_t w) |
| unsigned | parallel_popcnt_32 (unsigned b) |
| bool | is_const_set_operation (set_operation op) |
| Returns true if set operation is constant (bitcount). | |
| bm::operation | setop2op (bm::set_operation op) |
| Convert set operation to operation. | |
| template<typename W> | |
| void | xor_swap (W &x, W &y) |
| XOR swap two scalar variables. | |
| template<typename T> | |
| int | wordcmp0 (T w1, T w2) |
| Lexicographical comparison of two words as bit strings. Auxiliary implementation for testing and reference purposes. | |
| template<typename T> | |
| int | wordcmp (T a, T b) |
| Lexicographical comparison of two words as bit strings. Auxiliary implementation for testing and reference purposes. | |
| template<typename T> | |
| unsigned | gap_bfind (const T *buf, unsigned pos, unsigned *is_set) |
| template<typename T> | |
| unsigned | gap_test (const T *buf, unsigned pos) |
| Tests if bit = pos is true. | |
| template<class T, class F> | |
| void | for_each_nzblock (T ***root, unsigned size1, unsigned size2, F &f) |
| template<class T, class F> | |
| bool | for_each_nzblock_if (T ***root, unsigned size1, unsigned size2, F &f) |
| template<class T, class F> | |
| void | for_each_block (T ***root, unsigned size1, unsigned size2, F &f) |
| template<class T, class F> | |
| F | bmfor_each (T first, T last, F f) |
| template<class T> | |
| T | sum_arr (T *first, T *last) |
| template<typename T> | |
| unsigned | gap_bit_count (const T *buf, unsigned dsize=0) |
| Calculates number of bits ON in GAP buffer. | |
| template<typename T> | |
| unsigned | gap_bit_count_range (const T *buf, T left, T right) |
| Counts 1 bits in GAP buffer in the closed [left, right] diapason. | |
| template<class T, class Func> | |
| void | for_each_dgap (const T *gap_buf, Func &func) |
| template<typename T> | |
| T * | gap_2_dgap (const T *gap_buf, T *dgap_buf, bool copy_head=true) |
| Convert GAP buffer into D-GAP buffer. | |
| template<typename T> | |
| void | dgap_2_gap (const T *dgap_buf, T *gap_buf, T gap_header=0) |
| Convert D-GAP buffer into GAP buffer. | |
| template<typename T> | |
| int | gapcmp (const T *buf1, const T *buf2) |
| Lexicographical comparison of GAP buffers. | |
| template<typename T, class F> | |
| void | gap_buff_op (T *dest, const T *vect1, unsigned vect1_mask, const T *vect2, unsigned vect2_mask, F &f, unsigned &dlen) |
| Abstract operation for GAP buffers. Receives functor F as a template argument. | |
| template<typename T, class F> | |
| unsigned | gap_buff_any_op (const T *vect1, unsigned vect1_mask, const T *vect2, unsigned vect2_mask, F f) |
| Abstract distance test operation for GAP buffers. Receives functor F as a template argument. | |
| template<typename T> | |
| unsigned | gap_set_value (unsigned val, T *buf, unsigned pos, unsigned *is_set) |
| Abstract distance(similarity) operation for GAP buffers. Receives functor F as a template argument Sets or clears bit in the GAP buffer. | |
| template<typename T> | |
| int | gap_find_in_block (const T *buf, unsigned nbit, bm::id_t *prev) |
| Searches for the next 1 bit in the GAP block. | |
| void | set_bit (unsigned *dest, unsigned bitpos) |
| Set 1 bit in a block. | |
| unsigned | test_bit (const unsigned *block, unsigned bitpos) |
| Test 1 bit in a block. | |
| void | or_bit_block (unsigned *dest, unsigned bitpos, unsigned bitcount) |
| Sets bits to 1 in the bitblock. | |
| void | sub_bit_block (unsigned *dest, unsigned bitpos, unsigned bitcount) |
| SUB (AND NOT) bit interval to 1 in the bitblock. | |
| void | xor_bit_block (unsigned *dest, unsigned bitpos, unsigned bitcount) |
| XOR bit interval to 1 in the bitblock. | |
| template<typename T> | |
| void | gap_sub_to_bitset (unsigned *dest, const T *buf) |
| SUB (AND NOT) GAP block to bitblock. | |
| template<typename T> | |
| void | gap_xor_to_bitset (unsigned *dest, const T *buf) |
| XOR GAP block to bitblock. | |
| template<typename T> | |
| void | gap_add_to_bitset (unsigned *dest, const T *buf) |
| Adds(OR) GAP block to bitblock. | |
| template<typename T> | |
| void | gap_and_to_bitset (unsigned *dest, const T *buf) |
| ANDs GAP block to bitblock. | |
| template<typename T> | |
| bm::id_t | gap_bitset_and_count (const unsigned *block, const T *buf) |
| Compute bitcount of bit block AND masked by GAP block. | |
| template<typename T> | |
| bm::id_t | gap_bitset_and_any (const unsigned *block, const T *buf) |
| Bitcount test of bit block AND masked by GAP block. | |
| template<typename T> | |
| bm::id_t | gap_bitset_sub_count (const unsigned *block, const T *buf) |
| Compute bitcount of bit block SUB masked by GAP block. | |
| template<typename T> | |
| bm::id_t | gap_bitset_sub_any (const unsigned *block, const T *buf) |
| Compute bitcount test of bit block SUB masked by GAP block. | |
| template<typename T> | |
| bm::id_t | gap_bitset_xor_count (const unsigned *block, const T *buf) |
| Compute bitcount of bit block XOR masked by GAP block. | |
| template<typename T> | |
| bm::id_t | gap_bitset_xor_any (const unsigned *block, const T *buf) |
| Compute bitcount test of bit block XOR masked by GAP block. | |
| template<typename T> | |
| bm::id_t | gap_bitset_or_count (const unsigned *block, const T *buf) |
| Compute bitcount of bit block OR masked by GAP block. | |
| template<typename T> | |
| bm::id_t | gap_bitset_or_any (const unsigned *block, const T *buf) |
| Compute bitcount test of bit block OR masked by GAP block. | |
| void | bit_block_set (bm::word_t *dst, bm::word_t value) |
| Bitblock memset operation. | |
| template<typename T> | |
| void | gap_convert_to_bitset (unsigned *dest, const T *buf) |
| GAP block to bitblock conversion. | |
| template<typename T> | |
| void | gap_convert_to_bitset (unsigned *dest, const T *buf, unsigned dest_len) |
| GAP block to bitblock conversion. | |
| template<typename T> | |
| unsigned * | gap_convert_to_bitset_smart (unsigned *dest, const T *buf, id_t set_max) |
| Smart GAP block to bitblock conversion. | |
| template<typename T> | |
| unsigned | gap_control_sum (const T *buf) |
| Calculates sum of all words in GAP block. (For debugging purposes). | |
| template<class T> | |
| void | gap_set_all (T *buf, unsigned set_max, unsigned value) |
| Sets all bits to 0 or 1 (GAP). | |
| template<class T> | |
| void | gap_init_range_block (T *buf, unsigned from, unsigned to, unsigned value, unsigned set_max) |
| Init gap block so it has block in it (can be whole block). | |
| template<typename T> | |
| void | gap_invert (T *buf) |
| Inverts all bits in the GAP buffer. | |
| template<typename T> | |
| bool | gap_is_all_zero (const T *buf, unsigned set_max) |
| Temporary inverts all bits in the GAP buffer.Checks if GAP block is all-zero. | |
| template<typename T> | |
| bool | gap_is_all_one (const T *buf, unsigned set_max) |
| Checks if GAP block is all-one. | |
| template<typename T> | |
| unsigned | gap_length (const T *buf) |
| Returs GAP block length. | |
| template<typename T> | |
| unsigned | gap_capacity (const T *buf, const T *glevel_len) |
| Returs GAP block capacity. | |
| template<typename T> | |
| unsigned | gap_limit (const T *buf, const T *glevel_len) |
| Returs GAP block capacity limit. | |
| template<typename T> | |
| unsigned | gap_level (const T *buf) |
| Returs GAP blocks capacity level. | |
| template<typename T> | |
| void | set_gap_level (T *buf, unsigned level) |
| Sets GAP block capacity level. | |
| template<typename T> | |
| int | gap_calc_level (int len, const T *glevel_len) |
| Calculates GAP block capacity level. | |
| template<typename T> | |
| unsigned | gap_free_elements (const T *buf, const T *glevel_len) |
| Returns number of free elements in GAP block array. Difference between GAP block capacity on this level and actual GAP length. | |
| template<typename T> | |
| int | bitcmp (const T *buf1, const T *buf2, unsigned len) |
| Lexicographical comparison of BIT buffers. | |
| template<typename T> | |
| unsigned | bit_convert_to_gap (T *dest, const unsigned *src, bm::id_t bits, unsigned dest_len) |
| Converts bit block to GAP. | |
| template<class T, class F> | |
| void | for_each_gap_dbit (const T *buf, F &func) |
| Iterate gap block as delta-bits with a functor. | |
| template<typename D, typename T> | |
| D | gap_convert_to_arr (D *dest, const T *buf, unsigned dest_len, bool invert=false) |
| Convert gap block into array of ints corresponding to 1 bits. | |
| bm::id_t | bit_block_calc_count (const bm::word_t *block, const bm::word_t *block_end) |
| Bitcount for bit string. | |
| bm::id_t | bit_count_change (bm::word_t w) |
| bm::id_t | bit_block_calc_count_change (const bm::word_t *block, const bm::word_t *block_end, unsigned *bit_count) |
| bm::id_t | bit_block_calc_count_range (const bm::word_t *block, bm::word_t left, bm::word_t right) |
| bm::id_t | bit_block_any_range (const bm::word_t *block, bm::word_t left, bm::word_t right) |
| template<typename T> | |
| void | bit_invert (T *start, T *end) |
| bool | is_bits_one (const bm::wordop_t *start, const bm::wordop_t *end) |
| Returns "true" if all bits in the block are 1. | |
| bool | bit_is_all_zero (const bm::wordop_t *start, const bm::wordop_t *end) |
| Returns "true" if all bits in the block are 0. | |
| unsigned | and_op (unsigned v1, unsigned v2) |
| GAP and functor. | |
| unsigned | xor_op (unsigned v1, unsigned v2) |
| GAP xor functor. | |
| gap_word_t * | gap_operation_and (const gap_word_t *vect1, const gap_word_t *vect2, gap_word_t *tmp_buf, unsigned &dsize) |
| GAP AND operation. | |
| unsigned | gap_operation_any_and (const gap_word_t *vect1, const gap_word_t *vect2) |
| GAP AND operation test. | |
| gap_word_t * | gap_operation_xor (const gap_word_t *vect1, const gap_word_t *vect2, gap_word_t *tmp_buf, unsigned &dsize) |
| GAP XOR operation. | |
| unsigned | gap_operation_any_xor (const gap_word_t *vect1, const gap_word_t *vect2) |
| GAP XOR operation test. | |
| gap_word_t * | gap_operation_or (const gap_word_t *vect1, const gap_word_t *vect2, gap_word_t *tmp_buf, unsigned &dsize) |
| GAP OR operation. | |
| gap_word_t * | gap_operation_sub (const gap_word_t *vect1, const gap_word_t *vect2, gap_word_t *tmp_buf, unsigned &dsize) |
| GAP SUB (AND NOT) operation. | |
| unsigned | gap_operation_any_sub (const gap_word_t *vect1, const gap_word_t *vect2) |
| GAP SUB operation test. | |
| void | bit_block_copy (bm::word_t *dst, const bm::word_t *src) |
| Bitblock copy operation. | |
| void | bit_block_and (bm::word_t *dst, const bm::word_t *src) |
| Plain bitblock AND operation. Function does not analyse availability of source and destination blocks. | |
| unsigned | bit_block_and_count (const bm::word_t *src1, const bm::word_t *src1_end, const bm::word_t *src2) |
| Function ANDs two bitblocks and computes the bitcount. Function does not analyse availability of source blocks. | |
| unsigned | bit_block_and_any (const bm::word_t *src1, const bm::word_t *src1_end, const bm::word_t *src2) |
| Function ANDs two bitblocks and tests for any bit. Function does not analyse availability of source blocks. | |
| unsigned | bit_block_xor_count (const bm::word_t *src1, const bm::word_t *src1_end, const bm::word_t *src2) |
| Function XORs two bitblocks and computes the bitcount. Function does not analyse availability of source blocks. | |
| unsigned | bit_block_xor_any (const bm::word_t *src1, const bm::word_t *src1_end, const bm::word_t *src2) |
| Function XORs two bitblocks and and tests for any bit. Function does not analyse availability of source blocks. | |
| unsigned | bit_block_sub_count (const bm::word_t *src1, const bm::word_t *src1_end, const bm::word_t *src2) |
| Function SUBs two bitblocks and computes the bitcount. Function does not analyse availability of source blocks. | |
| unsigned | bit_block_sub_any (const bm::word_t *src1, const bm::word_t *src1_end, const bm::word_t *src2) |
| Function SUBs two bitblocks and and tests for any bit. Function does not analyse availability of source blocks. | |
| unsigned | bit_block_or_count (const bm::word_t *src1, const bm::word_t *src1_end, const bm::word_t *src2) |
| Function ORs two bitblocks and computes the bitcount. Function does not analyse availability of source blocks. | |
| unsigned | bit_block_or_any (const bm::word_t *src1, const bm::word_t *src1_end, const bm::word_t *src2) |
| Function ORs two bitblocks and and tests for any bit. Function does not analyse availability of source blocks. | |
| bm::word_t * | bit_operation_and (bm::word_t *dst, const bm::word_t *src) |
| bitblock AND operation. | |
| bm::id_t | bit_operation_and_count (const bm::word_t *src1, const bm::word_t *src1_end, const bm::word_t *src2) |
| Performs bitblock AND operation and calculates bitcount of the result. | |
| bm::id_t | bit_operation_and_any (const bm::word_t *src1, const bm::word_t *src1_end, const bm::word_t *src2) |
| Performs bitblock AND operation test. | |
| bm::id_t | bit_operation_sub_count (const bm::word_t *src1, const bm::word_t *src1_end, const bm::word_t *src2) |
| Performs bitblock SUB operation and calculates bitcount of the result. | |
| bm::id_t | bit_operation_sub_count_inv (const bm::word_t *src1, const bm::word_t *src1_end, const bm::word_t *src2) |
| Performs inverted bitblock SUB operation and calculates bitcount of the result. | |
| bm::id_t | bit_operation_sub_any (const bm::word_t *src1, const bm::word_t *src1_end, const bm::word_t *src2) |
| Performs bitblock test of SUB operation. | |
| bm::id_t | bit_operation_or_count (const bm::word_t *src1, const bm::word_t *src1_end, const bm::word_t *src2) |
| Performs bitblock OR operation and calculates bitcount of the result. | |
| bm::id_t | bit_operation_or_any (const bm::word_t *src1, const bm::word_t *src1_end, const bm::word_t *src2) |
| Performs bitblock OR operation test. | |
| void | bit_block_or (bm::word_t *dst, const bm::word_t *src) |
| Plain bitblock OR operation. Function does not analyse availability of source and destination blocks. | |
| bm::word_t * | bit_operation_or (bm::word_t *dst, const bm::word_t *src) |
| Block OR operation. Makes analysis if block is 0 or FULL. | |
| void | bit_block_sub (bm::word_t *dst, const bm::word_t *src) |
| Plain bitblock SUB (AND NOT) operation. Function does not analyse availability of source and destination blocks. | |
| bm::word_t * | bit_operation_sub (bm::word_t *dst, const bm::word_t *src) |
| bitblock SUB operation. | |
| void | bit_block_xor (bm::word_t *dst, const bm::word_t *src) |
| Plain bitblock XOR operation. Function does not analyse availability of source and destination blocks. | |
| bm::word_t * | bit_operation_xor (bm::word_t *dst, const bm::word_t *src) |
| bitblock XOR operation. | |
| bm::id_t | bit_operation_xor_count (const bm::word_t *src1, const bm::word_t *src1_end, const bm::word_t *src2) |
| Performs bitblock XOR operation and calculates bitcount of the result. | |
| bm::id_t | bit_operation_xor_any (const bm::word_t *src1, const bm::word_t *src1_end, const bm::word_t *src2) |
| Performs bitblock XOR operation test. | |
| template<class T> | |
| unsigned | bit_count_nonzero_size (const T *blk, unsigned data_size) |
| Inspects block for full zero words. | |
| int | bit_find_in_block (const bm::word_t *data, unsigned nbit, bm::id_t *prev) |
| Searches for the next 1 bit in the BIT block. | |
| template<typename T, typename F> | |
| void | bit_for_each_4 (T w, F &func) |
| Templated algorithm to unpacks octet based word into list of ON bit indexes. | |
| template<typename T, typename F> | |
| void | bit_for_each (T w, F &func) |
| Templated algorithm to unpacks word into list of ON bit indexes. | |
| template<typename T, typename B> | |
| unsigned | bit_list_4 (T w, B *bits) |
| Unpacks word into list of ON bit indexes (quad-bit based). | |
| template<typename T, typename B> | |
| unsigned | bit_list (T w, B *bits) |
| Unpacks word into list of ON bit indexes. | |
| template<typename T> | |
| T | bit_convert_to_arr (T *dest, const unsigned *src, bm::id_t bits, unsigned dest_len, unsigned mask=0) |
| Convert bit block into an array of ints corresponding to 1 bits. | |
| template<typename T> | |
| unsigned | gap_overhead (const T *length, const T *length_end, const T *glevel_len) |
| Convert bit block into an array of ints corresponding to 1 bits Calculates memory overhead for number of gap blocks sharing the same memory allocation table (level lengths table). | |
| template<typename T> | |
| bool | improve_gap_levels (const T *length, const T *length_end, T *glevel_len) |
| Finds optimal gap blocks lengths. | |
| template<class It1, class It2, class BinaryOp, class Encoder> | |
| void | bit_recomb (It1 &it1, It2 &it2, BinaryOp &op, Encoder &enc, unsigned block_size=bm::set_block_size) |
| template<class BV> | |
| unsigned | serialize (const BV &bv, unsigned char *buf, bm::word_t *temp_block, unsigned serialization_flags=0) |
| Saves bitvector into memory. | |
| template<class BV> | |
| unsigned | serialize (BV &bv, unsigned char *buf, unsigned serialization_flags=0) |
| Saves bitvector into memory. Allocates temporary memory block for bvector. | |
| template<class BV> | |
| unsigned | deserialize (BV &bv, const unsigned char *buf, bm::word_t *temp_block=0) |
| Bitvector deserialization from memory. | |
| bm::id_t | sse2_bit_count (const __m128i *block, const __m128i *block_end) |
| template<class Func> | |
| bm::id_t | sse2_bit_count_op (const __m128i *block, const __m128i *block_end, const __m128i *mask_block, Func sse2_func) |
| bm::id_t | sse2_bit_block_calc_count_change (const __m128i *block, const __m128i *block_end, unsigned *bit_count) |
| bm::id_t | sse4_bit_count (const __m128i *block, const __m128i *block_end) |
| unsigned | op_xor (unsigned a, unsigned b) |
| unsigned | op_or (unsigned a, unsigned b) |
| unsigned | op_and (unsigned a, unsigned b) |
| template<class Func> | |
| bm::id_t | sse4_bit_count_op (const __m128i *block, const __m128i *block_end, const __m128i *mask_block, Func sse2_func) |
| template<class Func> | |
| bm::id_t | sse4_bit_count_op2 (const __m128i *block, const __m128i *block_end, const __m128i *mask_block, Func op_func) |
| bm::id_t | sse4_bit_block_calc_count_change (const __m128i *block, const __m128i *block_end, unsigned *bit_count) |
| BMFORCEINLINE void | sse2_xor_arr_2_mask (__m128i *BMRESTRICT dst, const __m128i *BMRESTRICT src, const __m128i *BMRESTRICT src_end, bm::word_t mask) |
| XOR array elements to specified mask dst = *src ^ mask. | |
| BMFORCEINLINE void | sse2_andnot_arr_2_mask (__m128i *BMRESTRICT dst, const __m128i *BMRESTRICT src, const __m128i *BMRESTRICT src_end, bm::word_t mask) |
| Inverts array elements and NOT them to specified mask dst = ~*src & mask. | |
| BMFORCEINLINE void | sse2_and_arr (__m128i *BMRESTRICT dst, const __m128i *BMRESTRICT src, const __m128i *BMRESTRICT src_end) |
| AND array elements against another array dst &= *src. | |
| BMFORCEINLINE void | sse2_or_arr (__m128i *BMRESTRICT dst, const __m128i *BMRESTRICT src, const __m128i *BMRESTRICT src_end) |
| OR array elements against another array dst |= *src. | |
| BMFORCEINLINE void | sse2_xor_arr (__m128i *BMRESTRICT dst, const __m128i *BMRESTRICT src, const __m128i *BMRESTRICT src_end) |
| OR array elements against another array dst ^= *src. | |
| BMFORCEINLINE void | sse2_sub_arr (__m128i *BMRESTRICT dst, const __m128i *BMRESTRICT src, const __m128i *BMRESTRICT src_end) |
| AND-NOT (SUB) array elements against another array dst &= ~*src. | |
| BMFORCEINLINE void | sse2_set_block (__m128i *BMRESTRICT dst, __m128i *BMRESTRICT dst_end, bm::word_t value) |
| SSE2 block memset dst = value. | |
| BMFORCEINLINE void | sse2_copy_block (__m128i *BMRESTRICT dst, const __m128i *BMRESTRICT src, const __m128i *BMRESTRICT src_end) |
| SSE2 block copy dst = *src. | |
| BMFORCEINLINE void | sse2_invert_arr (bm::word_t *first, bm::word_t *last) |
| Invert array elements dst = ~*dst or dst ^= *dst. | |
| BMFORCEINLINE __m128i | sse2_and (__m128i a, __m128i b) |
| BMFORCEINLINE __m128i | sse2_or (__m128i a, __m128i b) |
| BMFORCEINLINE __m128i | sse2_xor (__m128i a, __m128i b) |
| BMFORCEINLINE __m128i | sse2_sub (__m128i a, __m128i b) |
| template<typename T, unsigned BPC, unsigned BPS> | |
| void | vect_bit_transpose (const T *arr, unsigned arr_size, T tmatrix[BPC][BPS]) |
| Generic bit-array transposition function T - array type (any int) BPC - bit plain count BPS - bit plain size. | |
| template<typename T, unsigned BPC, unsigned BPS> | |
| void | vect_bit_trestore (const T tmatrix[BPC][BPS], T *arr) |
| Restore bit array from the transposition matrix T - array type (any int) BPC - bit plain count BPS - bit plain size. | |
| template<typename T, unsigned BPC, unsigned BPS> | |
| void | tmatrix_distance (const T tmatrix[BPC][BPS], unsigned distance[BPC][BPC]) |
| Compute pairwise Row x Row Humming distances on plains(rows) of the transposed bit block. | |
| template<typename T, unsigned BPC, unsigned BPS> | |
| void | bit_iblock_make_pcv (const unsigned distance[BPC][BPC], unsigned char *pc_vector) |
| !< ibpc limiter Make a compression descriptor vector for bit-plains | |
| void | bit_iblock_pcv_stat (const unsigned char *BMRESTRICT pc_vector, const unsigned char *BMRESTRICT pc_vector_end, unsigned *BMRESTRICT pc_vector_stat) |
| Compute number of ibpc codes in pc_vector. | |
| void | bit_iblock_reduce (const unsigned tmatrix[bm::set_block_plain_cnt][bm::set_block_plain_size], const unsigned char *BMRESTRICT pc_vector, const unsigned char *BMRESTRICT pc_vector_end, unsigned tmatrix_out[bm::set_block_plain_cnt][bm::set_block_plain_size]) |
| Matrix reduction based on transformation pc vector. | |
| template<typename GT, typename BT> | |
| void | gap_2_bitblock (const GT *BMRESTRICT gap_buf, BT *BMRESTRICT block, unsigned block_size) |
| Copy GAP block body to bit block with DGap transformation. | |
| template<typename TM> | |
| unsigned | find_effective_columns (const TM &tmatrix) |
| Compute effective right column border of the t-matrix. | |
| template<typename T> | |
| T | bit_scan_fwd (T v) |
| template<typename T> | |
| T | ilog2 (T x) |
| Fast loop-less function to find LOG2. | |
| template<> | |
| bm::gap_word_t | ilog2 (gap_word_t x) |
| template<typename T> | |
| T | ilog2_LUT (T x) |
| Lookup table based integer LOG2. | |
| template<> | |
| bm::gap_word_t | ilog2_LUT< bm::gap_word_t > (bm::gap_word_t x) |
| Lookup table based short integer LOG2. | |
Variables | |
| const unsigned | id_max = 0xFFFFFFFF |
| const unsigned | set_block_size = 2048u |
| const unsigned | set_block_shift = 16u |
| const unsigned | set_block_mask = 0xFFFFu |
| const unsigned | set_blkblk_mask = 0xFFFFFFu |
| const unsigned | set_block_plain_size = set_block_size / 32u |
| const unsigned | set_block_plain_cnt = sizeof(bm::word_t) * 8u |
| const unsigned | set_word_shift = 5u |
| const unsigned | set_word_mask = 0x1Fu |
| const unsigned | gap_max_buff_len = 1280 |
| const unsigned | gap_max_bits = 65536 |
| const unsigned | gap_equiv_len |
| const unsigned | gap_levels = 4 |
| const unsigned | gap_max_level = bm::gap_levels - 1 |
| const unsigned | set_array_size = 256u |
| const unsigned | set_array_shift = 8u |
| const unsigned | set_array_mask = 0xFFu |
| const unsigned | set_total_blocks = (bm::set_array_size * bm::set_array_size) |
| const unsigned | bits_in_block = bm::set_block_size * sizeof(bm::word_t) * 8 |
| const unsigned | bits_in_array = bm::bits_in_block * bm::set_array_size |
| const word_t | all_bits_mask = 0xffffffff |
| const unsigned | set_block_size_op = bm::set_block_size |
| const unsigned char | set_block_end = 0 |
| End of serialization. | |
| const unsigned char | set_block_1zero = 1 |
| One all-zero block. | |
| const unsigned char | set_block_1one = 2 |
| One block all-set (1111...). | |
| const unsigned char | set_block_8zero = 3 |
| Up to 256 zero blocks. | |
| const unsigned char | set_block_8one = 4 |
| Up to 256 all-set blocks. | |
| const unsigned char | set_block_16zero = 5 |
| Up to 65536 zero blocks. | |
| const unsigned char | set_block_16one = 6 |
| UP to 65536 all-set blocks. | |
| const unsigned char | set_block_32zero = 7 |
| Up to 4G zero blocks. | |
| const unsigned char | set_block_32one = 8 |
| UP to 4G all-set blocks. | |
| const unsigned char | set_block_azero = 9 |
| All other blocks zero. | |
| const unsigned char | set_block_aone = 10 |
| All other blocks one. | |
| const unsigned char | set_block_bit = 11 |
| Plain bit block. | |
| const unsigned char | set_block_sgapbit = 12 |
| SGAP compressed bitblock. | |
| const unsigned char | set_block_sgapgap = 13 |
| SGAP compressed GAP block. | |
| const unsigned char | set_block_gap = 14 |
| Plain GAP block. | |
| const unsigned char | set_block_gapbit = 15 |
| GAP compressed bitblock. | |
| const unsigned char | set_block_arrbit = 16 |
| List of bits ON. | |
| const unsigned char | set_block_bit_interval = 17 |
| Interval block. | |
| const unsigned char | set_block_arrgap = 18 |
| List of bits ON (GAP block). | |
| const unsigned char | set_block_bit_1bit = 19 |
| Bit block with 1 bit ON. | |
| const unsigned char | set_block_gap_egamma = 20 |
| Gamma compressed GAP block. | |
| const unsigned char | set_block_arrgap_egamma = 21 |
| Gamma compressed delta GAP array. | |
| const unsigned char | set_block_bit_0runs = 22 |
| Bit block with encoded zero intervals. | |
| const unsigned char | set_block_arrgap_egamma_inv = 23 |
| Gamma compressed inverted delta GAP array. | |
| const unsigned char | set_block_arrgap_inv = 24 |
| List of bits OFF (GAP block). | |
| const unsigned char | ibpc_uncompr = 0 |
| const unsigned char | ibpc_all_zero = 1 |
| !< plain uncompressed | |
| const unsigned char | ibpc_all_one = 2 |
| !< plain ALL ZERO | |
| const unsigned char | ibpc_equiv = 3 |
| !< plain ALL ONE | |
| const unsigned char | ibpc_close = 4 |
| !< plain is equal to plain M | |
| const unsigned char | ibpc_end = 8 |
| !< plain is close to plain M | |
|
|
|
|
|
Class for decoding data from memory buffer. Properly handles aligment issues with integer data types. Converts data to big endian architecture (presumed it was encoded as little endian) Definition at line 114 of file encoding.h. |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Byte orders recognized by the library.
|
|
|
Bit operations enumeration.
|
|
|
Definition at line 95 of file bmserial.h. |
|
|
Nomenclature of set operations.
|
|
||||||||||||
|
GAP and functor.
Definition at line 2883 of file bmfunc.h. Referenced by gap_operation_and(), gap_operation_any_and(), gap_operation_any_sub(), gap_operation_or(), and gap_operation_sub(). |
|
||||||||||||||||
|
Compute number of ibpc codes in pc_vector.
Definition at line 457 of file bmtrans.h. References BM_ASSERT. |
|
||||||||||||||||||||
|
Matrix reduction based on transformation pc vector.
Definition at line 478 of file bmtrans.h. References BM_ASSERT, ibpc_all_one, ibpc_all_zero, ibpc_close, ibpc_equiv, and ibpc_uncompr. |
|
||||||||||||||||||||||||||||
|
Abstract recombination algorithm for two bit-blocks Bit blocks can come as dserialization decoders or bit-streams Definition at line 4631 of file bmfunc.h. Referenced by bm::serial_stream_iterator< DEC >::get_bit_block_COUNT_OR(), bm::serial_stream_iterator< DEC >::get_bit_block_COUNT_SUB_AB(), bm::serial_stream_iterator< DEC >::get_bit_block_COUNT_SUB_BA(), bm::serial_stream_iterator< DEC >::get_bit_block_COUNT_XOR(), bm::serial_stream_iterator< DEC >::get_bit_block_OR(), and TestRecomb(). |
|
||||||||||
|
Definition at line 54 of file bmutil.h. Referenced by bm::bit_in< TDecoder >::gamma(). |
|
||||||||||||||||||||||||
|
Internal algorithms scans the input for the block range limit.
Definition at line 1075 of file bmalgo_impl.h. References BM_ASSERT, id_max, and set_block_shift. Referenced by combine_or(), combine_sub(), and combine_xor(). |
|
||||||||||||||||||||
|
Special BM optimized analog of STL for_each Definition at line 586 of file bmfunc.h. References f(). |
|
||||||||||||||||||||||||||||
|
Convenience internal function to compute combine any for one metric Definition at line 619 of file bmalgo_impl.h. References combine_any_operation_with_block(), and bm::distance_metric_descriptor::result. |
|
||||||||||||||||||||||||||||||||
|
Internal function computes different existense of distance metric.
Definition at line 343 of file bmalgo_impl.h. References BMGAP_PTR, COUNT_A, COUNT_AND, COUNT_B, COUNT_OR, COUNT_SUB_AB, COUNT_SUB_BA, COUNT_XOR, gap_is_all_zero(), gap_max_bits, gap_max_buff_len, gap_operation_any_and(), gap_operation_any_sub(), gap_operation_any_xor(), and gap_operation_or(). Referenced by combine_any_operation_with_block(). |
|
||||||||||||||||||||||||||||
|
Convenience internal function to compute combine count for one metric Definition at line 597 of file bmalgo_impl.h. References combine_count_operation_with_block(), and bm::distance_metric_descriptor::result. |
|
||||||||||||||||||||||||||||||||
|
Internal function computes different distance metrics.
Definition at line 114 of file bmalgo_impl.h. References BMGAP_PTR, COUNT_A, COUNT_AND, COUNT_B, COUNT_OR, COUNT_SUB_AB, COUNT_SUB_BA, COUNT_XOR, gap_bit_count(), gap_equiv_len, gap_operation_and(), gap_operation_or(), gap_operation_sub(), and gap_operation_xor(). Referenced by combine_count_operation_with_block(), and bm::bvector< Alloc, MS >::combine_count_operation_with_block(). |
|
||||||||||||||||||||
|
Convert D-GAP buffer into GAP buffer. GAP representation is GAP[N] = DGAP[N] + DGAP[N-1]
Definition at line 766 of file bmfunc.h. References len. |
|
||||||||||||||||||||||||
|
Staging function for distance operation.
Definition at line 642 of file bmalgo_impl.h. References COUNT_SUB_AB, and COUNT_SUB_BA. Referenced by distance_operation(), and distance_operation_any(). |
|
||||||||||
|
Compute effective right column border of the t-matrix.
Definition at line 557 of file bmtrans.h. Referenced by bm::gap_transpose_engine< GT, BT, BLOCK_SIZE >::transpose(). |
|
||||||||||||||||||||||||
|
For each block executes supplied function. Definition at line 557 of file bmfunc.h. References f(). Referenced by count_intervals(), bm::bvector< Alloc, MS >::invert(), and bm::blocks_manager< Alloc, MS >::set_all_one(). |
|
||||||||||||||||
|
D-GAP block for_each algorithm D-Gap Functor is called for each element but last one.
Definition at line 701 of file bmfunc.h. Referenced by bm::serializer< BV >::gamma_gap_block(). |
|
||||||||||||||||||||||||
|
For each non-zero block executes supplied function. Definition at line 492 of file bmfunc.h. Referenced by bm::blocks_manager< Alloc, MS >::blocks_manager(), bm::bvector< Alloc, MS >::count(), bm::bvector< Alloc, MS >::count_blocks(), bm::blocks_manager< Alloc, MS >::deinit_tree(), bm::bvector< Alloc, MS >::optimize(), bm::blocks_manager< Alloc, MS >::set_all_zero(), and bm::bvector< Alloc, MS >::set_gap_levels(). |
|
||||||||||||||||||||||||
|
For each non-zero block executes supplied function-predicate. Function returns if function-predicate returns true Definition at line 532 of file bmfunc.h. References set_array_size. Referenced by bm::bvector< Alloc, MS >::any(). |
|
||||||||||||||||||||
|
Copy GAP block body to bit block with DGap transformation.
Definition at line 535 of file bmtrans.h. References GT. Referenced by bm::gap_transpose_engine< GT, BT, BLOCK_SIZE >::transpose(). |
|
||||||||||||||||||||
|
Convert GAP buffer into D-GAP buffer. Delta GAP representation is DGAP[N] = GAP[N] - GAP[N-1]
Definition at line 742 of file bmfunc.h. References bm::d_copy_func< T >::dgap_buf_. |
|
||||||||||||||||||||
|
Definition at line 426 of file bmfunc.h. References BM_ASSERT, and gap_max_bits. Referenced by gap_bit_count_range(), gap_find_in_block(), and gap_set_value(). |
|
||||||||||||||||||||
|
Counts 1 bits in GAP buffer in the closed [left, right] diapason.
Definition at line 654 of file bmfunc.h. References BM_ASSERT, and gap_bfind(). Referenced by gap_vector::count_range(), and bm::bvector< Alloc, MS >::count_range(). |
|
||||||||||||||||||||||||||||||||||||
|
Abstract operation for GAP buffers. Receives functor F as a template argument.
Definition at line 873 of file bmfunc.h. References f(), and gap_max_bits. Referenced by gap_operation_and(), gap_operation_or(), gap_operation_sub(), and gap_operation_xor(). |
|
||||||||||
|
|
|
||||||||||
|
Fast loop-less function to find LOG2.
|
|
||||||||||
|
Lookup table based integer LOG2.
Definition at line 93 of file bmutil.h. Referenced by bm::bit_out< TEncoder >::gamma(). |
|
||||||||||
|
Lookup table based short integer LOG2.
|
|
|
Returns true if set operation is constant (bitcount).
Definition at line 231 of file bmfunc.h. References set_COUNT. Referenced by operation2metric(). |
|
||||||||||||
|
|
|
||||||||||||
|
|
|
||||||||||||
|
|
|
||||||||||||||||
|
Definition at line 1555 of file bm.h. References bm::bvector< Alloc, MS >::bit_and(). |
|
||||||||||||||||
|
Definition at line 1600 of file bm.h. References bm::bvector< Alloc, MS >::bit_sub(). |
|
||||||||||||||||
|
Definition at line 1585 of file bm.h. References bm::bvector< Alloc, MS >::bit_xor(). |
|
||||||||||||||||
|
Definition at line 1570 of file bm.h. References bm::bvector< Alloc, MS >::bit_or(). |
|
|
|
|
|
Convert set operation to operation.
Definition at line 251 of file bmfunc.h. References BM_ASSERT, set_AND, set_OR, set_SUB, and set_XOR. |
|
||||||||||||
|
Definition at line 379 of file bmsse_util.h. |
|
||||||||||||||||
|
Definition at line 248 of file bmsse2.h. References BM_ALIGN16, BM_ALIGN16ATTR, BM_INCWORD_BITCOUNT, m1, and m2. Referenced by bit_block_calc_count_change(). |
|
||||||||||||||||||||||||
|
Definition at line 136 of file bmsse2.h. References BM_ALIGN16, BM_ALIGN16ATTR, m1, and m2. |
|
||||||||||||
|
Definition at line 385 of file bmsse_util.h. |
|
||||||||||||
|
Definition at line 398 of file bmsse_util.h. |
|
||||||||||||
|
Definition at line 392 of file bmsse_util.h. |
|
||||||||||||||||||||||||
|
|
|
||||||||||||||||||||||||
|
|
|
||||||||||||||||
|
Computes SUM of all elements of the sequence |
|
||||||||||||||||||||
|
Generic bit-array transposition function T - array type (any int) BPC - bit plain count BPS - bit plain size.
Definition at line 274 of file bmtrans.h. References BM_ASSERT. |
|
||||||||||||||||
|
Restore bit array from the transposition matrix T - array type (any int) BPC - bit plain count BPS - bit plain size.
|
|
||||||||||||
|
GAP xor functor.
Definition at line 2890 of file bmfunc.h. Referenced by gap_operation_any_xor(), and gap_operation_xor(). |
|
||||||||||||||||
|
XOR swap two scalar variables.
Definition at line 286 of file bmfunc.h. References BM_ASSERT. Referenced by bm::blocks_manager< Alloc, MS >::swap(), and bm::bvector< Alloc, MS >::swap(). |
|
|
Definition at line 101 of file bmconst.h. Referenced by is_bits_one(). |
|
|
Definition at line 86 of file bmconst.h. Referenced by bm::bvector< Alloc, MS >::enumerator::go_first(). |
|
|
|
Initial value: (sizeof(bm::word_t) * bm::set_block_size) / sizeof(gap_word_t) Definition at line 72 of file bmconst.h. Referenced by combine_count_operation_with_block(), bm::bvector< Alloc, MS >::combine_operation_with_block(), bm::iterator_deserializer< BV, SerialIterator >::deserialize(), and bm::serializer< BV >::encode_gap_block(). |
|
|
|
|
Definition at line 70 of file bmconst.h. Referenced by gap_vector::combine_and(), combine_any_operation_with_block(), gap_vector::combine_or(), gap_vector::combine_sub(), gap_vector::combine_xor(), and bm::blocks_manager< Alloc, MS >::extend_gap_block(). |
|
|
Definition at line 75 of file bmconst.h. Referenced by bm::blocks_manager< Alloc, MS >::extend_gap_block(), and bm::blocks_manager< Alloc, MS >::block_opt_func::operator()(). |
|
|
!< plain ALL ZERO
Definition at line 377 of file bmtrans.h. Referenced by bit_iblock_make_pcv(), and bit_iblock_reduce(). |
|
|
!< plain uncompressed
Definition at line 376 of file bmtrans.h. Referenced by bit_iblock_make_pcv(), and bit_iblock_reduce(). |
|
|
!< plain is equal to plain M
Definition at line 379 of file bmtrans.h. Referenced by bit_iblock_reduce(). |
|
|
!< plain is close to plain M
|
|
|
!< plain ALL ONE
Definition at line 378 of file bmtrans.h. Referenced by bit_iblock_reduce(). |
|
|
Definition at line 375 of file bmtrans.h. Referenced by bit_iblock_make_pcv(), and bit_iblock_reduce(). |
|
|
|
Definition at line 82 of file bmconst.h. Referenced by bm::blocks_manager< Alloc, MS >::get_block(), bm::blocks_manager< Alloc, MS >::get_block_coord(), bm::blocks_manager< Alloc, MS >::set_block(), and bm::blocks_manager< Alloc, MS >::set_block_ptr(). |
|
|
Definition at line 81 of file bmconst.h. Referenced by bm::blocks_manager< Alloc, MS >::get_block(), bm::blocks_manager< Alloc, MS >::get_block_coord(), bm::blocks_manager< Alloc, MS >::set_block(), and bm::blocks_manager< Alloc, MS >::set_block_ptr(). |
|
|
|
Definition at line 55 of file bmconst.h. Referenced by bm::bvector< Alloc, MS >::check_or_next(), and bm::bvector< Alloc, MS >::check_or_next_extract(). |
|
|
UP to 65536 all-set blocks.
Definition at line 72 of file bmserial.h. Referenced by bm::serial_stream_iterator< DEC >::next(), and bm::serializer< BV >::serialize(). |
|
|
Up to 65536 zero blocks.
Definition at line 71 of file bmserial.h. Referenced by bm::serial_stream_iterator< DEC >::next(), and bm::serializer< BV >::serialize(). |
|
|
One block all-set (1111...).
Definition at line 68 of file bmserial.h. Referenced by bm::serial_stream_iterator< DEC >::next(), and bm::serializer< BV >::serialize(). |
|
|
One all-zero block.
Definition at line 67 of file bmserial.h. Referenced by bm::serial_stream_iterator< DEC >::next(), and bm::serializer< BV >::serialize(). |
|
|
UP to 4G all-set blocks.
Definition at line 74 of file bmserial.h. Referenced by bm::serial_stream_iterator< DEC >::next(), and bm::serializer< BV >::serialize(). |
|
|
Up to 4G zero blocks.
Definition at line 73 of file bmserial.h. Referenced by bm::serial_stream_iterator< DEC >::next(), and bm::serializer< BV >::serialize(). |
|
|
Up to 256 all-set blocks.
Definition at line 70 of file bmserial.h. Referenced by bm::serial_stream_iterator< DEC >::next(), and bm::serializer< BV >::serialize(). |
|
|
Up to 256 zero blocks.
Definition at line 69 of file bmserial.h. Referenced by bm::serial_stream_iterator< DEC >::next(), and bm::serializer< BV >::serialize(). |
|
|
All other blocks one.
Definition at line 76 of file bmserial.h. Referenced by bm::serial_stream_iterator< DEC >::next(), and bm::serializer< BV >::serialize(). |
|
|
List of bits ON.
Definition at line 82 of file bmserial.h. Referenced by bm::serial_stream_iterator< DEC >::get_arr_bit(), and bm::serial_stream_iterator< DEC >::next(). |
|
|
List of bits ON (GAP block).
Definition at line 84 of file bmserial.h. Referenced by bm::serial_stream_iterator< DEC >::next(), and bm::deseriaizer_base< DEC >::read_gap_block(). |
|
|
Gamma compressed delta GAP array.
Definition at line 87 of file bmserial.h. Referenced by bm::serializer< BV >::gamma_gap_array(), bm::serial_stream_iterator< DEC >::next(), and bm::deseriaizer_base< DEC >::read_gap_block(). |
|
|
Gamma compressed inverted delta GAP array.
Definition at line 89 of file bmserial.h. Referenced by bm::serializer< BV >::gamma_gap_array(), bm::serial_stream_iterator< DEC >::next(), and bm::deseriaizer_base< DEC >::read_gap_block(). |
|
|
List of bits OFF (GAP block).
Definition at line 90 of file bmserial.h. Referenced by bm::serial_stream_iterator< DEC >::next(), and bm::deseriaizer_base< DEC >::read_gap_block(). |
|
|
All other blocks zero.
Definition at line 75 of file bmserial.h. Referenced by bm::serial_stream_iterator< DEC >::next(), and bm::serializer< BV >::serialize(). |
|
|
|
|
Bit block with 1 bit ON.
Definition at line 85 of file bmserial.h. Referenced by bm::serializer< BV >::encode_gap_block(), bm::serial_stream_iterator< DEC >::get_arr_bit(), bm::serial_stream_iterator< DEC >::get_gap_block(), bm::serial_stream_iterator< DEC >::next(), and bm::deseriaizer_base< DEC >::read_gap_block(). |
|
|
Interval block.
Definition at line 83 of file bmserial.h. Referenced by bm::serial_stream_iterator< DEC >::get_bit_block_OR(), and bm::serial_stream_iterator< DEC >::next(). |
|
|
End of serialization.
Definition at line 66 of file bmserial.h. Referenced by bm::serial_stream_iterator< DEC >::next(). |
|
|
Plain GAP block.
Definition at line 80 of file bmserial.h. Referenced by bm::deserializer< BV, DEC >::deserialize_gap(), bm::serializer< BV >::gamma_gap_block(), bm::serial_stream_iterator< DEC >::next(), and bm::deseriaizer_base< DEC >::read_gap_block(). |
|
|
Gamma compressed GAP block.
Definition at line 86 of file bmserial.h. Referenced by bm::serializer< BV >::gamma_gap_block(), and bm::serial_stream_iterator< DEC >::next(). |
|
|
GAP compressed bitblock.
Definition at line 81 of file bmserial.h. Referenced by bm::deserializer< BV, DEC >::deserialize_gap(), and bm::serial_stream_iterator< DEC >::next(). |
|
|
|
|
|
|
|
|
|
SGAP compressed bitblock.
Definition at line 78 of file bmserial.h. |
|
|
SGAP compressed GAP block.
Definition at line 79 of file bmserial.h. |
|
|
|
|
|
|
|
Definition at line 83 of file bmconst.h. Referenced by bm::bvector< Alloc, MS >::check_or_next(), bm::bvector< Alloc, MS >::check_or_next_extract(), CompareMiniSet(), export_array(), main(), MiniSetTest(), print_stat(), and bm::serializer< BV >::serialize(). |
|
|
1.4.6
Modified on Mon Dec 07 16:24:37 2009 by modify_doxy.py rev. 173732