From 19fda1671af8c07b39c3851ff048b4450f9480bb Mon Sep 17 00:00:00 2001 From: SebastianMorawiec <108305907+SebastianMorawiec@users.noreply.github.com> Date: Wed, 22 Nov 2023 15:03:13 +0100 Subject: [PATCH] Feat: Add factory_count param to get_physical_cost and add distillation/computational qubit value for CostEstimate --- .../resource_estimation/_footprint_analysis.py | 13 +++++++++---- src/benchq/resource_estimation/openfermion_re.py | 2 ++ 2 files changed, 11 insertions(+), 4 deletions(-) diff --git a/src/benchq/resource_estimation/_footprint_analysis.py b/src/benchq/resource_estimation/_footprint_analysis.py index 988a91da..7530d88d 100644 --- a/src/benchq/resource_estimation/_footprint_analysis.py +++ b/src/benchq/resource_estimation/_footprint_analysis.py @@ -29,6 +29,8 @@ class MagicStateFactory: @dataclasses.dataclass(frozen=True, unsafe_hash=True) class CostEstimate: physical_qubit_count: int + physical_computation_qubit_count: int + physical_distillation_qubit_count: int duration: float algorithm_failure_probability: float widget_name: str @@ -64,7 +66,7 @@ def estimate_cost(self) -> CostEstimate: * (1 + self.routing_overhead_proportion) ) ) - n_physical_qubits_used_for_clifford_circuit = ( + n_physical_qubits_used_for_computation = ( n_logical_qubits_used_for_computation * _physical_qubits_per_logical_qubit(self.logical_data_qubit_distance) ) @@ -84,7 +86,7 @@ def estimate_cost(self) -> CostEstimate: V_computation = ( self.proportion_of_bounding_box - * n_physical_qubits_used_for_clifford_circuit + * n_physical_qubits_used_for_computation * total_distillation_cycles ) data_failure = ( @@ -96,8 +98,10 @@ def estimate_cost(self) -> CostEstimate: ) return CostEstimate( - physical_qubit_count=n_physical_qubits_used_for_clifford_circuit + physical_qubit_count=n_physical_qubits_used_for_computation + n_physical_qubits_used_for_distillation, + physical_computation_qubit_count=n_physical_qubits_used_for_computation, + physical_distillation_qubit_count=n_physical_qubits_used_for_distillation, duration=total_distillation_cycles * self.surface_code_cycle_time, algorithm_failure_probability=min(1.0, data_failure + distillation_failure), widget_name=self.widget.details, @@ -235,6 +239,7 @@ def cost_estimator( portion_of_bounding_box=1.0, routing_overhead_proportion=0.5, hardware_failure_tolerance=1e-3, + factory_count: int = 4, ): """ Produce best cost in terms of physical qubits and real run time based on @@ -255,7 +260,7 @@ def cost_estimator( toffoli_count=num_toffoli, t_count=num_t, max_allocated_logical_qubits=num_logical_qubits, - factory_count=4, + factory_count=factory_count, routing_overhead_proportion=routing_overhead_proportion, proportion_of_bounding_box=portion_of_bounding_box, ) diff --git a/src/benchq/resource_estimation/openfermion_re.py b/src/benchq/resource_estimation/openfermion_re.py index d35cb5d8..1878363b 100644 --- a/src/benchq/resource_estimation/openfermion_re.py +++ b/src/benchq/resource_estimation/openfermion_re.py @@ -246,6 +246,7 @@ def get_physical_cost( routing_overhead_proportion=0.5, hardware_failure_tolerance=1e-3, decoder_model=None, + factory_count: int = 4, ) -> OpenFermionResourceInfo: """Get the estimated resources for single factorized QPE as described in PRX Quantum 2, 030305. @@ -265,6 +266,7 @@ def get_physical_cost( surface_code_cycle_time=architecture_model.surface_code_cycle_time_in_seconds, routing_overhead_proportion=routing_overhead_proportion, hardware_failure_tolerance=hardware_failure_tolerance, + factory_count=factory_count, ) decoder_info = get_decoder_info(