Skip to content

Commit 86aba2b

Browse files
Docs preview for PR #3313.
1 parent 3c1d10a commit 86aba2b

File tree

10 files changed

+18
-18
lines changed

10 files changed

+18
-18
lines changed

pr-3313/api/languages/python_api.html

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -2390,7 +2390,7 @@ <h3>Spin Operators<a class="headerlink" href="#spin-operators" title="Permalink
23902390
<em class="property"><span class="pre">static</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">random</span></span><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="headerlink" href="#cudaq.operators.spin.SpinOperator.random" title="Permalink to this definition">¶</a></dt>
23912391
<dd><dl class="py function">
23922392
<dt class="sig sig-object py">
2393-
<span class="sig-name descname"><span class="pre">random</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">qubit_count</span></span><span class="p"><span class="pre">:</span></span><span class="w"> </span><span class="n"><a class="reference external" href="https://docs.python.org/3/library/functions.html#int" title="(in Python v3.13)"><span class="pre">int</span></a></span></em>, <em class="sig-param"><span class="n"><span class="pre">term_count</span></span><span class="p"><span class="pre">:</span></span><span class="w"> </span><span class="n"><a class="reference external" href="https://docs.python.org/3/library/functions.html#int" title="(in Python v3.13)"><span class="pre">int</span></a></span></em>, <em class="sig-param"><span class="n"><span class="pre">seed</span></span><span class="p"><span class="pre">:</span></span><span class="w"> </span><span class="n"><a class="reference external" href="https://docs.python.org/3/library/functions.html#int" title="(in Python v3.13)"><span class="pre">int</span></a></span><span class="w"> </span><span class="o"><span class="pre">=</span></span><span class="w"> </span><span class="default_value"><span class="pre">3907078547</span></span></em><span class="sig-paren">)</span> <span class="sig-return"><span class="sig-return-icon">&#x2192;</span> <span class="sig-return-typehint"><a class="reference internal" href="#cudaq.operators.spin.SpinOperator" title="cudaq.operators.spin.SpinOperator"><span class="pre">SpinOperator</span></a></span></span></dt>
2393+
<span class="sig-name descname"><span class="pre">random</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">qubit_count</span></span><span class="p"><span class="pre">:</span></span><span class="w"> </span><span class="n"><a class="reference external" href="https://docs.python.org/3/library/functions.html#int" title="(in Python v3.13)"><span class="pre">int</span></a></span></em>, <em class="sig-param"><span class="n"><span class="pre">term_count</span></span><span class="p"><span class="pre">:</span></span><span class="w"> </span><span class="n"><a class="reference external" href="https://docs.python.org/3/library/functions.html#int" title="(in Python v3.13)"><span class="pre">int</span></a></span></em>, <em class="sig-param"><span class="n"><span class="pre">seed</span></span><span class="p"><span class="pre">:</span></span><span class="w"> </span><span class="n"><a class="reference external" href="https://docs.python.org/3/library/functions.html#int" title="(in Python v3.13)"><span class="pre">int</span></a></span><span class="w"> </span><span class="o"><span class="pre">=</span></span><span class="w"> </span><span class="default_value"><span class="pre">879875400</span></span></em><span class="sig-paren">)</span> <span class="sig-return"><span class="sig-return-icon">&#x2192;</span> <span class="sig-return-typehint"><a class="reference internal" href="#cudaq.operators.spin.SpinOperator" title="cudaq.operators.spin.SpinOperator"><span class="pre">SpinOperator</span></a></span></span></dt>
23942394
<dd></dd></dl>
23952395

23962396
<p>Return a random spin operator with the given number of terms (<code class="code docutils literal notranslate"><span class="pre">term_count</span></code>) where each term acts on all targets in the open range [0, qubit_count). An optional seed value may also be provided.</p>

pr-3313/applications/python/adapt_qaoa.html

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -979,7 +979,7 @@ <h1>ADAPT-QAOA algorithm<a class="headerlink" href="#ADAPT-QAOA-algorithm" title
979979
parameter</p>
980980
<p>3- Optimize all parameters currently in the Ansatz <span class="math notranslate nohighlight">\(\beta_m, \gamma_m = 1, 2, ...k\)</span> such that <span class="math notranslate nohighlight">\(\braket{\psi (k)|H_C|\psi(k)}\)</span> is minimized, and return to the second step.</p>
981981
<p>Below is a schematic representation of the ADAPT-QAOA algorithm explained above.</p>
982-
<div><p><img alt="7c6354d293514422a8acf6ba4a1831ce" class="no-scaled-link" src="../../_images/adapt-qaoa.png" style="width: 1000px;" /></p>
982+
<div><p><img alt="2b52d7f8fa6a4e06a84e915ae5326b1d" class="no-scaled-link" src="../../_images/adapt-qaoa.png" style="width: 1000px;" /></p>
983983
</div><div class="nbinput nblast docutils container">
984984
<div class="prompt highlight-none notranslate"><div class="highlight"><pre><span></span>[15]:
985985
</pre></div>

