summaryrefslogtreecommitdiff
path: root/girepository/cmph/brz_structs.h
blob: b781107f9aa7ca5dc33d6f1a9e92b213fd86c946 (plain)
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
#ifndef __CMPH_BRZ_STRUCTS_H__
#define __CMPH_BRZ_STRUCTS_H__

#include "hash_state.h"

struct __brz_data_t
{
	CMPH_ALGO algo;      // CMPH algo for generating the MPHFs for the buckets (Just CMPH_FCH and CMPH_BMZ8)
	cmph_uint32 m;       // edges (words) count
	double c;      // constant c
	cmph_uint8  *size;   // size[i] stores the number of edges represented by g[i][...]. 
	cmph_uint32 *offset; // offset[i] stores the sum: size[0] + size[1] + ... size[i-1].
	cmph_uint8 **g;      // g function. 
	cmph_uint32 k;       // number of components
	hash_state_t **h1;
	hash_state_t **h2;
	hash_state_t * h0;
};

struct __brz_config_data_t
{
	CMPH_HASH hashfuncs[3];
	CMPH_ALGO algo;      // CMPH algo for generating the MPHFs for the buckets (Just CMPH_FCH and CMPH_BMZ8)
	double c;      // constant c
	cmph_uint32 m;       // edges (words) count
	cmph_uint8  *size;   // size[i] stores the number of edges represented by g[i][...]. 
	cmph_uint32 *offset; // offset[i] stores the sum: size[0] + size[1] + ... size[i-1].
	cmph_uint8 **g;      // g function. 
	cmph_uint8  b;       // parameter b. 
	cmph_uint32 k;       // number of components
	hash_state_t **h1;
	hash_state_t **h2;
	hash_state_t * h0;    
	cmph_uint32 memory_availability; 
	cmph_uint8 * tmp_dir; // temporary directory 
	FILE * mphf_fd; // mphf file
};

#endif