A tool to write QBF family definitions and obtain instances in QCIR or QDIMACS.
QBDef is a computer-tool written in Python designed to make the generation of QBF instances easier. The tool gets as input the formal definition of a formula family in terms of some parameters and returns instances of it for specific values in the QCIR or QDIMACS formats.
The tool is written in Python, so it should work on any operating system. However, if you are using Windows, we recommend running the tool using the Windows Subsystem for Linux (WSL).
The tool requires:
- Python parsing library lark:
pip install lark-parser
- Python 2 (the tool runs on Python 3 but Python 2 is needed to run some third-party code; make sure you have it installed, as, for instance, Ubuntu 20.04 no longer has it by default). Check that you have both with
python2 --version
andpython3 --version
. - William Klieber's
qcir-to-qdimacs.py
conversion tool. A copy of his script is available in this same repo. The original source is this. The script must be in the same directory as the tool to be able to output QDIMACS files. This is already in the directory if you clone the repository.
After cloning the repository, you can run the tool by executing the QBDef.py
script on a terminal:
python3 QBDef.py definition_file values_file [-internal] [-verbose] [-QDIMACS {file.qdimacs | [-stdIO]}] [-QCIR {file.QCIR | [-stdIO]}] [-non-prenex-QCIR {file.QCIR | [-stdIO]}]
For example, if my_def.txt
is your QBF family definition and values.txt
is the file with the values for the parameters,
python3 QBDef.py my_def.txt values.txt -QCIR
outputs the QCIR format instance on a terminal.
The possible options are:
-QCIR [output_file]
: outputs a QCIR, if no output file is provided, it is printed in the standard output.-QDIMACS [output_file]
: outputs a QDIMACS, if no output file is provided, it is printed in the standard output.-non-prenex-QCIR [output_file]
: outputs a non-prenex QCIR. This feature is experimental.-internal
: outputs a human-readable version of the internal representation of the QBF.-verbose
: prints messages while parsing and processing the definition.
Formula family definitions are written in a formal language parsed by the generator, which then outputs an actual instance in a valid format for some values of the family's parameters. The cheat sheet contains information on the syntax and format of this language. The /examples
folder contains examples of formula families written in the formal language. An interesting and simple example is that of the QParity formulas. Below, a more basic example is discussed.
Let n ∊ ℕ*. We will consider the formula family containing QBF over variables x₁, ..., xₙ, y₁, ..., yₙ of the form
Φ(n) = ∃ x₁ ∀ y₁ ... ∃ xₙ ∀ yₙ : φ(x₁, ..., xₙ, y₁, ..., yₙ)
where φ is the matrix is given by
φ(x₁, ..., xₙ, y₁, ..., yₙ) = (¬ x₁ ∨ ... ∨ ¬ xₙ) ∧ (x₁ ∨ y₁) ∧ ... ∧ (xₙ ∨ yₙ)
For instance, for n = 2, the QBF is:
Φ(2) = ∃ x₁ ∀ y₁ ∃ x₂ ∀ y₂ : (¬ x₁ ∨ ¬ x₂) ∧ (x₁ ∨ y₁) ∧ (x₂ ∨ y₂)
In QBDef's formal language, Φ(n) is written as follows:
name: The simple parameterised example;
format: CNF; /* possible formats are: CNF, circuit-prenex, circuit-nonprenex */
parameters: {
n : int, `n >= 1`;
}
variables: {
x(i) where i in 1..n;
y(i) where i in 1..n;
}
blocks: {
/* === Quantifier prefix === */
define blocks grouped in QX {
QX(i) := x(i);
} where i in 1..n;
define blocks grouped in QY {
QY(i) := y(i);
} where i in 1..n;
define blocks grouped in QXY {
QXY(i) := QX(i), QY(i);
} where i in 1..n;
define block Q := all blocks in QXY;
all blocks in QX quantified with ∃; /* it's also possible to write E */
all blocks in QY quantified with ∀; /* it's also possible to write A */
/* === Matrix === */
define blocks {
NotX := ¬x(i);
} where i in 1..n;
define blocks grouped in XY {
XY(i) := x(i), y(i);
} where i in 1..n;
define block φ := NotX, all blocks in XY;
block NotX operated with ∨;
all blocks in XY operated with ∨; /* it's also possible to write OR */
block φ operated with ∧; /* it's also possible to write AND */
/* Define the output block: */
define block Φ := Q, φ;
}
output block: Φ;
Suppose the previous piece of code is in some file definition.txt
and we create a second file, values.txt
, containing:
value: n = 2;
Now, if we execute python3 QBDef.py definition.txt values.txt -QCIR
in a terminal, we get the following QCIR output:
#QCIR-G14
exists(1)
forall(3)
exists(2)
forall(4)
output(15)
12 = or(-1, -2)
13 = or(1, 3)
14 = or(2, 4)
15 = and(12, 13, 14)
If we execute python3 QBDef.py definition.txt values.txt -QDIMACS
, we get the output in QDIMACS:
c Formula Family: The simple parameterised example
c Values: {'n': 2}
p cnf 4 3
e 1 0
a 3 0
e 2 0
a 4 0
-1 -2 0
1 3 0
2 4 0
This work belongs to my Bachelor's thesis, A Formal Language and Tool for QBF Family Definitions, written in 2020 at the KU Leuven. The thesis text and the slides used for its defence can be found in the /documents
folder. These contain an in-depth discussion of the tool and its implementation, as well as many other examples.
Besides, this work was presented at the QBF Workshop 2020. The extended abstract is also available in the /documents
folder, alongside the video recording of the talk and the slides used for it.
Any of these documents, alongside the cheat sheet, can serve as documentation on how to use QBDef.
If you find bugs or errors when trying to use QBDef, please let me know at [email protected]. Besides, feel free to use this code and modify it for your own purposes.
QBDef.py
: Python script to run the tool.qcir-to-qdimacs.py
: third-party Python script for QCIR-to-QDIMACS conversion.QBDef Cheatsheet.pdf
: brief cheat sheet on how to use the language and the tool./examples
: example definitions in the formal language./documents
: some documents related to this project. These are an extended abstract presented at the QBF Workshop 2020, my Bachelor's thesis, to which this work belongs, as well as slides from talks given about this project./src
: source code and development files.