Skip to content

Commit

Permalink
Merge branch 'master' into demo_tutorial_lightning_tensor
Browse files Browse the repository at this point in the history
multiphaseCFD authored Jan 9, 2025
2 parents 9c684b5 + d135e0c commit 205621c
Showing 12 changed files with 47 additions and 47 deletions.
16 changes: 8 additions & 8 deletions .github/workflows/build-branch.yml
Original file line number Diff line number Diff line change
@@ -224,7 +224,7 @@ jobs:
echo "strategy-matrix=$matrix" >> $GITHUB_OUTPUT
- name: Upload Workers Load Data as Artifact
uses: actions/upload-artifact@v3
uses: actions/upload-artifact@v4
with:
name: ${{ steps.compute-strategy-matrix.outputs.worker_load_artifact_name }}
path: ${{ steps.compute-strategy-matrix.outputs.worker_load_file_name }}
@@ -323,7 +323,7 @@ jobs:
sudo apt install ocl-icd-opencl-dev
- name: Download Worker Load Data Artifact
uses: actions/download-artifact@v3
uses: actions/download-artifact@v4
with:
name: ${{ needs.compute-build-strategy-matrix.outputs.worker-load-artifact-name }}

@@ -466,7 +466,7 @@ jobs:
- name: Upload Execution Times
if: inputs.skip_execution_of_examples == false
uses: actions/upload-artifact@v3
uses: actions/upload-artifact@v4
with:
name: execution_times_${{ matrix.offset }}.zip
if-no-files-found: error
@@ -500,7 +500,7 @@ jobs:
- name: Upload Html
if: matrix.offset == 0
uses: actions/upload-artifact@v3
uses: actions/upload-artifact@v4
with:
name: html-${{ matrix.offset }}.zip
if-no-files-found: error
@@ -513,7 +513,7 @@ jobs:
# The step above this is executed by only one worker which uploads all static content.
- name: Upload Demo Html
if: matrix.offset != 0
uses: actions/upload-artifact@v3
uses: actions/upload-artifact@v4
with:
name: html-${{ matrix.offset }}.zip
if-no-files-found: error
@@ -534,7 +534,7 @@ jobs:
- build-branch
steps:
- name: Download Artifacts
uses: actions/download-artifact@v3
uses: actions/download-artifact@v4
with:
path: artifacts

@@ -564,15 +564,15 @@ jobs:
- name: Upload Sphinx Build files
if: inputs.skip_sphinx_build_file_aggregation == false
uses: actions/upload-artifact@v3
uses: actions/upload-artifact@v4
with:
name: ${{ inputs.sphinx_build_output_format }}.zip
if-no-files-found: error
path: artifacts/website

- name: Upload Execution Times
if: inputs.skip_execution_of_examples == false && inputs.skip_execution_times_aggregation == false
uses: actions/upload-artifact@v3
uses: actions/upload-artifact@v4
with:
name: execution_times.zip
path: /tmp/execution_times
2 changes: 1 addition & 1 deletion .github/workflows/build-pr.yml
Original file line number Diff line number Diff line change
@@ -149,7 +149,7 @@ jobs:
EOL
- name: Upload Pull Request Event Context as Artifact
if: github.event_name == 'pull_request'
uses: actions/upload-artifact@v3
uses: actions/upload-artifact@v4
with:
name: pr_info
path: /tmp/pr
10 changes: 5 additions & 5 deletions .github/workflows/demo_diff_check.yml
Original file line number Diff line number Diff line change
@@ -67,7 +67,7 @@ jobs:
make html
zip -r /tmp/qml_demos.zip demos
- uses: actions/upload-artifact@v2
- uses: actions/upload-artifact@v4
with:
name: built-website-dev
path: |
@@ -136,7 +136,7 @@ jobs:
make html
zip -r /tmp/qml_demos.zip demos
- uses: actions/upload-artifact@v2
- uses: actions/upload-artifact@v4
with:
name: built-website-master
path: |
@@ -156,15 +156,15 @@ jobs:
- name: Create dev dir
run: mkdir /tmp/dev/

