/* open source routing machine Copyright (C) Dennis Luxen, 2010 This program is free software; you can redistribute it and/or modify it under the terms of the GNU AFFERO General Public License as published by the Free Software Foundation; either version 3 of the License, or any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU Affero General Public License along with this program; if not, write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA or see http://www.gnu.org/licenses/agpl.txt. */ #include "../typedefs.h" #include "../Algorithms/StronglyConnectedComponents.h" #include "../DataStructures/BinaryHeap.h" #include "../DataStructures/DeallocatingVector.h" #include "../DataStructures/DynamicGraph.h" #include "../DataStructures/QueryEdge.h" #include "../DataStructures/TurnInstructions.h" #include "../Util/GraphLoader.h" #include "../Util/IniFile.h" #include "../Util/InputFileUtil.h" #include "../Util/OSRMException.h" #include "../Util/SimpleLogger.h" #include "../Util/UUID.h" #include #include #include #include #include #include #include typedef QueryEdge::EdgeData EdgeData; typedef DynamicGraph::InputEdge InputEdge; std::vector internal_to_external_node_map; std::vector restrictions_vector; std::vector bollard_node_IDs_vector; std::vector traffic_light_node_IDs_vector; int main (int argc, char * argv[]) { LogPolicy::GetInstance().Unmute(); if(argc < 3) { SimpleLogger().Write(logWARNING) << "usage:\n" << argv[0] << " "; return -1; } SimpleLogger().Write() << "Using restrictions from file: " << argv[2]; std::ifstream restriction_ifstream(argv[2], std::ios::binary); const UUID uuid_orig; UUID uuid_loaded; restriction_ifstream.read((char *) &uuid_loaded, sizeof(UUID)); if( !uuid_loaded.TestGraphUtil(uuid_orig) ) { SimpleLogger().Write(logWARNING) << argv[2] << " was prepared with a different build. " "Reprocess to get rid of this warning."; } if(!restriction_ifstream.good()) { throw OSRMException("Could not access files"); } uint32_t usable_restriction_count = 0; restriction_ifstream.read( (char*)&usable_restriction_count, sizeof(uint32_t) ); restrictions_vector.resize(usable_restriction_count); restriction_ifstream.read( (char *)&(restrictions_vector[0]), usable_restriction_count*sizeof(TurnRestriction) ); restriction_ifstream.close(); std::ifstream input_stream; input_stream.open( argv[1], std::ifstream::in | std::ifstream::binary ); if (!input_stream.is_open()) { throw OSRMException("Cannot open osrm file"); } std::vector edge_list; NodeID node_based_node_count = readBinaryOSRMGraphFromStream( input_stream, edge_list, bollard_node_IDs_vector, traffic_light_node_IDs_vector, &internal_to_external_node_map, restrictions_vector ); input_stream.close(); BOOST_ASSERT_MSG( restrictions_vector.size() == usable_restriction_count, "size of restrictions_vector changed" ); SimpleLogger().Write() << restrictions_vector.size() << " restrictions, " << bollard_node_IDs_vector.size() << " bollard nodes, " << traffic_light_node_IDs_vector.size() << " traffic lights"; /*** * Building an edge-expanded graph from node-based input an turn restrictions */ SimpleLogger().Write() << "Starting SCC graph traversal"; TarjanSCC * tarjan = new TarjanSCC ( node_based_node_count, edge_list, bollard_node_IDs_vector, traffic_light_node_IDs_vector, restrictions_vector, internal_to_external_node_map ); std::vector().swap(edge_list); tarjan->Run(); std::vector().swap(restrictions_vector); std::vector().swap(bollard_node_IDs_vector); std::vector().swap(traffic_light_node_IDs_vector); SimpleLogger().Write() << "finished component analysis"; return 0; }