//----------------------------------------------------------------------------------- // Implementation of a MPS algorithm via PC-tree. //----------------------------------------------------------------------------------- #include "mps.h" #include //----------------------------------------------------------------------------------- // Finding MPS //----------------------------------------------------------------------------------- int find_mps(string input_file) { maximal_planar_subgraph_finder m; return m.find_mps(input_file); } int maximal_planar_subgraph_finder::find_mps(string input_file) { read_from_gml(input_file); postOrderTraversal(); sort_adj_list(); determine_edges(); back_edge_traversal(); return output_removed_edge_size(); } //----------------------------------------------------------------------------------- // Imput, output //----------------------------------------------------------------------------------- // read input file of gml format void maximal_planar_subgraph_finder::read_from_gml(string input_file) { ogdf::Graph G; // utilize OGDF readGML if (!ogdf::GraphIO::read(G, input_file, ogdf::GraphIO::readGML)) { std::cerr << "Could not read " << input_file << ".gml" << std::endl; } // create nodes for (int i = 0; i < G.numberOfNodes(); ++i) { _node_list.push_back(new node(P_NODE)); _node_list[i]->set_id(i); } // create edges for (ogdf::edge e : G.edges) { ogdf::node source = e->source(); ogdf::node target = e->target(); _node_list[source->index()]->add_adj(_node_list[target->index()]); _node_list[target->index()]->add_adj(_node_list[source->index()]); } } //Output a maximal planar subgraph in the same format as input. int maximal_planar_subgraph_finder::output_removed_edge_size() { int sum = 0; for (int i = 0; i < _back_edge_list.size(); ++i) { if (_is_back_edge_eliminate[i]) ++sum; } return sum; }