-/**
- * @author Daniel Grund
- * @date 11.04.2005
- */
-#undef DO_STAT
-
-#ifdef DO_STAT
-
-#ifndef _BECOPYSTAT_H
-#define _BECOPYSTAT_H
-
-#include "irgraph.h"
-
-#define MAX_ARITY 10
-#define MAX_CLS_SIZE 10
-#define MAX_PHASE 2
-
-/**
- * For an explanation of these values see phi_stat_dump_pretty
- */
-enum vals_t {
- I_ALL_NODES = 0,
- I_BLOCKS,
-
- /* phi nodes */
- I_PHI_CNT, /* number of phi nodes */
- I_PHI_ARG_CNT, /* number of arguments of phis */
- I_PHI_ARG_SELF, /* number of arguments of phis being the phi itself */
- I_PHI_ARG_CONST, /* number of arguments of phis being consts */
- I_PHI_ARG_PRED, /* ... being defined in a cf-pred */
- I_PHI_ARG_GLOB, /* ... being defined elsewhere */
- I_PHI_ARITY_S,
- I_PHI_ARITY_E = I_PHI_ARITY_S+MAX_ARITY,
-
- /* phi classes */
- I_CLS_CNT, /* number of phi classes */
- I_CLS_IF_FREE, /* number of pc having no interference */
- I_CLS_IF_MAX, /* number of possible interferences in all classes */
- I_CLS_IF_CNT, /* number of actual interferences in all classes */
- I_CLS_SIZE_S,
- I_CLS_SIZE_E = I_CLS_SIZE_S+MAX_CLS_SIZE,
-
- /* TODO copy nodes */
- I_CPY_CNT, /* number of copynodes */
-
- /* TODO ilp values */
- I_ILP_TIME, /* !external set! solving time in 10th seconds */
- I_ILP_ITER, /* !external set! number of simplex iterations */
-
- /* copy instructions */
- I_COPIES_MAX, /* max number of copies possible */
- I_COPIES_INIT, /* !external set! number of copies in initial allocation */
- I_COPIES_HEUR, /* !external set! number of copies after heuristic */
- I_COPIES_OPT, /* !external set! number of copies after ilp */
- I_COPIES_LB, /* !external set! the lower bound used for number of copies */
- I_COPIES_IF, /* number of copies inevitable due to root-arg-interf */
-
- ASIZE
-};
-
-/**
- * Holds current values. Values are added till next phi_stat_reset
- */
-int curr_vals[ASIZE];
-
-void stat_init(void);
-
-/**
- * Resets the array holding the data
- */
-void stat_reset(void);
-
-/**
- * Collect common irg data
+/*
+ * Copyright (C) 1995-2007 University of Karlsruhe. All right reserved.
+ *
+ * This file is part of libFirm.
+ *
+ * This file may be distributed and/or modified under the terms of the
+ * GNU General Public License version 2 as published by the Free Software
+ * Foundation and appearing in the file LICENSE.GPL included in the
+ * packaging of this file.
+ *
+ * Licensees holding valid libFirm Professional Edition licenses may use
+ * this file in accordance with the libFirm Commercial License.
+ * Agreement provided with the Software.
+ *
+ * This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
+ * WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+ * PURPOSE.
*/
-void stat_collect_irg(ir_graph *irg);
/**
- * Dumps the current contents of the internal values to a file.
+ * @file
+ * @brief Copy node statistics.
+ * @author Daniel Grund
+ * @date 11.04.2005
+ * @version $Id$
*/
-void stat_dump(ir_graph *irg);
+#ifndef FIRM_BE_BECOPYSTAT_H
+#define FIRM_BE_BECOPYSTAT_H
+
+#include "firm_config.h"
+#include "firm_types.h"
+#include "bearch_t.h"
+#include "bechordal_t.h"
+
+void copystat_add_max_costs(int costs);
+void copystat_add_inevit_costs(int costs);
+void copystat_add_init_costs(int costs);
+void copystat_add_heur_costs(int costs);
+void copystat_add_opt_costs(int costs);
+void copystat_add_heur_time(int time);
+void copystat_dump(ir_graph *irg);
+void copystat_dump_pretty(ir_graph *irg);
+
+#ifdef WITH_ILP
+
+void copystat_add_ilp_5_sec_costs(int costs);
+void copystat_add_ilp_30_sec_costs(int costs);
+void copystat_add_ilp_time(int time);
+void copystat_add_ilp_vars(int vars);
+void copystat_add_ilp_csts(int csts);
+void copystat_add_ilp_iter(int iters);
+
+#endif /* WITH_ILP */
/**
- * Dumps the current contents of the values array and annotations to a file.
+ * Compares different solutions of the same problem
*/
-void stat_dump_pretty(ir_graph *irg);
+void co_compare_solvers(be_chordal_env_t *chordal_env);
-#endif
-#endif
+#endif /* FIRM_BE_BECOPYSTAT_H */