pr-3313/applications/python/adapt_vqe.html

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -976,7 +976,7 @@ <h1>ADAPT-VQE algorithm<a class="headerlink" href="#ADAPT-VQE-algorithm" title="
976976
<p>7- Perform a VQE experiment to re-optimize all parameters in the ansatz.</p>
977977
<p>8- go to step 4</p>
978978
<p>Below is a Schematic depiction of the ADAPT-VQE algorithm</p>
979-
<div><p><img alt="dd45928b84ca496b8d7d863965a7d06f" class="no-scaled-link" src="../../_images/adapt-vqe.png" style="width: 800px;" /></p>
979+
<div><p><img alt="a8dabc4b9de748ccb4b7b759b9db0867" class="no-scaled-link" src="../../_images/adapt-vqe.png" style="width: 800px;" /></p>
980980
</div><div class="nbinput docutils container">
981981
<div class="prompt highlight-none notranslate"><div class="highlight"><pre><span></span>[1]:
982982
</pre></div>

pr-3313/applications/python/deutsch_algorithm.html

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1036,7 +1036,7 @@ <h2>XOR <span class="math notranslate nohighlight">\(\oplus\)</span><a class="he
10361036
</section>
10371037
<section id="Quantum-oracles">
10381038
<h2>Quantum oracles<a class="headerlink" href="#Quantum-oracles" title="Permalink to this heading"></a></h2>
1039-
<p><img alt="d58dbe294e0c4e8fa4b428a343e84ad4" class="no-scaled-link" src="../../_images/oracle.png" style="width: 300px; height: 150px;" /></p>
1039+
<p><img alt="692047f854ac4fd6812a11209c9e97f0" class="no-scaled-link" src="../../_images/oracle.png" style="width: 300px; height: 150px;" /></p>
10401040
<p>Suppose we have <span class="math notranslate nohighlight">\(f(x): \{0,1\} \longrightarrow \{0,1\}\)</span>. We can compute this function on a quantum computer using oracles which we treat as black box functions that yield the output with an appropriate sequence of logical gates.</p>
10411041
<p>Above you see an oracle represented as <span class="math notranslate nohighlight">\(U_f\)</span> which allows us to transform the state <span class="math notranslate nohighlight">\(\ket{x}\ket{y}\)</span> into:</p>
10421042
<div class="math notranslate nohighlight">
@@ -1084,7 +1084,7 @@ <h2>Quantum parallelism<a class="headerlink" href="#Quantum-parallelism" title="
10841084
<h2>Deutsch’s Algorithm:<a class="headerlink" href="#Deutsch's-Algorithm:" title="Permalink to this heading"></a></h2>
10851085
<p>Our aim is to find out if <span class="math notranslate nohighlight">\(f: \{0,1\} \longrightarrow \{0,1\}\)</span> is a constant or a balanced function? If constant, <span class="math notranslate nohighlight">\(f(0) = f(1)\)</span>, and if balanced, <span class="math notranslate nohighlight">\(f(0) \neq f(1)\)</span>.</p>
10861086
<p>We step through the circuit diagram below and follow the math after the application of each gate.</p>
1087-
<p><img alt="387342021e8b446fa190eed51aa4b72f" class="no-scaled-link" src="../../_images/deutsch.png" style="width: 500px; height: 210px;" /></p>
1087+
<p><img alt="ab3bf153688c4115a5b3179221840681" class="no-scaled-link" src="../../_images/deutsch.png" style="width: 500px; height: 210px;" /></p>
10881088
<div class="math notranslate nohighlight">
10891089
\[\ket{\psi_0} = \ket{01}
10901090
\tag{1}\]</div>

