Gates

An implementation of gates that act on qubits.

Gates are unitary operators that act on the space of qubits.

Medium Term Todo:

  • Optimize Gate._apply_operators_Qubit to remove the creation of many intermediate Qubit objects.
  • Add commutation relationships to all operators and use this in gate_sort.
  • Fix gate_sort and gate_simp.
  • Get multi-target UGates plotting properly.
  • Get UGate to work with either sympy/numpy matrices and output either format. This should also use the matrix slots.
class sympy.physics.quantum.gate.Gate[source]

Non-controlled unitary gate operator that acts on qubits.

This is a general abstract gate that needs to be subclassed to do anything useful.

Parameters:

label : tuple, int

A list of the target qubits (as ints) that the gate will apply to.

get_target_matrix(format='sympy')[source]

The matrix rep. of the target part of the gate.

Parameters:

format : str

The format string (‘sympy’,’numpy’, etc.)

min_qubits

The minimum number of qubits this gate needs to act on.

nqubits

The total number of qubits this gate acts on.

For controlled gate subclasses this includes both target and control qubits, so that, for examples the CNOT gate acts on 2 qubits.

targets

A tuple of target qubits.

class sympy.physics.quantum.gate.CGate[source]

A general unitary gate with control qubits.

A general control gate applies a target gate to a set of targets if all of the control qubits have a particular values (set by CGate.control_value).

Parameters:

label : tuple

The label in this case has the form (controls, gate), where controls is a tuple/list of control qubits (as ints) and gate is a Gate instance that is the target operator.

controls

A tuple of control qubits.

decompose(**options)[source]

Decompose the controlled gate into CNOT and single qubits gates.

eval_controls(qubit)[source]

Return True/False to indicate if the controls are satisfied.

gate

The non-controlled gate that will be applied to the targets.

min_qubits

The minimum number of qubits this gate needs to act on.

nqubits

The total number of qubits this gate acts on.

For controlled gate subclasses this includes both target and control qubits, so that, for examples the CNOT gate acts on 2 qubits.

plot_gate(circ_plot, gate_idx)[source]

Plot the controlled gate. If simplify_cgate is true, simplify C-X and C-Z gates into their more familiar forms.

targets

A tuple of target qubits.

class sympy.physics.quantum.gate.UGate[source]

General gate specified by a set of targets and a target matrix.

Parameters:

label : tuple

A tuple of the form (targets, U), where targets is a tuple of the target qubits and U is a unitary matrix with dimension of len(targets).

get_target_matrix(format='sympy')[source]

The matrix rep. of the target part of the gate.

Parameters:

format : str

The format string (‘sympy’,’numpy’, etc.)

targets

A tuple of target qubits.

class sympy.physics.quantum.gate.OneQubitGate[source]

A single qubit unitary gate base class.

class sympy.physics.quantum.gate.TwoQubitGate[source]

A two qubit unitary gate base class.

class sympy.physics.quantum.gate.IdentityGate[source]

The single qubit identity gate.

Parameters:

target : int

The target qubit this gate will apply to.

class sympy.physics.quantum.gate.HadamardGate[source]

The single qubit Hadamard gate.

Parameters:

target : int

The target qubit this gate will apply to.

Examples

>>> from sympy import sqrt
>>> from sympy.physics.quantum.qubit import Qubit
>>> from sympy.physics.quantum.gate import HadamardGate
>>> from sympy.physics.quantum.qapply import qapply
>>> qapply(HadamardGate(0)*Qubit('1'))
sqrt(2)*|0>/2 - sqrt(2)*|1>/2
>>> # Hadamard on bell state, applied on 2 qubits.
>>> psi = 1/sqrt(2)*(Qubit('00')+Qubit('11'))
>>> qapply(HadamardGate(0)*HadamardGate(1)*psi)
sqrt(2)*|00>/2 + sqrt(2)*|11>/2
class sympy.physics.quantum.gate.XGate[source]

The single qubit X, or NOT, gate.

Parameters:

target : int

The target qubit this gate will apply to.

class sympy.physics.quantum.gate.YGate[source]

The single qubit Y gate.

Parameters:

target : int

The target qubit this gate will apply to.

class sympy.physics.quantum.gate.ZGate[source]

The single qubit Z gate.

Parameters:

target : int

The target qubit this gate will apply to.

class sympy.physics.quantum.gate.TGate[source]

The single qubit pi/8 gate.

This gate rotates the phase of the state by pi/4 if the state is |1> and does nothing if the state is |0>.

