VLSI (Very Large Scale Integration) refers to the trend of integrating circuits into silicon chips. A typical example is the smartphone. The modern trend of shrinking transistor sizes, allowing engineers to fit more and more transistors into the same area of silicon, has pushed the integration of more and more functions of cellphone circuitry into a single silicon die (i.e. plate).
The VLSI problem taken into account is the following: given a fixed-width plate and a list of rectangular circuits, the arrangement of the circuits must be decided in order to minimize the length of the plate.
Two variants of the problem are considered. In the first, each circuit must be placed in a fixed orientation with respect to the others. This means that, an
In the second case, the rotation is allowed, which means that an
This problem has been tackled using four different combinatorial optimization approaches, namely:
- Constraint Programming (CP)
- Boolean Satisfiability (SAT)
- Satisfiability Modulo Theory (SMT)
- Linear Programming (LP)
A total of
The directory src/scripts
contains the scripts of the project that the user directly interacts with. There are three main groups of scripts:
- Execute:
execute_cp.py
;execute_lp.py
;execute_sat.py
;execute_smt.py
. They run the specified model, of the selected approach (CP, LP, SAT or SMT), for solving the specified VLSI problem instance. The following is an example of a solved instance.
- Compare models:
compare_cp_models.py
;compare_lp_models.py
;compare_sat_encodings.py
;compare_smt_encodings.py
. They compare the specified model, of the selected approach, on solving the specified VLSI problem instances. The following is an example of a comparison plot.
- Solve all instances:
solve_all_instances_cp.py
;solve_all_instances_lp.py
;solve_all_instances_sat.py
;solve_all_instances_smt.py
. They solve the set of all the available instances using the best model of the selected approach.
In the folder src/*
, where *
refers to either cp
, lp
, sat
or smt
, the models related to the specific approach can be found.
In the folder instances
the .txt
representation of the
An instance of VLSI is a text file consisting of lines of integer values. The first line gives
For example, a file with the following lines:
$9$ $5$ $3 \ 3$ $2 \ 4$ $2 \ 8$ $3 \ 9$ $4 \ 12$
describes an instance in which the silicon plate has the width
In the folder out
the .txt
representation of the solutions of the
An solution of a VLSI instance is a text file consisting of lines of integer values. The first line gives
For example, a file with the following lines:
$9 \ 12$ $5$ $3 \ 3 \ 4 \ 0$ $2 \ 4 \ 7 \ 0$ $2 \ 8 \ 7 \ 4$ $3 \ 9 \ 4 \ 3$ $4 \ 12 \ 0 \ 0$
says thet for the given instance that the left-bottom corner of the
By default, the execute_*.py
scripts create a graphical representation of the solution. This is achieved thanks to the auxiliary visualize.py
script.
By default, the scripts of the compare models group create a comparison plot. of the solution. This is achieved thanks to the auxiliary plot_comparisons.py
script.
The names of the models and encodings presented inside the src
subfolders are numerical and therefore not easy to understand. The files MODELS RECAP.md
and ENCODINGS RECAP.md
inside the src
subfolders provide a description of each model (or encoding) name.
The following is the list of the best models (or encodings) for each approach:
- CP:
- Without rotation:
model_6D1
- With rotation:
model_r_7B
- Without rotation:
- LP:
- Without rotation:
model_grid
, CPLEX solver and symmetry breaking applied - With rotation:
model_r_0
, Gurobi solver and symmetry breaking applied
- Without rotation:
- SAT:
- Without rotation:
encoding_10B
- With rotation:
encoding_11B
- Without rotation:
- SMT:
- Without rotation:
encoding_2C
, z3 solver - With rotation:
encoding_5B
, z3 solver
- Without rotation:
# Execute instance "ins-3" with CP "model_6D1"
python src/scripts/execute_cp.py model_6D1 ins-3 --time-limit 300
# Execute instance "ins-3" with LP "model_1" and solver "Gurobi"
python src/scripts/execute_lp.py model_1 ins-3 gurobi --time-limit 300
# Execute instance "ins-3" with SAT "encoding_10B"
python src/scripts/execute_sat.py encoding_10B ins-3 --time-limit 300
# Execute instance "ins-3" with SMT "encoding_2C" and solver "z3"
python src/scripts/execute_smt.py encoding_2C ins-3 z3 --time-limit 300
# Compare the results of the first 10 instances with CP models "model_6D1" and "model_r_7B"
python src/scripts/compare_cp_models.py --models-list model_6D1 model_r_7B -lb 1 -ub 10
# Compare the results of the first 10 instances with LP models "model_1" and "model_r_0" and solvers "CPLEX" and "Gurobi"
python src/scripts/compare_lp_models.py --models-list model_1 model_r_0 --solvers-list cplex gurobi -lb 1 -ub 10
# Compare the results of the first 10 instances with SAT encodings "encoding_10B" and "encoding_11B"
python src/scripts/compare_sat_encodings.py --encodings-list encoding_10B encoding_11B -lb 1 -ub 10
# Compare the results of the first 10 instances with SMT encodings "encoding_2C" and "encoding_5B" and solvers "z3" and "cvc5"
python src/scripts/compare_smt_encodings.py --encodings-list encoding_2C encoding_5B --solvers-list z3 cvc5 -lb 1 -ub 10
# Solve all instances accounting for the rotation of the circuits with the best model for solver CP.
python src/scripts/solve_all_instances.py cp --rotation
It is required for the execution of the CP models to install MiniZinc and add the executable to the environment variable PATH.
To execute SAT the Z3 theorem prover for python is required. The simplest way to install it is to use Python's package manager pip:
pip install z3-solver
The SMT solvers executables are already present in the directory src/smt/solvers
.
For LP the AMPL software and license are required. Moreover at least one of the following solvers is needed: Gurobi, CPLEX and Cbc. Note that some scripts require the installation of Gurobi or CPLEX. Finally, the installation of the amplpy library is necessary. It can easily be installed through pip:
pip install amplpy
If not already installed Python libraries pandas and Numpy shall be installed.
The execute_*.py
scripts all present the following positional arguments:
model
: The model to execute (encoding
for SAT and SMt)instance
: The instance to solve
And the following optional parameters:
output-folder-path
: The path in which the output file is storedoutput-name
: The name of the output solution--time-limit
: The allowed time to solve the task in seconds--no-create-output
: Skip the creation of the output solution--no-visualize-output
: Skip the visualization of the output solution (defaults as true if--no-create-output
is passed).
Moreover execute_lp.py
presents the following parameters:
solver
: The solver used for optimization--use-symmetry
: Break symmetries in the presolve process.--use-dual
: Use the dual model.--use-no-presolve
: Avoid AMPL presolving process.
Finally, execute_smt.py
presents the following parameter:
solver
: The solver used for optimization.
The compare_*.py
scripts all present the following positional arguments:
output-name
: The name of the output solutionoutput-folder-path
: The path in which the output file is stored
And the following optional parameters:
--models-list
: List of models to compare--instances-lower-bound
: Lower bound of instances to solve (default 1)--instances-upper-bound
: Upper bound of instances to solve (default 40)--no-visualize
: Do not visualize the obtained comparisons
Moreover compare_lp_models.py
presents the following parameters:
--solvers-list
: List of solvers to use for comparison (default all solvers)--use-symmetry
: Break symmetries in the presolve process.--use-dual
: Use the dual model.--use-no-presolve
: Avoid AMPL presolving process.
Finally, compare_smt_encodings.py
presents the following parameter:
--solvers-list
: List of solvers to use for comparison (default z3)
.
├── images # Plots of the performances of different models for the different approaches
│ ├── cp
│ ├── lp
│ ├── sat
│ └── smt
├── instances
│ ⋮
│ └── ins-*-.txt # Instances to solve in `.txt` format
├── results # Json results of the performances of different models for the given approaches
│ ├── cp
│ ├── lp
│ ├── sat
│ └── smt
├── out # Solutions for the given instances using different approaches
│ ├── cp
│ ├── cp-rotation
│ ├── lp
│ ├── lp-rotation
│ ├── sat
│ ├── sat-rotation
│ ├── smt
│ └── smt-rotation
├── src
│ ├── cp
│ │ ├── data # Directory containing data examples for the problem in CP
│ │ ├── models # Directory containing the models solving the problem in CP
│ │ ├── rotation_models # Directory containing the models solving the problem in CP considering rotations
│ │ ├── solvers # Directory containing the solver configurations for CP
│ │ ├── MODELS RECAP.md # Recap of the CP MiniZinc models
│ │ └── project_cp.mzp # MiniZinc CP project
│ ├── lp
│ │ ⋮
│ │ ├── model_*.mod # AMPL model solving the problem in LP
│ │ ├── MODELS RECAP.md # Recap of the LP AMPL models
│ │ └── position_and_covering.py # Script applying the Position and Covering technique for LP
│ ├── sat
│ │ ⋮
│ │ ├── encoding_*.py # Encoding solving the problem in LP
│ │ ├── ENCODINGS RECAP.md # Recap of the SAT encodings
│ │ └── sat_utils.py # Script containing useful functions for SAT
│ ├── scripts
│ │ ├── compare_cp_models.py # Script to compare the results of CP models on the instances
│ │ ├── compare_lp_models.py # Script to compare the results of LP models on the instances
│ │ ├── compare_sat_encodings.py # Script to compare the results of SAT encodings on the instances
│ │ ├── compare_smt_encodings.py # Script to compare the results of SMT encodings on the instances
│ │ ├── execute_cp.py # Script to solve an instance using CP
│ │ ├── execute_lp.py # Script to solve an instance using LP
│ │ ├── execute_sat.py # Script to solve an instance using SAT
│ │ ├── execute_smt.py # Script to solve an instance using SMT
│ │ ├── plot_comparisons.py # Script to plot the results of the use of different models on the instances
│ │ ├── solve_all_instances_cp.py # Script solving all instances with CP
│ │ ├── solve_all_instances_lp.py # Script solving all instances with LP
│ │ ├── solve_all_instances_sat.py # Script solving all instances with SAT
│ │ ├── solve_all_instances_smt.py # Script solving all instances with SMT
│ │ ├── solve_all_instances.py # Script solving all instances with a desired methodology
│ │ ├── unify_jsons.py
│ │ ├── utils.py # Script containing useful functions
│ │ └── visualize.py # Script to visualize a solved instance
│ └── smt
│ ├── solvers # Directory containing the solvers executable files for SMT
│ │ ⋮
│ ├── encoding_*.py # Encoding solving the problem in SMT
│ ├── ENCODINGS RECAP.md # Recap of the SMT encodings
│ └── smt_utils.py # Script containing useful functions for SMT
├── assignment.pdf # Assignment of the project
├── .gitattributes
├── .gitignore
├── LICENSE
├── report.pdf # Report of the project
└── README.md
Git is used for versioning.
Name | Surname | Username | |
---|---|---|---|
Antonio | Politano | [email protected] |
S1082351 |
Enrico | Pittini | [email protected] |
EnricoPittini |
Riccardo | Spolaor | [email protected] |
RiccardoSpolaor |
This project is licensed under the MIT License - see the LICENSE file for details.