NAME="GENERATOR"
CONTENT="Modular DocBook HTML Stylesheet Version 1.52">Name Graph partitioning -- 
Synopsis 
#include <gts.h>
struct      GtsGraphBisection ;
GtsGraphBisection * gts_graph_bisection_new   (GtsWGraph  *wg,
                                             guint  ntry,
                                             guint  mmax,
                                             guint  nmin,
                                             gfloat  imbalance);
GtsGraphBisection * gts_graph_ggg_bisection   (GtsGraph  *g,
                                             guint  ntry);
GtsGraphBisection * gts_graph_bfgg_bisection  (GtsGraph  *g,
                                             guint  ntry);
gboolean     gts_graph_bisection_check        (GtsGraphBisection  *bg);
gdouble      gts_graph_bisection_kl_refine    (GtsGraphBisection  *bg,
                                             guint  mmax);
gdouble      gts_graph_bisection_bkl_refine   (GtsGraphBisection  *bg,
                                             guint  mmax,
                                             gfloat  imbalance);
GSList *     gts_graph_recursive_bisection    (GtsWGraph  *wg,
                                             guint  n,
                                             guint  ntry,
                                             guint  mmax,
                                             guint  nmin,
                                             gfloat  imbalance);
void        gts_graph_bisection_destroy      (GtsGraphBisection  *bg,
                                             gboolean  destroy_graphs);
GSList *     gts_graph_bubble_partition       (GtsGraph  *g,
                                             guint  np,
                                             guint  niter,
                                             GtsFunc  step_info,
                                             gpointer  data);
guint        gts_graph_edges_cut              (GtsGraph  *g);
gfloat       gts_graph_edges_cut_weight       (GtsGraph  *g);
guint        gts_graph_partition_edges_cut    (GSList  *partition);
gfloat       gts_graph_partition_balance      (GSList  *partition);
GSList *     gts_graph_partition_clone        (GSList  *partition);
void        gts_graph_partition_print_stats  (GSList  *partition,
                                             FILE  *fp);
gfloat       gts_graph_partition_edges_cut_weight 
                                            (GSList  *partition);
void        gts_graph_partition_destroy      (GSList  *partition); 
Details struct GtsGraphBisection {
  GtsGraph * g;
  GtsGraph * g1;
  GtsGraph * g2;
  GHashTable * bg1;
  GHashTable * bg2;
}; 
An implementation of a multilevel bisection algorithm as presented
in Karypis and Kumar (1997). A multilevel hierarchy of graphs is
created using the GtsPGraph  object. The bisection of the coarsest
graph is created using the gts_graph_ggg_bisection () function. The
graph is then uncoarsened using gts_pgraph_down () and at each level
the bisection is refined using gts_graph_bisection_bkl_refine ().
An implementation of the "Greedy Graph Growing" algorithm of
Karypis and Kumar (1997).  
ntry 
An implementation of a "Breadth-First Graph Growing" algorithm.
ntry 
Checks that the boundary of bg 
An implementation of the simplified Kernighan-Lin algorithm for
graph bisection refinement as described in Karypis and Kumar
(1997).
The algorithm stops if mmax mmax 
gdouble      gts_graph_bisection_bkl_refine  (GtsGraphBisection  *bg,
                                             guint  mmax,
                                             gfloat  imbalance);
An implementation of the simplified boundary Kernighan-Lin
algorithm for graph bisection refinement as described in Karypis
and Kumar (1997).
The algorithm stops if mmax mmax 
GSList *     gts_graph_recursive_bisection   (GtsWGraph  *wg,
                                             guint  n,
                                             guint  ntry,
                                             guint  mmax,
                                             guint  nmin,
                                             gfloat  imbalance);
Calls gts_graph_bisection_new () recursively in order to obtain a
2^n wg 
Frees all the memory allocated for bg destroy_graphs TRUE 
the graphs created by bg 
GSList *     gts_graph_bubble_partition      (GtsGraph  *g,
                                             guint  np,
                                             guint  niter,
                                             GtsFunc  step_info,
                                             gpointer  data);
An implementation of the "bubble partitioning algorithm" of
Diekmann, Preis, Schlimbach and Walshaw (2000). The maximum number
of iteration on the positions of the graph growing seeds is
controlled by niter 
If not NULL  step_info 
guint        gts_graph_edges_cut             (GtsGraph  *g);
gfloat       gts_graph_edges_cut_weight      (GtsGraph  *g);
guint        gts_graph_partition_edges_cut   (GSList  *partition);
gfloat       gts_graph_partition_balance     (GSList  *partition);
GSList *     gts_graph_partition_clone       (GSList  *partition);
void        gts_graph_partition_print_stats (GSList  *partition,
                                             FILE  *fp); 
Writes to fp partition 
gfloat       gts_graph_partition_edges_cut_weight
                                            (GSList  *partition);
void        gts_graph_partition_destroy     (GSList  *partition); 
Destroys all the graphs in partition partition