Skip to content
This repository has been archived by the owner on Jan 26, 2023. It is now read-only.

Commit

Permalink
Add index label decorator
Browse files Browse the repository at this point in the history
Only available for bqm now, so override sample instead of sample_qubo
  • Loading branch information
bellert committed Mar 29, 2018
1 parent 4ad3678 commit cbc6cea
Show file tree
Hide file tree
Showing 2 changed files with 7 additions and 4 deletions.
9 changes: 6 additions & 3 deletions python/dwave_qbsolv/dimod_wrapper.py
Original file line number Diff line number Diff line change
Expand Up @@ -26,9 +26,10 @@ def __init__(self):
'verbosity': [], 'timeout': [], 'solver_limit': [], 'solver': [],
'target': [], 'find_max': [], 'sample_kwargs': []}

def sample_qubo(self, Q, num_repeats=50, seed=None, algorithm=None,
verbosity=-1, timeout=2592000, solver_limit=None, solver=None,
target=None, find_max=False, **sample_kwargs):
@dimod.decorators.bqm_index_labels
def sample(self, bqm, num_repeats=50, seed=None, algorithm=None,
verbosity=-1, timeout=2592000, solver_limit=None, solver=None,
target=None, find_max=False, **sample_kwargs):
"""Sample low-energy states defined by a QUBO using qbsolv.
Note:
Expand Down Expand Up @@ -84,11 +85,13 @@ def sample_qubo(self, Q, num_repeats=50, seed=None, algorithm=None,
raise ValueError("num_repeats must be a positive integer")

# pose the QUBO to qbsolv
Q, offset = bqm.to_qubo()
samples, energies, counts = run_qbsolv(Q=Q, num_repeats=num_repeats, seed=seed, algorithm=algorithm,
verbosity=verbosity, timeout=timeout, solver_limit=solver_limit,
solver=solver, target=target, find_max=find_max, sample_kwargs=sample_kwargs)

# load the response
response = dimod.Response.from_dicts(samples, {'energy': energies, 'num_occurrences': counts}, dimod.BINARY)
response.change_vartype(bqm.vartype, {'energy': [offset] * len(energies)})

return response
2 changes: 1 addition & 1 deletion tests/test_dwave_qbsolv.py
Original file line number Diff line number Diff line change
Expand Up @@ -68,4 +68,4 @@ def test_energy_calculation(self):
response = qbs.QBSolv().sample_ising(h, J)

for sample, energy in response.data(['sample', 'energy']):
self.assertLessEqual(abs(dimod.ising_energy(sample, h, J) - energy), 10**-5)
self.assertAlmostEqual(dimod.ising_energy(sample, h, J), energy)

0 comments on commit cbc6cea

Please sign in to comment.