Document feedback

Question document fragment

When a question document fragment contains a formula, it is displayed as a space.

Submission type
issue

It's a little complicated...

I'd like to ask someone.

PR

Just a small problem.

I can fix it online!

Please select the submission type

Problem type
Specifications and Common Mistakes

- Specifications and Common Mistakes:

- Misspellings or punctuation mistakes,incorrect formulas, abnormal display.

- Incorrect links, empty cells, or wrong formats.

- Chinese characters in English context.

- Minor inconsistencies between the UI and descriptions.

- Low writing fluency that does not affect understanding.

- Incorrect version numbers, including software package names and version numbers on the UI.

Usability

- Usability:

- Incorrect or missing key steps.

- Missing main function descriptions, keyword explanation, necessary prerequisites, or precautions.

- Ambiguous descriptions, unclear reference, or contradictory context.

- Unclear logic, such as missing classifications, items, and steps.

Correctness

- Correctness:

- Technical principles, function descriptions, supported platforms, parameter types, or exceptions inconsistent with that of software implementation.

- Incorrect schematic or architecture diagrams.

- Incorrect commands or command parameters.

- Incorrect code.

- Commands inconsistent with the functions.

- Wrong screenshots.

- Sample code running error, or running results inconsistent with the expectation.

Risk Warnings

- Risk Warnings:

- Lack of risk warnings for operations that may damage the system or important data.

Content Compliance

- Content Compliance:

- Contents that may violate applicable laws and regulations or geo-cultural context-sensitive words and expressions.

- Copyright infringement.

Please select the type of question

Problem description

Describe the bug so that we can quickly locate the problem.

mindquantum.algorithm.compiler.qs_decompose

View Source On Gitee
mindquantum.algorithm.compiler.qs_decompose(gate: QuantumGate, with_barrier: bool = False)[source]

Quantum Shannon decomposition for arbitrary-dimension unitary gate.

The number of CNOT gates in the decomposed circuit is:

O(4n)

For more detail, please refer to Synthesis of Quantum Logic Circuits.

Parameters
  • gate (QuantumGate) – instance of quantum gate.

  • with_barrier (bool) – whether add barriers into decomposed circuit.

Returns

Circuit, composed of 1-qubit gates and CNOT gates.

Examples

>>> import mindquantum as mq
>>> from mindquantum.algorithm.compiler.decompose import qs_decompose
>>> from scipy.stats import unitary_group
>>> tqs = [1,2,3,6] # arbitrary qubit index order is OK
>>> n = len(tqs) # qubit number
>>> u = unitary_group.rvs(2 ** n, random_state=123)
>>> g = mq.UnivMathGate('U', u).on(tqs)
>>> circ = qs_decompose(g)
>>> num_cnot =  len([g for g in circ if isinstance(g, mq.XGate) and len(g.ctrl_qubits)==1])
>>> print('total gate number: {}, CNOT number: {}'.format(len(circ), num_cnot))
total gate number: 412, CNOT number: 180