Skip to content

Commit

Permalink
Merge branch 'main' into 2024-12/deps
Browse files Browse the repository at this point in the history
  • Loading branch information
mpharrigan authored Dec 19, 2024
2 parents b242339 + b6cc062 commit 8e52b88
Show file tree
Hide file tree
Showing 3 changed files with 26 additions and 9 deletions.
24 changes: 17 additions & 7 deletions qualtran/_infra/data_types.py
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@
We often wish to write algorithms which operate on quantum data. One can think
of quantum data types, similar to classical data types, where a collection of
qubits can be used to represent a specific quantum data type (eg: a quantum
integer of width 32 would comprise of 32 qubits, similar to a classical uint32
integer of width 32 would comprise 32 qubits, similar to a classical uint32
type). More generally, many current primitives and algorithms in qualtran
implicitly expect registers which represent signed or unsigned integers,
fixed-point (fp) numbers , or “classical registers” which store some classical
Expand All @@ -40,7 +40,7 @@
type assuming the bitsizes match. QInt(32) == QAny(32), QInt(32) !=
QFxp(32, 16). QInt(32) != QUInt(32).
5. We assume a big endian convention for addressing QBits in registers
throughout qualtran. Recall that in a big endian convention the most signficant
throughout qualtran. Recall that in a big endian convention the most significant
bit is at index 0. If you iterate through the bits in a register they will be
yielded from most significant to least significant.
6. Ones' complement integers are used extensively in quantum algorithms. We have
Expand Down Expand Up @@ -181,7 +181,7 @@ def __str__(self):

@attrs.frozen
class QAny(QDType):
"""Opaque bag-of-qbits type."""
"""Opaque bag-of-qubits type."""

bitsize: SymbolicInt

Expand Down Expand Up @@ -214,7 +214,10 @@ def assert_valid_classical_val_array(self, val_array, debug_str: str = 'val'):
class QInt(QDType):
"""Signed Integer of a given width bitsize.
A two's complement representation is assumed for negative integers.
A two's complement representation is used for negative integers.
Here (and throughout Qualtran), we use a big-endian bit convention. The most significant
bit is at index 0.
Attributes:
bitsize: The number of qubits used to represent the integer.
Expand Down Expand Up @@ -275,7 +278,11 @@ def __str__(self):
class QIntOnesComp(QDType):
"""Signed Integer of a given width bitsize.
A ones' complement representation is assumed for negative integers.
In contrast to `QInt`, this data type uses the ones' complement representation for negative
integers.
Here (and throughout Qualtran), we use a big-endian bit convention. The most significant
bit is at index 0.
Attributes:
bitsize: The number of qubits used to represent the integer.
Expand Down Expand Up @@ -323,8 +330,11 @@ def assert_valid_classical_val(self, val, debug_str: str = 'val'):
class QUInt(QDType):
"""Unsigned integer of a given width bitsize which wraps around upon overflow.
Similar to unsigned integer types in C. Any intended wrap around effect is
expected to be handled by the developer.
Any intended wrap around effect is expected to be handled by the developer, similar
to an unsigned integer type in C.
Here (and throughout Qualtran), we use a big-endian bit convention. The most significant
bit is at index 0.
Attributes:
bitsize: The number of qubits used to represent the integer.
Expand Down
7 changes: 7 additions & 0 deletions qualtran/_infra/data_types_test.py
Original file line number Diff line number Diff line change
Expand Up @@ -295,6 +295,9 @@ def test_qint_to_and_from_bits():
assert qint4.from_bits(qint4.to_bits(x)) == x
assert list(qint4.to_bits(-2)) == [1, 1, 1, 0]
assert list(QInt(4).to_bits(2)) == [0, 0, 1, 0]
# MSB at lowest index -- big-endian
assert qint4.from_bits([0, 0, 0, 1]) == 1
assert qint4.from_bits([0, 0, 0, 1]) < qint4.from_bits([0, 1, 0, 0])
assert qint4.from_bits(qint4.to_bits(-2)) == -2
assert qint4.from_bits(qint4.to_bits(2)) == 2
with pytest.raises(ValueError):
Expand Down Expand Up @@ -325,6 +328,10 @@ def test_quint_to_and_from_bits():
assert [*quint4.get_classical_domain()] == [*range(0, 16)]
assert list(quint4.to_bits(10)) == [1, 0, 1, 0]
assert quint4.from_bits(quint4.to_bits(10)) == 10
# MSB at lowest index -- big-endian
assert quint4.from_bits([0, 0, 0, 1]) == 1
assert quint4.from_bits([0, 0, 0, 1]) < quint4.from_bits([1, 0, 0, 0])

for x in range(16):
assert quint4.from_bits(quint4.to_bits(x)) == x
with pytest.raises(ValueError):
Expand Down
4 changes: 2 additions & 2 deletions qualtran/bloqs/chemistry/resource_estimation.ipynb
Original file line number Diff line number Diff line change
Expand Up @@ -64,12 +64,12 @@
"\n",
"| Name | $$V_{pqrs} $$ | Space complexity |\n",
"| :---- | :---- | :---- | \n",
"| [Sparse](sparse/sparse.ipynb) | $$\\tilde{V}_{pqrs}$$ | $$O(N^3)$$ |\n",
"| [Sparse](sparse/sparse.ipynb) | $$\\tilde{V}_{pqrs}$$ | $$O(N^4)$$ |\n",
"| [Single Factorization](sf/single_factorization.ipynb) | $$\\sum_X^{L} L_{pq}^X L_{rs}^X $$ | $$O(N^3)$$ |\n",
"| [Double Factorization](df/double_factorization.ipynb) | $$\\sum_X^{} \\left(\\sum_k^{\\Xi} U^{X}_{pk}f_k^X U_{qk}^{X*}\\right)^2$$ | $$O(N^2\\Xi)$$ |\n",
"| [Tensor Hypercontraction](thc/thc.ipynb) | $$\\sum_{\\mu\\nu}^{M} \\chi_p^{\\mu}\\chi_q^{\\mu}\\zeta_{\\mu\\nu}\\chi_r^\\nu\\chi_s^\\nu$$ | $$O(N^2)$$ |\n",
"\n",
"where the space complexity column represents the amount of classical data ($\\Gamma$, say) required to specify the Hamiltonian. The Toffoli complexity for state preparation for all of these approaches goes roughly like $\\sqrt{\\Gamma}$. "
"the space complexity column represents the amount of classical data ($\\Gamma$, say) required to specify the Hamiltonian. The Toffoli complexity for state preparation for all of these approaches goes roughly like $\\sqrt{\\Gamma}$. Note under certain conditions sparsity may lead to $O(N^3)$ non-zero elements. "
]
},
{
Expand Down

0 comments on commit 8e52b88

Please sign in to comment.