/******************************************************************************
 * initial_partition_bipartition.cpp 
 *
 * Source of KaHIP -- Karlsruhe High Quality Partitioning.
 *
 *****************************************************************************/

#include <fstream>
#include "initial_partition_bipartition.h"
#include "uncoarsening/refinement/kway_graph_refinement/kway_graph_refinement.h"
#include "uncoarsening/refinement/mixed_refinement.h"
#include "graph_partitioner.h"

initial_partition_bipartition::initial_partition_bipartition() {

}

initial_partition_bipartition::~initial_partition_bipartition() {

}

void initial_partition_bipartition::initial_partition( const PartitionConfig & config, 
                                                       const unsigned int seed,  
                                                       graph_access & G, int* partition_map) {
        graph_partitioner gp;
        PartitionConfig rec_config                  = config;
        rec_config.initial_partitioning_type        = INITIAL_PARTITIONING_BIPARTITION;
        rec_config.initial_partitioning_repetitions = 0;
        rec_config.global_cycle_iterations          = 1;
        rec_config.use_wcycles                      = false;
        rec_config.use_fullmultigrid                = false;
        rec_config.fm_search_limit                  = config.bipartition_post_ml_limits;
        rec_config.matching_type                    = MATCHING_GPA;
        rec_config.permutation_quality              = PERMUTATION_QUALITY_GOOD;
        rec_config.initial_partitioning             = true;
	rec_config.graph_allready_partitioned       = false;
        rec_config.label_propagation_refinement     = false;

	if( config.cluster_coarsening_during_ip == true) {
		rec_config.matching_type             = CLUSTER_COARSENING;
		rec_config.cluster_coarsening_factor = 12;
		rec_config.ensemble_clusterings      = false;
	}


        std::streambuf* backup = std::cout.rdbuf();
        std::ofstream ofs;
        ofs.open("/dev/null");
        std::cout.rdbuf(ofs.rdbuf()); 

        gp.perform_recursive_partitioning(rec_config, G); 

        ofs.close();
        std::cout.rdbuf(backup);

        forall_nodes(G, n) {
                partition_map[n] =  G.getPartitionIndex(n);
        } endfor

} 

void initial_partition_bipartition::initial_partition( const PartitionConfig & config, 
                                                       const unsigned int seed,  
                                                       graph_access & G, 
                                                       int* xadj,
                                                       int* adjncy, 
                                                       int* vwgt, 
                                                       int* adjwgt,
                                                       int* partition_map) {

        std::cout <<  "not implemented yet"  << std::endl;
}