Parameters:

target : int

The target qubit this gate will apply to.

class sympy.physics.quantum.gate.PhaseGate[source]

The single qubit phase, or S, gate.

This gate rotates the phase of the state by pi/2 if the state is |1> and does nothing if the state is |0>.

Parameters:

target : int

The target qubit this gate will apply to.

class sympy.physics.quantum.gate.SwapGate[source]

Two qubit SWAP gate.

This gate swap the values of the two qubits.

Parameters:

label : tuple

A tuple of the form (target1, target2).

decompose(**options)[source]

Decompose the SWAP gate into CNOT gates.

class sympy.physics.quantum.gate.CNotGate[source]

Two qubit controlled-NOT.

This gate performs the NOT or X gate on the target qubit if the control qubits all have the value 1.

Parameters:

label : tuple

A tuple of the form (control, target).

Examples

>>> from sympy.physics.quantum.gate import CNOT
>>> from sympy.physics.quantum.qapply import qapply
>>> from sympy.physics.quantum.qubit import Qubit
>>> c = CNOT(1,0)
>>> qapply(c*Qubit('10')) # note that qubits are indexed from right to left
|11>
controls

A tuple of control qubits.

gate

The non-controlled gate that will be applied to the targets.

min_qubits

The minimum number of qubits this gate needs to act on.

targets

A tuple of target qubits.

sympy.physics.quantum.gate.CNOT

alias of sympy.physics.quantum.gate.CNotGate

sympy.physics.quantum.gate.SWAP

alias of sympy.physics.quantum.gate.SwapGate

sympy.physics.quantum.gate.H

alias of sympy.physics.quantum.gate.HadamardGate

sympy.physics.quantum.gate.X

alias of sympy.physics.quantum.gate.XGate

sympy.physics.quantum.gate.Y

alias of sympy.physics.quantum.gate.YGate

sympy.physics.quantum.gate.Z

alias of sympy.physics.quantum.gate.ZGate

sympy.physics.quantum.gate.T

alias of sympy.physics.quantum.gate.TGate

sympy.physics.quantum.gate.S

alias of sympy.physics.quantum.gate.PhaseGate

sympy.physics.quantum.gate.Phase

alias of sympy.physics.quantum.gate.PhaseGate

sympy.physics.quantum.gate.normalized(normalize)[source]

Set flag controlling normalization of Hadamard gates by 1/sqrt(2).

This is a global setting that can be used to simplify the look of various expressions, by leaving off the leading 1/sqrt(2) of the Hadamard gate.

Parameters:

normalize : bool

Should the Hadamard gate include the 1/sqrt(2) normalization factor? When True, the Hadamard gate will have the 1/sqrt(2). When False, the Hadamard gate will not have this factor.

sympy.physics.quantum.gate.gate_sort(circuit)[source]

Sorts the gates while keeping track of commutation relations

This function uses a bubble sort to rearrange the order of gate application. Keeps track of Quantum computations special commutation relations (e.g. things that apply to the same Qubit do not commute with each other)

circuit is the Mul of gates that are to be sorted.

sympy.physics.quantum.gate.gate_simp(circuit)[source]

Simplifies gates symbolically

It first sorts gates using gate_sort. It then applies basic simplification rules to the circuit, e.g., XGate**2 = Identity

sympy.physics.quantum.gate.random_circuit(ngates, nqubits, gate_space=(<class 'sympy.physics.quantum.gate.XGate'>, <class 'sympy.physics.quantum.gate.YGate'>, <class 'sympy.physics.quantum.gate.ZGate'>, <class 'sympy.physics.quantum.gate.PhaseGate'>, <class 'sympy.physics.quantum.gate.TGate'>, <class 'sympy.physics.quantum.gate.HadamardGate'>, <class 'sympy.physics.quantum.gate.CNotGate'>, <class 'sympy.physics.quantum.gate.SwapGate'>))[source]

Return a random circuit of ngates and nqubits.

This uses an equally weighted sample of (X, Y, Z, S, T, H, CNOT, SWAP) gates.

Parameters:

ngates : int

The number of gates in the circuit.

nqubits : int

The number of qubits in the circuit.

gate_space : tuple

A tuple of the gate classes that will be used in the circuit. Repeating gate classes multiple times in this tuple will increase the frequency they appear in the random circuit.

class sympy.physics.quantum.gate.CGateS[source]

Version of CGate that allows gate simplifications. I.e. cnot looks like an oplus, cphase has dots, etc.