From c3a23adddf8f75559feabfcf488197be732e3a21 Mon Sep 17 00:00:00 2001 From: Charles Yuan Date: Thu, 1 Aug 2024 14:47:05 -0700 Subject: [PATCH] Add convenience constructors for block encodings (#1243) * Add convenience constructors for block encodings * Fix import of `Self` * Add docstrings --- qualtran/bloqs/block_encoding/linear_combination.py | 6 ++++++ qualtran/bloqs/block_encoding/product.py | 6 ++++++ qualtran/bloqs/block_encoding/tensor_product.py | 6 ++++++ 3 files changed, 18 insertions(+) diff --git a/qualtran/bloqs/block_encoding/linear_combination.py b/qualtran/bloqs/block_encoding/linear_combination.py index fc3a5a8e7..ed3038294 100644 --- a/qualtran/bloqs/block_encoding/linear_combination.py +++ b/qualtran/bloqs/block_encoding/linear_combination.py @@ -17,6 +17,7 @@ import numpy as np from attrs import evolve, field, frozen, validators +from typing_extensions import Self from qualtran import ( bloq_example, @@ -106,6 +107,11 @@ def __attrs_post_init__(self): "If given, select oracle must have block encoding `system` register as target." ) + @classmethod + def of_terms(cls, *terms: Tuple[float, BlockEncoding], lambd_bits: SymbolicInt = 1) -> Self: + """Construct a `LinearCombination` from pairs of (coefficient, block encoding).""" + return cls(tuple(t[1] for t in terms), tuple(t[0] for t in terms), lambd_bits) + @cached_property def signed_block_encodings(self): """Appropriately negated constituent block encodings.""" diff --git a/qualtran/bloqs/block_encoding/product.py b/qualtran/bloqs/block_encoding/product.py index f4b40a2d3..6bed00bab 100644 --- a/qualtran/bloqs/block_encoding/product.py +++ b/qualtran/bloqs/block_encoding/product.py @@ -18,6 +18,7 @@ import cirq from attrs import evolve, field, frozen, validators from numpy.typing import NDArray +from typing_extensions import Self from qualtran import ( bloq_example, @@ -87,6 +88,11 @@ def __attrs_post_init__(self): if not all(u.system_bitsize == self.system_bitsize for u in self.block_encodings): raise ValueError("All block encodings must have the same system size.") + @classmethod + def of(cls, *block_encodings: BlockEncoding) -> Self: + """Construct a `Product` from block encodings.""" + return cls(block_encodings) + @cached_property def signature(self) -> Signature: return Signature.build_from_dtypes( diff --git a/qualtran/bloqs/block_encoding/tensor_product.py b/qualtran/bloqs/block_encoding/tensor_product.py index f3bbc31fa..656623991 100644 --- a/qualtran/bloqs/block_encoding/tensor_product.py +++ b/qualtran/bloqs/block_encoding/tensor_product.py @@ -17,6 +17,7 @@ from typing import Dict, Set, Tuple from attrs import evolve, field, frozen, validators +from typing_extensions import Self from qualtran import ( bloq_example, @@ -64,6 +65,11 @@ class TensorProduct(BlockEncoding): converter=lambda x: x if isinstance(x, tuple) else tuple(x), validator=validators.min_len(1) ) + @classmethod + def of(cls, *block_encodings: BlockEncoding) -> Self: + """Construct a `TensorProduct` from block encodings.""" + return cls(block_encodings) + @cached_property def signature(self) -> Signature: return Signature.build_from_dtypes(