moving common code into a single file
This commit is contained in:
parent
10ea331909
commit
a07efcc4b7
@ -42,7 +42,7 @@ or see http://www.gnu.org/licenses/agpl.txt.
|
|||||||
typedef google::dense_hash_map<NodeID, NodeID> ExternalNodeMap;
|
typedef google::dense_hash_map<NodeID, NodeID> ExternalNodeMap;
|
||||||
|
|
||||||
template<typename EdgeT>
|
template<typename EdgeT>
|
||||||
inline NodeID readOSMRGraphFromStream(istream &in, vector<EdgeT>& edgeList, vector<NodeInfo> * int2ExtNodeMap) {
|
NodeID readOSRMGraphFromStream(istream &in, vector<EdgeT>& edgeList, vector<NodeInfo> * int2ExtNodeMap) {
|
||||||
NodeID n, source, target, id;
|
NodeID n, source, target, id;
|
||||||
EdgeID m;
|
EdgeID m;
|
||||||
bool locatable;
|
bool locatable;
|
||||||
@ -101,4 +101,34 @@ inline NodeID readOSMRGraphFromStream(istream &in, vector<EdgeT>& edgeList, vect
|
|||||||
return n;
|
return n;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
template<typename EdgeT>
|
||||||
|
void readHSGRFromStream(istream &in, vector<EdgeT> * edgeList) {
|
||||||
|
while(!in.eof())
|
||||||
|
{
|
||||||
|
EdgeT g;
|
||||||
|
EdgeData e;
|
||||||
|
|
||||||
|
int distance;
|
||||||
|
bool shortcut;
|
||||||
|
bool forward;
|
||||||
|
bool backward;
|
||||||
|
NodeID middle;
|
||||||
|
NodeID source;
|
||||||
|
NodeID target;
|
||||||
|
|
||||||
|
in.read((char *)&(distance), sizeof(int));
|
||||||
|
assert(distance > 0);
|
||||||
|
in.read((char *)&(shortcut), sizeof(bool));
|
||||||
|
in.read((char *)&(forward), sizeof(bool));
|
||||||
|
in.read((char *)&(backward), sizeof(bool));
|
||||||
|
in.read((char *)&(middle), sizeof(NodeID));
|
||||||
|
in.read((char *)&(source), sizeof(NodeID));
|
||||||
|
in.read((char *)&(target), sizeof(NodeID));
|
||||||
|
e.backward = backward; e.distance = distance; e.forward = forward; e.middle = middle; e.shortcut = shortcut;
|
||||||
|
g.data = e; g.source = source; g.target = target;
|
||||||
|
|
||||||
|
edgeList->push_back(g);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
#endif // CREATEGRAPH_H
|
#endif // CREATEGRAPH_H
|
||||||
|
@ -70,7 +70,7 @@ int main (int argc, char *argv[])
|
|||||||
cerr << "Cannot open " << argv[1] << endl; exit(-1);
|
cerr << "Cannot open " << argv[1] << endl; exit(-1);
|
||||||
}
|
}
|
||||||
vector<ImportEdge> edgeList;
|
vector<ImportEdge> edgeList;
|
||||||
const NodeID n = readOSMRGraphFromStream(in, edgeList, int2ExtNodeMap);
|
const NodeID n = readOSRMGraphFromStream(in, edgeList, int2ExtNodeMap);
|
||||||
in.close();
|
in.close();
|
||||||
|
|
||||||
char nodeOut[1024];
|
char nodeOut[1024];
|
||||||
|
73
routed.cpp
73
routed.cpp
@ -36,6 +36,7 @@ or see http://www.gnu.org/licenses/agpl.txt.
|
|||||||
#include <boost/thread.hpp>
|
#include <boost/thread.hpp>
|
||||||
#include <boost/bind.hpp>
|
#include <boost/bind.hpp>
|
||||||
#include "HttpServer/server.h"
|
#include "HttpServer/server.h"
|
||||||
|
#include "Contractor/GraphLoader.h"
|
||||||
#include "DataStructures/StaticGraph.h"
|
#include "DataStructures/StaticGraph.h"
|
||||||
|
|
||||||
using namespace std;
|
using namespace std;
|
||||||
@ -49,89 +50,31 @@ typedef http::server<StaticGraph<EdgeData> > server;
|
|||||||
*/
|
*/
|
||||||
int main (int argc, char *argv[])
|
int main (int argc, char *argv[])
|
||||||
{
|
{
|
||||||
double time;
|
|
||||||
|
|
||||||
if(argc < 4)
|
if(argc < 4)
|
||||||
{
|
{
|
||||||
cerr << "Correct usage:" << endl << argv[0] << " <hsgr data> <nodes data> <ram index> <file index>" << endl;
|
cerr << "Correct usage:" << endl << argv[0] << " <hsgr data> <nodes data> <ram index> <file index>" << endl;
|
||||||
exit(-1);
|
exit(-1);
|
||||||
}
|
}
|
||||||
|
|
||||||
ifstream in(argv[1], ios::binary);
|
ifstream hsgrInStream(argv[1], ios::binary);
|
||||||
ifstream in2(argv[2], ios::binary);
|
ifstream nodesInStream(argv[2], ios::binary);
|
||||||
NodeInformationHelpDesk * nodeInfoHelper = new NodeInformationHelpDesk(argv[3], argv[4]);
|
NodeInformationHelpDesk * nodeInfoHelper = new NodeInformationHelpDesk(argv[3], argv[4]);
|
||||||
|
|
||||||
time = get_timestamp();
|
double time = get_timestamp();
|
||||||
cout << "deserializing edge data from " << argv[1] << " ..." << flush;
|
cout << "deserializing edge data from " << argv[1] << " ..." << flush;
|
||||||
|
|
||||||
std::vector< GridEdge> * edgeList = new std::vector< GridEdge>();
|
std::vector< GridEdge> * edgeList = new std::vector< GridEdge>();
|
||||||
while(!in.eof())
|
readHSGRFromStream(hsgrInStream, edgeList);
|
||||||
{
|
hsgrInStream.close();
|
||||||
GridEdge g;
|
|
||||||
EdgeData e;
|
|
||||||
|
|
||||||
int distance;
|
|
||||||
bool shortcut;
|
|
||||||
bool forward;
|
|
||||||
bool backward;
|
|
||||||
NodeID middle;
|
|
||||||
NodeID source;
|
|
||||||
NodeID target;
|
|
||||||
|
|
||||||
in.read((char *)&(distance), sizeof(int));
|
|
||||||
assert(distance > 0);
|
|
||||||
in.read((char *)&(shortcut), sizeof(bool));
|
|
||||||
in.read((char *)&(forward), sizeof(bool));
|
|
||||||
in.read((char *)&(backward), sizeof(bool));
|
|
||||||
in.read((char *)&(middle), sizeof(NodeID));
|
|
||||||
in.read((char *)&(source), sizeof(NodeID));
|
|
||||||
in.read((char *)&(target), sizeof(NodeID));
|
|
||||||
e.backward = backward; e.distance = distance; e.forward = forward; e.middle = middle; e.shortcut = shortcut;
|
|
||||||
g.data = e; g.source = source; g.target = target;
|
|
||||||
|
|
||||||
edgeList->push_back(g);
|
|
||||||
}
|
|
||||||
|
|
||||||
in.close();
|
|
||||||
cout << "in " << get_timestamp() - time << "s" << endl;
|
cout << "in " << get_timestamp() - time << "s" << endl;
|
||||||
time = get_timestamp();
|
time = get_timestamp();
|
||||||
cout << "deserializing node map and building nearest neighbor grid ..." << flush;
|
cout << "deserializing node map and building nearest neighbor grid ..." << flush;
|
||||||
nodeInfoHelper->initNNGrid(in2);
|
nodeInfoHelper->initNNGrid(nodesInStream);
|
||||||
cout << "in " << get_timestamp() - time << "s" << endl;
|
cout << "in " << get_timestamp() - time << "s" << endl;
|
||||||
// time = get_timestamp();
|
|
||||||
StaticGraph<EdgeData> * graph = new StaticGraph<EdgeData>(nodeInfoHelper->getNumberOfNodes()-1, *edgeList);
|
StaticGraph<EdgeData> * graph = new StaticGraph<EdgeData>(nodeInfoHelper->getNumberOfNodes()-1, *edgeList);
|
||||||
delete edgeList;
|
delete edgeList;
|
||||||
// cout << "checking data sanity ..." << flush;
|
|
||||||
// NodeID numberOfNodes = graph->GetNumberOfNodes();
|
|
||||||
// for ( NodeID node = 0; node < numberOfNodes; ++node ) {
|
|
||||||
// for ( StaticGraph<EdgeData>::EdgeIterator edge = graph->BeginEdges( node ), endEdges = graph->EndEdges( node ); edge != endEdges; ++edge ) {
|
|
||||||
// const NodeID start = node;
|
|
||||||
// const NodeID target = graph->GetTarget( edge );
|
|
||||||
// const EdgeData& data = graph->GetEdgeData( edge );
|
|
||||||
// const NodeID middle = data.middle;
|
|
||||||
// assert(start != target);
|
|
||||||
// if(data.shortcut)
|
|
||||||
// {
|
|
||||||
// if(graph->FindEdge(start, middle) == SPECIAL_EDGEID && graph->FindEdge(middle, start) == SPECIAL_EDGEID)
|
|
||||||
// {
|
|
||||||
// assert(false);
|
|
||||||
// cerr << "hierarchy broken" << endl; exit(-1);
|
|
||||||
// }
|
|
||||||
// if(graph->FindEdge(middle, target) == SPECIAL_EDGEID && graph->FindEdge(target, middle) == SPECIAL_EDGEID)
|
|
||||||
// {
|
|
||||||
// assert(false);
|
|
||||||
// cerr << "hierarchy broken" << endl; exit(-1);
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// if(graph->GetOutDegree(node) == 0)
|
|
||||||
// {
|
|
||||||
// cerr << "found node with degree 0: " << node << endl;
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// cout << "in " << get_timestamp() - time << "s" << endl;
|
|
||||||
time = get_timestamp();
|
time = get_timestamp();
|
||||||
cout << "building search graph ..." << flush;
|
cout << "constructing search graph ..." << flush;
|
||||||
|
|
||||||
SearchEngine<EdgeData, StaticGraph<EdgeData> > * sEngine = new SearchEngine<EdgeData, StaticGraph<EdgeData> >(graph, nodeInfoHelper);
|
SearchEngine<EdgeData, StaticGraph<EdgeData> > * sEngine = new SearchEngine<EdgeData, StaticGraph<EdgeData> >(graph, nodeInfoHelper);
|
||||||
cout << "in " << get_timestamp() - time << "s" << endl;
|
cout << "in " << get_timestamp() - time << "s" << endl;
|
||||||
|
Loading…
Reference in New Issue
Block a user