181 lines
4.7 KiB
C
181 lines
4.7 KiB
C
|
/*
|
||
|
* basicQuery.h
|
||
|
*
|
||
|
* Created on: 2014-6-20
|
||
|
* Author: liyouhuan
|
||
|
*/
|
||
|
|
||
|
#ifndef BASICQUERY_H_
|
||
|
#define BASICQUERY_H_
|
||
|
|
||
|
#include<iostream>
|
||
|
#include<string.h>
|
||
|
#include<stdio.h>
|
||
|
#include<stdlib.h>
|
||
|
#include<map>
|
||
|
#include<set>
|
||
|
#include<vector>
|
||
|
#include "../Triple/Triple.h"
|
||
|
#include "../Signature/Signature.h"
|
||
|
#include "../KVstore/KVstore.h"
|
||
|
#include "IDList.h"
|
||
|
#include<sstream>
|
||
|
|
||
|
using namespace std;
|
||
|
|
||
|
class BasicQuery{
|
||
|
private:
|
||
|
vector<string> option_vs;
|
||
|
vector<Triple> triple_vt;
|
||
|
/* mapping from variables' name to their assigned id. */
|
||
|
map<std::string, int> var_str2id;
|
||
|
/* record each tuple's(subject, predicate, object) number of occurrences in this BasicQuery. */
|
||
|
map<std::string, int> tuple2freq;
|
||
|
map<std::string, int> var_not_in_select;
|
||
|
|
||
|
int select_var_num;
|
||
|
|
||
|
/* var_num is different from that in SPARQLquery
|
||
|
* because there are some variable not in select */
|
||
|
int graph_var_num;
|
||
|
string* var_name;
|
||
|
IDList* candidate_list;
|
||
|
vector<int*> result_list;
|
||
|
int* var_degree;
|
||
|
|
||
|
/* whether has added the variable's literal candidate */
|
||
|
bool* is_literal_candidate_added;
|
||
|
|
||
|
char encode_method;
|
||
|
|
||
|
/* edge_id[var_id][i] : the line id of the i-th edge of the var */
|
||
|
int** edge_id;
|
||
|
|
||
|
/* edge_id[var_id][i] : the neighbor id of the i-th edge of the var */
|
||
|
int** edge_nei_id;
|
||
|
|
||
|
/* edge_pre_id[var_id][i] : the preID of the i-th edge of the var */
|
||
|
int** edge_pre_id;
|
||
|
|
||
|
/* denote the type of edge, assigned with
|
||
|
* BasicQuery::IN or BasicQuery::OUT
|
||
|
* edge_type[var_id][i] */
|
||
|
char** edge_type;
|
||
|
|
||
|
EntityBitSet* var_sig;
|
||
|
|
||
|
/* edge_sig[sub_id][obj_id] */
|
||
|
EdgeBitSet** edge_sig;
|
||
|
|
||
|
void addInVarNotInSelect();
|
||
|
void findVarNotInSelect();
|
||
|
void buildTuple2Freq();
|
||
|
void initial();
|
||
|
|
||
|
public:
|
||
|
static const char EDGE_IN = 'i';
|
||
|
static const char EDGE_OUT= 'o';
|
||
|
static const int MAX_VAR_NUM = 10;
|
||
|
static const char NOT_JUST_SELECT = 'a';
|
||
|
static const char SELECT_VAR = 's';
|
||
|
|
||
|
/* _query is a SPARQL query string */
|
||
|
BasicQuery(const string _query="");
|
||
|
~BasicQuery();
|
||
|
void clear();
|
||
|
|
||
|
/* get the number of variables */
|
||
|
int getVarNum();
|
||
|
|
||
|
/* get the name of _var in the query graph */
|
||
|
std::string getVarName(int _var);
|
||
|
|
||
|
/* get triples number, also sentences number */
|
||
|
int getTripleNum();
|
||
|
|
||
|
std::string to_str();
|
||
|
|
||
|
|
||
|
/* get the ID of the i-th triple */
|
||
|
const Triple& getTriple(int _i_th_triple);
|
||
|
|
||
|
/* get the ID of the i-th edge of _var */
|
||
|
int getEdgeID(int _var, int _i_th_edge);
|
||
|
|
||
|
/* get the ID of the i-th edge of _var */
|
||
|
int getEdgeNeighborID(int _var, int _i_th_edge);
|
||
|
|
||
|
/* get the preID of the i-th edge of _var */
|
||
|
int getEdgePreID(int _var, int _i_th_edge);
|
||
|
|
||
|
/* get the type of the i-th edge of _var */
|
||
|
char getEdgeType(int _var, int _i_th_edge);
|
||
|
|
||
|
/* get the degree of _var in the query graph */
|
||
|
int getVarDegree(int _var);
|
||
|
|
||
|
/* */
|
||
|
const EntityBitSet& getVarBitSet(int _i)const;
|
||
|
|
||
|
/* get the candidate list of _var in the query graph */
|
||
|
IDList& getCandidateList(int _var);
|
||
|
|
||
|
int getCandidateSize(int _var);
|
||
|
|
||
|
/* get the result list of _var in the query graph */
|
||
|
vector<int*>& getResultList();
|
||
|
|
||
|
/* get the entity signature of _var in the query graph */
|
||
|
const EntityBitSet& getEntitySignature(int _var);
|
||
|
|
||
|
/* check whether the i-th edge of _var is IN edge */
|
||
|
bool isInEdge(int _var, int _i_th_edge)const;
|
||
|
|
||
|
/* check whether the i-th edge of _var is OUT edge */
|
||
|
bool isOutEdge(int _var, int _i_th_edge)const;
|
||
|
|
||
|
bool isOneDegreeNotSelectVar(std::string& _not_select_var);
|
||
|
|
||
|
/* check whether _var may include some literal results */
|
||
|
bool isLiteralVariable(int _var);
|
||
|
/* check whether _var is literal variable and do not have any entity neighbors */
|
||
|
bool isFreeLiteralVariable(int _var);
|
||
|
|
||
|
/* check whether has added _var's literal candidates */
|
||
|
bool isAddedLiteralCandidate(int _var);
|
||
|
|
||
|
/* set _var's literal candidates has been added */
|
||
|
void setAddedLiteralCandidate(int _var);
|
||
|
|
||
|
|
||
|
private:
|
||
|
void updateSubSig(int _sub_id, int _pre_id, int _obj_id, std::string _obj, int _line_id);
|
||
|
void updateObjSig(int _obj_id, int _pre_id, int _sub_id, std::string _sub, int _line_id);
|
||
|
|
||
|
public:
|
||
|
|
||
|
/* encode relative signature data of the query graph */
|
||
|
void encodeBasicQuery(KVstore* _p_kvstore, const std::vector<std::string>& _query_var);
|
||
|
|
||
|
/* add triple */
|
||
|
void addTriple(const Triple& _triple);
|
||
|
|
||
|
/* print whole Basic query */
|
||
|
void print(ostream& _out_stream);
|
||
|
|
||
|
int getVarID_MinCandidateList();
|
||
|
int getVarID_MaxCandidateList();
|
||
|
int getVarID_FirstProcessWhenJoin();
|
||
|
|
||
|
static int cmp_result(const void* _a, const void* _b);
|
||
|
bool dupRemoval_invalidRemoval();
|
||
|
|
||
|
|
||
|
std::string candidate_str();
|
||
|
std::string result_str();
|
||
|
std::string triple_str();
|
||
|
};
|
||
|
|
||
|
|
||
|
#endif /* BASICQUERY_H_ */
|