Counting QPU Access in Qbsolv

Counting QPU Access in Qbsolv#

!pip install dwave-ocean-sdk
import logging
import itertools
import random
import re
from datetime import datetime

import dimod
from dwave.system import DWaveCliqueSampler
from dwave_qbsolv import QBSolv
logger = logging.getLogger('dwave_qbsolv.qbsolv_binding')
logger.setLevel(logging.DEBUG)

ch = logging.StreamHandler()
ch.setLevel(logging.INFO)
ch_formatter = logging.Formatter('[%(asctime)s] %(message)s')
ch.setFormatter(ch_formatter)
logger.addHandler(ch)
def create_problem(qubo_size):
    Q = {t: random.uniform(-1, 1)
         for t in itertools.product(range(qubo_size), repeat=2)}
    return dimod.BinaryQuadraticModel.from_qubo(Q)
qubo_size = 120
bqm = create_problem(qubo_size)

config = dict(token='YOUR_TOKEN', solver='DW_2000Q_6')
sampler = QBSolv()
subqubo_size = 30
num_repeats = 1
num_iters = 3

# 実行のたびに、ログを分けて出力
for n in range(num_iters):
    logger.info(f'Iteration: {n}')

    log_file = datetime.now().strftime('%y%m%d%H%M%S%f') + '.log'
    fh = logging.FileHandler(log_file)
    fh.setLevel(logging.DEBUG)
    fh_formatter = logging.Formatter(
        '[%(asctime)s][%(filename)s:%(lineno)d] %(message)s'
    )
    fh.setFormatter(fh_formatter)
    logger.addHandler(fh)

    dw_sampler = DWaveCliqueSampler(**config)
    sampleset = sampler.sample(bqm, num_repeats=num_repeats,
                                solver=dw_sampler,
                                solver_limit=subqubo_size)

    logger.removeHandler(fh)

    with open(log_file) as f:
        log_text = f.read()

    match = re.findall('solver_callback invoked', log_text)
    num_qpu_access = len(match)
    logger.info(f'Number of QPU access: {num_qpu_access}')