From 1791639cd405b08693658631a2889180bfa51abd Mon Sep 17 00:00:00 2001 From: abbycross Date: Mon, 17 Jun 2024 16:39:51 -0400 Subject: [PATCH] Update broken threading code in Run-jobs-in-session (#1571) Closes #1568 --- docs/run/run-jobs-in-session.mdx | 23 ++++++++++++++++------- 1 file changed, 16 insertions(+), 7 deletions(-) diff --git a/docs/run/run-jobs-in-session.mdx b/docs/run/run-jobs-in-session.mdx index 03492892af3..5407d5f7352 100644 --- a/docs/run/run-jobs-in-session.mdx +++ b/docs/run/run-jobs-in-session.mdx @@ -203,20 +203,29 @@ with Session(backend=backend): ## Run two VQE algorithms in a session by using threading You can get more out of a session by running multiple workloads simultaneously. The following example shows how you can run two VQE algorithms, each using a different classical optimizer, simultaneously inside a single session. Job tags are also used to differentiate jobs from each workload. + ```python from concurrent.futures import ThreadPoolExecutor -from qiskit_ibm_runtime import Session, EstimatorV2 as Estimator +from qiskit_ibm_runtime import EstimatorV2 as Estimator def minimize_thread(estimator, method): - minimize(cost_func, x0, args=(ansatz, hamiltonian, estimator), method=method) + return minimize(cost_func, x0, args=(ansatz, hamiltonian, estimator), method=method) with Session(backend=backend), ThreadPoolExecutor() as executor: - # Add tags to differentiate jobs from different workloads. - estimator1.options.environment.job_tags = "cobyla" - estimator1.options.environment.job_tags = "nelder-mead" + estimator1 = Estimator() + estimator2 = Estimator() + + # Use different tags to differentiate the jobs. + estimator1.options.environment.job_tags = ["cobyla"] + estimator2.options.environment.job_tags = ["nelder-mead"] + + # Submit the two workloads. + cobyla_future = executor.submit(minimize_thread, estimator1, "cobyla") + nelder_mead_future = executor.submit(minimize_thread, estimator2, "nelder-mead") - cobyla_result = executor.submit(minimize_thread, estimator1, "cobyla").result() - nelder_mead_result = executor.submit(minimize_thread, estimator2, "nelder-mead").result() + # Get workload results. + cobyla_result = cobyla_future.result() + nelder_mead_result = nelder_mead_future.result() ```