Interoperability with annealing framework

One can translate from the presented problem formulations, namely Ising, QUBO and Combinatorial problem to a Binary Quadratic Model as specified by DWave’s library dimod. This is achived by simply calling the method to_bqm() of Ising (or the respective to_bqm() and to_bqm() for QUBO and CombinatorialProblem):

import numpy as np
from qat.opt import Ising

np.random.seed(316)

# Specify the Ising problem
problem_size = 5  # number of qubits
h_field = np.random.rand(problem_size)  # Magnetic field h

# J-coupling matrix
any_mat = np.random.rand(problem_size, problem_size)
j_mat = ((any_mat + np.transpose(any_mat)) / 2  # make it symmetric
         - np.diag(np.diag(any_mat)))  # make it with 0s as the diagonal elements

# Offset - can be 0
offset = 2.18

# Create an Ising problem
problem_Ising = Ising(J=j_mat, h=h_field, offset_i=offset)

# Translate to DWave's Binary Quadratic Model
bqm_problem = problem_Ising.to_bqm()

This method also works for the NP-Hard problems encoded on Qaptiva, for example:

# import required libraries
import numpy as np
import networkx as nx
from qat.opt import VertexCover

# Specify the problem
graph = nx.Graph()
graph.add_nodes_from(np.arange(6))
graph.add_edges_from([(0, 1), (0, 2), (0, 3), (0, 4), (0, 5), (1, 5)])

# Impose constraints for proper encoding
B = 1
A = B + 0.01

# Create problem
vertex_cover_problem = VertexCover(graph, A=A, B=B)

# Translate to DWave's Binary Quadratic Model
bqm_problem = vertex_cover_problem.to_bqm()