Skip to content

Latest commit

 

History

History
74 lines (62 loc) · 3.97 KB

README.md

File metadata and controls

74 lines (62 loc) · 3.97 KB

MinTriangulationsEnumeration

Enumerates all minimal triangulations or proper tree decompositions of a graph as described in the paper On the Enumeration of all Minimal Triangulations.

Compilation

To compile, run:

make

Alternatively, if you prefer not to use make or you do not want to store intermediate files, you can simply run:

g++ -o enumerator.exe src/*.cpp

Input

Specify the input file as the first argument, and possibly other configuration options using command line arguments. e.g:

enumerator.exe input_example.txt time_limit=1 out=bags

Only the input file is required.

Input File

The supported file formats are: hg, sp, wcnf, uai, bliss, and:

  • txt - each line holds names of vertices in a clique separated by spaces (specifying an edge in every line also works). A vertex name can be any string without whitespaces.
  • csv - the same as txt but the values are separated by commas.

Output Form

Flag name: out. Specifies the type of results that the algorithm enumerates. The options are: triang, bags, TDs, TDsAll. The default is triang.

  • triang - enumerates the minimal triangulations (a.k.a. chordal completions) of the input graph; each result is a list of fill edges (the edges to be added to the input graph).
  • bags - enumerates the equivalence classes of proper tree decompositions by bag sets; each result is a list of bags.
  • TDs - enumerates the equivalence classes of proper tree decompositions by bag sets; each result is a list of bags followed by a list of edges between the bags. (This lists all tree decompositions that cannot be improved by removing or splitting a bag, except it does not produce two decompositions with the same set of bags.)
  • TDsAll - enumerates the proper tree decompositions; each result is a list of bags followed by all options of a list of edges between the bags. (This lists all tree decompositions that cannot be improved by removing or splitting a bag, grouped by the set of bags.)

Time Limit

Flag name: time_limit. The next result after this specified time will be the last. Time is specified in seconds. -1 means no time limit. The default is no time limit.

Triangualtion Heuristic

Flag name: alg. The heuristic used for generating a single minimal triangulation. The options are: mcs, lb, degree, initialDegree, fill, initalFill, combined and separators. The default is mcs.

  • mcs - using MCS-M algorithm.
  • lb - using LB-Triang algorithm with no heuristic for the order of vertices (faster than the following options).
  • degree - using LB-Triang algorithm with min-degree heuristic for the order of vertices.
  • initialDegree - using LB-Triang algorithm, determining the order of vertices up-front by the min-degree.
  • fill - using LB-Triang algorithm with min-fill heuristic for the order of vertices.
  • initalFill - using LB-Triang algorithm, determining the order of vertices up-front by the min-fill.
  • combined - runs fill and mcs alternatively in each iteration.
  • separators - using a separator based approch instead of a triangualtion, as described in section 5 of the paper.

Triangulations Order

Flag name: t_order. The order of extending the generated minimal triangulations. The options are: width, fill, difference, sepsize, none. The default is none.

  • width - lowest width first.
  • fill - lowest number of fill edges first.
  • difference - lowest number of fill edges that were seen in previously extended triangulations.
  • sepsize - lowest size of maximal separator size.

Separators Order

Flag name: s_order. The order of extending the minimal separators. The options are: size, fill, none. The default is none.

  • size - lowest size first.
  • fill - lowest number of pairs in the separator that don't share an edge.

Output

The list of results is stored in an output file with the name of the input file followed by ".out". A summary of the results found is printed to the screen.