pr-3313/applications/python/edge_detection.html

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1016,7 +1016,7 @@ <h2>Image<a class="headerlink" href="#Image" title="Permalink to this heading">
10161016
<section id="Quantum-Probability-Image-Encoding-(QPIE):">
10171017
<h2>Quantum Probability Image Encoding (QPIE):<a class="headerlink" href="#Quantum-Probability-Image-Encoding-(QPIE):" title="Permalink to this heading"></a></h2>
10181018
<p>Lets take as an example a classical 2x2 image (4 pixels). We can label each pixel with its position</p>
1019-
<div><p><img alt="47ac4032144e44e08cfd9addad95e9eb" class="no-scaled-link" src="../../_images/pixels-img.png" style="width: 200px;" /></p>
1019+
<div><p><img alt="94b31964e15b478e8939910c563e90bf" class="no-scaled-link" src="../../_images/pixels-img.png" style="width: 200px;" /></p>
10201020
</div><p>Each pixel will have its own color intensity represented along with its position label as an 8-bit black and white color. To convert the pixel intensity to probability amplitudes of a quantum state</p>
10211021
<div class="math notranslate nohighlight">
10221022
\[c_i = \frac{I_{yx}}{\sqrt(\sum I^2_{yx})}\]</div>

pr-3313/applications/python/grovers.html

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -1058,7 +1058,7 @@ <h3>Good and Bad States<a class="headerlink" href="#Good-and-Bad-States" title="
10581058
<p>Let us now examine the geometric picture behind our current discussion. We’ll consider the ambient Hilbert space to be spanned by the standard basis vectors <span class="math notranslate nohighlight">\(|0\rangle, |1\rangle, \dots, |N-1\rangle\)</span>, where the full dimension is <span class="math notranslate nohighlight">\(N = 2^n\)</span>. Since the uniform superposition state <span class="math notranslate nohighlight">\(|\xi\rangle\)</span> can be expressed as a linear combination of the states <span class="math notranslate nohighlight">\(|G\rangle\)</span> and <span class="math notranslate nohighlight">\(|B\rangle\)</span> with real coefficients, all three states <span class="math notranslate nohighlight">\(|\xi\rangle, |G\rangle,\)</span> and <span class="math notranslate nohighlight">\(|B\rangle\)</span>
10591059
reside in a two-dimensional real subspace of the ambient Hilbert space, which we can visualize as a 2D plane as in the image below. Since, <span class="math notranslate nohighlight">\(|G\rangle\)</span> and <span class="math notranslate nohighlight">\(|B\rangle\)</span> are orthogonal, we can imagine them graphed as unit vectors in the positive <span class="math notranslate nohighlight">\(y\)</span> and positive <span class="math notranslate nohighlight">\(x\)</span> directions, respectively. From our previous expression, <span class="math notranslate nohighlight">\(\ket{\xi} = \sin(\theta) |G\rangle + \cos(\theta) |B\rangle,\)</span> we see that the state <span class="math notranslate nohighlight">\(|\xi\rangle\)</span> forms an angle <span class="math notranslate nohighlight">\(\theta\)</span> with
10601060
<span class="math notranslate nohighlight">\(|B\rangle\)</span>.</p>
1061-
<div style="text-align: center;"><p><img alt="d75e4b5a03444e799d9e159bfd16410d" src="../../_images/grovers-2D-plane.png" /></p>
1061+
<div style="text-align: center;"><p><img alt="486fbc3bbf7e4f90a9687822187aeed8" src="../../_images/grovers-2D-plane.png" /></p>
10621062
</div><p>Given that the number of marked states <span class="math notranslate nohighlight">\(t\)</span> is typically small compared to <span class="math notranslate nohighlight">\(N\)</span>, it follows that <span class="math notranslate nohighlight">\(\theta = \arcsin\left(\sqrt{\frac{t}{N}}\right)\)</span> is a small angle. This assumption is reasonable, as otherwise, a sufficient number of independent queries to the oracle would likely yield a solution through classical search methods.</p>
10631063
</section>
10641064
<section id="Step-2:-Oracle-application">
@@ -1173,9 +1173,9 @@ <h4>Completing Step 3<a class="headerlink" href="#Completing-Step-3" title="Perm
11731173
<div class="math notranslate nohighlight">
11741174
\[\mathcal{G} = r_\xi \circ r_B = H^{\otimes n} \big( 2|0^{\otimes n} \rangle \langle 0^{\otimes n}| - \text{Id} \big) H^{\otimes n} \mathcal{O}_f.\]</div>
11751175
<p>The circuit diagram below puts together steps 1 through 3:</p>
1176-
<div style="text-align: center;"><p><img alt="3f277b66ae8442c283bc6c1453a025d5" src="../../_images/grovers-steps1-3.png" /></p>
1176+
<div style="text-align: center;"><p><img alt="7c9b9a7f5ea84338b4df4af9aeb862c2" src="../../_images/grovers-steps1-3.png" /></p>
11771177
</div><p>Running this circuit initializes <span class="math notranslate nohighlight">\(\ket{\xi}\)</span> and performs a rotation by <span class="math notranslate nohighlight">\(2\theta\)</span> (twice the angle between <span class="math notranslate nohighlight">\(|\xi\rangle\)</span> and <span class="math notranslate nohighlight">\(|B\rangle\)</span>) in the direction from <span class="math notranslate nohighlight">\(|B\rangle\)</span> to <span class="math notranslate nohighlight">\(|G\rangle\)</span>.</p>
1178-
<div style="text-align: center;"><p><img alt="ba276c6bddb94dd9bd00f7cc5ab514db" src="../../_images/grovers-full-rotation.png" /></p>
1178+
<div style="text-align: center;"><p><img alt="fda5e196c8a34fe3a86f342c6275ea35" src="../../_images/grovers-full-rotation.png" /></p>
11791179
</div><p>Let’s verify that the state resulting from one iteration of Grover’s algorithm brings us closer to the good state, <span class="math notranslate nohighlight">\(\ket{G}\)</span>. In particular, notice that the amplitudes of <code class="docutils literal notranslate"><span class="pre">1001</span></code> and <code class="docutils literal notranslate"><span class="pre">1111</span></code> in the resulting state have been amplified compared to the equal superposition of states.</p>
11801180
<div class="nbinput docutils container">
11811181
<div class="prompt highlight-none notranslate"><div class="highlight"><pre><span></span>[18]:

