QIRO MaxSat#
Problem description#
Given
For example, for
where
Given
The cost function for the maximum satisfyability problem is given by
where for each clause
Replacement routine#
The replacements work based on the problem encoding. We discard clauses, based on the truth value assignments as those are what is described by the qubits. Based on the maximum absolute entry of the correlation matrix M and its sign, one of the following replacements is employed:
If
is the maximum absolute value, then the -th value is set to be true. In turn, we can remove all clauses that negate that value.If
is the maximum absolute value we remove -th value is set to be false and we will exclude clause that include that value.If
was selected, we transfer this correlation to the clauses, by replacing the first item with the second one.If
was selected, we transfer this correlation to the clauses, by replacing the first item with the negation of the second one.
- create_maxsat_replacement_routine(res, problem_updated)[source]#
Creates a replacement routine for the problem structure, i.e., defines the replacement rules. See the original paper for a description of the update rules.
- Parameters:
- resdict
Result dictionary of QAOA optimization procedure.
- problem_updatedList
Updates that happened during the QIRO routine. Consits of the updated problem, a list of Qubits which were found to be positively correlated, i.e. part of the problem solution, and a list Qubits which were found to be negatively correlated, i.e. they contradict solution qubits in accordance with the update rules.
- Returns:
- new_problem: list
Updated clauses of the problem instance.
- solutionslist
Updated set of solutions to the problem.
- signint
The sign of the correlation.
- exclusionslist
Updated set of exclusions to the problem.
QIRO Cost operator#
- create_maxsat_cost_operator_reduced(problem_updated)[source]#
Creates the
cost_operator
for the problem instance. This operator is adjusted to consider qubits that were found to be a part of the problem solution.- Parameters:
- problem_updatedList
Updates that happened during the QIRO routine. Consits of the updated problem, a list of Qubits which were found to be positively correlated, i.e. part of the problem solution, and a list Qubits which were found to be negatively correlated, i.e. they contradict solution qubits in accordance with the update rules.
- Returns:
- cost_operatorfunction
A function receiving a QuantumVariable and a real parameter
. This function performs the application of the cost operator.
Example implementation#
from qrisp import QuantumVariable
from qrisp.qaoa import create_maxsat_cl_cost_function
from qrisp.qiro import QIROProblem, qiro_init_function, qiro_rx_mixer, create_maxsat_replacement_routine, create_maxsat_cost_operator_reduced
clauses = [[1,2,-3],[1,4,-6],[4,5,6],[1,3,-4],[2,4,5],[1,3,5],[-2,-3,6],[1,7,8],[3,-7,-8],[3,4,8],[4,5,8],[1,2,7]]
num_vars = 8
problem = (num_vars, clauses)
qarg = QuantumVariable(num_vars)
qiro_instance = QIROProblem(problem = problem,
replacement_routine = create_maxsat_replacement_routine,
cost_operator = create_maxsat_cost_operator_reduced,
mixer = qiro_rx_mixer,
cl_cost_function = create_maxsat_cl_cost_function,
init_function = qiro_init_function
)
res_qiro = qiro_instance.run_qiro(qarg=qarg, depth = 3, n_recursions = 2)
That’s it! In the following, we print the 5 most likely solutions together with their cost values, and the final clauses.
cl_cost = create_maxsat_cl_cost_function(problem)
print("5 most likely QIRO solutions")
max_five_qiro = sorted(res_qiro, key=res_qiro.get, reverse=True)[:5]
for res in max_five_qiro:
print(res)
print(cl_cost({res : 1}))
final_clauses = qiro_instance.problem
print("final clauses")
print(final_clauses)