Kernighan-Lin heuristic algorithm for finding partitions of graphs implented in C++.
The algorithm has important applications in the layout of digital circuits and components in VLSI.
The algorithm starts with a random partition of equal sized vertices. For example (1, ..., n) vertices in partition #1 and (1+n, ..., 2n) vertices in partition #2.
The project will be completed in 3 steps:
Program will read an input file and print out a partition in a specified format
- 
A. Each input file contains 2n vertices. 
- 
B. As the starting partition, assign (1, ..., n) vertices in partition #1 & (n+1, ..., 2n) vertices in partition #2. 
- 
A. Calculate the cost of a partition. 
- 
B. Update your output formate to show "cost of the partition". 
- 
A. Calculate the internal & external costs for all of the vertices in both partitions. 
- 
B. Calculate the D values for each node 
- 
C. Calculate the Gain values for each possible "move". 
- 
D. In addition to the cost of the partition, print the largest Gain value. 
Step1: cd KL_Algorithm/src
Step2: make
Step3: ./KL_Algorithm.o <benchmarkFile.txt>
Example: ./KL_Algorithm.o ../../Benchmark/ClassEx/ClassEx.txt
Step4 (once finished): make clean
Note: As of November 21, 2018 the algorithm is function and tested using the provided benchmarks on Linux Ubuntu 18.04.1 LST and will be tested on more systems in the near future.