-
Notifications
You must be signed in to change notification settings - Fork 14
/
Copy pathApplication.h
120 lines (93 loc) · 3.75 KB
/
Application.h
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
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
#ifndef _APPLICATION_H_
#define _APPLICATION_H_
#include "Utility.h"
#include "Graph.h"
enum LB_Method { LSa, BMa, BMao };
struct State {
State *parent;
State *pre_sibling; // previous sibling
ushort level;
ushort image;
ushort mapped_cost;
ushort lower_bound;
ushort cs_cnt; // cs_cnt stores how many children and right sibling depends on this state; this state can be removed if and only cs_cnt becomes 0
#ifdef _EXPAND_ALL_
ushort *siblings; // remaining siblings
ushort siblings_n;
#endif
};
class Application {
private:
ui q_n;
ui *q_starts, *q_edges;
ui *q_vlabels, *q_elabels;
ui g_n;
ui *g_starts, *g_edges;
ui *g_vlabels, *g_elabels;
ui vlabels_n, elabels_n;
ui verify_upper_bound;
ui upper_bound;
LB_Method lb_method;
bool q_g_swapped;
ui *MO;
ui search_n;
ui search_n_for_IS;
char *visX, *visY;
int *mx, *my;
ui *BX;
ui *candidates;
ui *queue, *prev;
std::vector<State *> states_memory;
std::vector<State *> states_pool;
ui states_pool_n;
std::vector<ushort *> siblings_memory;
std::vector<ushort *> siblings_pool;
ui siblings_pool_n;
int *elabels_map, *vlabels_map;
short *elabels_matrix;
uchar *q_matrix;
ushort *visited_siblings; // these two arrays only used in DFS
ushort *visited_siblings_n;
/***** for bipartite matching based lower bounds ****/
ui *cost;
int *lx, *ly, *slack, *slackmy;
std::pair<int, int> *children;
long long search_space;
public:
Application(ui _verify_upper_bound, const char *lower_bound) ;
~Application() ;
long long get_search_space() { return search_space; }
void init(const std::vector<std::pair<int,int> > &g_v, const std::vector<std::pair<std::pair<int,int>,int> > &g_e, const std::vector<std::pair<int,int> > &q_v, const std::vector<std::pair<std::pair<int,int>,int> > &q_e) ;
void init(const Graph *g, const Graph *q) ;
ui DFS(State *node = NULL) ;
ui AStar(std::vector<std::pair<ui,ui> > *mapping_ptr = NULL, int *lb_ptr = NULL) ;
ui compute_ged_of_BX() ;
void get_mapping(std::vector<std::pair<ui,ui> > &mapping, ui n) ;
private:
void preprocess() ;
void add_to_pool(State *st) ;
void add_to_heap(State *st, ui &heap_n, std::vector<State*> &heap) ;
State* get_a_new_state_node() ;
void put_a_state_to_pool(State *st) ;
ushort* get_a_new_siblings_node() ;
void put_a_sibling_to_pool(ushort *sibling) ;
void verify_induced_ged(State *now) ;
void verify_LS_lower_bound(State *now) ;
ui relabel(ui len1, ui *array1, ui len2, ui *array2) ;
ui search_index(ui val, std::vector<ui> &array, ui array_len) ;
void compute_mapping_order() ;
void generate_best_extension(State *parent, State *now) ; // compute the best child of a state
void compute_mapped_cost_and_upper_bound(State *now, ui n, ui *candidates, int *mapping) ;
void construct_sibling(State *pre_sibling, State *now) ; // compute the best ungenerated sibling of a state
void extend_to_full_mapping(State *parent, State *now) ;
void compute_mapped_cost(State *now) ;
void compute_best_extension_LSa(State *now, ui candidate_n, ui *candidates, ui pre_siblings) ;
void compute_best_extension_BM(char anchor_aware, State *now, ui candidate_n, ui *candidates, ui pre_siblings, char no_siblings, char IS = 0) ;
void compute_best_extension_BMa(char anchor_aware, State *now, ui n, ui *candidates, ui pre_siblings) ;
ui Hungarian(char initialization, ui n, ui *cost) ; // minimum cost bipartite matching
void heap_top_down(ui idx, ui heap_n, std::vector<std::pair<double, int> > &heap, ui *pos) ;
void heap_bottom_up(ui idx, std::vector<std::pair<double,int> > &heap, ui *pos) ;
void heap_top_down(ui idx, ui heap_n, std::vector<State*> &heap) ;
void heap_bottom_up(ui idx, std::vector<State*> &heap) ;
};
#endif