Qapply

Logic for applying operators to states.

Todo: * Sometimes the final result needs to be expanded, we should do this by hand.

sympy.physics.quantum.qapply.qapply(e, **options)[source]

Apply operators to states in a quantum expression.

Parameters:

e : Expr

The expression containing operators and states. This expression tree will be walked to find operators acting on states symbolically.

options : dict

A dict of key/value pairs that determine how the operator actions are carried out.

The following options are valid:

  • dagger: try to apply Dagger operators to the left (default: False).

  • ip_doit: call .doit() in inner products when they are encountered (default: True).

  • sum_doit: call .doit() on sums when they are encountered (default: False). This is helpful for collapsing sums over Kronecker delta’s that are created when calling qapply.

Returns:

e : Expr

The original expression, but with the operators applied to states.

Examples

>>> from sympy.physics.quantum import qapply, Ket, Bra
>>> b = Bra('b')
>>> k = Ket('k')
>>> A = k * b
>>> A
|k><b|
>>> qapply(A * b.dual / (b * b.dual))
|k>
>>> qapply(k.dual * A / (k.dual * k))
<b|