pr-3313/applications/python/qm_mm_pe.html

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -976,7 +976,7 @@ <h2>Key concepts:<a class="headerlink" href="#Key-concepts:" title="Permalink to
976976
</section>
977977
<section id="PE-VQE-SCF-Algorithm-Steps">
978978
<h2>PE-VQE-SCF Algorithm Steps<a class="headerlink" href="#PE-VQE-SCF-Algorithm-Steps" title="Permalink to this heading"></a></h2>
979-
<div><p><img alt="5ce8012033294ca89f76ec3d69e8a959" class="no-scaled-link" src="../../_images/qm-mm-pe.png" style="width: 600px;" /></p>
979+
<div><p><img alt="c6facf2bd9334b7788248835dcc4196f" class="no-scaled-link" src="../../_images/qm-mm-pe.png" style="width: 600px;" /></p>
980980
</div><section id="Step-1:-Initialize-(Classical-pre-processing)">
981981
<h3>Step 1: Initialize (Classical pre-processing)<a class="headerlink" href="#Step-1:-Initialize-(Classical-pre-processing)" title="Permalink to this heading"></a></h3>
982982
<ul class="simple">

pr-3313/applications/python/quantum_transformer.html

Lines changed: 5 additions & 5 deletions
Large diffs are not rendered by default.

pr-3313/examples/python/performance_optimizations.html

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -964,9 +964,9 @@ <h1>Optimizing Performance<a class="headerlink" href="#Optimizing-Performance" t
964964
<section id="Gate-Fusion">
965965
<h2>Gate Fusion<a class="headerlink" href="#Gate-Fusion" title="Permalink to this heading"></a></h2>
966966
<p>Gate fusion is an optimization technique where consecutive gates are combined into a single gate operation to improve the efficiency of the simulation (See figure below). By targeting the <code class="docutils literal notranslate"><span class="pre">nvidia-mgpu</span></code> backend and setting the <code class="docutils literal notranslate"><span class="pre">CUDAQ_MGPU_FUSE</span></code> environment variable, you can select the degree of fusion that takes place. A full command line example would look like <code class="docutils literal notranslate"><span class="pre">CUDAQ_MGPU_FUSE=4</span> <span class="pre">python</span> <span class="pre">c2h2VQE.py</span> <span class="pre">--target</span> <span class="pre">nvidia</span> <span class="pre">--target-option</span> <span class="pre">fp64,mgpu</span></code></p>
967-
<p><img alt="4a090358935e46f4b75693cd417c5a4b" src="../../_images/gate-fuse.png" /></p>
967+
<p><img alt="1925a1277b26435f8d624e9250dc9f3f" src="../../_images/gate-fuse.png" /></p>
968968
<p>The importance of gate fusion is system dependent, but can have a large influence on the performance of the simulation. See the example below for a 24 qubit VQE experiment where changing the fusion level resulted in significant performance boosts.</p>
969-
<p><img alt="cccf40f01ed9439e9d9025275fccfc4e" src="../../_images/gatefusion.png" /></p>
969+
<p><img alt="852ad70a149a4e9c8c25cc498cfbea6e" src="../../_images/gatefusion.png" /></p>
970970
</section>
971971
</section>
972972

pr-3313/searchindex.js

Lines changed: 1 addition & 1 deletion
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

0 commit comments

Comments
 (0)