Source code for pennylane.labs.resource_estimation.templates.subroutines
# Copyright 2024 Xanadu Quantum Technologies Inc.
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
# http://www.apache.org/licenses/LICENSE-2.0
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
r"""Resource operators for PennyLane subroutine templates."""
from typing import Dict
import pennylane as qml
from pennylane.labs.resource_estimation import (
CompressedResourceOp,
ResourceControlledPhaseShift,
ResourceHadamard,
ResourceOperator,
ResourceSWAP,
)
# pylint: disable=arguments-differ
[docs]class ResourceQFT(qml.QFT, ResourceOperator):
"""Resource class for QFT.
Resources:
The resources are obtained from the standard decomposition of QFT as presented
in (chapter 5) `Nielsen, M.A. and Chuang, I.L. (2011) Quantum Computation and Quantum Information
<https://www.cambridge.org/highereducation/books/quantum-computation-and-quantum-information/01E10196D0A682A6AEFFEA52D53BE9AE#overview>`_.
"""
@staticmethod
def _resource_decomp(num_wires, **kwargs) -> Dict[CompressedResourceOp, int]:
gate_types = {}
hadamard = ResourceHadamard.resource_rep()
swap = ResourceSWAP.resource_rep()
ctrl_phase_shift = ResourceControlledPhaseShift.resource_rep()
gate_types[hadamard] = num_wires
gate_types[swap] = num_wires // 2
gate_types[ctrl_phase_shift] = num_wires * (num_wires - 1) // 2
return gate_types
[docs] @classmethod
def resource_rep(cls, num_wires) -> CompressedResourceOp:
params = {"num_wires": num_wires}
return CompressedResourceOp(cls, params)
_modules/pennylane/labs/resource_estimation/templates/subroutines
Download Python script
Download Notebook
View on GitHub