
    xh%                         d Z ddlmZ ddlmZ ddlmZ ddlmZ ddl	m
Z
 ddlmZ ddlmZmZ dd	lmZ dd
lmZ ddlmZ ddlmZ ddlmZmZ ddlmZmZmZmZ ddl m!Z! dgZ"d Z#d Z$d Z%d Z&y)z}Logic for applying operators to states.

Todo:
* Sometimes the final result needs to be expanded, we should do this by hand.
    )Sum)Add)
NumberKind)Mul)Pow)S)sympify_sympify)AntiCommutator)
Commutator)Dagger)InnerProduct)OuterProductOperator)StateKetBaseBraBaseWavefunction)TensorProductqapplyc                 0    | j                  t        d       S )zETransform the inner products in an expression by calling ``.doit()``.c                  .    t        |  j                         S N)r   doitargss    Z/var/www/html/eduruby.in/venv/lib/python3.12/site-packages/sympy/physics/quantum/qapply.py<lambda>zip_doit_func.<locals>.<lambda>#   s    t1D1I1I1K     )replacer   es    r   ip_doit_funcr#   !   s    99\#KLLr   c                 0    | j                  t        d       S )z;Transform the sums in an expression by calling ``.doit()``.c                  .    t        |  j                         S r   )r   r   r   s    r   r   zsum_doit_func.<locals>.<lambda>(   s    T
(9 r   )r    r   r!   s    r   sum_doit_funcr&   &   s    99S9::r   c           
         ddl m} |j                  dd      }|j                  dd      }|j                  dd      }t        |       } | j                  t
        k(  r|rt        |       S | S | j                  dd      } t        | t              r| S t        | t              r2d}| j                  D ]  }|t        |fi |z  } |j                         S t        | |      r/| j                  D 	cg c]  \  }}	t        |fi ||	f }
}}	 ||
 S t        | t              r*t        | j                  D cg c]  }t        |fi | c} S t        | t              r=t        t        | j                  fi |g| j                    }|rt#        |      }|S |}|S t        | t$              r#t        | j&                  fi || j(                  z  S t        | t*              r| j-                         \  }}t+        | }t+        | }|s|}n/t        |t*              r|t/        |fi |z  }n|t        |fi |z  }|| k(  r |rt1        t/        t1        |       fi |      }|rt        |      n|}|rt#        |      }|S |}|S | S c c}	}w c c}w )	a  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|
    r   )DensitydaggerFsum_doitip_doitT)
commutatortensorproduct)sympy.physics.quantum.densityr(   getr
   kindr   r#   expand
isinstancer   r   r   r   r   r   functionlimitsr&   r   baseexpr   args_cnc
qapply_Mulr   )r"   optionsr(   r)   r*   r+   resultargstateprobnew_argstc_partnc_partc_mulnc_muls                   r   r   r   +   s   V 6[[5)F{{:u-Hkk)T*GA 	vv")|A0q0 	
D5A !W 
As	66 	-CfS,G,,F	-}} 
Aw	ff& :% E-W-t4 & &!! 
A}	%QVVDva373DEE 
As	VAJJ2'2>QXX>*2v& 9? 
As	aff((!%%// 
As	**,VgF$:f888F6&4G44FQ;6Jvay<G<=F)0f%f*2v& 9?
 M& Es   ,I6/I<c           
      ~   t        | j                        }t        j                  }d }t	        |      dk  st        | t              s| S |j                         }|j                         }t        |t              st        |      j                  s%t        |t              st        |      j                  r| S t        |t              rM|j                  j                  r7|j                  |j                  |j                  dz
  z         |j                  }t        |t               r'|j                  |j"                         |j$                  }t        |t               r|j$                  }|j"                  }t        |t&        t(        f      r|j+                         }t        |t,              rPt/         | j0                  ||j                  d   |gz     | j0                  ||j                  d   |gz    z   fi ||z  S t/         | j0                  | |z  |z  fi ||z  S t        |t2              rt5        d |j                  D              rt        |t2              rt5        d |j                  D              rt	        |j                        t	        |j                        k(  rt3        t7        t	        |j                              D cg c]+  }t/        |j                  |   |j                  |   z  fi |- c} j9                  d      }t;         | j0                  | fi ||z  |z  S t        |t<              rt        |t<              rt?        |j@                        jC                  t?        |j@                              rtE        d      |jF                  |jF                  z   }	t=        t/        |jH                  |jH                  z  fi |g|	 }t;         | j0                  | |z  fi |S t=        t/        ||jH                  z  fi |g|jF                   }t;         | j0                  | |z  fi |S t        |t<              rIt=        t/        |jH                  |z  fi |g|jF                   }t;         | j0                  | |z  fi |S tK        |dd       }