- uses: actions/download-artifact@v2
- uses: actions/download-artifact@v4
with:
name: built-website-dev
path: /tmp/dev/

- name: Create master dir
run: mkdir /tmp/master/

- uses: actions/download-artifact@v2
- uses: actions/download-artifact@v4
with:
name: built-website-master
path: /tmp/master/
@@ -186,7 +186,7 @@ jobs:
git commit -m "Update the demonstration differences found"
git push
- uses: actions/upload-artifact@v2
- uses: actions/upload-artifact@v4
with:
name: demo_diffs
path: |
2 changes: 1 addition & 1 deletion .github/workflows/upload-json.yml
Original file line number Diff line number Diff line change
@@ -61,7 +61,7 @@ jobs:

- name: Download HTML
id: qml_json
uses: actions/download-artifact@v3
uses: actions/download-artifact@v4
with:
name: ${{ inputs.artifact_name }}
path: qml_json
2 changes: 1 addition & 1 deletion .github/workflows/upload-text.yml
Original file line number Diff line number Diff line change
@@ -45,7 +45,7 @@ jobs:

- name: Download Text
id: qml_text
uses: actions/download-artifact@v3
uses: actions/download-artifact@v4
with:
name: ${{ inputs.artifact_name }}
path: qml_text
Original file line number Diff line number Diff line change
@@ -6,7 +6,7 @@
}
],
"dateOfPublication": "2024-12-19T00:00:00+00:00",
"dateOfLastModification": "2024-12-20T00:00:00+00:00",
"dateOfLastModification": "2024-01-07T09:00:00+00:00",
"categories": [
"Quantum Computing",
"Algorithms"
@@ -53,7 +53,7 @@
"relatedContent": [
{
"type": "demonstration",
"id": "tutorial_kak_theorem",
"id": "tutorial_kak_decomposition",
"weight": 1.0
},
{
Original file line number Diff line number Diff line change
@@ -20,7 +20,7 @@
Introduction
------------
The :doc:`KAK theorem </demos/tutorial_kak_theorem>` is an important result from Lie theory that states that any Lie group element :math:`U` can be decomposed
The :doc:`KAK theorem </demos/tutorial_kak_decomposition>` is an important result from Lie theory that states that any Lie group element :math:`U` can be decomposed
as :math:`U = K_1 A K_2,` where :math:`K_{1, 2}` and :math:`A` are elements of two special sub-groups
:math:`\mathcal{K}` and :math:`\mathcal{A},` respectively. In special cases, the decomposition simplifies to :math:`U = K A K^\dagger.`
@@ -36,7 +36,7 @@
We can use this general result from Lie theory as a powerful circuit decomposition technique.
.. note:: We recommend a basic understanding of Lie algebras, see e.g. our :doc:`introduction to (dynamical) Lie algebras for quantum practitioners </demos/tutorial_liealgebra>`.
Otherwise, this demo should be self-contained, though for the mathematically inclined, we further recommend our :doc:`demo on the KAK theorem </demos/tutorial_kak_theorem>`
Otherwise, this demo should be self-contained, though for the mathematically inclined, we further recommend our :doc:`demo on the KAK theorem </demos/tutorial_kak_decomposition>`
that dives into the mathematical depths of the theorem and provides more background info.
Goal: Fast-forwarding time evolutions using the KAK decomposition
Original file line number Diff line number Diff line change
@@ -1,12 +1,12 @@
{
"title": "The KAK theorem",
"title": "The KAK decomposition",
"authors": [
{
"username": "dwierichs"
}
],
"dateOfPublication": "2024-11-25T00:00:00+00:00",
"dateOfLastModification": "2024-11-25T00:00:00+00:00",
"dateOfLastModification": "2025-01-07T09:00:00+00:00",
"categories": [
"Quantum Computing",
"Algorithms"
@@ -15,14 +15,14 @@
"previewImages": [
{
"type": "thumbnail",
"uri": "/_static/demo_thumbnails/regular_demo_thumbnails/thumbnail_kak_theorem.png"
"uri": "/_static/demo_thumbnails/regular_demo_thumbnails/thumbnail_kak_decomposition.png"
},
{
"type": "large_thumbnail",
"uri": "/_static/demo_thumbnails/large_demo_thumbnails/thumbnail_large_kak_theorem.png"
"uri": "/_static/demo_thumbnails/large_demo_thumbnails/thumbnail_large_kak_decomposition.png"
}
],
"seoDescription": "Learn about the KAK theorem and how it powers circuit decompositions.",
"seoDescription": "Learn about the KAK decomposition and how it powers circuit decompositions.",
"doi": "",
"references": [
{
Original file line number Diff line number Diff line change
@@ -1,26 +1,26 @@
r"""The KAK theorem
===================
r"""The KAK decomposition
=========================
The KAK theorem is a beautiful mathematical result from Lie theory, with
The KAK decomposition is a beautiful mathematical result from Lie theory, with
particular relevance for quantum computing. It can be seen as a
generalization of the singular value decomposition (SVD), as it decomposes a group
element :math:`U` (think: unitary operator) into :math:`U=K_1AK_2,` where
:math:`K_{1,2}` and :math:`A` belong to special subgroups that we will introduce.
This means the KAK theorem falls under the large umbrella of matrix factorizations,
This means the KAK decomposition falls under the large umbrella of matrix factorizations,
and it allows us to break down arbitrary quantum circuits into smaller building blocks,
i.e., we can use it for quantum circuit decompositions.
In this demo, we will dive into Lie algebras and their groups. Then, we will discuss
so-called symmetric spaces, which arise from certain subgroups of those Lie groups.
With these tools in our hands, we will then learn about the KAK theorem itself, which
exploits a so-called Cartan decomposition to break up such a Lie group.
With these tools in our hands, we will then learn about the KAK decomposition itself,
breaking up the Lie group into the subgroup and the symmetric space.
We will make all steps explicit on a toy example on paper and in code, which splits
single-qubit gates into a well-known sequence of rotations.
Finally, we will get to know a handy decomposition of arbitrary
two-qubit unitaries into rotation gates as another application of the KAK theorem.
two-qubit unitaries into rotation gates as another application of the KAK decomposition.
.. figure:: ../_static/demo_thumbnails/opengraph_demo_thumbnails/OGthumbnail_kak_theorem.png
.. figure:: ../_static/demo_thumbnails/opengraph_demo_thumbnails/OGthumbnail_kak_decomposition.png
:align: center
:width: 70%
:target: javascript:void(0)
@@ -123,7 +123,7 @@
# .. admonition:: Math detail: (semi)simple Lie algebras
# :class: note
#
# Our main result for this demo will be the KAK theorem, which applies to so-called
# Our main result for this demo will be the KAK decomposition, which applies to so-called
# *semisimple* Lie algebras, which are in turn composed of *simple* Lie algebras as building
# blocks. Without going into detail, it often is sufficient to think of these building
# blocks as (1) special orthogonal algebras :math:`\mathfrak{so}(n),` (2) unitary symplectic
@@ -277,7 +277,7 @@ def is_orthogonal(op, basis):
#
# In this context, :math:`\mathfrak{k}` is commonly called the *vertical space*,
# :math:`\mathfrak{p}` accordingly is the *horizontal space*.
# The KAK theorem will apply to scenarios in which these spaces satisfy additional
# The KAK decomposition will apply to scenarios in which these spaces satisfy additional
# commutation relations, which do not hold for all subalgebras:
#
# .. math::
@@ -455,7 +455,7 @@ def check_cartan_decomposition(g, k, space_name):
# It turns out that they *all* can be found by starting with *any*
# :math:`\mathfrak{a}` and applying all of :math:`\mathcal{K}` to it.
#
# *This is what powers the KAK theorem.*
# *This is what powers the KAK decomposition.*
#
# **Example**
#
@@ -663,8 +663,8 @@ def theta_Y(x):
# (AII). It is instructive to try and see why those three are *not* equivalent
# under a unitary basis change!
#
# The KAK theorem
# ---------------
# The KAK decomposition
# ---------------------
#
# Now that we covered all prerequisites, we are ready for our main result. It consists of two
# steps that are good to know individually, so we will look at both of them in sequence.
@@ -724,19 +724,19 @@ def theta_Y(x):
# where we abbreviated :math:`\mathcal{A} = \exp(\mathfrak{a}).`
#
# Chaining the two steps together and combining the left factor :math:`K^{-1}` with the group
# :math:`\mathcal{K}` in the *KP* decomposition, we obtain the *KAK theorem*
# :math:`\mathcal{K}` in the *KP* decomposition, we obtain the *KAK decomposition*
#
# .. math::
#
# \mathcal{G}
# =\mathcal{K}\mathcal{P}
# = \mathcal{K}\{K^{-1} \mathcal{A} K | K\in\mathcal{K}\},
# = \{K_1 \mathcal{A} K_2 | K_{1,2}\in\mathcal{K}\},
# = \mathcal{K} \mathcal{A} \mathcal{K} \qquad\textbf{(KAK Theorem).}
# = \mathcal{K} \mathcal{A} \mathcal{K} \qquad\textbf{(KAK Decomposition).}
#
# It teaches us that any group element can be decomposed into two factors from the Lie subgroup and
# the exponential of a CSA element, i.e., of commuting elements from the horizontal subspace
# :math:`\mathfrak{p}.` This may already hint at the usefulness of the KAK theorem for matrix
# :math:`\mathfrak{p}.` This may already hint at the usefulness of the KAK decomposition for matrix
# factorizations in general, and for quantum circuit decompositions in particular.
# Given a group operation :math:`G=\exp(x)` with :math:`x\in\mathfrak{g},` there are two
# subalgebra elements :math:`y_{1,2}\in\mathfrak{k}` (or subgroup elements
@@ -792,7 +792,7 @@ def theta_Y(x):
# \text{Rot}(\phi, \theta, \omega) = R_Y(\eta_1) R_X(\vartheta) R_Y(\eta_2).
#
# And that's it for our main discussion. We conclude this demo by applying the
# KAK theorem to the group of arbitrary two-qubit gates.
# KAK decomposition to the group of arbitrary two-qubit gates.
#
# Application: Two-qubit gate decomposition
# -----------------------------------------
@@ -841,7 +841,7 @@ def theta_Y(x):
# These three operators commute, making :math:`\mathfrak{a}` Abelian.
# They also form a *maximal* Abelian algebra within :math:`\mathfrak{p},` which is less obvious.
#
# The KAK theorem now tells us that any two-qubit gate :math:`U,` being part of
# The KAK decomposition now tells us that any two-qubit gate :math:`U,` being part of
# :math:`SU(4),` can be implemented by a sequence
#
# .. math::
@@ -883,18 +883,18 @@ def su4_gate(params):
fig, ax = qml.draw_mpl(su4_gate, wire_order=[0, 1])(params)

######################################################################
# And that's a wrap on our KAK theorem application for two-qubit gates!
# And that's a wrap on our application of the KAK decomposition for two-qubit gates!
#
# You may have noticed that the theorem only states the existence of a
# You may have noticed that this mathematical result only states the existence of a
# decomposition, but does not provide a constructive way of finding
# :math:`y_{1,2}` and :math:`a` for a given gate :math:`U.` For this,
# some additional work is required, as explained in [#kokcu_fdhs]_, for example.
#
# Conclusion
# ----------
#
# In this demo we learned about the KAK theorem and how it uses a Cartan
# decomposition of a Lie algebra to decompose its Lie group.
# In this demo we learned about the KAK decomposition and how it breaks up a
# Lie group using the Cartan decomposition of its Lie algebra.
# This allows us to break down arbitrary quantum gates from that group,
# as we implemented in code for the groups of single-qubit and two-qubit gates,
# :math:`SU(2)` and :math:`SU(4).`

0 comments on commit 205621c

Please sign in to comment.