|
	  |
|fi |}nd }|tK        |d	d       }|
	  ||fi |}|,t        |tN              rt        |tP              rtS        ||      }t        |tT        tV        tX        f      rt[        |      S |3t	        |      dk(  r| S t;         | j0                  ||gz    fi ||z  |z  S t        |tR              r|t;         | j0                  | fi |z  |z  S t/         | j0                  | |z  fi ||z  S c c}w # tL        $ r d }Y w xY w# tL        $ r d }Y w xY w)
N   r   c              3   j   K   | ]+  }t        |t        t        t        t        f      xs |d k(   - ywrE   Nr2   r   r   r   r   .0r;   s     r   	<genexpr>zqapply_Mul.<locals>.<genexpr>   s2     -{knjxPSUX>Y.Z.f^aef^f.f-{   13c              3   j   K   | ]+  }t        |t        t        t        t        f      xs |d k(   - ywrG   rH   rI   s     r   rK   zqapply_Mul.<locals>.<genexpr>   s8       3Aps:cHeUXZ]C^3_3kcfjkck3k  3ArL   T)r-   z4Duplicated dummy indices in separate sums in qapply._apply_operator_apply_from_right_to).listr   r   Onelenr2   r   popr   r	   is_commutativer   r6   
is_Integerappendr5   r   ketbrar   r   r   r   r   funcr   allranger1   r8   r   set	variablesintersection
ValueErrorr4   r3   getattrNotImplementedErrorr   r   r   intcomplexfloatr
   )r"   r9   r   extrar:   rhslhscommnr4   _apply_apply_rights               r   r8   r8      s-   <DEEEF 4yA~Z3/
((*C
((*C sL)gcl.I.IC.73<3N3N #s 2 2CHHsww{+,hh #|$CGGgg#|$gg #
N34xxzdC 1s 3351s 3356  	  &!&&$-,S0<G<UBB #}%#-{rurzrz-{*{sM*s  3Awzww  3A  0AMS]*UZ[^_b_g_g[hUi jPQCHHQK(?!K7!K jkrr  BFr  G&!&&$-373F:5@@ #sc33==!..s3==/AB !WXXZZ#**,FS\\ 9EWEOOFfaffdmF2>g>>CLL 0<G<JszzJFfaffdmF2>g>>#sVCLL,88F3::F&!&&$-.:':: S+T2F	C+7+F ~s$:DA#%c5W5 ~c7#
3(@!#s+F &3/0	t9>Hfafftse|5AA#EeKK	FL	)j:'::5@@faffdmF*6g6u<<k !k0 # 	F	 ' s*    0V	V 7	V. V+*V+.V<;V<N)'__doc__sympy.concreter   sympy.core.addr   sympy.core.kindr   sympy.core.mulr   sympy.core.powerr   sympy.core.singletonr   sympy.core.sympifyr	   r
   $sympy.physics.quantum.anticommutatorr    sympy.physics.quantum.commutatorr   sympy.physics.quantum.daggerr   "sympy.physics.quantum.innerproductr   sympy.physics.quantum.operatorr   r   sympy.physics.quantum.stater   r   r   r   #sympy.physics.quantum.tensorproductr   __all__r#   r&   r   r8    r   r   <module>r}      s]      &    " 0 ? 7 / ; A M M = M
;
tne=r   