
    \h|}                    F	   S SK r S SKrS SKJr  S SKJr  S SKJrJ	r	J
r
  S SKJrJrJrJrJrJrJrJr  S SKJr  S SKJr  S SKJrJr  S S	KJr  S S
KJr  S SKJ r J!r!  S SK"J#r#J$r$J%r%  S SK&J'r'J(r(J)r)  S SK*J+r+  S SK,J-r-  S SK.J/r/J0r0J1r1  S SK2J3r3J4r4  S SK5J6r6  S SK7J8r8  S SK9J:r:  S SK;J<r<J=r=  S SK>J?r?  S SK@JArAJBrBJCrC  S SKDJErE  S SKFJGrG  S SKHJIrI  S SKJJKrKJLrLJMrMJNrNJOrOJPrPJQrQJRrRJSrSJTrTJUrUJVrVJWrWJXrXJYrYJZrZJ[r[J\r\J]r]J^r^J_r_J`r`JaraJbrb  S SKHJcrc  S SKdJereJfrf  S SKgJhrh  S SKiJjrjJkrkJlrl  S S KmJnrn  S S!KoJprpJqrqJrrrJsrsJtrtJuru  S S"KvJwrw  S S#KxJyry  S S$KzJ{r{  S S%K|J}r}  S S&K~Jr  S S'KJr  S S(KJrJrJrJrJrJrJrJr  \N\O\L\M4rS S)KJrJr  S S*KJrJr  \u" 5           " S+ S,\\\5      rSSS5        \u" 5           " S- S.\\\5      rSSS5        S/ rS0 rS1 rS2 rS3 rS4 rS5 rS6 rS7 rS8 rS9 rS: rS; rS< rS= rS> rS? rS@ rSA rSB rSC rSD rSE rSF rSG rSH rSI rSJ rSK rSL rSM rSN rSO rSP rSQ rSR rSS rST rSU rSV rSW rSX rSY rSZ rS[ rS\ rS] rS^ rS_ rS` rSa rSb rSc rSd rSe rSf rSg rSh rSi rSj rSk rSl rSm rSn rSo rSp rSq rSr rSs rSt rSu rSv rSw rSx rSy rSz rS{ rS| rS} rS~ rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS rS Gr S GrS GrS GrS GrS GrS GrS GrS GrS Gr	S Gr
S GrS GrS GrS GrS GrS GrS GrS GrS GrS GrS GrS GrS GrS GrS GrS GrS GrS GrS GrS GrS GrS Gr S Gr!S Gr"S Gr#S Gr$S Gr%S Gr&S Gr'S Gr(S Gr)\qS 5       Gr*S Gr+S Gr,S Gr-S Gr.S Gr/S Gr0\rS 5       Gr1S Gr2S Gr3S Gr4S Gr5S Gr6S Gr7S Gr8S Gr9S Gr:S Gr;S Gr<S Gr=S Gr>S Gr?S Gr@S GrAS GrBS GrCS GrDS GrES GrFS GrGS GrHS GrIS GrJ\t" S5      S 5       GrKS GrLS GrMS GrNS GrOS GrPS GrQS GrRS GrSS GrTS GrUS GrVS GrWS GrXS GrYS GrZg! , (       d  f       GN= f! , (       d  f       GN= f)    N)Hashable)Add)Functiondiffexpand)EFloatIIntegerRationalnanoopi)Pow)S)Symbolsymbols)sympify)Abs)explog)MaxMinsqrt)cossintan)	integrate)	transpose)HermitianOperatorOperatorDagger)PolyPurePoly)RootOf)sstr)	FiniteSet)signsimpsimplify)trigsimp)
ShapeErrorMatrixErrorNonSquareMatrixErrorDeferredVector)_find_reasonable_pivot_naive)	_simplify)GramSchmidtImmutableMatrixImmutableSparseMatrixMatrixSparseMatrix
casoratiandiageyehessianmatrix_multiply_elementwiseones
randMatrix	rot_axis1	rot_axis2	rot_axis3	wronskianzerosMutableDenseMatrixImmutableDenseMatrixMatrixSymboldotprodsimprot_ccw_axis1rot_ccw_axis2rot_ccw_axis3)_dotprodsimp_state)TupleWild)KroneckerDelta)flattencaptureiterable)ignore_warnings)raisesXFAILslowskipskip_under_pyodidewarns_deprecated_sympyQ)Array)ArrayDerivative)MatPow)
Quaternion)O)abcdxyzt)_MinimalMatrix_CastableMatrix)MatrixSubspacesMatrixReductionsc                       \ rS rSrSrg)SubspaceOnlyMatrixG    N__name__
__module____qualname____firstlineno____static_attributes__rn       Z/var/www/auris/envauris/lib/python3.13/site-packages/sympy/matrices/tests/test_matrices.pyrl   rl   G       ru   rl   c                       \ rS rSrSrg)ReductionsOnlyMatrixL   rn   Nro   rn   ru   rv   ry   ry   L   rw   ru   ry   c                     [        X S 5      $ )Nc                     [        X:H  5      $ N)intijs     rv   <lambda> eye_Reductions.<locals>.<lambda>Q   s
    3qv;ru   ry   ns    rv   eye_Reductionsr   P   s    &>??ru   c                     [        X S 5      $ )Nc                     gNr   rn   r   s     rv   r   "zeros_Reductions.<locals>.<lambda>U   s    1ru   r   r   s    rv   zeros_Reductionsr   T   s    n55ru   c                  2   [        [        5       GH  u  pUR                  SS5      nUR                  S:X  a!  [	        S UR                   5       5      (       d   eUR
                  S:X  a  [        UR
                  5      [        L d   eUR                  S:X  a  [        UR                  5      [        L d   eU S-  (       d0  [        UR                  5       5      [        [        [        4;   d   eM  [        UR                  5       5      [        L a  GM   e   g )N      )r   r   c              3   D   #    U  H  n[        U5      [        L v   M     g 7fr}   )typer~   ).0r   s     rv   	<genexpr>test_args.<locals>.<genexpr>\   s     (IAaCs    )	enumerateclassesrB   shapeallrowsr   r~   colsflatlisttuplerK   todokdict)r   clsms      rv   	test_argsr   X   s    G$IIaOww& S(I(I%I%IIIvv{tAFF|s222vv{tAFF|s2221u>dE5%9999	?d*** %ru   c                     [         [        4 HJ  n U R                  SS5      n[        5          UR                  nS S S 5        WUR                  5       :X  a  MJ   e   [        [        4 HJ  n U R                  SS5      n[        5          UR                  nS S S 5        WUR                  5       :X  a  MJ   e   g ! , (       d  f       N= f! , (       d  f       N:= fNr   r   )
r5   r3   rB   rW   _matr   r6   r4   _smatr   )r   r   matsmats       rv   test_deprecated_mat_smatr   e   s    &IIaO#%&&C &affh	 '
 22IIaO#%77D &qwwy   	 3 &%
 &%s   B6C6
C	
C	c                      [        SS[        [        /5      n U [        -  [        SS[        [        -  [        [        -  /5      :X  d   eg N   r   )r5   rc   rd   re   )vs    rv   test_divisionr   r   s;    q!aVAQ3&A!QqSz****ru   c            	      J  ^ ^ [        / SQ[        [        [        /S[        -  S[        [        -  //5      m T T -   [        / SQS[        -  S[        -  S[        -  /S[        -  SS[        -  [        -  //5      :X  d   e[        SSSS/5      m[	        [
        U U4S j5        g )	Nr   r   r   r   i)r         r   ir   c                     > T T-   $ r}   rn   r   r   s   rv   r   test_sum.<locals>.<lambda>{   s	    q1uru   )r5   rc   rd   re   rR   r+   r   s   @@rv   test_sumr   w   s    	Aq!9qsC1o67Aq5FI!QqS!A#1dAaCE8JKLLLLq!aVA
:}%ru   c                      [        SSS[        /5      n [        SSS[        [        5      /5      n[        U 5      U:X  d   eg )Nr   r   r   )r5   rc   r   absr   s     rv   test_absr   }   s:    q!b!WAq!aQ[!Aq6Q;;ru   c                      [        S5      n [        S5      nX-   U R                  " U5      s=:X  a  [        SS/SS//5      :X  d   e   eg )N)r   r   r   r   r   )r   r   r   r   r   r   )r5   addr_   r`   s     rv   test_additionr      sY      	A
 	  	A
 5AEE!H8AA'7 888888ru   c            
         [         [        4 GH  n U " SS[        S5      5      nXS S 2S S 24   :X  d   eUSS S 24   [        SS/ SQ5      :X  d   eUS S 2S4   [        / SQ5      :X  d   eUSS/S S 24   [        / SQ/ SQ/5      :X  d   eUSS/S4   USS/S/4   :X  d   eUSSS/4   US/SS/4   :X  d   eUS S 2SS/4   [        SS/SS	/S
S//5      :X  d   eUS   S:X  d   eUSS2S S 24   [        / SQ/ SQ/5      :X  d   eUS S 2SS24   [        SS/SS	/S
S//5      :X  d   eUS S S2S4   USS/S4   :X  d   eUSS S S24   USSS/4   :X  d   eU " SS[        S5      5      nU/ SQS S 24   [        / SQ/ SQ/ SQ/ SQ/ SQ/5      :X  d   eUS S 2/ SQ4   [        / SQ/ SQ/ SQ/5      :X  a  GM   e   [        R                  " S5      nSUS'   SUS'   S	US'   UR                  " SS/S/5      [        S/S//5      :X  d   eUR                  " SS// SQ5      [        / SQ/ SQ/5      :X  d   eUR                  " / SQ/ SQ5      [        / SQ/ SQ/ SQ/ SQ/5      :X  d   eg )Nr   	   r   r   r      )r   r      r   r   r   r   r   r   r   r   r   r   )r   r   r   r   r   )r   r      )r   r   r   r   r   )r   r   r   r   r   r   r   r   r   r   )r   r   r   r   r   r   )r   r   r   r   )r   r   r   r   r   r   r   r   )r   r   r   r   )r   r   r   r   )r5   r6   rangerB   extract)Mr_   s     rv   test_fancy_index_matrixr      s   l#aE!HadG||Aw&Ay1111Aw&++++!Q|vy)&<====!Q|q!Q!~---QF|q!q!f~---QF|v1v1v1v&>????w!||1ayFIy#9::::AaCyFQFQFQF#;<<<<1ayAq!faiL(((CaCyAa!QiL(((aE!H!#$0 )  	  K F, %  	 + $4 	1AAdGAdGAdG99aVaS!VCC-	 &
 
 
 
 99aVY'63 ,    99\<0F	< 5   ru   c                    ^^ [        S5      m[        S5      mTT-  n U S   S:X  d   eU S   S:X  d   eU S   S:X  d   eU S	   S:X  d   eU S
   S:X  d   eU S   S:X  d   e [        S5        U S   S:X  d   eU S   S:X  d   eU S   S:X  d   eU S	   S:X  d   eU S
   S:X  d   eU S   S:X  d   e [        TU 5      nUTR                  " U 5      :X  d   eUS   S:X  d   eUS   S:X  d   eUS   S:X  d   eUS	   S:X  d   eUS
   S:X  d   eUS   S:X  d   e[        [        UU4S j5        T[        S5      -  n [        U [         5      (       d   eU S   [        :X  d   eU S   S[        -  :X  d   eU S   S[        -  :X  d   eU S	   S:X  d   e[        T-  nX:X  d   eST-  n [        U [         5      (       d   eU S   S:X  d   eU S   S:X  d   eU S   S:X  d   eU S	   S:X  d   e [        S5        [        U [         5      (       d   eU S   S:X  d   eU S   S:X  d   eU S   S:X  d   eU S	   S:X  d   eg ! [         a     GNf = f! [         a     g f = f)N)r   r   r   r   r   r   r   r   r   r   r   r   r   r   r      r   r   r   z	c = a @ br   c                     > [        T T5      $ r}   )r;   r   s   rv   r   %test_multiplication.<locals>.<lambda>   s    :1a@ru   rc   r   r   
      z	c = 5 @ b)
r5   evalSyntaxErrorr;   multiply_elementwiserR   r+   r   
isinstancerc   )ra   hc2r_   r`   s      @@rv   test_multiplicationr      s     	A 	  	A
 	
!AT7a<<T7a<<T7a<<T7a<<T7b==T7a<<
[ w!||w!||w!||w!||w"}}w!||#Aq)A&&q))))T7a<<T7a<<T7b==T7a<<T7a<<T7a<<
:@A	F3KAa    T7a<<T7ac>>T7ac>>T7a<<	
QB7N7	AAa    T7a<<T7c>>T7c>>T7a<<	[ !V$$$$w!||w#~~w#~~w!||]  N  s$   !H5 &I 5
II
IIc                    ^^ [        [        S/S[        //5      n U S-  U :X  d   e[        [        [        /SS//5      n U S-  [        [        [        /[        [        //5      :X  d   e[        SSS[        S5      * S-  // SQ/ SQ[        S5      * S-  SSS//5      m[        [        [
        S-  -  S[        [        -  [
        S-  -  S-  [        [        -  [
        S-  -  S-  -   [        [
        S-  5      -   [        [
        S-  -  S-  [        [        S-  -  [
        S	-  -  S
-  -   [        [        -  [        -  [
        S	-  -  S-  -   [        [        S-  -  [
        S	-  -  S
-  -   [        [
        S-  5      -   /S[        [
        S-  -  S-  [        [
        S	-  5      [        [
        S-  5      /[        [        -  [
        S-  -  S-  [        [        -  [
        S-  -  S-  -   [        [
        S-  5      -   [        [
        S	-  5      [        [        S-  -  [
        S	-  -  S
-  [        [        -  [        -  [
        S	-  -  S-  -   [        [        S-  -  [
        S	-  -  S
-  -   [        [
        S-  5      -   [        [        -  [
        S	-  -  S-  [        [        -  [
        S	-  -  S-  -   [        [
        S-  5      -   /[        [
        S-  -  S-  [        [        S-  -  [
        S	-  -  S
-  -   [        [        -  [        -  [
        S	-  -  S-  -   [        [        S-  -  [
        S	-  -  S
-  -   [        [
        S-  5      -   [        [
        S-  5      [        [        -  [
        S	-  -  S-  [        [        -  [
        S	-  -  S-  -   [        [
        S-  5      -   [        [
        S	-  -  S-  S[        -  [        S-  -  [
        S-  -  S-  -   [        [        -  [        -  [
        S-  -  S
-  -   S[        -  [        S-  -  [
        S-  -  S-  -   [        [
        S-  5      -   //5      m[        [        * [
        S-  -  S-  [        [        S-  -  [
        S	-  -  S-  -
  [        [        -  [        -  [
        S	-  -  S-  -
  [        [        S-  -  [
        S	-  -  S-  -
  [        [
        S-  5      -   [        [
        S-  5      [        * [        -  [
        S	-  -  S-  [        [        -  [
        S	-  -  S-  -
  [        [
        S-  5      -   [        * [
        S	-  -  S	-  S[        -  [        S-  -  [
        S-  -  S-  -
  [        [        -  [        -  [
        S-  -  S-  -
  S[        -  [        S-  -  [
        S-  -  S-  -
  [        [
        S-  5      -   /S[        [
        S-  -  S-  [        [
        S	-  5      [        [
        S-  5      /[        [        -  [
        S-  -  S-  [        [        -  [
        S-  -  S-  -   [        [
        S-  5      -   [        [
        S	-  5      [        [        S-  -  [
        S	-  -  S
-  [        [        -  [        -  [
        S	-  -  S-  -   [        [        S-  -  [
        S	-  -  S
-  -   [        [
        S-  5      -   [        [        -  [
        S	-  -  S-  [        [        -  [
        S	-  -  S-  -   [        [
        S-  5      -   /[        * [
        S-  -  S-  S[        * [        -  [
        S-  -  S-  [        [        -  [
        S-  -  S-  -
  [        [
        S-  5      -   [        * [
        S-  -  S-  [        [        S-  -  [
        S	-  -  S-  -
  [        [        -  [        -  [
        S	-  -  S-  -
  [        [        S-  -  [
        S	-  -  S-  -
  [        [
        S-  5      -   //5      n[        SSUU4S j5      nTT-  Us=:X  a  U:X  d   e   eg )Nr   r   r   r   r   r   r   r   r   r   r   r   r   r   r       0   r      r   @   r   `            c                 D   >^ ^ [        UUU U4S j[        S5       5       6 $ )Nc              3   B   >#    U  H  nTTU4   TUT4   -  v   M     g 7fr}   rn   )r   kABr   r   s     rv   r   Atest_multiplication_inf_zero.<locals>.<lambda>.<locals>.<genexpr>  s%     (I11Q3!A#s   r   )r   r   )r   r   r   r   s   ``rv   r   .test_multiplication_inf_zero.<locals>.<lambda>  s    3(Ia(I#Jru   )	r5   r   r   r   r   rc   r`   r_   r^   )r   CC2r   r   s      @@rv   test_multiplication_inf_zeror     s.   Q!R!"A6Q;;R1a&!"A6Vc3Z#s45555	
Aq1Q4%'
A$q!Q	 	A 		AqD!RT!Q$Yq[2a419Q;.1a48"QT'!)bAgaQRdlSUo:UXZ[\X\]^X^_`bc_cXcdfXf:fiklmoplpipqrtuquiuvxix:x{|}~  AB  ~B  |C  ;C  	D	
Bq!tGAIqAw!Q$(	Aad1r!tAqDy{	"Qq!tW	,a1gr!Q$wq!t|BAaPQSTPTUW7WZ\]^`a]aZabcefbfZfgiZi7ilmnoqrnrls7suwxyuyz{}~z~u~  @B  vB  EG  HI  EI  JK  MN  JN  EN  OQ  EQ  vQ  TU  VW  YZ  VZ  T[  v[  	\	AqDR1WQT\"_	$r!tAvad{2~	51a41R	G!AqD'	QSTUVXYUYSZ\^_`\`abdeae\efh\hkmnokopqstptktuwkw\wz{|}  @A  }A  {B  ]B  DF  GH  JK  GK  DK  LM  DM  PQ  RT  PT  UV  XY  UY  PY  Z[  ]^  Z^  P^  _a  Pa  Da  df  gh  dh  ij  dj  kl  no  ko  do  pr  dr  Dr  uv  wy  uy  z{  }~  z~  u~  @  BC  C  uC  DF  uF  DF  IJ  KL  NO  KO  IP  DP  	Q	R 	SA 	SAXaZ"QT'!Q$,r/!BqDF1a4KN2R1WQT\"_DqAwNRSTUWXTXRYrtqtuvqvwxz{w{q{|~q~  BD  EF  BF  GH  JK  GK  BK  LN  BN  rN  QR  ST  VW  SW  QX  rX  []  Z]  ^_  ab  ^b  Zb  cd  Zd  gh  ik  gk  lm  op  lp  gp  qr  tu  qu  gu  vy  gy  Zy  |~  @  |@  AB  |B  CD  FG  CG  |G  HJ  |J  ZJ  MN  OQ  MQ  RS  UV  RV  MV  WX  Z[  W[  M[  \_  M_  Z_  bc  de  gh  dh  bi  Zi  jMNPRSTVWSWPWXYPY  QR  ST  VW  SW  QX  bc  de  gh  dh  bi  j+-a419Q;Aad1+DqAw+NRSTUWXTXRY[]^_ab^b[bcdfgcg[ghj[jmopqmqrsmstuwxtxmxy{m{[{  A  BC  EF  BF  F  GH  JK  GK  K  LN  N  \N  QR  ST  VW  SW  QX  \X  DF  GH  DH  IJ  LM  IM  DM  NP  DP  SU  VW  SW  XY  [\  X\  S\  ]_  S_  D_  bc  de  gh  dh  bi  Di  jEGC1HQJXYrtqtuvqvwxz{w{q{|~q~  BD  EF  BF  GH  JK  GK  BK  LN  BN  rN  QR  ST  VW  SW  QX  rX  ac  `c  de  gh  dh  `h  ij  `j  mo  pq  st  pt  mt  uv  xy  uy  my  z|  m|  `|  A  BC  C  DE  E  FG  IJ  FJ  J  KM  M  `M  PR  ST  VW  SW  PW  XY  [\  X\  P\  ]_  P_  `_  bc  de  gh  dh  bi  `i  j	k 	lA 
1J	KBQ3!>r>>>ru   c                  p  ^^^^ [        [        S 5        [        n [        SS/SS//5      mTS-  S S  U " S5      S-  U " S	5      S-  U " S
5      S-  U " S5      S-  /:X  d   eTS-  S S  / SQ:X  d   e[        / SQ/ SQ/ SQ/5      mTS-  S S  / SQ:X  d   eTS-  [	        S5      :X  d   eTS-  T:X  d   e[        S//5      S-  S   SS-  :X  d   e[	        S5      S-  [	        S5      :X  d   e[        SS/SS//5      [        S5      -  [        SS/SS//5      :X  d   e[        SS/SS//5      mT[        R                  -  S S  / SQ:X  d   e[        SS/SS//5      mT[        R                  -  S-  T:X  d   e[        SS/SS//5      [        R                  -  [        SS/[        R                  S//5      :X  d   e[        SS/SS//5      S -  [        SS/S S//5      :X  d   eSS!KJ	m  [        S[        /SS//5      T-  [        S[        T-  /SS//5      :X  d   e[        [        [        /S[        //5      T-  [        [        T-  [        [        TS-
  -  -  T-  /S[        T-  //5      :X  d   e[        [        T-  [        TS-
  -  T-  [        T-  TS-  -  [        T-  T-  -
  S[        S-  -  -  /S[        T-  [        TS-
  -  T-  /SS[        T-  //5      (       d   e[        [        SS/S[        S/SS[        //5      T-  [        [        T-  [        TS-
  -  T-  S/S[        T-  S/SS[        T-  //5      :X  d   e[        SS/SS//5      mTR                  [        S5      5      TR                  S5      :X  d   e[        S//5      mTS-  [        S"//5      s=:X  a5  TR                  [        S5      5      s=:X  a  TR                  S5      :X  d   e   e[        / S#Q/ S$Q/ S%Q/ S&Q/ S'Q/5      m[        [        U4S( j5        [        [        S) 5        [        / S*Q/ S+Q/ S,Q/5      mTS--  [        / S,Q/ S,Q/ S,Q/5      :X  d   e[        [        U4S. j5        [        [        U4S/ j5        [        SS/SS//5      mTS--  [        S0S1/S2S3//5      :X  d   e[        / S+Q/ S+Q/ S+Q/5      mTS--  [        / S+Q/ S+Q/ S+Q/5      :X  d   e[        / S*Q/ S+Q/ S+Q/5      mTS--  [        / S+Q/ S+Q/ S+Q/5      :X  d   e[!        S4S5S69m[#        TT-  [$        5      (       d   e[!        S4S5S5S79m[        [        UU4S8 j5        [!        S4S5S5S99mTT-  [        ['        ST5      ['        ST5      ['        ST5      * ['        ST5      -
  S-   /S['        ST5      S['        ST5      -
  // S+Q/5      :X  d   eTTS-   -  [        / S+Q/ S+Q/ S+Q/5      :X  d   e[        [        U4S: j5        [        / S+Q/ S;Q/ S<Q/5      mTS=-  [        / S>Q/ S?Q/ S@Q/5      :X  d   eTS=-  TS-  :X  d   e[        / S*Q/ SAQ/ S,Q/5      m[!        S45      mTT-  mTR)                  TS5      R+                  5       TS-  :X  d   e[        [        UU4SB j5        TT-  TST-  -  :X  d   e[        / S,Q/ S,Q/ S,Q/5      m[!        S4S5S5SC9mTT-  T:X  d   e[!        S4S5S5S99mTT-  [-        ST-  ST-  ST-  5      :X  d   eTT-  R)                  TS5      [	        S5      :X  d   eTT-  R)                  TS5      [/        S5      :X  d   e[        / SDQ/ SEQ/ SFQ/5      mTSG-  [-        SHSHSH5      :X  d   eT[0        -  [-        S[0        -  S[0        -  S[0        -  5      :X  d   e[        / S*Q/ S+Q/ S+Q/5      m[        [        U4SI j5        [        [        U4SJ j5        [        [        R                  [        R                  /[        R                  [        R                  //5      mT[        R                  -  T:X  d   e[        SS/SS//5      mT[        R                  -  [        [        R                  [        R                  /S[        R                  -  S[        R                  -  //5      :X  d   eg )KNc                      [        S5      S-  $ Nr   r   r5   rn   ru   rv   r   test_power.<locals>.<lambda>#  s    ):ru   r   r   r   r   r   ir      3   i)i  i  i,*  i7  )r   r   r   )r   r   r   )r   r   r   )	i"  i     i  i  ip  i  i  i  r   r   d   r   i r   r   r      !   r   r   9   )r   r   r   r   g      ?r   i   )r   r   r   r   r   )r   r   r   r   r   )r   r   r   r   r   )r   r   r   r   r   )r   r   r   r   r   c                  8   > T R                  [        S5      5      $ Nr   )_matrix_pow_by_jordan_blocksr   r   s   rv   r   r   L  s     > >qu Eru   c                  T    [        SS/SS//5      R                  [        S5      5      $ )Nr   r   )r5   r  r   rn   ru   rv   r   r   O  s(    AA'7 8 U UVWX[V\ ]ru   r   r   r   r   r   r   r         $@c                     > T S-  $ N @rn   r   s   rv   r   r   R  	    q#vru   c                  "   > T [        SS5      -  $ r   r   r  s   rv   r   r   S      q(1a.0ru   ihiO<iv0ir   T)integer)r  negativec                     > T T-  $ r}   rn   )r   r   s   rv   r   r   ]  s	    q!tru   )r  nonnegativec                  "   > T [        SS5      -  $ r   r  r  s   rv   r   r   d  r  ru   )r   r   r   )r   r   r   g      @)   H   Y   )i#        )i<  i  iI  r  r   r   c                  D   > T R                  TS5      R                  5       $ )N)subsdoit)Anr   s   rv   r   r   l  s    rwwq"~224ru   )r  positiver   r   r   )r   r   r   r   r   r   r  gd%%@c                     > T S-  $ r  rn   r  s   rv   r   r   {  r  ru   c                     > T [         -  $ r}   r
   r  s   rv   r   r   |  s	    q!tru   )rR   r-   r   r5   r9   r   r   Half	sympy.abcr   r_   r`   r  _eval_pow_by_recursionr,   
ValueErrorr   r   r\   rM   r#  r$  r8   rB   r
   )Rr   r%  r   r   s    @@@@rv   
test_powerr1  "  s   
!:;AAA ArE1:!D'!)QsVAXquQw#qAAAAqD!92222	9j12AqD!9EEEEa43q6>>a4199QC5MS $'1c6111q68s1v%%%Aq6Aq6"#WQZ/6Ar7RH:M3NNNNR2r(#$AqvvIq>\)))AQ !AqvvI>QAq6Aq6"#QVV+v1v{6K/LLLLAq6Aq6"#S(FQFS!H3E,FFFFAq6Aq6"#Q&&1ac(QF1C*DDDDAq6Aq6"#Q&&1a41qs8A2FAqD	1R*SSSS	
Aq1q5z!|ad1a4i!Q$q&01QT6:;q!ta!a%jl;!ad;= > > > > Aq!9q!Qi!Q34a76	
Aq1Q3xz1	
AqD!	
Aq!tC <   
 	AA A))!A$/13K3KA3NNNNuAb5FUG9% %)G)G")N %	  $% % % % % 	 "3_oWfghA
;EF ;]^	9i01Ad7fiI>????
:~&
:01AA Ad7fz95	97MNOOOO	9i01Ad7fiI>????	9i01Ad7fiI>????sD!AadF####sD40A
:|$sDd3Aa46	1	~a3nQ6J5J^\]_`Ma5ade5ef~a3QQ_`acdQeMeffh i i i i q1u:Iy ABBBB
:01	9i01Ac6V_oOPPPPc6QT>>	*Y/0AsA	
AB771a=1a4'''
:457a!A#h 	()AsD40Aa4199sDd3Aa441adAqD))))qD;;q!A&&&qD;;q!a((()*Ac6T6662222a44Aq!tQT****	9i01A
:~&
:|$ 166166"234Aaff9>>A1vAaff9!&&!&&!1AaffHah3G HIIIIru   c            
         [        S[        -   S[        -
  /S[        -
  S[        -   //5      n [        S5         U R                  5       R	                  5       [        [        S[        -  5      [        S5      -   S-  [        S[        -  5      * [        S5      -   S-  /[        S[        -  5      * [        S5      -   S-  [        S[        -  5      [        S5      -   S-  //5      :X  d   e S S S 5        g ! , (       d  f       g = f)Nr   Tr   )r5   rc   rF   r   r   r   s    rv   $test_issue_17247_expression_blowup_1r4    s    1ac
QqS!A#J'(A	T	uuw~~61Q3x#a& !#s1Q3xi#a&&8!%;<1Q3xi#a& !#s1Q3x#a&'8!&;<+> $? ? 	? ? 
		s   B2C55
Dc                     [        S[        -   S[        -
  /S[        -
  S[        -   //5      n [        S5         U R                  5       u  pX-  UR	                  5       -  (       d   e S S S 5        g ! , (       d  f       g = fNr   T)r5   rc   rF   jordan_forminvr   PJs      rv   $test_issue_17247_expression_blowup_2r<    s_    1ac
QqS!A#J'(A	T	}}s1557{{ 
		s   /A22
B c            	      F   [        S[        -   S[        -
  /S[        -
  S[        -   //5      n [        S5         U S-  [        S[        S-  -  S-   SS[        S-  -  -
  /SS[        S-  -  -
  S[        S-  -  S-   //5      :X  d   e S S S 5        g ! , (       d  f       g = f)Nr   Tr   l                )r5   rc   rF   r3  s    rv   $test_issue_17247_expression_blowup_3r>    s    1ac
QqS!A#J'(A	T	#v+AsF25SSUs  wU  VW  Y\  V\  w\  V\  ]+.LQPSV.SSUstuwztzUz  ~\  V\  ]!^ _ _ 	_ _ 
		s   AB
B c                      [        [        S5      5      n [        S5         U S-  [        [        S5      5      :X  d   e S S S 5        g ! , (       d  f       g = f)Na1  [
        [             -3/4,       45/32 - 37*I/16,         1/4 + I/2,      -129/64 - 9*I/64,      1/4 - 5*I/16,      65/128 + 87*I/64],
        [-149/64 + 49*I/32, -177/128 - 1369*I/128,  125/64 + 87*I/64, -2063/256 + 541*I/128,  85/256 - 33*I/16,  805/128 + 2415*I/512],
        [          1/2 - I,         9/4 + 55*I/16,              -3/4,       45/32 - 37*I/16,         1/4 + I/2,      -129/64 - 9*I/64],
        [   -5/8 - 39*I/16,   2473/256 + 137*I/64, -149/64 + 49*I/32, -177/128 - 1369*I/128,  125/64 + 87*I/64, -2063/256 + 541*I/128],
        [            1 + I,         -19/4 + 5*I/4,           1/2 - I,         9/4 + 55*I/16,              -3/4,       45/32 - 37*I/16],
        [         21/8 + I,    -537/64 + 143*I/16,    -5/8 - 39*I/16,   2473/256 + 137*I/64, -149/64 + 49*I/32, -177/128 - 1369*I/128]]Tr   a  [
            [     7369525394972778926719607798014571861/604462909807314587353088 - 229284202061790301477392339912557559*I/151115727451828646838272,   -19704281515163975949388435612632058035/1208925819614629174706176 + 14319858347987648723768698170712102887*I/302231454903657293676544,      -3623281909451783042932142262164941211/604462909807314587353088 - 6039240602494288615094338643452320495*I/604462909807314587353088,    109260497799140408739847239685705357695/2417851639229258349412352 - 7427566006564572463236368211555511431*I/2417851639229258349412352, -16095803767674394244695716092817006641/2417851639229258349412352 + 10336681897356760057393429626719177583*I/1208925819614629174706176,    -42207883340488041844332828574359769743/2417851639229258349412352 - 182332262671671273188016400290188468499*I/4835703278458516698824704],
            [50566491050825573392726324995779608259/1208925819614629174706176 - 90047007594468146222002432884052362145*I/2417851639229258349412352,  74273703462900000967697427843983822011/1208925819614629174706176 + 265947522682943571171988741842776095421*I/1208925819614629174706176, -116900341394390200556829767923360888429/2417851639229258349412352 - 53153263356679268823910621474478756845*I/2417851639229258349412352, 195407378023867871243426523048612490249/1208925819614629174706176 - 1242417915995360200584837585002906728929*I/9671406556917033397649408,   -863597594389821970177319682495878193/302231454903657293676544 + 476936100741548328800725360758734300481*I/9671406556917033397649408, -3154451590535653853562472176601754835575/19342813113834066795298816 - 232909875490506237386836489998407329215*I/2417851639229258349412352],
            [   -1715444997702484578716037230949868543/302231454903657293676544 + 5009695651321306866158517287924120777*I/302231454903657293676544,     -30551582497996879620371947949342101301/604462909807314587353088 - 7632518367986526187139161303331519629*I/151115727451828646838272,           312680739924495153190604170938220575/18889465931478580854784 - 108664334509328818765959789219208459*I/75557863725914323419136,    -14693696966703036206178521686918865509/604462909807314587353088 + 72345386220900843930147151999899692401*I/1208925819614629174706176,  -8218872496728882299722894680635296519/1208925819614629174706176 - 16776782833358893712645864791807664983*I/1208925819614629174706176,      143237839169380078671242929143670635137/2417851639229258349412352 + 2883817094806115974748882735218469447*I/2417851639229258349412352],
            [   3087979417831061365023111800749855987/151115727451828646838272 + 34441942370802869368851419102423997089*I/604462909807314587353088, -148309181940158040917731426845476175667/604462909807314587353088 - 263987151804109387844966835369350904919*I/9671406556917033397649408,   50259518594816377378747711930008883165/1208925819614629174706176 - 95713974916869240305450001443767979653*I/2417851639229258349412352,  153466447023875527996457943521467271119/2417851639229258349412352 + 517285524891117105834922278517084871349*I/2417851639229258349412352,  -29184653615412989036678939366291205575/604462909807314587353088 - 27551322282526322041080173287022121083*I/1208925819614629174706176,   196404220110085511863671393922447671649/1208925819614629174706176 - 1204712019400186021982272049902206202145*I/9671406556917033397649408],
            [     -2632581805949645784625606590600098779/151115727451828646838272 - 589957435912868015140272627522612771*I/37778931862957161709568,     26727850893953715274702844733506310247/302231454903657293676544 - 10825791956782128799168209600694020481*I/302231454903657293676544,      -1036348763702366164044671908440791295/151115727451828646838272 + 3188624571414467767868303105288107375*I/151115727451828646838272,     -36814959939970644875593411585393242449/604462909807314587353088 - 18457555789119782404850043842902832647*I/302231454903657293676544,      12454491297984637815063964572803058647/604462909807314587353088 - 340489532842249733975074349495329171*I/302231454903657293676544,      -19547211751145597258386735573258916681/604462909807314587353088 + 87299583775782199663414539883938008933*I/1208925819614629174706176],
            [  -40281994229560039213253423262678393183/604462909807314587353088 - 2939986850065527327299273003299736641*I/604462909807314587353088, 331940684638052085845743020267462794181/2417851639229258349412352 - 284574901963624403933361315517248458969*I/1208925819614629174706176,      6453843623051745485064693628073010961/302231454903657293676544 + 36062454107479732681350914931391590957*I/604462909807314587353088,  -147665869053634695632880753646441962067/604462909807314587353088 - 305987938660447291246597544085345123927*I/9671406556917033397649408,  107821369195275772166593879711259469423/2417851639229258349412352 - 11645185518211204108659001435013326687*I/302231454903657293676544,     64121228424717666402009446088588091619/1208925819614629174706176 + 265557133337095047883844369272389762133*I/1208925819614629174706176]])r5   r   rF   r3  s    rv   $test_issue_17247_expression_blowup_4r@    sb    8 	q K L 	MA 
T	"uq "H  I J J 	J J 
		s   A
Ac                     [        SSS 5      n [        S5         U R                  S5      [        [        S-  SS[
        -  -
  [        S-  -  -   S[
        -  [        S-  -  -   [        S	S
9:X  d   e S S S 5        g ! , (       d  f       g = f)Nr   c                 $    SSX-   -  [         -  -   $ Nr   r  r+  r   s     rv   r   6test_issue_17247_expression_blowup_5.<locals>.<lambda>      !rQSk!m"3ru   Trc   r   $   r   EXdomain)r5   rF   charpolyr$   rc   r
   r3  s    rv   $test_issue_17247_expression_blowup_5rL    so    q!34A	T	zz#(1a42!8QT/+ABqDAI+MqY]"^^^^ 
		s   AA;;
B	c            	          [        SS[        S5       V s/ s H  n [        U -   PM     sn 5      n[        S5         UR	                  S5      S:X  d   e S S S 5        g s  sn f ! , (       d  f       g = f)Nr   r   Tbareissr   r5   r   rc   rF   detr   r   s     rv   $test_issue_17247_expression_blowup_6rR    sZ    q!5":.:aac:./A	T	uuY1$$$ 
	 /		   AA!!
A/c                      [        SSS 5      n [        S5         U R                  S5      S:X  d   e S S S 5        g ! , (       d  f       g = f)Nr   c                 $    SSX-   -  [         -  -   $ rC  r+  r   s     rv   r   6test_issue_17247_expression_blowup_7.<locals>.<lambda>  rE  ru   T	berkowitzr   )r5   rF   rP  r3  s    rv   $test_issue_17247_expression_blowup_7rX    s<    q!34A	T	uu[!Q&&& 
		s	   <
A
c            	          [        SS[        S5       V s/ s H  n [        U -   PM     sn 5      n[        S5         UR	                  S5      S:X  d   e S S S 5        g s  sn f ! , (       d  f       g = f)Nr   r   Tlur   rO  rQ  s     rv   $test_issue_17247_expression_blowup_8r[    sY    q!5":.:aac:./A	T	uuT{a 
	 /		rS  c                  (   [        SS[        S5       V s/ s H  n [        U -   PM     sn 5      n[        S5         UR	                  5       [        / SQ/ SQ/ SQ/ SQ/ SQ/ SQ/ SQ/ SQ/5      S4:X  d   e S S S 5        g s  sn f ! , (       d  f       g = f)Nr   r   T)r   r   r  r"  r   rF  r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   )r5   r   rc   rF   rrefrQ  s     rv   $test_issue_17247_expression_blowup_9rb    s    q!5":.:aac:./A	T	vvxF********$, - /56 6 	6 6 
	 /		s   A>:B
Bc                      [        SSS 5      n [        S5         U R                  SS5      S:X  d   e S S S 5        g ! , (       d  f       g = f)Nr   c                 $    SSX-   -  [         -  -   $ rC  r+  r   s     rv   r   7test_issue_17247_expression_blowup_10.<locals>.<lambda>  rE  ru   Tr   )r5   rF   cofactorr3  s    rv   %test_issue_17247_expression_blowup_10rg    s>    q!34A	T	zz!Q1$$$ 
		s	   =
Ac                      [        SSS 5      n [        S5         U R                  5       [        SSS/S-  5      :X  d   e S S S 5        g ! , (       d  f       g = f)Nr   c                 $    SSX-   -  [         -  -   $ rC  r+  r   s     rv   r   7test_issue_17247_expression_blowup_11.<locals>.<lambda>  rE  ru   Tr   rG  )r5   rF   cofactor_matrixr3  s    rv   %test_issue_17247_expression_blowup_11rl    sK    q!34A	T	  "fQA3r6&:::: 
		s   &A


Ac                      [        SSS 5      n [        S5         U R                  5       SSS[        -  SSS0:X  d   e S S S 5        g ! , (       d  f       g = f)Nr   c                 $    SSX-   -  [         -  -   $ rC  r+  r   s     rv   r   7test_issue_17247_expression_blowup_12.<locals>.<lambda>  rE  ru   Tr   r   r   )r5   rF   	eigenvalsr
   r3  s    rv   %test_issue_17247_expression_blowup_12rq    sJ    q!34A	T	{{}AqsAq! 4444 
		s   $A
Ac            
         [        SS[        -
  [        S-   S[        -
  /S[        -
  [        S-   S[        S-   /SS[        -
  [        S-   S[        -
  /SSS[        -
  S//5      n U R                  5       nUS   SS[        / SQ5      /4:X  d   eUS   S   [        [        S5      [        S-
  -  -
  S-   :X  d   eUS   S   S:X  d   eUS   S   S   R	                  SSS9[        [        * [        S5      [        S-
  -  -   S-
  [        S-
  -  /S[        -  [        S-  S[        -  -
  S-   -  [        S-   [        [        S5      [        S-
  -  -
  S-   -  [        S-  S[        -  -
  S-   -  -   /[        * [        S5      [        S-
  -  -   S-
  [        S-
  -  /S//5      :X  d   eUS   S   [        [        S5      [        S-
  -  -   S-   :X  d   eUS   S   S:X  d   eUS   S   S   R	                  SSS9[        [        * [        S5      [        S-
  -  -
  S-
  [        S-
  -  /S[        -  [        S-  S[        -  -
  S-   -  [        S-   [        [        S5      [        S-
  -  -   S-   -  [        S-  S[        -  -
  S-   -  -   /[        * [        S5      [        S-
  -  -
  S-
  [        S-
  -  /S//5      :X  d   eg )	Nr   r   r   )r   r  r   r   FT)deepnumerr]  )r5   rc   
eigenvectsr   r   )r   evs     rv   %test_issue_17247_expression_blowup_13rw    s   Aq1ua!e$	
QA1a!e$Aq1ua!e$A1q5!$	& 	'A 
Ba5QF=123333a58q47AE?*Q....a58q==a58A;55"tAwA

"QU	+,	Aq!taczA~	!a%!d1gq1uo*=*A!BAqD1Q3JQRN!S	ST"tAwA

"QU	+,	
	A :    a58q47AE?*Q....a58q==a58A;55"tAwA

"QU	+,	Aq!taczA~	!a%!d1gq1uo*=*A!BAqD1Q3JQRN!S	ST"tAwA

"QU	+,	
	A :   ru   c                     [        SSS[        -   S[        -
  /S-  S[        -
  S[        -   /S-  -   S-  5      n [        S5         U R                  5       [        [        S-   S[        -
  [        S-   S[        -
  [        S-   S[        -
  [        S-   S[        -
  /SS[        -  SS[        -  SS[        -  SS[        -  // SQ/ SQ/ SQ/ SQ/ SQ/ SQ/5      :X  d   e S S S 5        g ! , (       d  f       g = f)Nr   r   r   Tr   r`  )r5   rc   rF   echelon_formr3  s    rv   %test_issue_17247_expression_blowup_14rz    s    q!qsAaCjlac1Q3Z\1145A	T	~~6UAE1q5!a%QAq1ua!eDacqAaCQ!A#1!DDDDDDD+F $G G 	G G 
		s   BC''
C5c                     [        SSS[        -   S[        -
  /S-  S[        -
  S[        -   /S-  -   S-  5      n [        S5         U R                  5       [        [        S-   S[        -
  [        S-   S[        -
  [        S-   S[        -
  [        S-   S[        -
  //5      [        SS[        -  SS[        -  SS[        -  SS[        -  //5      /:X  d   e S S S 5        g ! , (       d  f       g = f)Nr   r   r   Tr   )r5   rc   rF   rowspacer3  s    rv   %test_issue_17247_expression_blowup_15r}    s   q!qsAaCjlac1Q3Z\1145A	T	zz|QAq1ua!eQUAPQESTWXSXZ[^_Z_(`'a bdjmnpqrspsuvxyz{x{}~  AB  CD  AD  FG  IJ  KL  IL  mM  lN  eO   P  P  	P  P 
		s   BC  
C.c                  6   [        SSS[        -   S[        -
  /S-  S[        -
  S[        -   /S-  -   S-  5      n [        S5         U R                  5       [        [        S-   /S[        -
  /[        S-   /S[        -
  /[        S-   /S[        -
  /[        S-   /S[        -
  //5      [        S[        -
  /[        S-   /S[        -
  /[        S-   /S[        -
  /[        S-   /S[        -
  /[        S-   //5      /:X  d   e S S S 5        g ! , (       d  f       g = f)Nr   r   r   T)r5   rc   rF   columnspacer3  s    rv   %test_issue_17247_expression_blowup_16r  !  s   q!qsAaCjlac1Q3Z\1145A	T	}}6AE7AE7AE7AE7APQE7TUXYTYSZ\]`a\a[bdehidicj*k#lntwx{|w|v}  @A  DE  @E  F  HI  LM  HM  GN  PQ  TU  PU  OV  XY  \]  X]  W^  `a  de  `e  _f  hi  lm  hm  gn  pq  tu  pu  ov  vw  ox  #y  y  	y  y 
		s   B;D


Dc                     [        SS[        S5       V s/ s H  n [        U -   PM     sn 5      n[        S5         UR	                  5       [        S/S/S/S/S/S/S/S//5      [        S/S/S/S/S/S/S/S//5      [        S	/S
/S/S/S/S/S/S//5      [        S/S/S/S/S/S/S/S//5      [        S/S/S/S/S/S/S/S//5      [        S/S/S/S/S/S/S/S//5      /:X  d   e S S S 5        g s  sn f ! , (       d  f       g = f)Nr   r   Tr   r"  r   r   r   r   r]  r   r^  r   rF  r   )r5   r   rc   rF   	nullspacerQ  s     rv   %test_issue_17247_expression_blowup_17r  &  sV   q!5":.:aac:./A	T	{{}QCaS!aS!aS!56QCaS!aS!aS!56QCaS!aS!aS!56QCaS!aS!aS!56QCaS!aS!aS!56QCaS!aS!aS!56!8 8 	8 8 
	 /		s   C7B3C<<
D
c                      [        SSS[        -   S[        -
  /S-  S[        -
  S[        -   /S-  -   S-  5      n [        S5         U R                  5       (       a   e S S S 5        g ! , (       d  f       g = f)Nr   r   r   T)r5   rc   rF   is_nilpotentr3  s    rv   %test_issue_17247_expression_blowup_18r  1  sd    q!qsAaCjlac1Q3Z\1145A	T	>>##### 
		s   A''
A5c                      [        [        S5      5      n [        S5         U R                  5       (       a   e S S S 5        g ! , (       d  f       g = f)Nay  [
        [             -3/4,                     0,         1/4 + I/2,                     0],
        [                0, -177/128 - 1369*I/128,                 0, -2063/256 + 541*I/128],
        [          1/2 - I,                     0,                 0,                     0],
        [                0,                     0,                 0, -177/128 - 1369*I/128]]T)r5   r   rF   is_diagonalizabler3  s    rv   %test_issue_17247_expression_blowup_19r  6  sI    q a b 	cA
 
T	&&((((( 
		s   A
Ac                     [        [        S-   S[        -
  SS/S[        -
  [        S-   S[        S-   /SS[        -
  [        S-   S/SSS[        S-   //5      n [        S5         U R                  5       [        SSS[        S-   [        S-
  -  // SQ/ SQ/ SQ/5      [        / SQSS[        -  SS/SS[        S-   S/SSS[        S-   //5      4:X  d   e S S S 5        g ! , (       d  f       g = f)	Nr   r   T)r   r  r   r   r   r   r   r   r   r   r   r   r   r   )r5   rc   rF   diagonalizer3  s    rv   %test_issue_17247_expression_blowup_20r  ?  s   UQU#UQUQU#	
QUQU#	
QU#	% 	&A
 
T	}}6AAA''''	+) $*
 "!"!QU"!AE"	$ %	#& 	& 		& 	& 
		s   #A1C
C,c                      [        [        S5      5      n [        S5         U R                  SS9[        [        S5      5      :X  d   e S S S 5        g ! , (       d  f       g = f)N  [
        [             -3/4,       45/32 - 37*I/16,                   0,                     0],
        [-149/64 + 49*I/32, -177/128 - 1369*I/128,                   0, -2063/256 + 541*I/128],
        [                0,         9/4 + 55*I/16, 2473/256 + 137*I/64,                     0],
        [                0,                     0,                   0, -177/128 - 1369*I/128]]TGEmethodv  [
            [-26194832/3470993 - 31733264*I/3470993, 156352/3470993 + 10325632*I/3470993, 0, -7741283181072/3306971225785 + 2999007604624*I/3306971225785],
            [4408224/3470993 - 9675328*I/3470993, -2422272/3470993 + 1523712*I/3470993, 0, -1824666489984/3306971225785 - 1401091949952*I/3306971225785],
            [-26406945676288/22270005630769 + 10245925485056*I/22270005630769, 7453523312640/22270005630769 + 1601616519168*I/22270005630769, 633088/6416033 - 140288*I/6416033, 872209227109521408/21217636514687010905 + 6066405081802389504*I/21217636514687010905],
            [0, 0, 0, -11328/952745 + 87616*I/952745]]r5   r   rF   r8  r3  s    rv   %test_issue_17247_expression_blowup_21r  Q  a    q c d 	eA
 
T	uuDu!VA /: -; &< < 	< < 
		   (A
A c                      [        [        S5      5      n [        S5         U R                  SS9[        [        S5      5      :X  d   e S S S 5        g ! , (       d  f       g = f)Nr  TLUr  r  r  r3  s    rv   %test_issue_17247_expression_blowup_22r  ^  r  r  c                      [        [        S5      5      n [        S5         U R                  SS9R	                  5       [        [        S5      5      :X  d   e S S S 5        g ! , (       d  f       g = f)Nr  TADJr  r  )r5   r   rF   r8  r   r3  s    rv   %test_issue_17247_expression_blowup_23r  k  sj    q c d 	eA
 
T	uuEu"))+va 9: 7; 0< < 	< < 
		s   6A  
A.c                      [        [        S5      5      n [        S5         U R                  SS9[	        [        S5      5      :X  d   e S S S 5        g ! , (       d  f       g = f)Nr  TCHr  r  r6   r   rF   r8  r5   r3  s    rv   %test_issue_17247_expression_blowup_24r  x  sa    Q c d 	eA
 
T	uuDu!VA /: -; &< < 	< < 
		r  c                      [        [        S5      5      n [        S5         U R                  SS9[	        [        S5      5      :X  d   e S S S 5        g ! , (       d  f       g = f)Nr  TLDLr  r  r  r3  s    rv   %test_issue_17247_expression_blowup_25r    sa    Q c d 	eA
 
T	uuEu"fQ 0: .; '< < 	< < 
		r  c                      [        [        S5      5      n [        S5         U R                  5       S:X  d   e S S S 5        g ! , (       d  f       g = f)Na  [
        [             -3/4,       45/32 - 37*I/16,         1/4 + I/2,      -129/64 - 9*I/64,      1/4 - 5*I/16,      65/128 + 87*I/64,         -9/32 - I/16,      183/256 - 97*I/128],
        [-149/64 + 49*I/32, -177/128 - 1369*I/128,  125/64 + 87*I/64, -2063/256 + 541*I/128,  85/256 - 33*I/16,  805/128 + 2415*I/512, -219/128 + 115*I/256, 6301/4096 - 6609*I/1024],
        [          1/2 - I,         9/4 + 55*I/16,              -3/4,       45/32 - 37*I/16,         1/4 + I/2,      -129/64 - 9*I/64,         1/4 - 5*I/16,        65/128 + 87*I/64],
        [   -5/8 - 39*I/16,   2473/256 + 137*I/64, -149/64 + 49*I/32, -177/128 - 1369*I/128,  125/64 + 87*I/64, -2063/256 + 541*I/128,     85/256 - 33*I/16,    805/128 + 2415*I/512],
        [            1 + I,         -19/4 + 5*I/4,           1/2 - I,         9/4 + 55*I/16,              -3/4,       45/32 - 37*I/16,            1/4 + I/2,        -129/64 - 9*I/64],
        [         21/8 + I,    -537/64 + 143*I/16,    -5/8 - 39*I/16,   2473/256 + 137*I/64, -149/64 + 49*I/32, -177/128 - 1369*I/128,     125/64 + 87*I/64,   -2063/256 + 541*I/128],
        [               -2,         17/4 - 13*I/2,             1 + I,         -19/4 + 5*I/4,           1/2 - I,         9/4 + 55*I/16,                 -3/4,         45/32 - 37*I/16],
        [     1/4 + 13*I/4,    -825/64 - 147*I/32,          21/8 + I,    -537/64 + 143*I/16,    -5/8 - 39*I/16,   2473/256 + 137*I/64,    -149/64 + 49*I/32,   -177/128 - 1369*I/128]]Tr   r5   r   rF   rankr3  s    rv   %test_issue_17247_expression_blowup_26r    sC    q z { 	|A 
T	vvx1}} 
		   A
Ac            	         [        SS[        -
  [        S-   S[        -
  /S[        -
  [        S-   S[        S-   /SS[        -
  [        S-   S[        -
  /SSS[        -
  S//5      n [        S5         U R                  5       u  pUR	                  5       [        [        S5      5      R	                  5       :X  d   eU[        [        S5      5      :X  d   e S S S 5        g ! , (       d  f       g = f)Nr   r   Ta  [
            [    0,  4*x/(x**2 - 2*x + 1), -(-17*x**4 + 12*sqrt(2)*x**4 - 4*sqrt(2)*x**3 + 6*x**3 - 6*x - 4*sqrt(2)*x + 12*sqrt(2) + 17)/(-7*x**4 + 5*sqrt(2)*x**4 - 6*sqrt(2)*x**3 + 8*x**3 - 2*x**2 + 8*x + 6*sqrt(2)*x - 5*sqrt(2) - 7), -(12*sqrt(2)*x**4 + 17*x**4 - 6*x**3 - 4*sqrt(2)*x**3 - 4*sqrt(2)*x + 6*x - 17 + 12*sqrt(2))/(7*x**4 + 5*sqrt(2)*x**4 - 6*sqrt(2)*x**3 - 8*x**3 + 2*x**2 - 8*x + 6*sqrt(2)*x - 5*sqrt(2) + 7)],
            [x - 1, x/(x - 1) + 1/(x - 1),                       (-7*x**3 + 5*sqrt(2)*x**3 - x**2 + sqrt(2)*x**2 - sqrt(2)*x - x - 5*sqrt(2) - 7)/(-3*x**3 + 2*sqrt(2)*x**3 - 2*sqrt(2)*x**2 + 3*x**2 + 2*sqrt(2)*x + 3*x - 3 - 2*sqrt(2)),                       (7*x**3 + 5*sqrt(2)*x**3 + x**2 + sqrt(2)*x**2 - sqrt(2)*x + x - 5*sqrt(2) + 7)/(2*sqrt(2)*x**3 + 3*x**3 - 3*x**2 - 2*sqrt(2)*x**2 - 3*x + 2*sqrt(2)*x - 2*sqrt(2) + 3)],
            [    0,                     1,                                                                                            -(-3*x**2 + 2*sqrt(2)*x**2 + 2*x - 3 - 2*sqrt(2))/(-x**2 + sqrt(2)*x**2 - 2*sqrt(2)*x + 1 + sqrt(2)),                                                                                            -(2*sqrt(2)*x**2 + 3*x**2 - 2*x - 2*sqrt(2) + 3)/(x**2 + sqrt(2)*x**2 - 2*sqrt(2)*x - 1 + sqrt(2))],
            [1 - x,                     0,                                                                                                                                                                                               1,                                                                                                                                                                                             1]]a  [
            [0, 1,                       0,                       0],
            [0, 0,                       0,                       0],
            [0, 0, x - sqrt(2)*(x - 1) + 1,                       0],
            [0, 0,                       0, x + sqrt(2)*(x - 1) + 1]])r5   rc   rF   r7  r   r   r9  s      rv   %test_issue_17247_expression_blowup_27r    s    Aq1ua!e$	
QA1a!e$Aq1ua!e$A1q5!$	& 	'A
 
T	}}xxzVA 'o %p q rx  rx  rz	z 	z z
 F1 I J K K 	K K 
		s   1A#C
C,c                      [        [        S5      5      n [        S5         U R                  5       [        S5      :X  d   e S S S 5        g ! , (       d  f       g = f)Nr  Ta  [
            sqrt(14609315/131072 + sqrt(64789115132571/2147483648 - 2*(25895222463957462655758224991455280215303/633825300114114700748351602688 + sqrt(1213909058710955930446995195883114969038524625997915131236390724543989220134670)*I/22282920707136844948184236032)**(1/3) + 76627253330829751075/(35184372088832*sqrt(64789115132571/4294967296 + 3546944054712886603889144627/(110680464442257309696*(25895222463957462655758224991455280215303/633825300114114700748351602688 + sqrt(1213909058710955930446995195883114969038524625997915131236390724543989220134670)*I/22282920707136844948184236032)**(1/3)) + 2*(25895222463957462655758224991455280215303/633825300114114700748351602688 + sqrt(1213909058710955930446995195883114969038524625997915131236390724543989220134670)*I/22282920707136844948184236032)**(1/3))) - 3546944054712886603889144627/(110680464442257309696*(25895222463957462655758224991455280215303/633825300114114700748351602688 + sqrt(1213909058710955930446995195883114969038524625997915131236390724543989220134670)*I/22282920707136844948184236032)**(1/3)))/2 + sqrt(64789115132571/4294967296 + 3546944054712886603889144627/(110680464442257309696*(25895222463957462655758224991455280215303/633825300114114700748351602688 + sqrt(1213909058710955930446995195883114969038524625997915131236390724543989220134670)*I/22282920707136844948184236032)**(1/3)) + 2*(25895222463957462655758224991455280215303/633825300114114700748351602688 + sqrt(1213909058710955930446995195883114969038524625997915131236390724543989220134670)*I/22282920707136844948184236032)**(1/3))/2),
            sqrt(14609315/131072 - sqrt(64789115132571/2147483648 - 2*(25895222463957462655758224991455280215303/633825300114114700748351602688 + sqrt(1213909058710955930446995195883114969038524625997915131236390724543989220134670)*I/22282920707136844948184236032)**(1/3) + 76627253330829751075/(35184372088832*sqrt(64789115132571/4294967296 + 3546944054712886603889144627/(110680464442257309696*(25895222463957462655758224991455280215303/633825300114114700748351602688 + sqrt(1213909058710955930446995195883114969038524625997915131236390724543989220134670)*I/22282920707136844948184236032)**(1/3)) + 2*(25895222463957462655758224991455280215303/633825300114114700748351602688 + sqrt(1213909058710955930446995195883114969038524625997915131236390724543989220134670)*I/22282920707136844948184236032)**(1/3))) - 3546944054712886603889144627/(110680464442257309696*(25895222463957462655758224991455280215303/633825300114114700748351602688 + sqrt(1213909058710955930446995195883114969038524625997915131236390724543989220134670)*I/22282920707136844948184236032)**(1/3)))/2 + sqrt(64789115132571/4294967296 + 3546944054712886603889144627/(110680464442257309696*(25895222463957462655758224991455280215303/633825300114114700748351602688 + sqrt(1213909058710955930446995195883114969038524625997915131236390724543989220134670)*I/22282920707136844948184236032)**(1/3)) + 2*(25895222463957462655758224991455280215303/633825300114114700748351602688 + sqrt(1213909058710955930446995195883114969038524625997915131236390724543989220134670)*I/22282920707136844948184236032)**(1/3))/2),
            sqrt(14609315/131072 - sqrt(64789115132571/4294967296 + 3546944054712886603889144627/(110680464442257309696*(25895222463957462655758224991455280215303/633825300114114700748351602688 + sqrt(1213909058710955930446995195883114969038524625997915131236390724543989220134670)*I/22282920707136844948184236032)**(1/3)) + 2*(25895222463957462655758224991455280215303/633825300114114700748351602688 + sqrt(1213909058710955930446995195883114969038524625997915131236390724543989220134670)*I/22282920707136844948184236032)**(1/3))/2 + sqrt(64789115132571/2147483648 - 2*(25895222463957462655758224991455280215303/633825300114114700748351602688 + sqrt(1213909058710955930446995195883114969038524625997915131236390724543989220134670)*I/22282920707136844948184236032)**(1/3) - 76627253330829751075/(35184372088832*sqrt(64789115132571/4294967296 + 3546944054712886603889144627/(110680464442257309696*(25895222463957462655758224991455280215303/633825300114114700748351602688 + sqrt(1213909058710955930446995195883114969038524625997915131236390724543989220134670)*I/22282920707136844948184236032)**(1/3)) + 2*(25895222463957462655758224991455280215303/633825300114114700748351602688 + sqrt(1213909058710955930446995195883114969038524625997915131236390724543989220134670)*I/22282920707136844948184236032)**(1/3))) - 3546944054712886603889144627/(110680464442257309696*(25895222463957462655758224991455280215303/633825300114114700748351602688 + sqrt(1213909058710955930446995195883114969038524625997915131236390724543989220134670)*I/22282920707136844948184236032)**(1/3)))/2),
            sqrt(14609315/131072 - sqrt(64789115132571/4294967296 + 3546944054712886603889144627/(110680464442257309696*(25895222463957462655758224991455280215303/633825300114114700748351602688 + sqrt(1213909058710955930446995195883114969038524625997915131236390724543989220134670)*I/22282920707136844948184236032)**(1/3)) + 2*(25895222463957462655758224991455280215303/633825300114114700748351602688 + sqrt(1213909058710955930446995195883114969038524625997915131236390724543989220134670)*I/22282920707136844948184236032)**(1/3))/2 - sqrt(64789115132571/2147483648 - 2*(25895222463957462655758224991455280215303/633825300114114700748351602688 + sqrt(1213909058710955930446995195883114969038524625997915131236390724543989220134670)*I/22282920707136844948184236032)**(1/3) - 76627253330829751075/(35184372088832*sqrt(64789115132571/4294967296 + 3546944054712886603889144627/(110680464442257309696*(25895222463957462655758224991455280215303/633825300114114700748351602688 + sqrt(1213909058710955930446995195883114969038524625997915131236390724543989220134670)*I/22282920707136844948184236032)**(1/3)) + 2*(25895222463957462655758224991455280215303/633825300114114700748351602688 + sqrt(1213909058710955930446995195883114969038524625997915131236390724543989220134670)*I/22282920707136844948184236032)**(1/3))) - 3546944054712886603889144627/(110680464442257309696*(25895222463957462655758224991455280215303/633825300114114700748351602688 + sqrt(1213909058710955930446995195883114969038524625997915131236390724543989220134670)*I/22282920707136844948184236032)**(1/3)))/2)])r5   r   rF   singular_valuesr3  s    rv   %test_issue_17247_expression_blowup_28r    s]    q c d 	eA
 
T	  "a )c 'd d 	d d 
		s    A


Ac                      [        [        S5      5      n [        S5         U R                  5       S:X  d   e S S S 5        g ! , (       d  f       g = f)Na	  [
        [1+I,-19/4+5/4*I,1/2-I,9/4+55/16*I,-3/4,45/32-37/16*I,1/4+1/2*I,-129/64-9/64*I,1/4-5/16*I,65/128+87/64*I,-9/32-1/16*I,183/256-97/128*I,3/64+13/64*I,-23/32-59/256*I,15/128-3/32*I,19/256+551/1024*I],
        [21/8+I,-537/64+143/16*I,-5/8-39/16*I,2473/256+137/64*I,-149/64+49/32*I,-177/128-1369/128*I,125/64+87/64*I,-2063/256+541/128*I,85/256-33/16*I,805/128+2415/512*I,-219/128+115/256*I,6301/4096-6609/1024*I,119/128+143/128*I,-10879/2048+4343/4096*I,129/256-549/512*I,42533/16384+29103/8192*I],
        [-2,17/4-13/2*I,1+I,-19/4+5/4*I,1/2-I,9/4+55/16*I,-3/4,45/32-37/16*I,1/4+1/2*I,-129/64-9/64*I,1/4-5/16*I,65/128+87/64*I,-9/32-1/16*I,183/256-97/128*I,3/64+13/64*I,-23/32-59/256*I],
        [1/4+13/4*I,-825/64-147/32*I,21/8+I,-537/64+143/16*I,-5/8-39/16*I,2473/256+137/64*I,-149/64+49/32*I,-177/128-1369/128*I,125/64+87/64*I,-2063/256+541/128*I,85/256-33/16*I,805/128+2415/512*I,-219/128+115/256*I,6301/4096-6609/1024*I,119/128+143/128*I,-10879/2048+4343/4096*I],
        [-4*I,27/2+6*I,-2,17/4-13/2*I,1+I,-19/4+5/4*I,1/2-I,9/4+55/16*I,-3/4,45/32-37/16*I,1/4+1/2*I,-129/64-9/64*I,1/4-5/16*I,65/128+87/64*I,-9/32-1/16*I,183/256-97/128*I],
        [1/4+5/2*I,-23/8-57/16*I,1/4+13/4*I,-825/64-147/32*I,21/8+I,-537/64+143/16*I,-5/8-39/16*I,2473/256+137/64*I,-149/64+49/32*I,-177/128-1369/128*I,125/64+87/64*I,-2063/256+541/128*I,85/256-33/16*I,805/128+2415/512*I,-219/128+115/256*I,6301/4096-6609/1024*I],
        [-4,9-5*I,-4*I,27/2+6*I,-2,17/4-13/2*I,1+I,-19/4+5/4*I,1/2-I,9/4+55/16*I,-3/4,45/32-37/16*I,1/4+1/2*I,-129/64-9/64*I,1/4-5/16*I,65/128+87/64*I],
        [-2*I,119/8+29/4*I,1/4+5/2*I,-23/8-57/16*I,1/4+13/4*I,-825/64-147/32*I,21/8+I,-537/64+143/16*I,-5/8-39/16*I,2473/256+137/64*I,-149/64+49/32*I,-177/128-1369/128*I,125/64+87/64*I,-2063/256+541/128*I,85/256-33/16*I,805/128+2415/512*I],
        [0,-6,-4,9-5*I,-4*I,27/2+6*I,-2,17/4-13/2*I,1+I,-19/4+5/4*I,1/2-I,9/4+55/16*I,-3/4,45/32-37/16*I,1/4+1/2*I,-129/64-9/64*I],
        [1,-9/4+3*I,-2*I,119/8+29/4*I,1/4+5/2*I,-23/8-57/16*I,1/4+13/4*I,-825/64-147/32*I,21/8+I,-537/64+143/16*I,-5/8-39/16*I,2473/256+137/64*I,-149/64+49/32*I,-177/128-1369/128*I,125/64+87/64*I,-2063/256+541/128*I],
        [0,-4*I,0,-6,-4,9-5*I,-4*I,27/2+6*I,-2,17/4-13/2*I,1+I,-19/4+5/4*I,1/2-I,9/4+55/16*I,-3/4,45/32-37/16*I],
        [0,1/4+1/2*I,1,-9/4+3*I,-2*I,119/8+29/4*I,1/4+5/2*I,-23/8-57/16*I,1/4+13/4*I,-825/64-147/32*I,21/8+I,-537/64+143/16*I,-5/8-39/16*I,2473/256+137/64*I,-149/64+49/32*I,-177/128-1369/128*I]]Tr   r  r3  s    rv   test_issue_16823r    sC    q F G 	HA 
T	vvx1}} 
		r  c                  r   [        / SQS[        S5      -   S[        S5      -   S[        S5      -
  [        S5      * S-
  SSSSS/	SS[        S5      -  -   SS[        S5      -  -
  SS[        S5      -  -
  SS[        S5      -  -   SSSSS/	S	[        S5      -  S-
  SS
[        S5      -  -
  SS
[        S5      -  -   SS
[        S5      -  -   SSSSS
/	SS[        S5      -  -
  S[        S5      -  S-   S[        S5      -  S-   SS[        S5      -  -
  SSSSS/	SS
[        S5      -  -   SS
[        S5      -  -   S	[        S5      -  S-
  SS
[        S5      -  -
  SSSSS
/	S	S[        S5      -  -   S	S[        S5      -  -
  S	S[        S5      -  -
  S	S[        S5      -  -   SSSSS/	S[        S5      -
  [        S5      * S-
  S[        S5      -   S[        S5      -   SSSSS/	/5      n [        S5         U R                  5       [        SSSSSSSS[	        S5      S-  /	SSSSSSSS[	        S5      * S-  /	SSSSSSSS[	        S5      S-  /	SSSSSSSS[	        S5      * S-  /	/ SQSSSSSSSS[	        S5      * S-  /	/ SQSSSSSSSS[	        S5      * S-  /	/5      S4:X  d   e S S S 5        g ! , (       d  f       g = f)N)	r   r   r   r   r   r   r   r   r   r   r   r  r^  r  r"  r   r   r   r   r   r   T)	r   r   r   r   r   r   r   r   r   )	r   r   r   r   r   r   r   r   r   r_  )r5   r   rF   ra  r   r3  s    rv   test_issue_18531r    s   #	
T!Wb47lAQK$q'Aq!RAN	aQiaQiaQiaQiQPRTVXYZ	DGaQtAwYQtAwYAd1gIr2qRTVWX	
QtAwY$q'	Aqay1}a!DG)mQQPRTUV	aQiQtAwY47
QAd1gIq"bRTVWX	aQiaQiaQiaQiQPRTVXYZ	
T!WtAwhlAQKd1gr1aAN	
 		A 
T	vvxF1aAq!ad1f-1aAq!adU1W-1aAq!ad1f-1aAq!adU1W-*1aAq!adU1W-*1aAq!adU1W-$/ 0 2JK K 	K K 
		s   .B0J((
J6c            	      
   [        [        S 5        [        [        S 5        [        [        S 5        [        [        5         S[        S5      S'   S S S 5        [        5       [        / 5      s=:X  a  [        SS/ 5      :X  d   e   e[        / /5      [        SS/ 5      :X  d   e[        / / /5      [        S	S/ 5      :X  d   e[	        5          [        S/S
//5      R                  5       S/S
//:X  d   e S S S 5        [	        5          [        S/S
//5      R                  R                  5       S//S
//:X  d   e S S S 5        [        S//5      n [	        5          [        R                  U S'   S S S 5        [        [        S/SS//5      nUnUR                  UR                  :X  d   eUR                  S	:X  d   eUS S  [        SSS/:X  d   e[        S	S	[        SSS/5      nUnUR                  UR                  :X  d   eUR                  S	:X  d   eUS S  [        SSS/:X  d   eX:X  d   e[        U5      U:X  d   e[        S	S[        SS5      5      n[        SS[        SS5      5      n[        XE/5      nUR                  S:X  d   eUR                  S:X  d   eUS S  / SQ:X  d   e[        [        S	5      5      [        S	5      :X  d   e[        [        [        S	5      5      5      [        [        S	5      5      :X  d   e[        U5      UR                  " 5       :X  d   e[        [        U5      5      [        U5      R!                  5       :X  d   eU[        U5      Ld   e[#        SS	5      [#        SS5      S	-  /[#        S	S5      S-  [#        S	S	5      S-  //n[        U5      n U [        / SQ/ SQ/ SQ/ SQ/ SQ/5      :X  d   eU R                  5       U:w  d   e[        USS9R                  5       U:X  d   e[%        SS	S	5      n[#        S	5      U/n[        U5      [        SS/SS/US   US   /US   US   //5      :X  d   e[	        5          [        USS9R                  5       U V	s/ s H  o/PM     sn	:X  d   e S S S 5        [        [#        S	5      [#        S5      /5      [        [#        S	5      /5      :X  d   e[        [        S 5        [        [        S 5        [        SS	/SS//5      n [        U S/5      n
U
[        SS	/SS/SS//5      :X  d   eg ! , (       d  f       GN= f! , (       d  f       GN@= f! , (       d  f       GN= f! , (       d  f       GN= fs  sn	f ! , (       d  f       N= f)Nc                  .    [        SS[        S5      5      $ )Nr      )r5   r   rn   ru   rv   r   test_creation.<locals>.<lambda>  s    vaE"I6ru   c                      [        SS/ 5      $ )Nr   r  r   rn   ru   rv   r   r    s    vaR0ru   c                      [        S5      S   $ r   r   rn   ru   rv   r   r    s    vf~a0ru   r   r   r   r   r   r   )r   r   r   r   	r   r   r   r   r   r   r   r   r   r   )r   r   r   r   r   )r   r   r   r   r   Fevaluater   r   r   r   c                  B    [        [        S5      [        SS5      /5      $ )Nr   r   r   r5   r<   rn   ru   rv   r   r  4      vtAwQ
&;<ru   c                  B    [        [        S5      [        SS5      /5      $ )Nr   r   r   r  rn   ru   rv   r   r  5  r  ru   )r   r   r   )rR   r/  
IndexErrorr5   rW   tolistTr   EmptySetrc   r   r   r   r9   r3   as_immutable
as_mutabler<   rE   )r   r_   r   r`   c23c13ra   datr   r   M2s              rv   test_creationr    s   
:67
:01
:01	
	vq 
 8vbz5VAq"%5555552$<6!Q++++2r(vaB//// 
 	!T{m$++-A3+>>> 
"		!T{m$&&--/aSED6?BBB 
"uA		!**$ 
" 	AA A	A66QVV66Q;;Q4Aq!Q<q!aAq\"A	A66QVV66Q;;Q4Aq!Q<6M6!9>>
AuQ{
#C
AuQ|
$CzA66Q;;66Q;;Q4....#a&>SV###?3q623s1v7NNNN1!1111/!$%);)F)F)HHHHF1I1ItAay{#d1Qik4!9Q;%?
@CsA     88:#&--/3666S!QA7A,C#;&AAtWagtWag	"    
 
 	!cE*113S7ISS7IIII 
" 47DG$%a	)::::
:<=
:<= 	AA A	F	B!Q!Q!Q01111W 
	 
"	!	!	! 
"	!h 8J 
"	!sN   T(T/3UUU*-U%9U*
T,/
T>
U
U"%U**
U8c                  $   [         R                  " S[        SS5      [        SS5      S-  [        SS5      S-  [        SS5      S-  [        SS5      S-  [        SS5      S-  [        SS5      S-  5      [        / SQ/ SQ/ S	Q/ S
Q/5      :X  d   eg )Nr   r   r   r   r   r   r   )r   r   r   r   r   r   )r   r   r   r   r   r   )r   r   r   r   r   r   )r5   	irregularr<   rn   ru   rv   test_irregular_blockr  =  s    AtAay$q)A+tAay{Qq	!T!AYq[$q)A+tAay{<?E	G @  ru   c                  4   [         R                  [         R                  [        [        -  [         R
                  /[        [        [        [        S-  /[        [         R                  * [        [        -  S//n [        U 5      nUR                  5       U :X  d   eg )Nr   r   )	r   Oner,  rc   rd   Zerore   r5   r  )lstr   s     rv   test_tolistr  F  sc    EE1661Q3'!Q1a41quufac1:M
NCsA88:ru   c                  $   [        SS5      R                  5       [        SS5      :X  d   e[        SS5      R                  5       [        [        SS5      5      :X  d   e[        SS5      R                  5       [        [        SS5      5      :X  d   eg Nr   r   )rB   r  r  r3   rn   ru   rv   test_as_mutabler  L  su    A;!!#uQ{222A;##%q!)EEEEA;##%q!)EEEEru   c                     [        S5      n U S S2S S24   [        S5      :X  d   eU SS2SS24   [        S5      :X  d   e[        SSS 5      nUSS S 24   [        SSS5      :X  d   eUSS2S4   [        SSS5      :X  d   e[        / S	Q/ S
Q/ SQ/ SQ/5      nUS S 2S4   [        SS/ SQ5      :X  d   eUSS 2S S 24   [        / SQ/ SQ/5      :X  d   eg )Nr   r   r   r   c                 
    X-   $ r}   rn   r   s     rv   r   test_slicing.<locals>.<lambda>W      15ru   r   r   r   r   )r   r   r   r   r   r   r   r   r   r   r      r         r   r  )r   r   r  r   r"  )r9   rB   r5   )m0m1m2s      rv   test_slicingr  R  s    	QBbqb"1"f:Qac1Q3h<58###	1(	)Bad8vaI....ac1f:1f----	|^=MN	OBae9q!^4444bc1f:1A BCCCCru   c                     [        S5      n [        S5      U SS2SS24'   U [        S5      :X  d   e[        S5      U S S2S S24'   U [        S5      :X  d   e[        SSS5      U S S 2S4'   U [        S5      :X  d   e[        S5      U S S 2S S 24'   U [        S5      :X  d   e/ SQU S S 2S S 24'   U [        S5      :X  d   eSS/U S S2S4'   U [        S	5      :X  d   eg )
Nr   r   )r   r   r   r   r  r   r  r   r   r   r   r   r   )r   r   r   r   )r   r   r   r   )r   r   r   r   )r   r   r   r   r  r   r   r   r   r   r   r  r   r  r  r   r   ))r   r   r   r   )r   r   r   r   r  r  )rB   r9   r5   r  s    rv   test_submatrix_assignmentr  `  s$   aAa&Aac1Q3hK & ' ' ' ' AAbqb"1"fIA;;Q<(AadG & ' ' ' ' AhAadGa==MAadG * + + + + 1vAbqb!eH * + + + +ru   c                  j  ^  [        SSS 5      m T R                  / SQSS/5      [        SS/ SQ5      :X  d   eT R                  SS// S	Q5      [        SS/ S
Q5      :X  d   eT R                  [        S5      [        S5      5      T :X  d   e[        [        U 4S j5        [        [        U 4S j5        g )Nr   r   c                     U S-  U-   $ Nr   rn   r   s     rv   r   test_extract.<locals>.<lambda>}  s    !A#'ru   )r   r   r   r   r   r   )r   r   r   r   r   r   r(  )r   r   r   r   r   r  c                  ,   > T R                  S/S/5      $ )Nr   r   r   r  s   rv   r   r        qyy!qc2ru   c                  ,   > T R                  S/S/5      $ r  r  r  s   rv   r   r    r  ru   )r5   r   r   rR   r  r  s   @rv   test_extractr  |  s    q!)*A99YA'6!Q8K+LLLL99aVY'6!Q8K+LLLL99U1XuQx(A---
:23
:23ru   c                      [        S5      n U R                  SS5      [        SSS5      :X  d   e[        SSS 5      nUR                  SS5      [        S5      :X  d   eUR                  SS	5      [        S
5      :X  d   eg )Nr   r   r   )	r   r   r   r   r   r   r   r   r   r   c                 
    X-   $ r}   rn   r   s     rv   r   test_reshape.<locals>.<lambda>  r  ru   )r   r   r   r   )r   r   r   r   r   r   ))r   r   r   r   r   r   )r   r   r   r   r   r   )r9   reshaper5   r  r  s     rv   test_reshaper     s    	QB::ava,GHHHH	1(	)B::	1DEF F F::av&NOOOOru   c                      [        S5      n U R                  S 5      [        S5      S-  :X  d   eU R                  S 5      [        S5      :X  d   eg )Nr   c                     SU -  $ Nr   rn   rc   s    rv   r    test_applyfunc.<locals>.<lambda>  s    !A#ru   r   c                     gr   rn   r  s    rv   r   r    s    !ru   )r9   	applyfuncrB   )r  s    rv   test_applyfuncr    sE    	QB<<&#a&(222<<$a000ru   c            	         [        [        [        [        -   -  S/[        [        -   [        -  [        -  [        [        [        [        [        -   -  -   -  //5      n U R                  5       nU[        [        [        -  [        S-  -   S/[        [        S-  -  [        [        S-  -  -   [        [        -  [        [        S-  -  -   [        S-  -   //5      :X  d   e[	        SSS9n[        [        [        U-  5      /5      R                  SS9[        [        U5      [        [        U5      -  -   /5      :X  d   e[        / SQ/ SQ/ S	Q/5      R                  5       [        S
S
[        SS5      // SQ/ SQ/5      :X  d   eg )Nr   r   r_   Treal)complexr   )r   r   r  r   r   )r   r   r  r  )
r5   rc   rd   r   r   r   r
   r   r   r   )r  r  r_   s      rv   test_expandr    sW   	!QU)QAE19a-A1q5	M1B!CD	EB	B
A#1*a1QT6AadF?AaC!AqD&L1a4,?@AC C C C 	sA3qs8*$$T$2A3q6!"#$ $ $ 9j)4599;v	
Ax1~G @   ru   c            	      :   [        [        [        5      S-  [        [        S-  5      /[        [        S-  5      [        [        5      S-  -  [        [        S-  5      [        [        5      S-  -  //5      n U R                  [        R                  " [        5      [        R                  " [        5      -  5      nU[        [        S-  [        [        5      /[        S-  [        [        5      -  [        S-  [        [        5      -  //5      :X  d   eU R                  [        R                  " [        5      [        R                  " [        5      -  5      nU[        [        S-  [        /[        [        S-  -  [        S-  [        -  //5      :X  d   eU R                  [        R                  " [        5      [        R                  " [        5      -  5      nU[        [        S-  [        * /[        * [        S-  -  [        S-  * [        -  //5      :X  d   eg r  )
r5   r   rc   r   rd   refinerY   r  r&  r  r  s     rv   test_refiner    st   	#a&!)T!Q$Z(adCFAI%tAqDz#a&!)';<> 
?B	166!9qvvay(	)B!Q$A!Q$s1v+q!tCF{)CDEEEE	1::a=1::a=0	1B!Q$Qq!tVQT!V$456666	1::a=1::a=0	1B!Q$qbAg1uQw%789999ru   c            	      j   [        SS5      n [        SSSS9n U [        SSSS9:X  d   e[        SSSS5      n [        SSSS9n U [        SSSS9:X  d   eU R                  5       nUR                  " 5         X:X  d   e[        R                  " S5      nU [        SSUS9:X  d   eS	 H(  nS
 H  n[        USXBS9n X R
                  :X  a  M   e   M*     [        SSSS9n Sn[        U R                  S   5       H3  n[        U R                  S   5       H  nXU4   S:X  d  M  US-  nM     M5     US:X  d   eg )Nr   )seedr   r      T)r  	symmetric)r  prng)r   r  )r   F      )r  percentr  r   r   r  )minr  r  )r=   copyr)   randomRandomr  r   r   )r   r   rngsizer  
zero_countr   r   s           rv   test_randomr     sD   1aA1aa A
1aa((((1aC A11-A
115555	AJJL6M6
--
C
137777 $G44KA8O8 % 
 	21b)AJ1771:qwwqz"AAw!|a
 #  ru   c                    ^^ [        S5      n U R                  5       [        S5      :X  d   eU R                  SS9[        S5      :X  d   eU R                  SS9[        S5      :X  d   eU R                  SS9[        S5      :X  d   eU R                  SS9[        S5      :X  d   eU R                  SS9[        S5      :X  d   e[        / SQ/ S	Q/ S
Q/5      n U R                  5       nX-  [        S5      :X  d   eU R                  SS9U:X  d   eU R                  SS9U:X  d   eU R                  SS9U:X  d   eU R                  SS9U:X  d   eU R                  SS9U:X  d   e[        / SQ/ SQ/ SQ/ SQ/ SQ/ SQ/ SQ/ SQ/ SQ/ SQ/ SQ/ SQ/ SQ/ SQ/ SQ/ SQ/ SQ/ SQ/ SQ/ SQ/ S Q/ S!Q/ S"Q/ S#Q/ S$Q/5      nUR                  S%S9U-  [        UR                  S&   5      :X  d   e[        mT" / S'Q/ S(Q/ S)Q/5      m[        UU4S* jS+R                  5        5       5      (       d   e[        mT" / S'Q/ S(Q/ S)Q/5      m[        UU4S, jS+R                  5        5       5      (       d   eg )-Nr   r  r  r  r  r  QR)r   r   r   )r   r   r   )r   r   r   r   )r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   )r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   )r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   )r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   )r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   )r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   )r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   )r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   )r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   )r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   )r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   )r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   )r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   )r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   )r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   )r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   )r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   )r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   )r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   )r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   )r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   )r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   )r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   )r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   )r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   BLOCKr   )r   1      )r   rm   ^   );      A   c              3   \   >#    U  H!  n[        TR                  U5      5      TL v   M#     g 7fr}   r   r8  r   sr   r   s     rv   r   test_inverse.<locals>.<genexpr>  $     L.KtAEE!H~$.K   ),zGE ADJ LU CH LDL QRc              3   \   >#    U  H!  n[        TR                  U5      5      TL v   M#     g 7fr}   r+  r,  s     rv   r   r.    r/  r0  )r9   r8  r5   r   r3   r   splitr4   )r   AinvAAr   r   s      @@rv   test_inverser5    sq   AA557c!f555Q'''555#a&(((555Q'''555#a&(((555Q'''	 	A 557D6SV555%%%555$&&&555%%%555$&&&555%%%	\WWWWWWWWWWWWWWWWWWWWWWWW1Y 
ZB2 666!B&#bhhqk*::::
C\ 	A L.C.I.I.KLLLLL
C\ 	A L.C.I.I.KLLLLLru   c                     [        SS[        S-  [        -  S[        S-  -  [        [        -  -   /5      n [        [        /nU R                  U5      [        S[        -  [        -  [        S-  /[        S[        -  [        -   //5      :X  d   e[        SS[        [        S-  [        S-  -  /5      n U R                  U5      [        SS/S[        -  [        S-  -  [        S-  S-  [        S-  -  //5      :X  d   e[        S-  [        -  n[        [        /n[	        X!5      [        S[        -  S[        -  /S[        -  S//5      :X  d   e[        S-  [        S-  -  n[	        X!5      [        S[        S-  -  S[        -  [        S-  -  /S[        -  [        S-  -  S[        S-  -  [        -  //5      :X  d   e[
        [        [        S-  -  -   n[        S-  S[        S-  -  -   n[        SS[        -  /S[        -  S[        -  //5      nU[	        U[        [        [        /5      5      :X  d   eU[	        U[        [        [        /5      R                  5      :X  d   e[	        U[        [        4U/5      [        SS[        S-  -  S[        -  /S[        S-  -  S[        -  S[        -  /S[        -  S[        -  S//5      :X  d   eg )Nr   r   r   r   r   r   )r5   rc   rd   jacobianr:   re   r  )Lsymsfganss        rv   test_jacobian_hessianr=  
  s   q!ad1fa1fqsl+,Aq6D::dv!Aq!t}q!A#'l&CDDDDq!aAad^$A::dv1v!AqD!Q$q&A+/F&GHHHH	1QAq6D1v!QqSzAaC8&<====	1QT	A11a41QT"QqSAXqAvax$89:; ; ; 	
AadF
A	1qAvA
1!*Q3!* C'!VQF^,,,,'!VQF^--....1q!fqc"f1a41	
1a4AaC1aCAaC1. '       ru   c                     [        [        [        5      [        [        5      /[        5      [        [        5      S-  [        [        5      S-  -   :X  d   e[        [	        [        5      [	        S[        -  5      /[        5      [	        S[        -  5      :X  d   e[        [	        [        5      [        /[        5      [	        [        5      [        [	        [        5      -  -
  :X  d   e[        S[        [        S-  /[        5      S:X  d   eS[	        [        5      -  [        [        5      -  [        -  S[        [        5      -  [	        [        5      -  [        S-  -  -   S[	        [        5      -  [        [        5      -  [        -  -
  [	        [        5      [        [        5      -  [        S-  -  -
  [	        [        5      [        [        5      -  [        S-  -  -   n [        [	        [        5      [        [        5      [        S-  /[        5      R                  5       U :X  d   e[        [	        [        5      [        [        5      [        S-  /[        SS9R                  5       U :X  d   e[        S-  * [        [        5      S-  -  [        S-  [        [        5      S-  -  -
  S[        -  [        [        5      S-  -  -
  S[        -  [        [        5      S-  -  -
  n[        [        [        5      [        [        5      [        S-  /[        5      R                  5       U:X  d   e[        [        [        5      [        [        5      [        S-  /[        SS9R                  5       U:X  d   e[        / [        5      S:X  d   eg )Nr   r   r   rF  r   rW  r  )rA   r   rc   r   r   r   )w1w2s     rv   test_wronskianrA  &  s   c!fc!f%q)SVQYQ-BBBBc!fc!A#h'+s1Q3x777c!fa[!$A3q6(9999aAqD\1%***	CF3q6	!	aAhs1voad2	2Qs1vXc!f_Q5F	FAs1vad
 VCF]1a4/
0Bc!fc!fad+Q/668B>>>c!fc!fad+Q{CJJL  
Q$s1vqy1a4A	>	)AaCA	M	9AaCA	M	IBc!fc!fad+Q/668B>>>c!fc!fad+Q{CJJL  Rq   ru   c                     [        S[        /[        S//5      R                  [        S5      [        SS/SS//5      :X  d   e[        [        S/[        [        -   S//5      R                  [        S/[        S//5      [        SS/SS//5      :X  d   e[        [        S/[        [        -   S//5      R                  [        S4[        S4/5      [        SS/SS//5      :X  d   e[        [        S/[        [        -   S//5      R                  [        S[        S05      [        SS/SS//5      :X  d   e[        [        [        -  /5      R                  [        [        S-
  [        [        S-
  0SS	9[        [        S-
  [        S-
  -  /5      :X  d   e[         H9  n [        SS
/S
S//5      U R                  S5      R                  SS5      :X  a  M9   e   g )Nr   r   r   r   r  r"  r   T)simultaneousr   )r5   rc   r#  rd   r   r9   r   s    rv   	test_subsrE  7  s   Aq6Aq6"#((A.&1a&1a&9I2JJJJAq6AE1:&',,q"g2w-?@Q"a!"# # #Aq6AE1:&',,q"g2w-?@Q"a!"# # #Aq6AE1:&',,aQ^<Q"a!"# # #1Q3%=q!a%AE2FQQ !" " " 1v1v&'3771:??1a+@@@@ ru   c                     [        S[        /[        S//5      R                  [        S05      [        SS/SS//5      :X  d   e[        [        S/[        [        -   S//5      R                  [        S[        S05      [        SS/SS//5      :X  d   e[         H:  n [        SS/SS//5      U R                  S5      R                  SS05      :X  a  M:   e   g )	Nr   r   r   r   r  r"  r   r   )r5   rc   xreplacerd   r   r9   rD  s    rv   test_xreplacerH  E  s    Aq6Aq6"#,,aV4AA ! ! !Aq6AE1:&'00!RB@Q"a!"# # #1v1v&'3771:+>+>1v+FFFF ru   c                  
   [        S5      n [        S5      n[        S[        -  S[        -  -   [        [        [        -  -   [        -  /U" [        5      [        U" [        5      -  -   U" [        5      -  SSU -  [        U [        -  5      U -  -
  -  [        -  //5      nUR                  5         U[        [        [        -   [        [        -  -  S[        -   /S[        -   SSS[        [        U -  5      -  -
  [        U -  -  -  //5      :X  d   eS[        -   S-  n[        U//5      nUR                  5         U[        U//5      :X  d   eUR                  [        S9  U[        UR                  [        S9//5      :X  d   eg )Nr   r:  r   r   )ratio)	r   r   r5   rc   rd   r   r   r)   r   )r   r:  r   eqs       rv   test_simplifyrL  M  s\   sAAQqS1Q3YQqSAHQ4!AaD&=!A$&QqS3q2v;q=-@(AB(FHJ 	KAJJL1q51q5/!a%I$%E1q1SAY;A.F+GIK L L L L
a%!BvAJJLvJJRJ2./01111ru   c                     [        / SQ/ SQ/5      n U R                  [        SS/SS/SS/SS/SS/SS/SS/S	S	/S
S
/SS//
5      :X  d   eU R                  R                  U :X  d   eU R                  U R                  5       :X  d   eg )N)
r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   )r5   r  r   r3  s    rv   test_transposerN  ^  s    ..0 	1A33&QFFFFFFFFFF	% 	& 	& 	& 	& 3355A::33!++-ru   c                     [        S[        S// SQ/5      n U R                  [        SS/[        S/SS//5      :X  d   eU R                  [        S[        * S// SQ/5      :X  d   eU R                  U R	                  5       :X  d   eU R
                  U R                  R                  :X  d   eU R
                  [        SS/[        * S/SS//5      :X  d   eg )Nr   r   )r   r   r   r   r   )r5   r
   r  r   	conjugateHr3  s    rv   test_conjugaterR  o  s    Aq	 	A 33&1a&a&a&" # # # # 33&1qb!*$& ' ' ' '33!++-33!##%%<<33&Aq'2q'q'# $ $ $ $ru   c            
      $   [        [        S 5        [        S[        [        [        /SS[        [        /SSS[        // SQ/5      n U R                  [        / SQ[        * SSS/[        * [        * SS/[        * [        * [        S//5      :X  d   eg )Nc                  ,    [        S5      R                  $ r  )r9   Drn   ru   rv   r   !test_conj_dirac.<locals>.<lambda>  s    3q688ru   r   r   r  r  r  )rR   AttributeErrorr5   r
   rU  r3  s    rv   test_conj_diracrX    s    
>+,Aq!Aq!Aq! 	A
 33&*2A*2r2*2rAr*, - - - -ru   c                  X    [        / SQ/ SQ/ SQ/5      n U R                  5       S:X  d   eg )Nr   r   r   r   r   r   )r   r   r   r  r5   tracer3  s    rv   
test_tracer^    s-    	 	A 779??ru   c                  ^    [        [        SS/S[        S//5      n U R                  S:X  d   eg )Nr   r  )r5   rc   rd   r   r3  s    rv   
test_shaper`    s4    Aq	Aq	 	A77fru   c                     [        [        SS/S[        S//5      n U R                  SS 5        U [        [        SS/S[        S-   S//5      :X  d   eU R	                  SS 5        U [        [        S-   SS/S[        -   [        S-   S//5      :X  d   eU R                  S5      [        [        S-   SS//5      :X  d   eU R                  S5      nSUS'   U S   [        S-   :X  d   eU SS S	24   nSUS'   U S   [        S-   :X  d   eU R                  S5      nU[        [        S-   S[        -   /5      :X  d   eSUS'   U S   [        S-   :X  d   eU S S 2S4   nSUS'   U S   [        S-   :X  d   eg )
Nr   r   c                     X-   S-   $ Nr   rn   )rr   s     rv   r   !test_col_row_op.<locals>.<lambda>  s
    QUQYru   r   r   c                     U [         U-  -   $ r}   )rd   )ra   r   s     rv   r   re    s    QAXru   *   r   r  )r5   rc   rd   row_opcol_oprowcol)r   r1c1s      rv   test_col_row_oprn    s   Aq	Aq	 	AHHQ&'1AE1' ( ( ( ( HHQ%&QAq)QAq)+ , , , ,
 558vAq!}o....	
qBBqET7a!e	
1crc6BBqET7a!e	
qBQA''''BqET7a!e	
1a4BBqET7a!eru   c                      [        / SQ/ SQ/5      n U R                  SS5        U S   S:X  d   eU S   S:X  d   eU S   S	:X  d   eg )
Nr   r   r   r   r   r   r   r   r   r   r   )r5   row_multr3  s    rv   test_row_multrr    sS     	AJJqOS6R<<S6Q;;S6R<<ru   c                      [        / SQ/ SQ/ SQ/5      n U R                  SSS5        U S   S:X  d   eU S	   S
:X  d   eU S   S:X  d   eg )Nr   rp  r   r   r   r   r   r   r   r   r   r   r   r   r   )r5   row_addr3  s    rv   test_row_addrw    s[     	A IIa!S6Q;;S6Q;;S6Q;;ru   c                  $   [         S S  H  n U R                  S5      nUR                  SSS 5        X" / SQ/ SQ/ SQ/5      :X  d   eU R                  S5      S-  nS	US
'   UR                  SSS 5        U  X" / SQ/ SQ/ SQ/5      :X  a  M   e   g )Nr   r   r   r   c                     U SU-  -   $ r  rn   r   us     rv   r   !test_zip_row_op.<locals>.<lambda>      AaCru   rZ  r   r   r   r  r  r   c                     U SU-  -   $ r  rn   rz  s     rv   r   r|    r}  ru   )r   r  r   )r   r   r   r(  )r   r9   
zip_row_op)r   r   s     rv   test_zip_row_opr    s    r{GGAJ	Q/0C""$ % % 	% % GGAJqL$	Q/0!C##% & & 	& & ru   c                      [        / SQ5      n [        / SQ5      n[        / SQ5      nU S;  d   eU S;  d   eU S:w  d   eX:X  d   eX:w  d   eg )Nr   )r   r   r   rn   )r   r   r   )r   r_   r`   s      rv   test_issue_3950r    sU    yAyAyARS6M66M66M6ru   c                  h    " S S5      n  " S S5      nU " 5       nU" 5       n[        / SQ5      nXC   S:X  d   eSXC'   US   S:X  d   e[        / SQ/ S	Q/5      nXBU4   S
:X  d   eUSU4   S
:X  d   eXBS4   S
:X  d   eSXBU4'   US   S:X  d   eS
USU4'   US   S
:X  d   eSXBS4'   US   S:X  d   eg )Nc                       \ rS rSrS rSrg)test_issue_3981.<locals>.Index1i  c                     grc  rn   selfs    rv   	__index__)test_issue_3981.<locals>.Index1.__index__      ru   rn   Nrp   rq   rr   rs   r  rt   rn   ru   rv   Index1r        	ru   r  c                       \ rS rSrS rSrg)test_issue_3981.<locals>.Index2i  c                     gr  rn   r  s    rv   r  )test_issue_3981.<locals>.Index2.__index__  r  ru   rn   Nr  rn   ru   rv   Index2r    r  ru   r  r   r   r   r   rp  r   r   r   r   r   r   )r  r  index1index2r   s        rv   test_issue_3981r    s       XFXFyA9>>AIQ4199	9%&AV^!!!QY<1QY<1AfnT7a<<AaiLT7a<<AaiLT7a<<ru   c                    ^  [        [        S5      S/5      m [        U 4S j[        S5       5       5      (       d   e[        U 4S j[        S5       5       5      (       d   e[        U 4S j[        S5       5       5      (       d   eg )Nr   r   c              3   t   >#    U  H-  nTR                   " 5       U   TU   R                  5       :H  v   M/     g 7fr}   evalfr   r   r_   s     rv   r   test_evalf.<locals>.<genexpr>  s*     >Xqwwy|qtzz|+Xs   58r   c              3   x   >#    U  H/  nTR                   " S 5      U   TU   R                  S 5      :H  v   M1     g7fr   Nr  r  s     rv   r   r    s.     @x!qwwqz!}!

1-x   7:c              3   x   >#    U  H/  nTR                   " S 5      U   TU   R                  S 5      :H  v   M1     g7fr  r   r  s     rv   r   r  	  s.     8x!qss1vayAaDFF1I%xr  )r5   r   r   r   r_   s   @rv   
test_evalfr    sf    Q|A>U1X>>>>>@uQx@@@@@8uQx88888ru   c                  X   [        [        [        /[        [        //5      n U R                  " 5       SL d   e[        / SQ/ SQ/5      n U R                  " 5       SL d   e[        / SQSS[        S//5      n U R                  " 5       SL d   e[        S[        S	//5      n U R                  " 5       SL d   e[        / S
Q/5      n U R                  " 5       SL d   e[        S/[        /S	//5      n U R                  " 5       SL d   e[        S/S/S	//5      n U R                  " 5       SL d   eg )NTr  r  Fr   r   r   r   r   r   r   )r5   rc   is_symbolicr  s    rv   test_is_symbolicr    s   AA A==?d"""l+,A==?e###q!Ql+,A==?d"""Aq	{A==?d"""	{A==?e###aS1#A==?d"""aS1#A==?e###ru   c                      [        / SQ/5      n U R                  SL d   e[        S/S/S//5      n U R                  SL d   e[        SS5      n U R                  SL d   eg )Nr   Tr   r   r   Fr   )r5   is_upperrB   r  s    rv   test_is_upperr    se    	{A::aS1#A::aA::ru   c                      [        / SQ/5      n U R                  SL d   e[        S/S/S//5      n U R                  SL d   eg )Nr   Fr   r   r   T)r5   is_lowerr  s    rv   test_is_lowerr  &  sH    	{A::aS1#A::ru   c                      [        SS/ SQ5      n U R                  " 5       (       d   e[        SS/SS//5      n U R                  " 5       (       a   e[        / 5      n U R                  " 5       (       d   eg )Nr   )r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r5   r  r  s    rv   test_is_nilpotentr  -  sj    q!EFA>>AA A~~r
A>>ru   c                     Su  p[        X5      nUR                  " S5        S[        X5      -  nX#:X  d   eUR                  UR                  s=:X  a  S:X  d   e   eUR                  UR                  s=:X  a  S:X  d   e   eUR
                  UR
                  s=:X  a  S:X  d   e   e[        S5      [        SS5      :X  d   e[        S5      [        SS5      :X  d   e[        SS5      [        SSS/S-  5      :X  d   e[        SS5      [        SSS/S-  5      :X  d   eUR                  " S5        U[        X5      :X  d   eg )N)r   r   r   r   r   r   r   r   )rB   fillr<   r   r   r   r5   )r   r   r_   r`   s       rv   test_zeros_ones_fillr  6  s)   DAaAFFAK	DJA6M666QVV q     66QVV q     77agg''''''8uQ{"""7d1aj   A;&As1u----1:1qc!e,,,,FF1Iaru   c                      [        S5      n U [        5       :X  d   e[        SS5      n U R                  S:X  d   eU R                  S:X  d   e[        SS5      n U R                  S:X  d   eU R                  S:X  d   eg )Nr   r   )rB   r5   r   r   r  s    rv   test_empty_zerosr  K  so    aA==aA66Q;;66Q;;aA66Q;;66Q;;ru   c                     [        [        S-  [        [        -  /[        [        [        5      -  [        [	        [        5      -  //5      n U R
                  " [        5      [        S[        -  [        /[        [        5      [	        [        5      //5      :X  d   e[        [        [        * [        S-  /[        [        5      S[        -  [        [        * 5      -
  [        S[        -  -   //5      R                  [        [        5      [        [        [        * [        /[        S[        //5      :X  d   e[        [        [        5      S-
  [        -  S[        -  [        [        -  -   [        [        -  /S[        -  [        [        5      [        [        [        S-   5      5      //5      R                  [        S5      [        / SQ[        S[        S5      //5      :X  d   eU R                  " [        5      [        [        SS5      [        S-  -  [        [        S-  -  S-  /[        S-  [        [        5      -  S-  [        S-  [	        [        5      -  S-  //5      :X  d   eg )Nr   r   r   )r   r   r   r   )r5   rc   rd   r   r   r   r   limitr   r   r   r   r  s    rv   test_issue_3749r  V  s   AqsaAh#a&123A66!91a3q63q6*:;<<<<	
QB1	Q1sA2wAaC(* ++05B<bS"Ar{+,- - - 
a&1*a1qsAqD*	
1c!fc#a!e*o&( )).q!	B3q6?+,- - - ;;q>V	!Q1	a1fQh'	
Ac!fQ1SVA&%( ) ) ) )ru   c                      [        S5      n U R                  SS5        S H'  nU R                  US S9U R                  SS9:X  a  M'   e   g )	Nr   r   r   )r  r  c                     U S:H  $ r   rn   r  s    rv   r   %test_inv_iszerofunc.<locals>.<lambda>j  s    aru   )r  
iszerofuncr  r  )r9   col_swapr8  )r   r  s     rv   test_inv_iszerofuncr  f  sQ    AAJJq!uuF/?u@EEE  	    ru   c                  $   [        S5      u  p[        U [        U5      -  U [        U5      -  /5      n[        X/5      nUR	                  U5      nXBR	                  UR
                  5      :X  d   eXBR
                  R	                  U5      :X  d   eXBR
                  R	                  UR
                  5      :X  d   eUR
                  [        UR                  S   5      -  U-  nUR                  [        5      nU[        SS/SU S-  //5      :X  d   eg )Nrho,phir   r   r   )
r   r5   r   r   r7  r  r9   r   r  r*   )rhophiXYr;  r;  s         rv   test_jacobian_metricsr  n  s    y!HCCHc#c(l+,AzA	

1A

133q!!!!qss####	C
OAA	HAACF,----ru   c                  :   [        S5      u  p[        U [        U5      -  U [        U5      -  U S-  /5      n[        X/5      n[        [        U5      U * [        U5      -  /[        U5      U [        U5      -  /SU -  S//5      nUR	                  U5      U:X  d   eg )Nr  r   r   )r   r5   r   r   r7  )r  r  r  r  r;  s        rv   test_jacobian2r  {  s    y!HCCHc#c(lCF34AzA	SC4C=!	SCCL!cEq! 	A
 ::a=Aru   c                     [        [        [        [        -   [        -   5      [        [        [        -   [        -   5      [        [        [        -   [        -   5      /5      n [        [        [        [        /5      n[        SS5       H  n[        SS5       Ho  nU S U2S S 24   nUS U2S S 24   nUR                  U5      nUR                  U:X  d   eUR                  U:X  d   e[        U5       H  nUS S 2U4   U:X  a  M   e   Mq     M     g Nr   r   )	r5   r   rc   rd   re   r   r7  r   r   )r  r  r   r   X_sliceY_slicer;  r   s           rv   test_issue_4564r    s    AEAIAEAIAEAI?@A1ayA1a[q!AAhGAhG  )A66Q;;66Q;;1XAw')))   ru   c                    ^ ^ [        [        [        [        -   [        -   5      [        [        [        -   [        -   5      /[        [        [        -   [        -   5      [        [        [        -   [        -   5      //5      m [        [        U 4S j5        T SS S 24   m [        [        [        /[        [        //5      m[        [        U U4S j5        [        [        U 4S j5        g )Nc                  V   > T R                  [        [        [        [        /5      5      $ r}   r7  r5   rc   rd   re   r  s   rv   r   (test_nonvectorJacobian.<locals>.<lambda>  s    ajjAq	):;ru   r   c                  &   > T R                  T5      $ r}   )r7  r  r  s   rv   r   r    s    ajjmru   c                  d   > T R                  [        [        [        /[        [        //5      5      $ r}   r  r  s   rv   r   r    s     ajj1a&1a&0B)CDru   )r5   r   rc   rd   re   rR   	TypeErrorr  s   @@rv   test_nonvectorJacobianr    s    QUQYQUQY0QUQYQUQY02 	3A
9;<	!Q$AAA A
9+,
9DEru   c                      [        SS/SS//5      n U R                  5       nUR                  S:X  d   e[        S5       H  nX   US-   :X  a  M   e   g Nr   r   r   r   )r5   vecr   r   )r   m_vecr   s      rv   test_vecr    sV    AA AEEGE::??1Xx1q5    ru   c                     [        SS/SS//5      n U R                  5       nUR                  S:X  d   e[        S5       H  nX   US-   :X  a  M   e   U R                  SS9nUS   S:X  d   e[        S[        [        [
        -   -  /[
        [        -  [        S-  -   S//5      n U R                  SS9nUS   [
        [        -  [        S-  -   :X  d   e[        S[        [        [
        -   -  /[
        [        -  S//5      n U R                  SSS9nUS   [
        [        -  :X  d   e[        [        S 5        [        [        S	 5        [        [        S
 5        [        [        S 5        g )Nr   r   r   F)diagonalr   )r  check_symmetryc                  :    [        SS//5      R                  5       $ r  r5   vechrn   ru   rv   r   test_vech.<locals>.<lambda>      v1vh/446ru   c                  @    [        SS/SS//5      R                  5       $ r  r  rn   ru   rv   r   r        v1v1v&67<<>ru   c                  :    [        SS//5      R                  5       $ r  r  rn   ru   rv   r   r    r  ru   c                  @    [        SS/SS//5      R                  5       $ r  r  rn   ru   rv   r   r    r  ru   )	r5   r  r   r   rc   rd   rR   r+   r/  )r   m_vechr   s      rv   	test_vechr    sH   AA AVVXF;;!1XyAE!!! VVUV#F!9>>Aq1uI1q!tQ01AVVUV#F!9!ad
"""Aq1uI1a)*AVVU5V9F!9!
:67
:>?
:67
:>?ru   c                     ^  [        / SQ5      [        / SQ5      :X  d   eSSS//m [        [        U 4S j5        [        T SS9[        / SQ5      :X  d   eg )Nr   r   r   r   c                     > [        T 5      $ r}   )r8   r  s   rv   r   test_diag.<locals>.<lambda>  s	    tAwru   F)strict)r8   r5   rR   r/  r  s   @rv   	test_diagr    sK    	?fY////	
AsA
:'% F9$5555ru   c                  F   [        SS/SS//5      n [        S[        /[        S//5      n[        S[        S/[        S[        /[        [        [        //5      nU R                  " 5       U /:X  d   eUR                  " 5       U/:X  d   eUR                  " 5       U/:X  d   eg Nr   r   r   )r5   rc   rd   re   get_diag_blocksr_   r`   ra   s      rv   test_get_diag_blocks1r    s    AA AAA AAq	Aq!9q!Qi01A1#%%%1#%%%1#%%%ru   c                     [        SS/SS//5      n [        S[        /[        S//5      n[        S[        S/[        S[        /[        [        [        //5      n[	        XU5      R                  5       XU/:X  d   e[	        XU5      R                  5       XU/:X  d   e[	        XU5      R                  5       XU/:X  d   e[	        X"U5      R                  5       X"U/:X  d   eg r  )r5   rc   rd   re   r8   r  r  s      rv   test_get_diag_blocks2r    s    AA AAA AAq	Aq!9q!Qi01Aa=((*qQi777a=((*qQi777a=((*qQi777a=((*qQi777ru   c                     [        SS/SS//5      n [        S[        /[        S//5      n[        S[        S/[        S[        /[        [        [        //5      n[	        XU5      nUR                  SS9[	        U R
                  " 5       UR
                  " 5       UR
                  " 5       5      :X  d   e[	        XU5      nUR                  SS9[	        U R
                  " 5       UR
                  " 5       UR
                  " 5       5      :X  d   e[	        XU5      nUR                  SS9[	        U R
                  " 5       UR
                  " 5       UR
                  " 5       5      :X  d   e[	        X XX 5      nUR                  SS9[	        U R
                  " 5       U R
                  " 5       UR
                  " 5       U R
                  " 5       UR
                  " 5       U R
                  " 5       5      :X  d   eUR                  SSS9[	        U R
                  " SS9U R
                  " SS9UR
                  " SS9U R
                  " SS9UR
                  " SS9U R
                  " SS95      :X  d   eg )	Nr   r   r   T)try_block_diagr  )r  r  r  )r5   rc   rd   re   r8   r8  )r_   r`   ra   r   s       rv   test_inv_blockr    s   AA AAA AAq	Aq!9q!Qi01AQ1A555%aeegquuw)HHHHQ1A555%aeegquuw)HHHHQ1A555%aeegquuw)HHHHQ1A555%	!%%'1557AEEGQUUW*> > > >55U53t	UQUU%0!%%u2E	UQUU%0!%%u2E8G G G Gru   c                  f   [        [        S 5        [        [        S 5        [        [	        S5      5      [        S5      :X  d   e[        [        S5      5      [        S5      :X  d   e[        [        S 5        [        [	        S5      5      [        S5      :X  d   e[        [        S5      5      [        S5      :X  d   e[        [        S 5        [        [	        S5      [        S5      5      [        SS5      :X  d   e[        [        S 5        [        [        S 5        [        [        S	 5        g
)z[
Check that matrix dimensions can be specified using any reasonable type
(see issue 4614).
c                      [        SS5      $ )Nr   r  rB   rn   ru   rv   r   $test_creation_args.<locals>.<lambda>  s
    uQ|ru   c                      [        SSSS5      $ Nr   r   r   r   r  rn   ru   rv   r   r    s    eAq!Q/ru   r   c                      [        S5      $ N      @r  rn   ru   rv   r   r    s    uRyru   c                      [        S5      $ r  r9   rn   ru   rv   r   r    s    s2wru   r   c                      [        S5      $ Nr   r   rn   ru   rv   r   r    s    fQiru   c                      [        SS5      $ r   r   rn   ru   rv   r   r    s
    fQlru   c                      [        SS//5      $ r   r   rn   ru   rv   r   r    s    vq1#h/ru   N)rR   r/  r  rB   r~   r   r9   r<   rn   ru   rv   test_creation_argsr    s    
 :+,
9/0Q=E!H$$$a(((
:()s1v;#a&   wqz?c!f$$$
:'A
#tAqz111
9'(
9*+
:/0ru   c                     [        SS/ SQ5      n U R                  5       (       a   eU R                  5       (       d   eU R                  SS9(       d   e[        SS/ SQ5      n U R                  5       (       d   e[        SSS5      n U R                  5       (       d   eU R                  5       (       d   e[        SS/ SQ5      n U [        SSS5      :X  d   e[        SS[	        SS5      5      n U R                  5       (       a   eU R                  5       (       d   e[        S	5      n U R                  5       (       d   e[        S
5      n U R                  5       (       d   e[        SSS[
        S-  S[
        -  -   S-   [        [
        S-   S-  SS[        SS/	5      n U R                  5       (       d   eU R                  SS9(       a   eU R                  5       R                  SS9(       d   eg )Nr   r   r   r   r   Fr)   r   r   r   r   r   r   )	r   r   r   r   r   r   r   r   r   ))r   r   r   r   )r   r   r   )r   r   r   r   )r5   is_diagonalis_symmetricr8   rB   rc   rd   r   r  s    rv   test_diagonal_symmetricalr    s   q!\"A}}>>>>5>)))q!\"A==???Q1A==???>>q!01AQ1q!U1a[!A~~==???'(A==???%&A==???q!aA!aQUQJ1aAFGA>>~~u~---88:""E"222ru   c                  x  ^ [        SS[        -   /S[        -
  S//5      mTR                  5       (       d   e[        SS/ SQ5      mTR                  5       (       a   eTR                  5       (       a   e[	        [
        U4S j5        [        SSS5      mTR                  5       u  pU [        S5      :X  d   eUT:X  d   e[        SS/ SQ5      mTR                  5       (       d   eTR                  5       (       d   eTR                  5       u  pU R                  5       T-  U -  U:X  d   e[        SS/ SQ5      mTR                  5       (       d   eTR                  5       (       d   eTR                  5       u  pU R                  5       T-  U -  U:X  d   eU [        S5      :X  d   eUT:X  d   e[        SS/ SQ5      mTR                  5       (       d   eTR                  5       u  pU R                  5       T-  U -  U:X  d   e[        SS/ S	Q5      mTR                  5       (       d   eTR                  5       u  pU R                  5       T-  U -  U:X  d   eU  H  nUR                  5       S   S:X  a  M   e   [        SS/ S
Q5      mTR                  5       (       d   eTR                  5       (       d   eTR                  5       u  pU R                  5       T-  U -  U:X  d   eU [        SS/SS//5      :X  d   e[        SS/ SQ5      mTR                  S5      (       a   e[	        [        U4S j5        TR                  5       (       d   eTR                  5       u  pU R                  5       T-  U -  U:X  d   e[        SS/ SQ5      mTR                  5       (       a   e[	        [        U4S j5        [        SS/ SQ5      mTR                  5       (       a   e[	        [        U4S j5        [        S5      u  p4pV[        SSX5XT/5      mTR                  5       (       d   eTR                  5       (       d   eg )Nr   r   r   r   r   r   r  r   r   c                  $   > T R                  5       $ r}   r  r  s   rv   r   &test_diagonalization.<locals>.<lambda>%      ru   r	  )r   r   r   r   r   r   r   r   )	r   r   r   r   r   r   r   r]  r   r  r   )r   r   r  r   Tc                  &   > T R                  S5      $ )NTr  r  s   rv   r   r  Q  s    d 3ru   r   c                  $   > T R                  5       $ r}   r  r  s   rv   r   r  Y      ru   )	r   r   r   r  r   r   r   r"  r   c                  $   > T R                  5       $ r}   r  r  s   rv   r   r  ]  r  ru   a b c d)r5   r
   r  r  rR   r-   r8   r  r9   r8  as_numer_denomr  r,   r   )r:  rU  r   r_   r`   ra   rb   r   s          @rv   test_diagonalizationr    s   AaC1Q3(#$A    q!+,A""$$$$~~
!89 	Q1A]]_FQA;;6M6q!\"A>>    ]]_FQ557Q;?aq!\"A>>    ]]_FQ557Q;?aA;;6M6q!\"A    ]]_FQ557Q;?aq!12A    ]]_FQ557Q;?a!!$)))  	q!\"A==???    ]]_FQ557Q;?aAA'(((( 	q!]#A""4((((
;34    ]]_FQ557Q;?a 	q!\"A""$$$$
;/0q!56A""$$$$
;/0 #JA!q!aA\"A>>    ru   c                     ^  [        SS/SS//5      m T R                  " 5       SL d   eST S'   T R                  " 5       SL d   e[        SS/SS//5      m T R                  " 5         ST S'   [        [        U 4S j5        g )Nr   r   Tr   Fc                  &   > T R                   " 5       $ r}   r  r  s   rv   r   "test_issue_15887.<locals>.<lambda>p  s    ru   )rC   r  r  rR   r,   r  s   @rv   test_issue_15887r!  f  s    QFQF+,A D(((AdG E)))QFQF+,AMMOAdG
;/0ru   c            	        ^ [        SS/ SQ5      m[        [        U4S j5        [        SS/ SQ5      m[        SS/ SQ5      n TR                  5       u  pX:X  d   eU TR	                  5       S   :X  d   e[        SS/ SQ5      m[        SS/ S	Q5      n TR                  5       u  pX:X  d   e[        SS/ S
Q5      m[        SS/ SQ5      n TR                  5       u  pX:X  d   e[        SS/ SQ5      m[        SS/ SQ5      n TR                  5       u  pX:X  d   e[        SS/ SQ5      m[        SS/ SQ5      n TR                  5       u  pX:X  d   e[        SS/ SQ5      m[        SS/ SQ5      n TR                  5       u  pX:X  d   e[        SS/ SQ5      mTR                  5       (       a   e[        SS/ SQ5      n TR                  5       u  pX:X  d   e[        [        SSS9[        SSS9/[        SSS9[        SSS9//5      mTR                  5       u  pUR                  5        H,  n[        U[        5      (       d  M  UR                  S:X  a  M,   e   g )Nr   r   r  c                  $   > T R                  5       $ r}   )r7  r  s   rv   r   "test_jordan_form.<locals>.<lambda>v  r  ru   )	r   r  r   r   ir   r   ir  )	r  r   r   r   r   r   r   r   r   r   	r   r   r   r]  r   r   r"  r   r   )	r   r   r   r   r   r   r   r   r   )	r   r   r   r   r^  r   r   rF  )	r  r   r   r   r  r   r   r   r  )	r   r^  r   r   r  r   r   r   )	r   r   r   r   r   r   r   r   r   r   )r   r   r"  r   r   r  r   r   r   r   r"  r   r  r   r   r   )r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   )r   r   rF  r   r   r   r   r   r"  r(  rF  r  r   r   r   )r"  r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   )r   r   r   r   r   r   r  r  r  r  r   r   r   r   r  r   )r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   z1.0n   )	precisionz2.0z3.14159265358979323846264338327z4.0)
r5   rR   r-   r7  r  r  r	   valuesr   _prec)Jmustr:  r;  termr   s       @rv   test_jordan_formr/  s  sV   q!+,A
!89 	q!:;A1a56E==?DA::AMMOA&&&& 	q!23A 1a45E==?DA:: 	q!45A 1a78E==?DA:: 	q!34A1a45E==?DA::q!LMA1a  E
 ==?DA::q!LMA 1a ' (E ==?DA::q!JKA""$$$$1aIJE==?DA:: 	u,eES.IJ8CH%PUadJefh 	iA==?DA
dE""::$$$ ru   c            	      b   [        / SQ/ SQ/ SQ/ SQ/5      n SS[        -  -
  nSS[        -  -   n[        USSS/SUSS/SSUS/SSSU//5      n[        USSS/SUSS/SSUS/SSSU//5      nU R                  5       u  pVXc:X  d  Xd:X  d   e[        XV-  UR	                  5       -  5      U :X  d   eg )	N)r   r   r   r   )r]  r   r   r   )r   r   r   r   )r   r   r]  r   r   r   r   r   )r5   r
   r7  r)   r8  )r   pqJmust1Jmust2r:  r;  s          rv   #test_jordan_form_complex_issue_9274r5    s        " 	#A 	
AaCA	AaCAaAq\Aq\Aq\Aq\# $F aAq\Aq\Aq\Aq\# $F ==?DA;!+%%ACK A%%%ru   c                      [        / SQ/ SQ/ SQ/ SQ/5      n U R                  5       u  pU[        / SQ/ SQ/ SQ/ SQ/5      :X  d   eU[        / S	Q/ SQ/ SQ/ SQ/5      :X  d   eg )
Nr  r	  )r   r   r   r   r  r   r   r   r   r  r   r   r  )r5   r7  r9  s      rv   test_issue_10220r8    s     	A ==?DA$$$& ' ' ' ' $$$$	& ' ' ' 'ru   c                     [        / SQ/ SQ/ SQ/ SQ/5      n U R                  5       u  pUR                  5       [        [        * [        * S-  [        [        S-  /S[        -   SS[        -
  S/S[	        S5      * S-  [        S-  -
  S[	        S5      * S-  [        S-  -   // S	Q/5      :X  d   eU[        [        * SSS/S[        * SS/SS[        S/SSS[        //5      :X  d   eg )
Nr  r"  r  r   r  r   r   r  r  r   r   r   r   r   r  r   r   r7  )r5   r7  r   r
   r   )r   r:  r;  s      rv   test_jordan_form_issue_15858r=    s    	 	A
 ]]_FQ88:R1"Q$Q!A#6	aQQA6!A$q1Q3Q1a!A#66	!8 9 9 9 9
 
Q1	
QB1	
Aq!	
Aq!	    ru   c                  <   [        S5      u  pn[        U* U -
  US-  X-   -  -   X-  X-   -  /X-  X-   -  U* US-  X-   -  -   //5      nUR                  [        5      nU[	        [        S-  X-  X -  -   SU-  U-  -   X-   -  [        -  -   X-  U -  X-   -  -   [        SS9:X  d   e[        U5      [        L d   e[        SS/SS//5      nUR                  5       UR                  [        5      s=:X  a!  [        [        S-  [        -
  S-
  5      :X  d   e   e[        SS/[        S//5      nUR                  [        5      nUR                  [        :w  d   eUR                  5       R                  UR                  [        5      [        S-  S[        -  -
  :X  d   eg )	Nz
UA K_i K_wr   zZZ(K_i,K_w,UA)rI  r   r   r   r   )
r   r5   rK  rc   r#   r   r$   genas_exprr#  )UAK_iK_wr   rK  r1  s         rv   test_Matrix_berkowitz_charpolyrD    s   <(LBS#S!VSY//sw	7JKGSY/#Q	8J1JKM 	NA zz!}HQTSVcf_quSy039=a??
CI !*:	<< < < >X%%%AA A::<1::a=BHQTAX\,BBBBBBAA A	

1A55A::99;AEE1%A!333ru   c            
         [        S5      n [        R                  " SU 5      nUR                  5       [        [	        U 5      //5      :X  d   e[        R                  " SU 5      nUR                  5       [        [	        U 5      [	        U 5      [	        U 5      S-  /S[	        U 5      [	        U 5      /SS[	        U 5      //5      :X  d   eg )Nlamdar   r   r   r   )r   r5   jordan_block_eval_matrix_exp_jblockr   lr   s     rv   test_exp_jordan_blockrK    s    wAAq!A$$&&3q6(*<<<<Aq!A$$&VSVSVAX&AA3q6N 	  ru   c            	         [        SS/SS//5      n [        [        S5      S[        S5      -  S-  S[        S5      -  S-  -   /S[        S5      //5      nU R                  5       U:X  d   e[        U 5      U:X  d   e[        SS/SS//5      n U R                  5       [        [        S/S[        //5      :X  d   e[        U 5      [        [        S/S[        //5      :X  d   e[        SS/SS//5      n U R                  5       [        [        [        S5      -  [        * [	        S5      -  /[        [	        S5      -  [        [        S5      -  //5      :X  d   eg )	Nr   r   r   r"  r]  r   r   r  )r5   r   r   r   r   )r   m_exps     rv   test_exprN    s<   AB !ASVRBZ\Ac!fHQJ67!SWFGE557eq6U??AA A557fq!fq!f-....q6VaVaV,----B!Q !A557fqQx!CF3aAh#a&5IJKKKKru   c                    ^ [        S5      n [        R                  " SU 5      mTR                  5       [        [	        U 5      //5      :X  d   e[        R                  " SU 5      mTR                  5       [        [	        U 5      SU -  SSU S-  -  -  SSU S-  -  -  /S[	        U 5      SU -  SSU S-  -  -  /SS[	        U 5      SU -  /SSS[	        U 5      //5      :X  d   e[        / SQ/ S	Q/ S
Q/5      m[        [        U4S j5        g )NrF  r   r   r  r   r   r   r  r   r   c                  $   > T R                  5       $ r}   )r   r  s   rv   r   test_log.<locals>.<lambda>=  s    ru   )r   r5   rG  _eval_matrix_log_jblockr   rR   r,   rI  s    @rv   test_logrS  '  s   wAAq!A$$&&3q6(*<<<<Aq!A$$&Q1b!AqD&k1a1f:6CFAaCQq!tV-As1vqs#Aq#a&!		

 
 
 				A
 ;(ru   c                  >   [        [        [        4S45      n U R                  [        5      (       d   eU R                  [        5      (       a   eU R                  [
        5      (       d   eU R                  [        S5      n U R                  [        5      (       a   eg )Nr  r   )r5   rc   rd   hasre   r   r#  r  s    rv   test_hasrV  @  sm    A A5588O8uuQxx<55===	q!AuuQxx<xru   c            	          [        S5      n [        SSU [        U 5      S-  [        U 5      S-  -   [        R
                  /5      n[        U5      u  p#pEU[        R
                  :X  d   eg )Nrc   r   r   r   )r   r5   r   r   r   r,  r0   rc   columnpivot_offset	pivot_valpivot_assumed_nonzero
simplifieds         rv   :test_find_reasonable_pivot_naive_finds_guaranteed_nonzero1r^  J  s_     	sAAq1c!fai#a&!)3QVV<=F$V, ?L2ru   c            
          [        S5      n [        SSU [        U 5      S-  [        U 5      S-  -   U S-  -   [        U 5      S-  [        U 5      S-  -   /5      n[	        U[
        S9u  p#pEUS:X  d   eg )Nrc   r   r   r   simpfunc)r   r5   r   r   r0   r1   rX  s         rv   :test_find_reasonable_pivot_naive_finds_guaranteed_nonzero2rb  V  s~     	sAAqVQYs1vqy(A-VQYs1vqy(*+F
 	%Vi@ ?L2>>ru   c            
      f   [        S5      n [        SSU [        U 5      S-  [        U 5      S-  -   U -   [        U 5      S-  [        U 5      S-  -   /5      n[	        U[
        S9u  p#pE[        U5      S:X  d   eUS   S   S:X  d   eUS   S   SU -   :X  d   eUS   S   S:X  d   eUS   S   S:X  d   eg )Nrc   r   r   r   r`  r   )r   r5   r   r   r0   r1   lenrX  s         rv   +test_find_reasonable_pivot_naive_simplifiesre  e  s     	sAAqVQYs1vqy(*VQYs1vqy(*+F
 	%Vi@ ?L2 z?aa=q   a=qs"""a=q   a=q   ru   c                  V  ^ ^ [        [        S 5        [        [        S 5        [        [        S 5        [        [        S 5        [        [        S 5        [        [        S 5        [        [        S 5        [        [
        S 5        [        [        S	 5        [        [        S
 5        [        [        S 5        [        [        S 5        [        [
        S 5        [        [        S 5        [        [        S 5        [        [        S 5        [        [        S 5        [        [        S 5        [        [        S 5        [        [        S 5        [        [        S 5        [        [        S 5        [        [
        S 5        [        [        S 5        [        [        S 5        [        [
        S 5        [        [        S 5        [        [
        S 5        [        [        S 5        [        [
        S 5        [        [
        S 5        [        [
        S  5        [        [        S! 5        [        [        S" 5        [        [        S# 5        [        [        S$ 5        [        [        S% 5        [        [        S& 5        [        [        S' 5        [        [        S( 5        [        S)5      m [        [        U 4S* j5        [        / S+Q/5      m[        / S,Q/ S-Q/ S.Q/5      m [        [        U U4S/ j5        [        / S,Q/ S-Q/ S.Q/5      m [        [        U U4S0 j5        g )1Nc                  "    [        SS/S//5      $ r   r   rn   ru   rv   r   test_errors.<locals>.<lambda>x  s    v1vsm4ru   c                  $    [        SS//5      S   $ )Nr   r   )g333333?r   r   rn   ru   rv   r   rh  y      v1vh/7ru   c                  $    [        SS//5      S   $ )Nr   r   )r   g@r   rn   ru   rv   r   rh  z  rj  ru   c                      [        SSSS9$ )Nr   r   T)ra   r  )r=   rn   ru   rv   r   rh  {  s    z!qDAru   c                  <    [        SS/5      R                  SS5      $ )Nr   r   r   r   )r5   r  rn   ru   rv   r   rh  |  s    vq!f~55a;ru   c                  ^    [        SS/SS//5      R                  SS/[        SS/5      5      $ Nr   r   r   r   r   )r5   copyin_matrixrn   ru   rv   r   rh  ~  s/    AA'(661vvq!f~Nru   c                  X    [        SS/SS//5      R                  SS/[        5       5      $ ro  )r5   copyin_listsetrn   ru   rv   r   rh    s1    fq!fq!f%56BBADuru   c                  @    [        / SQ/ SQ/5      R                  5       $ )Nr   )r   r   r   r5   r8  rn   ru   rv   r   rh    s    I0F)G)K)K)Mru   c                  \    [        SSSS/5      R                  [        SS/SS//5      5      $ r  )r5   row_joinrn   ru   rv   r   rh    s.    q!aV$--fq!fq!f5E.FGru   c                  X    [        SS/5      R                  [        SS/SS//5      5      $ r  )r5   col_joinrn   ru   rv   r   rh    s)    FAq6N33FQFQF;K4LMru   c                  X    [        S/5      R                  S[        SS/SS//5      5      $ r  )r5   
row_insertrn   ru   rv   r   rh    6    vqc{55a!B1vA :  ru   c                  X    [        S/5      R                  S[        SS/SS//5      5      $ r  )r5   
col_insertrn   ru   rv   r   rh    r|  ru   c                  8    [        SS/5      R                  5       $ r   r\  rn   ru   rv   r   rh    s    A)=)=)?ru   c                  8    [        S/5      R                  S5      $ rc  )r5   r  rn   ru   rv   r   rh    s    faSk33A6ru   c                  D    [        SS/SS//5      R                  SS5      $ Nr   r   r   r   r   )r5   minorrn   ru   rv   r   rh    s#    v1v1v&67==aCru   c                  D    [        SS/SS//5      R                  SS5      $ r  )r5   minor_submatrixrn   ru   rv   r   rh    s#    v1v1v&67GG1Mru   c                  :    [        / SQ5      R                  S5      $ Nr   r   r5   crossrn   ru   rv   r   rh    s    fY/55a8ru   c                  :    [        / SQ5      R                  S5      $ r  r5   dotrn   ru   rv   r   rh    s    fY/33A6ru   c                  P    [        / SQ5      R                  [        SS/5      5      $ )Nr   r   r   r  rn   ru   rv   r   rh    s    vi044VQF^Dru   c                  :    [        SS/5      R                  / 5      $ r   r  rn   ru   rv   r   rh    s    vq!f~11"5ru   c                  :    [        SS/5      R                  S5      $ )Nr   r   r_   r  rn   ru   rv   r   rh    s    faVn005ru   c                  >    [        SS/5      R                  / SQ5      $ )Nr   r   r   r  rn   ru   rv   r   rh    s    vq!f~11)<ru   c                  8    [        / SQ5      R                  5       $ )Nr   )r5   r   rn   ru   rv   r   rh    s    	):)>)>)@ru   c                  @    [        SS/SS//5      R                  5       $ r  )r5   
normalizedrn   ru   rv   r   rh        v1v1v&67BBDru   c                  6    [        SS/5      R                  SS9$ )Nr   r   znot a methodr  ru  rn   ru   rv   r   rh    s    vq!f~111Hru   c                  8    [        SS/5      R                  5       $ r   r5   
inverse_GErn   ru   rv   r   rh        A)B)B)Dru   c                  @    [        SS/SS//5      R                  5       $ r   r  rn   ru   rv   r   rh    r  ru   c                  8    [        SS/5      R                  5       $ r   r5   inverse_ADJrn   ru   rv   r   rh    s    A)C)C)Eru   c                  @    [        SS/SS//5      R                  5       $ r   r  rn   ru   rv   r   rh    s    v1v1v&67CCEru   c                  8    [        SS/5      R                  5       $ r   )r5   
inverse_LUrn   ru   rv   r   rh    r  ru   c                  8    [        SS/5      R                  5       $ r   r  rn   ru   rv   r   rh    s    A)D)D)Fru   c                  8    [        SS/5      R                  5       $ r   r5   rP  rn   ru   rv   r   rh    s    A););)=ru   c                  >    [        SS/SS//5      R                  SS9$ )Nr   r   r   r   zNot a real methodr  r  rn   ru   rv   r   rh    s%    AA'(,,4G,Hru   c                  J    [        / SQ/ SQ/ SQ/ SQ/5      R                  SS9$ )Nr  r  r  r  zNot functionr  r  rn   ru   rv   r   rh    s*    l)+ ,,/C>C,JKru   c                  J    [        / SQ/ SQ/ SQ/ SQ/5      R                  SS9$ )Nr  r  r  r  Fr  r  rn   ru   rv   r   rh    s*    l)+ ,,/C5C,ABru   c                  V    [        [        SS/SS//5      [        SS/SS//5      5      $ r  r:   r5   rn   ru   rv   r   rh    s/    AA/0&1a&1a&9I2JKru   c                  8    [        [        SS/SS//5      / 5      $ r  r  rn   ru   rv   r   rh    s    wv1v1v.>'?Dru   c                  2    [        [        S5      S-  S5      $ )Nrc   r   r_   )r:   r   rn   ru   rv   r   rh    s    wvc{A~s;ru   c                      [        S5      S   $ )Nr   )r   r   r  rn   ru   rv   r   rh        s1vd|ru   c                      [        S5      S   $ )Nr   )r   r   r  rn   ru   rv   r   rh    r  ru   r  c                  &   > T R                  S5      $ )Nzmethod=LU_decomposition())rP  r3  s   rv   r   rh    s    quu%@Aru   )r   r   r   r   r   r   r   r   c                  (   > T R                  ST5      $ )Ng@)r{  r   Vs   rv   r   rh    s    q||C3ru   c                  (   > T R                  ST5      $ )Ng)r~  r  s   rv   r   rh    s    q||D!4ru   )rR   r/  r  r+   r  r-   r5   r  s   @@rv   test_errorsr  w  sI   
:45
:78
:78
:AB
:;<
:NP
9  
!MN
:GI
MO
:  
:  
!?@
967
:CD
:MN
989
967
:DE
:56
956
:<=
!@A
:DE
:HI
!DE
:DE
!EF
:EF
!DE
!FG
!=>
:HJ
:	KL :	BC :KM
:DE
:;<
:+,
:+,NOA
:AB~A	9i01A
:34	9i01A
:45ru   c                     [        [        5       5      S:X  d   e[        [        SS//5      5      [        [        S/S//5      5      s=:X  a  S:X  d   e   e[        [        SSS 5      5      [        [        SSS 5      5      s=:X  a  S:X  d   e   e[        [        / SQ/ SQ/5      5      S:X  d   e[        S/5      [        S//5      :X  d   e[        5       (       a   e[        5       [        / 5      :X  d   eg )	Nr   r   r   c                     gr   rn   r   s     rv   r   test_len.<locals>.<lambda>  s    ru   c                     gr   rn   r   s     rv   r   r    s    aru   r   r   r   )rd  r5   rn   ru   rv   test_lenr    s    vx=Av1vh CaSz(:$;@q@@@@@vaN+,F1a()/-./ / / / /vy),-.!3331#;&1#-'''xx<8vbz!!!ru   c            
      0   [        SS[        4[        SS4SS[        S-  445      n U R                  [        5      [        [        S[        -  [        S-  S-  4[        [        -  S[        -  S[        -  4S[        -  S[        -  [        S-  S-  445      :X  d   eU R                  [        5      [        [        S[        -  [        [        -  4[        S-  S-  S[        -  S[        -  4S[        -  S[        -  [        [        S-  -  445      :X  d   eg )Nr   r   r   r   r   r   )r5   rc   rd   r   r  s    rv   test_integrater    s    Aq	Aq!9r1adm45A;;q>AaCAa 1Q3!QqS/BqD!A#q!tAv3FGHI I I;;q>AaC11Q!QqS1BqD!A#qAv3FGHI I Iru   c                      [        SS[        [        5      [        -  4[        SS4SS[        S-  S-   445      n U R	                  [        S5      [        S[        SS4S45      :X  d   eg )	Nr   r   r   r   r   r   )r   r   r   )r   r   r   )r5   r   rc   rd   r  r  s    rv   
test_limitr    sa    As1vax 1a)b!QTAX->?@A771a=FI1ay*#EFFFFru   c            	      D   [        SS[        4[        SS4SS[        S-  S-   445      n [        U R	                  [        5      [        U 5      5      (       d   eU R	                  [        5      [        SSSSS[        -  445      :X  d   eU R	                  [        5      [        S	5      :X  d   e[	        U [        5      [        SSSSS[        -  445      :X  d   e[	        U [        5      [        S	5      :X  d   eU R                  5       n[        UR	                  [        5      [        U5      5      (       d   eUR	                  [        5      [        SSSSS[        -  445      :X  d   eUR	                  [        5      [        S	5      :X  d   e[	        U[        5      [        SSSSS[        -  445      :X  d   e[	        U[        5      [        S	5      :X  d   eU R	                  [        S
S9[        U [        S
S9:X  d   e[	        U [        S
S9[        U [        S
S9:X  d   eg )Nr   r   r   r   r   r  r   r   )r   rZ  r   Fr  )	rC   rc   rd   r   r   r   r  rD   r[   )r   A_imms     rv   	test_diffr    s   Q1I1ay2q!Q$(2CDEAaffQia))))66!9*Iy1a1++NOOOO66!9*+LMMMM1:+Y	Aq!A#;,OPPPP1:+,MNNNNNNEejjmT%[1111::a=0)YAqQRs1TUUUU::a=01RSSSSq>19i!QPQRSPS2UVVVVq>12STTTT66!e6$1u(MMMM1u%A)NNNNru   c                     [        [        [        /[        [        //5      n U R                  U 5      [        SS/SS//SS/SS///SS/SS//SS/SS////5      :X  d   e[        X 5      [        SS/SS//SS/SS///SS/SS//SS/SS////5      :X  d   eU R                  5       nUR                  U5      [        SS/SS//SS/SS///SS/SS//SS/SS////5      :X  d   e[        X5      [        SS/SS//SS/SS///SS/SS//SS/SS////5      :X  d   eU R                  [        5      [        SS/SS//5      :X  d   e[        [        [        /5      nU R                  U5      [        R                  " SSSS5      :X  d   eU R                  U 5      [        SS/SS//SS/SS///SS/SS//SS/SS////5      :X  d   eUR                  [        [        //5      nUR                  S:X  d   eU[        S/S//S/S///5      :X  d   e[        S5      nU" [        [        [        5      nUR                  [        [        [        //5      [        UR                  [        5      UR                  [        5      UR                  [        5      /5      :X  d   eUR                  [        [        [        /S45      [        UR                  [        S5      UR                  [        [        5      UR                  [        [        5      /UR                  [        [        5      UR                  [        S5      UR                  [        [        5      /UR                  [        [        5      UR                  [        [        5      UR                  [        S5      //5      :X  d   e[        [        5      [        [        5      -  nUR                  [        [        //5      [        [!        [        5      [        [        5      -  [        [        5      [        [        5      -  /5      :X  d   eUR                  [        [        [        445      [        [!        [        5      [        [        5      -  [        [        5      [        [        5      -  /5      :X  d   eUR                  [        [        [        445      [        [        [        5      * [        [        5      -  [!        [        5      [        [        5      -  /5      :X  d   eUR                  [        [        44[        [        //5      [        [!        [        5      [        [        5      -  [        [        5      * [        [        5      -  /[        [        5      [        [        5      -  [!        [        5      [        [        5      -  //5      :X  d   eUR                  [        5      R                  [        5      R                  [        5      UR                  [        [        [        44S5      S   :X  d   eUR                  [        5      R                  [        5      R                  [        5      UR                  [        [        [        44S5      S   :X  d   eUR                  [        [        [        //[        [        [        445      [        [        [        [        4 VVs/ s HB  n[        [        [        4 Vs/ s H"  oR                  U5      R                  U5      PM$     snPMD     snn5      :X  d   e[        R
                  " [#        [        [        //5      5      n	[%        U	[        5      (       d   eU	[#        SS//5      :X  d   e[        S-  R                  [#        [        [        //5      5      n	[%        U	[        5      (       d   eU	[#        S[        S-  -  S//5      :X  d   eg s  snf s  snnf )	Nr   r   r   )r   r   r   r:  r   r  r~  )rC   rc   rd   re   rf   r   rZ   r  r_   rD   r`   rB   r   r   r   r   r   r5   r   )
r   r  r   dBr:  fxyzexprr   r   ress
             rv   test_diff_by_matrixr    s    	QFQF+,A66!9!Q!Q 0Aq6Aq62BC1vPQSTvFVZ[]^Y_bcefagXhEijkkkk:1a&1a&!1QFQF3C DAQRTUPVGW[\^_Z`cdfgbhYiFjkllllNNE::e!Q!Q(8Aq6Aq6:J'KPQSTvXY[\W]N^bcefagjkmnio`pMq&r ssss1a&1a&)9QFQF;K(LQRTUPVYZ\]X^O_cdfgbhklnojpaqNr's!tttt 66!9*QFQF+;<<<<aV$A66!9Aq!Q////66!9!Q!Q 0Aq6Aq62BC1vPQSTvFVZ[]^Y_bcefagXhEijkkkk 
!Q	B88y   !qc
aS1#J/0000AQ1:D99q!Qi[!UDIIaL$))A,		RS+U%VVVV99q!Qi^$	1a$))Aq/499Q?;	1a$))Aq/499Q?;	1a$))Aq/499Q?;/ )    q6#a&=D99q!fX%QAAs1v(F"GGGG99Q!Q	"eSVCF]CF3q6M,J&KKKK99Q!Q	"ec!fWSV^SVCF],K&LLLL99q!fY!Q)USVCF]SVGCPQFN4SVYZ[V\]`ab]cVcehijeklopqlrerUs3t-uuuu 99Q<Q$$Q'499q!Qi\1+Eg+NNNN99Q<Q$$Q'499q!Qi\1+Eg+NNNN99q!Qi[Aq!9,/5noqrtumv9wmvhiZ[]^`aYb:cYbTU99Q<;L;LQ;OYb:cmv9w3xxxx &&!Q!
"Cc/0000&1a&""""a4++fq!fX&
'Cc/0000&1QT61+'''' ;d9ws   _$)___c            	         ^  [        SS[        4[        SS4SS[        S-  S-   445      m [        [        U 4S j5        [        T S5      " [        5      [        SS	S
S
S[        -  445      :X  d   eg )Nr   r   r   r   r   c                     > T R                   $ r}   )nonexistantattributer  s   rv   r   test_getattr.<locals>.<lambda>  s    1#9#9ru   r   r  r   r   )r5   rc   rd   rR   rW  getattrr  s   @rv   test_getattrr    sj    Aq	Aq!9r1adQh&789A
>9:1fa FIy1a1++N$OOOOru   c                  H   [        / SQ/ SQ/ SQ/5      n U R                  (       d   eU R                  n U R                  (       d   eSU S'   U R                  SL d   e[        / SQ/ SQ/ SQ/5      n U R                  (       a   e[	        SS	5      n U R                  (       d   eg )
N)r   r   r   )r   r   r   r   r   )r   r  Fr  r   r   )r5   is_upper_hessenbergr  is_lower_hessenbergrB   r  s    rv   test_hessenbergr    s    	9i01A    	A    AeH  E)))	9i01A$$$$aA    ru   c            	      L   [        [        S 5        [        [        S 5        [        [        S 5        [        [        S 5        [        [        S 5        [        S[        -   S4S45      R                  S	S
9[        [        S[        -   5      S/SS//5      :X  d   e[        S5      n U R                  S	S
9nU[        SS/SS[        S5      -  [        -  //5      :X  d   eXR                  -  U :X  d   e[        S5      n U R                  5       nXR                  -  U :X  d   eUR                  (       d   eU[        / SQ/ SQ/ SQ/5      :X  d   e[        SS[        -  SS[        -  -   4S[        -  SS[        -   4SS[        -  -
  S[        -
  S445      n U R                  5       R                  5       [        S[        SS4S[        -
  SS445      :X  d   e[        [        S 5        [        [        S 5        [        [        S 5        [        [        S 5        [        [        S 5        [        S[        -   S4S45      R                  S	S
9[        [        S[        -   5      S/SS//5      :X  d   e[        S5      n U R                  S	S
9nU[        SS/SS[        S5      -  [        -  //5      :X  d   eXR                  -  U :X  d   e[        S5      n U R                  5       nXR                  -  U :X  d   eUR                  (       d   eU[        / SQ/ SQ/ SQ/5      :X  d   e[        SS[        -  SS[        -  -   4S[        -  SS[        -   4SS[        -  -
  S[        -
  S445      n U R                  5       [        S[        SS4S[        -
  SS445      :X  d   eg )Nc                  4    [        S5      R                  5       $ Nr   r5   choleskyrn   ru   rv   r   test_cholesky.<locals>.<lambda>.  s    )@)@)Bru   c                  4    [        S5      R                  5       $ Nr   )r   r   r  rn   ru   rv   r   r  /      v&67@@Bru   c                  J    [        S[        -   S4S45      R                  5       $ Nr   r   r   )r5   r
   r  rn   ru   rv   r   r  0  s    vAqz6&:;DDFru   c                  4    [        S5      R                  5       $ N)r   r   )r   r   r  rn   ru   rv   r   r  1  r  ru   c                  2    [        S5      R                  SS9$ Nr  F	hermitianr  rn   ru   rv   r   r  2  s    v&67@@5@Qru   r   r   r   Fr  r   r  r   r   ))   r   r^  )r   r   r   )r^  r   r  r  )r   r   r   )r  r   r   r   r"  r  r  r'  r   c                  4    [        S5      R                  5       $ r  r6   r  rn   ru   rv   r   r  A  s    f)=)F)F)Hru   c                  4    [        S5      R                  5       $ r  r  rn   ru   rv   r   r  B      |,<=FFHru   c                  J    [        S[        -   S4S45      R                  5       $ r  )r6   r
   r  rn   ru   rv   r   r  C  s    |a!eQZ,@AJJLru   c                  4    [        S5      R                  5       $ r  r  rn   ru   rv   r   r  D  r  ru   c                  2    [        S5      R                  SS9$ r  r  rn   ru   rv   r   r  E  s    |,<=FFQVFWru   )rR   r-   r/  r5   r
   r  r   r  r  r   r6   )r   r8  s     rv   test_choleskyr  -  sc   
!BC
:BC
:FG
:BC
:QRAE1:v&'0050AV	a!ea1a&M" F# # # # A	

U
#AAAd1gIaK 012222SS5A::78A	

Ass7a<<:::	9j9::::BqD!ac'"QqS!R!V$4q1Q3wQ6KLMA::< FI1ay1q5!Q-+P$QQQQ
!HI
:HI
:LM
:HI
:WX!a%V,-666G6	a!ea1a&S" L# # # #%&A	

U
#AAAd1gIaK 012222SS5A::=>A	

Ass7a<<:::	9j9::::q"Q$AaC(1Q326*:Q1Wb1fb<QRSA::<69q!Qi!a%A"GHHHHru   c            	      L   [        SSS9n [        [        U 5      [        U 5      /5      n[	        UR                  S5      5      S:X  d   eUR                  S5      [        [        U 5      S-  [        U 5      S-  -   [        SS5      5      :X  d   e[        S[        SS5      //5      nUR                  5       [        S	[        S
S5      -   [        R                  5      :X  d   eUR                  [        5      [        U5      :X  d   eUR                  [        * 5      [        U5      :X  d   e[        SS/SS//5      nUR                  S5      S:X  d   eUR                  S5      S:X  d   eUR                  S5      S:X  d   e[        S5      R                  S5      [        S5      R                  S5      s=:X  a  S:X  d   e   eUR                  [        5      S:X  d   e[        S[        [        /U [        R                  [        * //5      nUR                  S5      [!        [        SS5      S[#        [        5      S-  -  -   [        S-  -   U S-  -   5      :X  d   e[        / SQSS[        SS5      //5      nUR                  S5      [!        [        SS5      [!        S5      S-  -   5      :X  d   eUR                  S5      [        R$                  L d   eUR                  S5      [!        S5      S-  :X  d   e[        SS/SS//5      n[        SS/SS//5      n[        S[&        * /[&        S//5      n[        SS/SS//5      nX#XE/n[        SSS9nS H  n[)        S5      R                  U5      [        R$                  L d   eU HK  n	U HB  n
U	R                  U5      U
R                  U5      -   X-   R                  U5      -
  nUS:  a  MB   e   MM     X#XE4 HE  n[+        X|-  R                  U5      [#        U5      UR                  U5      -  -
  5      nUS:X  a  ME   e   M     [        SSS[&        -  -
  S/5      n[        [        R                  S[&        -  S/5      n[        / SQ5      n[        SS[&        /5      n[        [-        S5      [        SS5      S/5      nXUUU/n[        SSS9nSSSS[        R.                  [        R0                  [        4 GH  nUS:  a/  [        / SQ5      R                  U5      [        R$                  L d   eUS:  aj  U Hd  n	U H[  n
U	R                  U5      U
R                  U5      -   X-   R                  U5      -
  n[+        US:  5      [        R2                  L a  M[   e   Mf     USSSS[        R.                  [        R0                  4;   d  M  U HE  n	[+        Xy-  R                  U5      [#        U5      U	R                  U5      -  -
  5      nUS:X  a  ME   e   GM!     [        SS/ SQ5      nUR                  S5      S:X  d   eg )Nrc   Tr
  r   r   r   r   r   r  r   r   r"  r   	frobeniusfro%   )r   r   r   r  i  r   iI3 r  alpha)r  r   r"  r   )r  r  r  g      Y@r   )	r   r   r   r"  r  r   r   r   r   )r   r5   r   r   r*   normr   r   r   r,  r   maxr  r9   rd   r   r   r   r  r
   rB   r)   r   InfinityNegativeInfinitytrue)rc   r   r   r   r   rU  r8  r  orderr  r  difr   r_   r`   ra   rb   es                     rv   test_matrix_normr  U  s~    	sAAA AAFF1I!###66":SVRZ#a&"*4hq"oFFFF 	HQN#$%A668s2A.777766":Q662#;#a&    	AA A66!9>>66":??66+!###r7<<?c"gll2.3!3333366":?? 	Aq	Aqvvs+,-AFF5M8B?Qs1vqy[02q581a4?@A B A 	
Q8B?345A66!9Xc1-UA=>>>>66":66+$s)A+---
 	AA AAQ !AQB!Q !AAB !A	
qA7&EQx}}U#qvv---Avve}qvve}4ULL'(q!   AEG>>%0J./ 0C!8O8   $ 	1qs7B A!Q A|A1ayAhq#.23A	
q!QA7&EQB

A,>,>C19)$))%0AFF:::A:A66%=166%=8U+,C#C1H-777   Q2r1::q/A/ABB~~e4Z!&&-/ 1 2axx  D& 	q!23A66!9??ru   c                    ^^ [        SSS9m[        S5      n SU S'   [        SS5      U S'   U R                  5       S	:X  d   eTU S
'   U R                  5       [	        S[        T5      5      [        [        SS5      [        T5      5      -  :X  d   e[        [        T5      [        T5      /[        T5      * [        T5      //5      nUR                  5       m[        UU4S j[        SS5      [        R                  [        SS5      [        S-  [        [        [        SS5      -  4 5       5      (       d   e[        / 5      R                  5       S:X  d   eg )Nrc   Tr
  r   r   r   r   r   r   r   r   c              3      >#    U  H=  n[        S 5      R                  TR                  TU5      R                  5       5      v   M?     g7f)      ?N)r	   
epsilon_eqr#  r  )r   valMcrc   s     rv   r   (test_condition_number.<locals>.<genexpr>  s@      QO BEuRy##BGGAsO$9$9$;<<Os   AAr   r   r   r   r   )r   r9   r   condition_numberr   r   r   r5   r   r   r   r   r,  r   )r   r   r  rc   s     @@rv   test_condition_numberr    s3   sAAAAdGq"oAdG3&&&AdG3r3q6?S!R#a&5Q#QQQQQQ CF7CF"345A	
			B Q	!Q!R"Q$Bx1~<MOQ Q Q Q Q ":&&(A---ru   c                      [        S5      n [        S5      nX S S 2S S 24   :X  d   eX S S 2S S 24   :w  a   eX:X  a   eX:w  d   eU S:w  d   eU S:X  a   e[        S5      n[        S5      nX#:X  d   eX#:w  a   eg )N)r   rp  r   r   r   ))r   r   r   )r   r   r   )r   r   r   r   )rZ  r  r  )r5   r6   )r   r   r   rU  s       rv   test_equalityr    s    01A01A!Q$<<adG|v:6M67N7Bw; 	67A01A6M6v:vru   c                      [        S5      R                  [        / SQ/5      5      [        / SQ/ SQ/ SQ/ SQ/5      :X  d   eg )Nr   )r   r   r   rZ  r  r  )r9   ry  r5   rn   ru   rv   test_col_joinr
    s@    q6??69+./	 	  ru   c                      [        / SQ/5      n [        SS5       H_  n/ SQnUR                  US5        [        [	        S5      R                  X5      R                  S5      R                  5       5      U:X  a  M_   e   g )Nr   r   r   r]  r   rZ  r   r   r   )r5   r   insertrN   r9   r{  rk  r  )r4r   rJ  s      rv   test_row_insertr    sf    		B2q\	As1v((/33A6==?@AEEE ru   c                      [        / SQ5      n [        SS5       H_  n/ SQnUR                  US5        [        [	        S5      R                  X5      R                  S5      R                  5       5      U:X  a  M_   e   g )Nr  r]  r   r   r   r   r   )r5   r   r  rN   rB   r~  rj  r  )c4r   rJ  s      rv   test_col_insertr    sd    			B2q\	AuQx**1155a8??ABaGGG ru   c                  8   [        SS/5      R                  5       [        [        SS5      [        SS5      /5      :X  d   e[        / SQ5      R                  5       [        / SQ5      :X  d   e[        / SQ5      n U R                  S S9[        / SQ5      :X  d   eg )Nr   r   r   r   )r   r   g0.++c                 8    U R                   " SSS9R                  $ )Nr   T)r   chop)r  is_zeror  s    rv   r   !test_normalized.<locals>.<lambda>  s    2D199ru   r  )r5   r  r   r  s    rv   test_normalizedr    s    1a&>$$&AA/01 1 1 )'')VI->>>> 	}A<<9  			  ru   c                  L    [        S 5      S:X  d   e[        S 5      S:X  d   eg )Nc                  4    [        S5      R                  5       $ r  r9   print_nonzerorn   ru   rv   r   $test_print_nonzero.<locals>.<lambda>  s    3q6//1ru   z[X  ]
[ X ]
[  X]
c                  6    [        S5      R                  S5      $ )Nr   .r  rn   ru   rv   r   r    s    3q6//4ru   z[.  ]
[ . ]
[  .]
)rO   rn   ru   rv   test_print_nonzeror     s8    12     45     ru   c                     [         R                  " S5      [        S5      :X  d   e[         R                  " S5      [        S5      :X  d   e[        SS5      [        SSS/S-  5      :X  d   e[        SS/SS//5      n [        SS/SS//5      n[         Hu  nUR                  S5      nX:X  d   eU [        SUS9:X  d   e[        U5      U:X  d   eUR                  S5      nX:X  d   eU[        SUS9:X  d   e[        U5      U:X  a  Mu   e   g )Nr   r   r   r   r   r   rD  )r5   r9   rB   r<   r   r   )r   re   r   r   s       rv   test_zeros_eyer"  	  s   ::a=CF"""<<?eAh&&&1:1qc"f----AA AAA AGGAJvvCsO###Aw#~~IIaLvvE!%%%%Aw#~~ ru   c                     [        5       R                  (       d   e[        SS/SS//5      R                  (       d   e[        SS5      R                  (       d   e[        S5      R                  (       a   e[        [        S/SS//5      R                  S :X  d   e[        [        S/SS//5      R                  S :X  d   e[        [        S/SS//5      R                  S :X  d   e[        [        S/SS//5      R                  S :X  d   e[        [        S/SS//5      R                  S:X  d   e[        SSS9n [        U S/SS//5      R                  S:X  d   eg )	Nr   r   r   r   Fr_   T)nonzero)	r5   is_zero_matrixrB   r9   rc   r6   r3   r4   r   r  s    rv   test_is_zeror&  	  sL   8""""Aq6Aq6"#2222A;%%%%1v$$$$Aq6Aq6"#22d:::!Q!Q()88D@@@QFQF+,;;tCCC 1a&1a&!12AATIIIAq6Aq6"#22e;;;sD!AAq6Aq6"#22e;;;ru   c                  h   [         S-  n [        U 5      n[        U * 5      n[        U 5      n[        U * 5      n[        U 5      n[        U * 5      nX!-  [	        S5      -  [	        S5      :X  d   eXC-  [	        S5      -  [	        S5      :X  d   eXe-  [	        S5      -  [	        S5      :X  d   eUR                  5       SS[        U 5      -  -   :X  d   eUR                  5       SS[        U 5      -  -   :X  d   eUR                  5       SS[        U 5      -  -   :X  d   e[        S5      [	        S5      :X  d   e[        S5      [	        S5      :X  d   e[        S5      [	        S5      :X  d   e[        R                  " / SQ[         S-  5      n[        R                  " / SQ[         S-  5      n[        R                  " / SQ[         S-  5      n	[        [         * S-  5      UR                  5       :X  d   e[        [         * S-  5      UR                  5       :X  d   e[        [         * S-  5      U	R                  5       :X  d   e[        [         7S-  5      UR                  5       :X  d   e[        [         7S-  5      UR                  5       :X  d   e[        [         7S-  5      U	R                  5       :X  d   eg )Nr   r   r   r   rZ  r  r  )r   r@   r?   r>   r9   r]  r   r]   from_axis_angleto_rotation_matrixrG   rH   rI   )
thetar3_plusr3_minusr2_plusr2_minusr1_plusr1_minusq1q2q3s
             rv   test_rotation_matricesr4  #	  s`   qDEG% HG% HG% HCF"c!f,,,CF"c!f,,,CF"c!f,,, ==?a!CJ,....==?a!CJ,....==?a!CJ,.... Q<3q6!!!Q<3q6!!!Q<3q6!!! 
	#	#IrAv	6B		#	#IrAv	6B		#	#IrAv	6BrTAX""7"7"9999rTAX""7"7"9999rTAX""7"7"99992"b&;&;&====2"b&;&;&====2"b&;&;&====ru   c                     [        [        S5      S   5      S:X  d   e[        [        S5      5      [        S5      :X  d   e[        [        S 5        [        [        S5      5      S:X  d   e[        [        S5      5      S:X  d   eg )Nvectorr   z	vector[4]rb   c                      [        S5      S   $ )Nrb   r  r.   rn   ru   rv   r   %test_DeferredVector.<locals>.<lambda>K	  s    ~c226ru   testzDeferredVector('test'))strr/   r   rR   r  reprrn   ru   rv   test_DeferredVectorr<  H	  sx    ~h'*+{:::>#&'>#+>>>>
:67~c"#s***v&'+CCCCru   c                  :    [        [        S5      5      (       a   eg )Nr  )rP   r/   rn   ru   rv    test_DeferredVector_not_iterabler>  O	  s    s+,,,,,ru   c                  &    [        [        S 5        g )Nc                  *    [        [        S5      5      $ )Nr  )r5   r/   rn   ru   rv   r   ,test_DeferredVector_Matrix.<locals>.<lambda>S	  s    f^C%89ru   )rR   r  rn   ru   rv   test_DeferredVector_MatrixrB  R	  s    
99:ru   c            
         [         n [        SSSS/5      n[        SSSS/5      n[        X/5      [        SSSS/5      [        SSU " S5      S-  U " S5      S-  /5      /:X  d   e[        UR                  UR                  /5      [        SSSS/5      [        SSU " S5      S-  U " S5      S-  /5      /:X  d   e[        [        SS/5      [        SS/5      /S5      [        S[	        S5      -  S-  [	        S5      S-  /5      [        [	        S5      * S-  S[	        S5      -  S-  /5      /:X  d   e[        [        S/5      5      n[        U5      [        S//5      /:X  d   eg )Nr   r   r   r   r  Tr   )r   r5   r2   r  r   r'   )r0  r  r  r8  s       rv   test_GramSchmidtrD  U	  s{   A	1q!f	B	1q!f	Bx 	1q!f	vaQqT!VQrU1W,=>?@ @ @bdd|$	1q!f	vaQqT!VQrU1W,=>?@ @ @ 1v1v7>$r(
2tBx{+,b	"aRjm,-C/ / / / 	&!+Aq>fqcUm_,,,ru   c                  R    [        / SQS5      S:X  d   e[        / SQSSS9S:X  d   eg )Nr  r   r   F)zero)r7   rn   ru   rv   test_casoratianrG  f	  s.    lA&!+++lAE2a777ru   c                      [        5       [        SS5      -  R                  S:X  d   e[        SS5      [        SS5      -  [        SS5      :X  d   e[        SS5      [        SS5      -  [        5       :X  d   eg )Nr   r   )r   r   )r5   rB   r   rn   ru   rv   test_zero_dimension_multiplyrI  k	  si    HU1a[ ''6111A;uQ{"eAqk111A;uQ{"fh...ru   c                    ^  [        SS[        S5      5      m T SS S 24   [        SS//5      :X  d   eT SS S 24   [        SS//5      :X  d   eT S S 2S4   [        SS//5      R                  :X  d   eT S S 2S4   [        SS//5      R                  :X  d   e[        [        U 4S j5        [        [        U 4S j5        g )Nr   r   r   r   r  c                     > T SS S 24   $ r  rn   r  s   rv   r   'test_slice_issue_2884.<locals>.<lambda>w	  s    qAwru   c                     > T S   $ )Nr  rn   r  s   rv   r   rL  x	  s	    qwru   )r5   r   r  rR   r  r  s   @rv   test_slice_issue_2884rN  q	  s    q!U1XAQT7fq!fX&&&&RU8v1vh''''QT7fq!fX&(((((QU8v1vh')))))
:'
:'ru   c                      [        SS5      S S 2S4   R                  S:X  d   e[        SS5      SS S 24   [        SS/ 5      :X  d   eg )Nr   r   r  r   r   )rB   r   r5   rn   ru   rv   test_slice_issue_3401rP  {	  sK    A;q"u##v---A;q!tq!R 0000ru   c                     [        SS5      n SU S'   U S S 2S4   [        / SQ5      :X  d   eU S   S:X  d   eU SS S/:X  d   eSU S'   U S   S:X  d   eU SSS 24   [        SS//5      :X  d   e[        SS	//5      U SSS 24'   U SS S 24   [        / S
Q/5      :X  d   eSS//U SSS 24'   U SS S 24   [        / SQ/5      :X  d   eSU S'   U S S 2S S24   [        / SQ5      :X  d   e/ SQU S'   U S S 2S4   [        / SQ5      :X  d   e[        / SQ5      U S'   U S S 2S4   [        / SQ5      :X  d   e[        / SQ5      U S'   U S S 2S4   [        / SQ5      :X  d   eg )Nr   r   r   r  r   rg  r   r   r   )r   r   r   +   )r   rg  rR     r   )rS  r   r   rt  )rB   r5   r6   )r-  s    rv   test_copyinrT  	  s   aAAaDQT7fY''''Q4199Q7qc>>AdGT7b==QU8vAwi((((1vhAaeHQT7fi[))))RzAaeHQT7fk]++++AdGQU8vj))))AdGQT7fY''''YAdGQT7fY''''9%AdGQT7fY''''ru   c                  .  ^  [        SS/SS//5      R                  5       [        SS/SS//5      S4:X  d   e[        [        S 5        [        / SQ[        SS/S[        S//5      m [        T R                  5       S   5      T R                  :w  d   eT R                  5       S   [        S5      :w  d   eT R                  [        S	9S   [        S5      :w  d   e[        [        U 4S
 j5        [        [        U 4S j5        [        [        U 4S j5        g )Nr   r   r   )r   c                  @    [        SS/SS//5      R                  5       $ r   ru  rn   ru   rv   r   'test_invertible_check.<locals>.<lambda>	  s    v1v1v&67;;=ru   )r  r  r   r  r   r
  c                  "   > T R                  SS9$ )Nr  r  r8  r  s   rv   r   rW  	  s    quuEu2ru   c                  "   > T R                  SS9$ )Nr  r  rY  r  s   rv   r   rW  	      quuDu1ru   c                  "   > T R                  SS9$ )Nr  r  rY  r  s   rv   r   rW  	  r[  ru   )	r5   ra  rR   r/  rc   rd  r   r9   r(   r  s   @rv   test_invertible_checkr]  	  s     Aq6Aq6"#((*v1v1v6F/G.NNNN
:=>
a!
a 	A
 qvvx{qvv%%% 668A;#a&   6686$Q'3q6111
:23
:12
:12ru   c                      [        S5      u  pX-  nUR                  U [        / SQ5      5      [        / SQ5      U-  :X  d   eg )Nzx, y)r   r   r   )r   r#  r5   )rc   rd   r  s      rv   test_issue_3959r_  	  s<    6?DA	A66!VI&'6)+<Q+>>>>ru   c                  D    [        [        SS/SS//5      5      S:X  d   eg )Nr   r   r   r   zMatrix([[1, 2], [3, 4]]))r:  r5   rn   ru   rv   test_issue_5964ra  	  s(    v1v1v&'(,FFFFru   c                  p    [        S5      u  p[        [        U SU-  /US-  U S-   //5      5      S:X  d   eg )Nx yr   r   z'Matrix([
[   x,   2*y],
[y**2, x + 3]]))r   r&   r5   )rc   rd   s     rv   test_issue_7604rd  	  sE    5>DAAaC1a4Q-01234 4 4ru   c            
      Z   [        S5      R                  (       d   e[        S5      R                  5       R                  (       d   e[        S5      R                  (       a   e[	        S5      R                  (       a   e[        / SQ/5      R                  (       a   e[        SSSSSS.5      R                  (       d   e[        SS[        S5      5      R                  (       a   e[        SSSSS.5      R                  (       a   e[        SSSSSSSS.5      R                  (       a   eg )	Nr   rZ  r   )r   r   r  r   r   )r   r   )r   r   r  r   ru  )r9   is_Identityr  rB   r<   r5   r6   r   rn   ru   rv   test_is_Identityrg  	  s    q6q6 ,,,,Qx####Aw""""yk"....!AQa89EEEEAaq*6666Aa!34@@@@Aa!1A!NO[[[[[ru   c                  ~   [        SS5      R                  [        SS5      5      S:X  d   e[        SS5      R                  / SQ5      S:X  d   e[        / SQ5      R                  [        / SQ5      5      S:X  d   e[        SSS[        -  /5      R                  [        [        SS[        -  /5      5      S[        -   :X  d   e[        SSS[        -  /5      R                  [        [        SS[        -  /5      SS	9S[        -   :X  d   e[        SSS[        -  /5      R                  [        [        SS[        -  /5      S
S	9S[        -   :X  d   e[        SSS[        -  /5      R                  [        [        SS[        -  /5      S
SS9S[        -
  :X  d   e[        SSS[        -  /5      R                  [        SS[        -  S/5      S
SS9SS[        -  -   :X  d   e[        SSS[        -  /5      R                  [        SS[        -  S/5      S
SS9SS[        -  -
  :X  d   e[        [        S[        -  /5      R                  [        [        S[        -  /5      SSS9S:X  d   e[        [        S[        -  /5      R                  [        [        S[        -  /5      SS9S:X  d   e[	        [
        S 5        g )Nr   r   rt  r   r  r   r^  Fr  Tr  physicsr  conjugate_conventionr   r   r   rightr   left)rk  c                  P    [        SS/5      R                  [        SS/5      SSS9$ )Nr   r   r   r   Tr9  rj  r  rn   ru   rv   r   test_dot.<locals>.<lambda>	  s'    vq!f~11&!Q.Dgm1nru   )r<   r  r5   r
   rR   r/  rn   ru   rv   test_dotrp  	  s   1:>>$q!*%***1:>>)$))))  	!23r9991a1+""61a1+#6726AAA1a1+""61a1+#6%"HBQRFRRR1a1+""61a1+#6$"G2PQ6QQQ1a1+""61a1+#6$]f"gkmpqkqqqq1a1+""61ac1+#6$]d"eijmnopmpipppp1a1+""61ac1+#6$]c"dhilmnolohoooo1ac(1Q3x 0EX^_ceeee1ac(1Q3x 0vNRSSSS
:noru   c            	         [        SSS9u  pp#pE[        SX4U4U* SX!* 4U* U* SU 4U* X* S445      n[        SU * U* U* 4U SXT* 4X* SU4X$U* S445      nUR                  5       R                  U5      (       d   e[	        S5      R                  5       R                  [        S5      5      (       d   eUR                  5       R                  5       R                  U* 5      (       d   eg )NzB_x B_y B_z E_x E_y E_zTr
  r   r   )r   r5   dualequalsr9   rB   )B_xB_yB_zE_xE_yE_zFFds           rv   	test_dualr|  	  s   #*!$. CcC 
!c4 
tC 
Ta 	 	A 
sdSD3$	S$	dq3	SDQ	 
B 668??2q6;;=a))))668==?!!1"%%%%ru   c                  (   [        SS/5      R                  5       SL d   e[        SSS[        S-  S[        -  -   S-   [        [        S-   S-  * S[        [        -  [        * [        * [        -  S/	5      n U R                  5       SL d   eU R                  SS9b   eU R                  S S9b   eU S	   * U S	'   U R                  5       b   eU S	   * U S	'   U R	                  5       n U R                  SS9SL d   eSU S
'   U R                  5       SL d   eg )Nr   r   Fr   r   Tr
  c                     U $ r}   rn   r  s    rv   r   %test_anti_symmetric.<locals>.<lambda>	  s    !ru   r   r   )r5   is_anti_symmetricrc   rd   r   r  s    rv   test_anti_symmetricr  	  s/   1a&>++-666q!aA!aa!eaZKAaC!aRT1MNA D(((.6664<<< whAdG (((whAdG	
A.$666AdG E)))ru   c                     [        S5      n U R                  SS9u  pXR                  -  UR                  U-  s=:X  a  [        UR                  5      :X  d   e   eU R                  SSS9u  pXR                  -  UR                  U-  s=:X  a  [        UR                  5      :X  d   e   eX-  UR                  5       -  U :X  d   eg )N)r   r   T)	normalize)r  sort)r5   r  r  r9   r   r8  )r   r:  rY   s      rv   #test_normalize_sort_diogonalizationr  	  s     A==4=(DASS5ACCE(S[(((((==4d=3DASS5ACCE(S[(((((3quuw;!ru   c                  &    [        [        S 5        g )Nc                  6    [        / SQ[        SS/ 5      /5      $ )Nr   r   r   r   rn   ru   rv   r   !test_issue_5321.<locals>.<lambda>	
  s    vy&Ar2B&CDru   )rR   r/  rn   ru   rv   test_issue_5321r  
  s    
:DEru   c            	         [         R                  " [        S5      S[        S5      -  5      [        / SQ/ SQ/5      :X  d   e[         R                  " [        S5      S[        S5      -  5      [        SS/SS/SS/SS//5      :X  d   e[        n U R                  U " [        S5      5      U " S[        S5      -  5      5      [        / SQ/ SQ/5      :X  d   eg )Nr   )r   r   r   r   )r   r   r   r   r   r   )r5   hstackr9   vstackr6   rD  s    rv   test_issue_5320r  
  s    ==Q3q6*f6 /    ==Q3q6*f	
A	
A	
A	
A	6 /    C::c#a&k3qQx=1V= 6   ru   c                      [        S//5      n [        U 5      n[         R                  " X5      [        SS//5      :X  d   e[         R                  " X5      [        S/S//5      :X  d   eg rc  )r5   r   r  r  )r   AIms     rv   test_issue_11944r  
  s^    uA
!*C== FQF8$4444== FQC!:$6666ru   c                    ^ / SQn / SQn[        / SQ5      nUR                  nU4S jn[         H  mT" U 5      nT" U5      nU" UR                  U5      U5        U" UR                  UR                  5      U5        U" UR                  R                  UR                  5      U5        U" UR                  R                  U5      U5        M     [	        [
        S 5        g )Nr   r   )r"  r   r"  c                 6   > X:X  d   e[        U 5      T:X  d   eg r}   )r   )r   r<  r   s     rv   r9  test_cross.<locals>.test)
  s    xxAw#~~ru   c                  X    [        SSSS/5      R                  [        SSSS/5      5      $ r   r  rn   ru   rv   r   test_cross.<locals>.<lambda>3
  s*    q!aV""6!QA#78ru   )r5   r  r   r  rR   r+   )r_   r`   rk  rj  r9  r   r   r   s          @rv   
test_crossr  #
  s    AA

C
%%C FFQWWQZQWWQSS\3QSSYYqss^S!QSSYYq\3  : 9 :ru   c                  N   [        [        [        [        /5      n [        [        [
        [        /5      nU R                  5       U-  U R                  U5      :X  d   eU R                  5       R                  5       (       d   eU R                  5       R                  5       U :X  d   eg r}   )r5   rc   rd   re   r_   r`   ra   hatr  r  vee)v1v2s     rv   test_hat_veer  6
  sw    	Aq		B	Aq		B668b=BHHRL(((668%%''''668<<>Rru   c                  <   [         SS   HY  n U R                  S5      U R                  S5      1n[        U5      S:X  a%  UR                  5       U R                  S5      :X  a  MY   e   [         S S  H)  n [	        U R                  S5      [
        5      (       d  M)   e   g )Nr"  r   r   )r   r9   rd  popr   r   )r   r-  s     rv   	test_hashr  =
  s    rs|WWQZ$1v{quuw#''!*444  r{cggaj(3333 ru   c                  @   ^  [         S   m [        [        U 4S j5        g )Nr   c                  8   > [        T R                  S5      5      $ rc  )hashr9   rD  s   rv   r   !test_issue_3979.<locals>.<lambda>K
  s    4
#3ru   )r   rR   rW  rD  s   @rv   test_issue_3979r  F
  s     !*C
>34ru   c                      S[         /SS//n [        SS/[         * S//5      n[         H  nX" U 5      R                  5       :X  a  M   e   g Nr   r   )r
   r5   r   adjoint)r  r<  r   s      rv   test_adjointr  N
  sR    q6Aq6
C
1a&A2q'"
#Cc#h&&(((( ru   c                  T   SS K n U R                  R                  R                  R	                  S5      nU R                  R                  R                  U5      nS[        U-  /SU//n[        SS/[        * U-  U//5      n[         H  nXE" U5      R                  5       :X  a  M   e   g )Nr   r_   )
sympy.physics.quantumri  quantumoperatorr!   r"   r
   r5   r   r  )sympyr_   a_dagr  r<  r   s         rv   test_adjoint_with_operatorr  U
  s     &&//4AMM!!((+Eq1u:5z
"C
1a&A2:q/*
+Cc#h&&(((( ru   c                      [        [        [        [        5      S-  [	        [        5      S-  -   //5      5      [        S//5      :X  d   eg )Nr   r   )r)   r3   r   rc   r   rn   ru   rv   test_simplify_immutabler  `
  sE    Oc!fai#a&!)&;%<$=>?#aSE*+ + +ru   c                     ^^ [        S[        S9u  mm[        SSU4S j5      n [        SSU4S j5      nUR                  TT5      nX :X  d   eg )NzF, GrD  r   c                    > T" X-   5      $ r}   rn   )r   r   Gs     rv   r   test_replace.<locals>.<lambda>f
      !AC&ru   c                    > T" X-   5      $ r}   rn   )r   r   rz  s     rv   r   r  g
  r  ru   )r   r   r5   replace)Kr   Nrz  r  s      @@rv   test_replacer  d
  sI    6x(DAqq!()Aq!()A			!QA6M6ru   c                     [        SS/[        SS[        -  -
  //5      n U R                  5       [        R                  [        S5      [        R
                  [        1:X  d   eU R                  [        5      [        1:X  d   eg r   )r5   rc   atomsr   r  NegativeOner   r  s    rv   
test_atomsr  l
  sb    AA!G%&A779qtAMM15555776?qc!!!ru   c            	        ^	 [        [        [        /[        [        //5      n [        U R                  SS95      [        U R                  5       5      :X  d   e[        SS/SS/SS//5      [        / S	Q/ S
Q/5      [        [        [        /5      /nU Hd  nUR                  SS9nX#-  nX2-  n[        XB-  5      U:X  d   e[        XS-  5      U:X  d   eUR                  U:X  d   eUR                  U:X  a  Md   e   U Hm  n[        UR                  SS95      nX#-  nX2-  n[        XB-  5      U:X  d   e[        XS-  5      U:X  d   eUR                  U:X  d   eUR                  U:X  a  Mm   e   SSK	J
m	  U R                  SS9nU R                  5       n[        S[        S[        S[        S0n[        U	4S j[        UR                  U5      UR                  U5      5       5       5      (       d   eg )NRDr  r  h   i  r   r   r   )r   r   r   )r  rS     EDr   )compi_ib,  i  ij  c              3   r   >#    U  H,  u  pT" UR                  5       UR                  5       5      v   M.     g 7fr}   r   )r   r   r   r  s      rv   r   test_pinv.<locals>.<genexpr>
  s0      
3DA 	QSSUACCE3s   47)r5   r_   r`   ra   rb   r)   pinvr8  rQ  sympy.core.numbersr  r   zipr#  )
A1Asr   A_pinvAApApAr2  wrepsr  s
            @rv   	test_pinvr  r
  s   	!Q!Q 	!BBGG4G()Xbffh-???? 2s)dAYQ0
1
)\*
+
!Q.
B t$jj A%%%%///uu||uu||  !&&&-.jj A%%%%///uu||uu||  (
tA
Avq%E1e4D 
taffTl3
 
 
 
 
ru   c            	          [        / SQ/ SQ/ SQ/ SQ/ SQ/ SQ/5      /n U  HI  nUR                  SS9nX-  nX!-  nUR                  U:X  d   eS	 nU" UR                  U5      (       a  MI   e   g )
N)=   r  7   r  rm   r   )>   r   U   r  r   r   )E   8   rS  r   6   r   )r   r  [   )   rm   r   )r   r  r   r   Z   r   )r   r   r   r   r   r   r  r  c                     U R                  [        5      nU Vs0 s H  o3UR                  5       _M     nnX-
  R                  U5      R                  5       n[	        S U 5       5      $ s  snf )Nc              3   >   #    U  H  n[        U5      S :  v   M     g7f)g|=Nr   r   r  s     rv   r   Xtest_pinv_rank_deficient_when_diagonalization_fails.<locals>.allclose.<locals>.<genexpr>
  s     ;{!s1v~{s   )r  r%   r  rG  r   )M1r  rootofsrd  rootofs_approxdiff_approxs         rv   allcloseEtest_pinv_rank_deficient_when_diagonalization_fails.<locals>.allclose
  s]    hhv&G4;<GqlGN<7,,^<BBDK;{;;; =s   A))r5   r  rQ  )r  r   r  r  r  r  s         rv   3test_pinv_rank_deficient_when_diagonalization_failsr  
  s    
 	#####  	!
B t$jjuu||	< s####- ru   c                      [        SS5      [        SS5      -   [        SS/ 5      :X  d   e[        SS5      [        SS5      -   [        SS/ 5      :X  d   eg r  )r<   r5   rn   ru   rv   test_issue_7201r  
  sR    1:Q
"fQ2&66661:Q
"fQ2&6666ru   c                      [         [        [        [        4 H(  n U " [        /S//5      R
                  [        1:X  a  M(   e   g r   )r3   r4   r5   r6   rc   free_symbolsr3  s    rv   test_free_symbolsr  
  s9    3V\I1#s}))aS000 Jru   c                    ^   SSK Jm   [	        T " / SQ5      5      [	        / SQ5      :X  d   e[	        T " / SQ/5      5      [	        / SQ/5      :X  d   e[	        T " / SQ/ SQ/5      5      [	        / SQ/ SQ/5      :X  d   e[	        T " [
        [        [        /5      5      [	        [
        [        [        /5      :X  d   e[        [        U 4S j5        [	        T " SS/5      T " S	S
/5      /5      [	        SS/S	S
//5      :X  d   e[	        T " SS/5      S	S
//5      [	        SS/S	S
//5      :X  d   e[	        T " / 5      T " / 5      /5      [	        SS/ 5      s=:X  a  [	        SS/ 5      :w  d   e   eg! [         a    [        S5         GN~f = f)zSee issue 7465.r   array?NumPy must be available to test creating matrices from ndarraysr   rp  c                  B   > [        T " SS/SS//SS/SS///5      5      $ )	Nr   r   r   r   r   r   r   r   r   r  s   rv   r   #test_from_ndarray.<locals>.<lambda>
  s.    u1v1v.!Q!Q0@ABCru   r   r   r   r   N)
numpyr  ImportErrorrU   r5   rc   rd   re   rR   NotImplementedErrorr  s   @rv   test_from_ndarrayr  
  s{   P %	"#vi'8888%$%)<<<<%I./0	9%&' ' '%Aq	"#vq!Qi'8888
CE5!Q=%A-01VaVaV<L5MMMM5!Q=1a&)*fq!fq!f5E.FFFF59eBi()VAq"-=Q1bAQQQQQQ  PNOPs   E/ /FFc                  r   SSK Jn    SSKJnJn  U " W" SS/SS//5      5      nUS   S:X  d   e[        U5      / S	Q:X  d   e[        [        5         U " W" SS/SS//5      5      nS S S 5        US   S:X  d   e[        U5      / S	Q:X  d   eg ! [
         a    [        S5         Nf = f! , (       d  f       NH= f)
Nr   
_matrixify)r  matrixzPNumPy must be available to test indexing matrixified NumPy ndarrays and matricesr   r   r   r   r  )
sympy.matrices.commonr  r  r  r  r  rU   r   rQ   PendingDeprecationWarning)r  r  r  r   s       rv   test_17522_numpyr  
  s    0a' 	51a&1a&)*+AQ41997l"""	2	3v1v1v./0 
4Q41997l"""  a_`a 
4	3s   B B(B%$B%(
B6c                      SSK Jn    SSKJn  U " W" SS/SS//5      5      nUS   S	:X  d   e[        U5      / S
Q:X  d   eg ! [         a    [        S5         NJf = f)Nr   r  )r  zEmpmath must be available to test indexing matrixified mpmath matricesr   r   r   r         @)r  g       @r   r  )r  r  mpmathr  r  rU   r   )r  r  r   s      rv   test_17522_mpmathr  
  sk    0V! 	6Aq6Aq6*+,AQ43;;7****  VTUV   A AAc                      SSK Jn    SSKJn  U " W" SS/SS//5      5      nUS   S:X  d   e[        U5      / S	Q:X  d   eg ! [         a    [        S5         NJf = f)
Nr   r  )
csr_matrixzJSciPy must be available to test indexing matrixified SciPy sparse matricesr   r   r   r   r  )r  r  scipy.sparser  r  rU   r   )r  r  r   s      rv   test_17522_scipyr  
  sj    0[+ 	:1v1v./0AQ41997l"""  [YZ[r  c                  H   [        S[        /[        * S//5      n U R                  (       d   eS[        -  U S'   U R                  SL d   e[        U S'   U R                  b   eU S   [        -  U S'   U R                  SL d   e[	        S5      n[        S5      n[        U//5      R                  S	L d   e[        X/[        U5      U//5      R                  S	L d   e[        X/X!//5      R                  SL d   e[        X/[        U5      U//5      R                  SL d   eg )
Nr   r   r   Fr   r   r`   ra   T)r5   r
   is_hermitianrc   r    r!   r"   r   r  s      rv   test_hermitianr    s$   A!Q !A>>>cAdG>>U"""AdG>>!!!gaiAdG>>U"""#AAA3%=%%---A6F1Iq>*+88D@@@A6A6"#00E999A6IaL!,-.;;uDDDru   c                      [        [        [        [        SS9//5      n U S   S[        -  :w  d   eU R                  " 5       [        S[        -  //5      :X  d   eg )NFr  r   r   )r5   r   rc   r$  r  s    rv   	test_doitr    sO    Qq5)*+,AQ41Q3;;668v!ug&&&ru   c                    ^^ [        / SQ/ SQ/ SQ/5      n U R                  S5        U [        / SQ/ SQ/5      :X  d   e[        / SQ/ SQ/ SQ/5      nUR                  S5        U[        / SQ/ SQ/5      :X  d   e[        / SQ/ SQ/ SQ/5      nUR                  " S5        U[        / SQ/ SQ/5      :X  d   e[        / SQ/ SQ/ SQ/5      m[        [        U4S	 j5        [        / SQ/ SQ/ SQ/5      m[        [        U4S
 j5        [        / SQ/ SQ/ SQ/5      n U R	                  S5        U [        SS/SS/SS//5      :X  d   e[        / SQ/ SQ/ SQ/5      nUR	                  S5        U[        SS/SS/SS//5      :X  d   e[        / SQ/ SQ/ SQ/5      m[        [        U4S j5        [        / SQ/ SQ/ SQ/5      m[        [        U4S j5        g )Nr   r  r   r   r"  )r   r   r   )r   r   r  r  c                  &   > T R                  S5      $ r  row_delr:  s   rv   r   +test_issue_9457_9467_9876.<locals>.<lambda>&      qyy}ru   c                  (   > T R                   " S5      $ Nr
  r  rX   s   rv   r   r  (      qyy~ru   r   r   r   r   c                  &   > T R                  S5      $ r  col_delr  s   rv   r   r  2  r  ru   c                  (   > T R                   " S5      $ r  r  rX   s   rv   r   r  4  r  ru   )r5   r  rR   r  r  )r   r  r^   r:  rY   s      @@rv   test_issue_9457_9467_9876r    s   	9i01AIIaL	9-....	9i01AIIbM	9-....	9k23AIIbM	9-....	9i01A
:,-	9i01A
:-. 		9i01AIIaLAAA/0000	9i01AIIbMAAA/0000	9i01A
:,-	9i01A
:-.ru   c                  ,   [        SSS9u  p[        S5      u  p#[        S5      n[        SSXU[        /5      nX-  U-  X-  U-  :w  d   eX2-  U-  X#-  U-  :X  d   eX-  XP-  :w  d   eX%-  XR-  :X  d   eX-  U-  [        X-  S/SX-  //5      :X  d   eg )Nrc  F)commutativeza br   r   )r   r9   r5   re   )rc   rd   r_   r`   r   r  s         rv   test_issue_9422r  6  s    5e,DA5>DAAA	1qQl	#B3q5ACE>>3q5ACE>>424<<424<<3q5FQS!Hq!#h/0000ru   c                  :   [        / 5      n SS/[        / SQ5      4nSS/US   R                  4nSS/[        SS/SS	//5      4nXU4 HO  u  pEU HD  n[        X5      nS
U;   a  U" U5      OU" SU5      nX:X  a  [        U5      [        U5      :w  a  MD   e   MQ     g )Nr~  rw  )r   r   r   r{  ry  r   r   r   r   joinrg  )r5   r  r  id)	r   r_   r`   ra   opsr   opr:  news	            rv   test_issue_10770r&  B  s    r
A	z"F9$55A	z"AaDFF*A	|$fq!fq!f-=&>>A)BA B,!A$Ab!HC832a5 000  ru   c                  r   [        / SQ/ SQ/ SQ/5      n U R                  / SQ/ SQ5      [        SS/SS	/S
S//5      :X  d   eU R                  / SQ/ SQ5      [        S/S/S
//5      :X  d   eU R                  / SQ/ SQ5      [        / SQ/5      :X  d   eU R                  / SQ/ SQ5      [        / SQ/ SQ/5      :X  d   eU R                  / SQ/ SQ5      [        SS/ 5      :X  d   eU R                  / SQ/ SQ5      [        SS/ 5      :X  d   eU R                  / SQ/ SQ5      [        S/S//5      :X  d   eg )Nr   rp  r  r   )TTFr   r   r   r   r   r   )TFF)TFT)FFFr   r   )FTF)r5   r   r  s    rv   test_issue_10658r(  N  s8   	9i01A99Y 34AAA'() ) )99Y 45!qcA39PPPP99)959LLLL99()4	9%&' ' '99Y 56&Ar:JJJJ99*I6&Ar:JJJJ99(*>?aSz  ru   c                     [        SS[        S5      -  -   S/S[        S5      -  S-  S-   S[        S5      -  S-  //5      n U R                  5       S:X  d   e[        SS[        S5      -  [        -  -   S/SSS[        S5      -  [        -  -   //5      n [	        U R                  5       S	   [        SSSS[        S5      -  [        -  -   -  /S	S	//5      -
  5      [        SS5      :X  d   e[        S
5      u  pp4pVpxpp[        XX-  X+-  S	/X4X;-  XK-  S	/XVX[-  Xk-  S/XxX{-  X-  S/XSU	-  U-  X-  -
  SU
-  U-  X-  -
  S	//5      n U R                  5       S:X  d   eg )Nr^  r   r   r   r   r'  r   r   r   /a_x a_y b_x b_y c_x c_y d_x d_y e_x e_y t_0 t_1)r5   r   r  r
   r)   ra  rB   r   )r   axaybxbycxcydxdyexeyt0t1s                rv   !test_opportunistic_simplificationr7  [  s    	aQi$r$q'z!|a'7DGA&FGHA668q== 	1T!W9Q;#Qr!DG)A+~$678AAFFHQK&1b!aQik/.B*CaV)L"MMNRWXY[\R]]]] +22c*d'B"bB"ruRU1%rRU25&;R25q<QSUY[Y^_a_defRgikopqsostvovwyw|o|}~  @B  ~B  CE  ~E  FH  FK  ~K  LM  iN  O  	PA668q==ru   c                     [        / SQ/ SQ/5      n U R                  5       S   [        / SQ/ SQ/5      -
  R                  5       S:  d   e[        / SQ/ SQ/ S	Q/5      n[        / S
Q/ SQ/ SQ/5      n[        / SQ/ SQ/ S	Q/5      nUR                  5       U-
  R                  5       S:  d   eUR                  5       U-
  R                  5       S:  d   eg )N)g~jth?gRM@g(\M@)gDl)@gQgp=
cG@r   )r  r   r  )r   r  r  V瞯<)q7K<r  r   )      r   r   r  )r:  r  r  )r;                 @)r<  r<  r  )r   r;  r=  )r  r:  g      )r5   ra  r  r8  )mmm_mixedm_floatm_invs       rv   test_partial_pivotingrB  k  s    
 $&;<=BGGIaL6#3#3#5 6 67;tvF F F o%%' (G ''') *G (((* +E
 KKME!'')E111KKME!'')E111ru   c                      [        / SQ/ SQ/ SQ/5      n U R                  S S9S   n[        / SQ/ SQ/ S	Q/5      nX-
  nUR                  5       S
:  d   eUS   S:X  d   eg)zWhen doing numerical computations, all elements that pass
the iszerofunc test should be set to numerically zero if they
aren't already. )?皙gɿr   )皙rD  gٿr   )rE  rF  g333333?r   c                     [        U 5      S:  $ )Ng [n<r  r  s    rv   r   *test_iszero_substitution.<locals>.<lambda>  s    Qru   r  r   )r  r   g4iҤIӿr   )r   r  glٲer   r  r9  r  N)r5   ra  r  )r   m_rref	m_correctm_diffs       rv   test_iszero_substitutionrL    sp     	$%9:NOPAVV5V6q9F9:[\}~IF;;=5   #;!ru   c            	         SSK Jn   S[        [        [	        SS5      -  5      -  [        [        [	        SS5      -  5      [        S5      -   -  nS[        S5      -  [        [        [	        SS5      -  5      S-  -  S	[        [        [	        SS5      -  5      -  -   S
[        [        [	        SS5      -  5      S-  -   -  nU " SS5      nU " S[        S5      * 5      nU " X5      n[        U[        U5      -
  U[        U5      -
  /5      n[        X5-
  XE-
  /5      n[        [        X5-
  5      [        XE-
  5      /5      nS n	UR                  SU	S9S:X  d   eUR                  SU	S9S:X  d   eUR                  SU	S9S:X  d   eg )Nr   )Pointr   r  -   r   r(  r   r   r   r   c                 <    [        U R                  " 5       5      S:  $ )Ng#B;)r   r   r  s    rv   r   "test_issue_11238.<locals>.<lambda>  s    #acce*u$ru   T)r)   r  )	sympy.geometry.pointrN  r   r   r   r   r5   r)   r  )
rN  xxyyp1p2p0r  r  m3Zs
             rv   test_issue_11238rZ    sx   *	
3r(2r""#	#SHR,<)<%=Q%G	HB
T!W*SHR,,-q0
02c"Xb"=M:M6N3N
NQSVYZ\]efhjl]mZmVnpqVqQq	rB	q!B	q47(	B	rB	hrl"B"$56	7B	"'"	#B	"'"HRW$56	7B
 	%A77DQ7/144477DQ7/144477DQ7/1444ru   c                     [        SS/ SQ5      n U [        R                  -  nX-   n[         HO  nU" U5      R	                  5       u  pE[        U5      [        U 5      :X  d   e[        U5      [        U 5      :X  a  MO   e   g )Nr   r  )r5   r   ImaginaryUnitr   as_real_imagr   )r  r  rX  klsr_   r`   s         rv   test_as_real_imagr_    so    	!I	B	AOO	B	B"g""$Aw$r("""Aw$r(""" ru   c                      [        SS/ SQ5      n U R                  5       u  pUS   [        SSS/5      :X  d   eUS   [        SS/ SQ5      :X  d   eg )Nr   r%  r   r   r   )r   r   r   r   )r5   jordan_cells)r   r:  Jcellss      rv   test_deprecatedrc    sY    
 	q!23A IA!9q!aS))))!9q!\2222ru   c                      SSK Jn   [        / SQ5      n[        / SQ5      nU " US5      [        / SQ5      :X  d   eU " US5      [        / SQ5      :X  d   eg )	Nr   )Mod)r  r   r   )r   r  r&  r   )r   r   r   r   )r   r   r   )sympy.core.modre  r5   )re  r   r   s      rv   test_issue_14489rg    sK    "zA}Aq!9y))))q!9y))))ru   c                       SSK Jn   [	        SS/SS//5      nW " U[
        S9R                  R                  S	:X  d   eg ! [         a    [        S5         NNf = f)
Nr   r  r  r   r   r   r   )dtypefloat64)r  r  r  rU   r5   floatri  name)r  r   s     rv   test_issue_14943rm    s`    P 	1!u~A% &&++y888	  PNOPs   ? AAc                  f    [        SSS5      n [        S5      nU S   S:  n[        U5      S:X  d   eg )Nr   r   r_   r   r   zm[0, 0] > 0)rE   r   r:  )r   r_   s     rv   test_case_6913ro    s8    S!QAsA	$	Aq6]"""ru   c                  d    [        SSS5      n [        S5      nU R                  U5      X0:X  d   eg )Nr   r   r_   )rE   rL   match)r   r_   s     rv   test_issue_11948rr    s1    S!QAS	A771:!ru   c                  j   [        S[        /5      [        S[        * /5      /n [         R                  " U 6 [        S/[        //5      [        S/[        * //5      /:X  d   e[        S[        S/5      [        [        S[        * /5      /n [         R                  " U 6 [        S/[        /S//5      [        [        S-  /[        S5      S-  /[        * //5      /:X  d   e[        S[        /S[        * //5      nUR	                  5       u  p#X"R
                  -  [         R                  " S5      :X  d   eg )Nr   r   r   )r5   r
   orthogonalizer   QRdecompositionrQ  r9   )vecsr   rY   r0  s       rv   test_gramschmidt_conjugate_dotrw    s#   Aq6NFAr7O,D&	!qc
	VaSA2$K012 2 2 Aq!9vq!aRj12D&	!qcA3	 &1Q3%!A$q&QB4)@"ABC C C 1a&1qb'"
#C DAss7fjjm###ru   c                      [        [        SSS5      5      n [        [        SSS5      5      nU R                  " U5      n[        X S   5      n[        X0S   5      nX1S   :X  d   eUS:X  d   eg )Nr_   r   r   r`   r   r   )r5   rE   r  r   )r_   r`   ra   rb   r  s        rv   test_issue_8207ry    sj    |CA&'A|CA&'A	aAQ$AQ$A$<<6M6ru   c            	        ^ SSK Jn   [        SS/SS//5      mTR                  [	        [
        [        -  5      [
        5      [        [	        [        5      [	        S[        -  5      [	        [        5      -
  /S[	        S[        -  5      //5      :X  d   e[        SS/SS//5      m[        T-  S-  R                  [        [
        5      [
        5      [        [        S5      S-  [        S5      * S-  /[        S5      * S-  [        S5      S-  //5      :X  d   e[        [        S 5        [        [        U4S	 j5        [        / S
Q/ S
Q/ SQ/ SQ/5      mTR                  [        [
        5      [
        5      TR                  5       :X  d   e[        [        U4S j5        [        SS/SS//5      m[        TR                  [        [
        5      [
        5      S-  5      T:X  d   e[        / SQ/ SQ/ SQ/5      m[        TR                  U " [
        S5      [
        5      S-  5      T:X  d   e[        / SQ/ SQ/ SQ/ SQ/5      mTR                  [        [
        5      [
        5      TR                  5       :X  d   e[        / SQ/ SQ/ SQ/ SQ/5      mTR                  [        [
        [        -  5      [
        5      [        [        T[        -  R                  5       5      5      :X  d   eg )Nr   )nthrootr   r   r   r   r   c                  Z    [        S5      R                  [        [        5      [        5      $ r  )rB   analytic_funcr   rc   rn   ru   rv   r   test_func.<locals>.<lambda>  s    a 6 6s1vq Aru   c                  X   > T [         -  R                  [        [         5      [         5      $ r}   )rc   r}  r   r  s   rv   r   r~    s    1 3 3CFA >ru   )r   r  r"  r   )r   r   r   r  )r   r   r  r   c                  J   > T R                  [        [        5      [        5      $ r}   )r}  r   rc   r  s   rv   r   r~    s    Q ;ru   r  r   "   )r   r  r   )r  r   r"  )r  r   r  r   )r   r   r   r   )r   r   r   r   )r   r   r   r   )r   r   r   r   )r   r   r   r   )r   r   r   r   r  )sympy.simplify.simplifyr{  r5   r}  r   rc   rf   r   r   r   rR   r/  r   r)   r   )r{  r   s    @rv   	test_funcr    sD   /A1vA??3qs8Q'6CFC!Hs1v<M3NQRTWXYZ[X[T\P]2^+____A1vAFQJ%%c!fa0FT!WQYaQR
<SW[\]W^V^_`V`bfghbijkbkUl;m4nnnn :AB
:>?}MNA??3q61%000
:;<R"b"#AAOODGQ/23q888[+67AAOOGAqM15q89Q>>>lL,GHA??3q61%000lL,GHA??3qs8Q'6(AaC99;2G+HHHHru   z$Cannot create threads under pyodide.c                     S n [        S5         [        R                  R                  5        nUR	                  U 5      nUR                  5       (       d   e S S S 5        S S S 5        g ! , (       d  f       N= f! , (       d  f       g = f)Nc                  R    [         R                  S :X  d   e[        S//5      n X -  n gr6  )rJ   stater5   r  s    rv   r:  test_issue_19809.<locals>.f  s-    !''4///QC5MEru   T)rF   
concurrentfuturesThreadPoolExecutorsubmitresult)r:  executorfutures      rv   test_issue_19809r  
  s`     
T	224__Q'F==??"? 5 
	44 
	s"   A:)A)A:)
A7	3A::
Bc                      [        [        [        /5      n [        U [        SS4[        SS45      [        [        R
                  /[        R
                  //5      :X  d   eg r  )r5   rc   rd   r   r   r,  r3  s    rv   test_issue_23276r    sT    1vAQAq	Aq!9-	
	
9 2   ru   c                  N   [        / SQ/ SQ/ SQ/ SQ/5      n U R                  5       nUS   [        / SQ5      :X  d   eUS   [        / SQ5      :X  d   eUS	   [        / S
Q5      :X  d   e[        U5      S:X  d   e[        R                  " U /UQ76 R                  5       U:X  d   eg )Nr   r   r   r   r   r"  r^  r   r  r(  r   r   r   r   r   r   r   r   r  r   r   )r   r"  r   r   r   )r   r^  r   r   r   )r   r  r   r  r   )rl   r  r5   rd  r  r   basiss     rv   test_columnspace_oner  !  s    00002 	3A
 MMOE8vm,,,,8vn----8vn----u:??==#U#//1U:::ru   c                      [        / SQ/ SQ/ SQ/ SQ/5      n U R                  5       nUS   [        / SQ/5      :X  d   eUS   [        / SQ/5      :X  d   eUS   [        / S	Q/5      :X  d   e[        U5      S
:X  d   eg )Nr  r  r  r  r   r   )r   r  r   r   r   r   )r   r   r   r   r   r   )rl   r|  r5   rd  r  s     rv   test_rowspacer  0  s    00002 	3A
 JJLE8v/00008v/011118v/0000u:??ru   c                  "   [        / SQ/ SQ/ SQ/ SQ/5      n U R                  5       nUS   [        / SQ5      :X  d   eUS   [        / SQ5      :X  d   e[        S	 XS   -   5       5      (       d   e[        S
 XS   -   5       5      (       d   eg )Nr  r  r  r  r   )r"  r   r   r   r   r   )r  r  r   r  r   c              3   8   #    U  H  oR                   v   M     g 7fr}   r  r  s     rv   r   %test_nullspace_one.<locals>.<genexpr>H       -*Qyy*   c              3   8   #    U  H  oR                   v   M     g 7fr}   r  r  s     rv   r   r  I  r  r  )rl   r  r5   r   r  s     rv   test_nullspace_oner  >  s    00002 	3A
 KKME8v.////8v01111-!!H*------!!H*-----ru   c                    ^ [        S5      m[        [        U4S j5        [        [        U4S j5        [        [        U4S j5        [        [        U4S j5        [        [        U4S j5        [        [        U4S j5        [        [        U4S j5        [        [        U4S	 j5        [        [        U4S
 j5        [        [        U4S j5        [        [        U4S j5        [        [        U4S j5        [        [        U4S j5        TR                  SSS5      [	        / SQ/ SQ/ SQ/5      :X  d   eTR                  SSS5      [	        / SQ/ SQ/ SQ/5      :X  d   eTR                  SSSS9[	        / SQ/ SQ/ SQ/5      :X  d   eTR                  SSSS9[	        / SQ/ SQ/ SQ/5      :X  d   eTR                  SSS5      [	        / SQ/ SQ/ SQ/5      :X  d   eTR                  SSSS9[	        / SQ/ SQ/ SQ/5      :X  d   eTR                  SSSS9[	        / SQ/ SQ/ SQ/5      :X  d   eTR                  SSSS5      [	        / SQ/ SQ/ SQ/5      :X  d   eTR                  SSSSS9[	        / SQ/ SQ/ SQ/5      :X  d   eTR                  SSSSS 9[	        / SQ/ SQ/ SQ/5      :X  d   e[        S!SS/S"-  5      n U R                  " SSS5      [	        S!SS/S"-  5      :X  d   eU R                  " SSS5      [	        S!SS/S"-  5      :X  d   eU R                  " SSSS5      [	        S!SS/S"-  5      :X  d   eg )#Nr   c                  &   > T R                  S5      $ Nabcelementary_row_opr  s   rv   r   test_row_op.<locals>.<lambda>P      q2259ru   c                  $   > T R                  5       $ r}   r  r  s   rv   r   r  Q      q224ru   c                  &   > T R                  SSSS9$ )Nn->knr   rj  r   r  r  s   rv   r   r  R      q227Q2Gru   c                  &   > T R                  SSSS9$ )Nr  r^  r   r  r  r  s   rv   r   r  S      q227a2Hru   c                  &   > T R                  SSSS9$ )Nn<->mr   r   row1row2r  r  s   rv   r   r  T      q2272Kru   c                  &   > T R                  SSSS9$ )Nr  r   r   r  r  r  s   rv   r   r  U  r  ru   c                  &   > T R                  SSSS9$ )Nr  r^  r   r  r  r  s   rv   r   r  V      q227!2Lru   c                  &   > T R                  SSSS9$ )Nr  r   r^  r  r  r  s   rv   r   r  W      q2272Lru   c                  (   > T R                  SSSSS9$ Nn->n+kmr   r   r  r  r   r  r  s   rv   r   r  X      q22911PQ2Rru   c                  (   > T R                  SSSSS9$ )Nr  r   r   r  r  r  s   rv   r   r  Y  r  ru   c                  (   > T R                  SSSSS9$ )Nr  r^  r   r   r  r  r  s   rv   r   r  Z      q2292AQR2Sru   c                  (   > T R                  SSSSS9$ )Nr  r   r^  r   r  r  r  s   rv   r   r  [      q22912QR2Sru   c                  (   > T R                  SSSSS9$ r  r  r  s   rv   r   r  \  r  ru   r  r   r   r  r  r  r   rZ  r[  r  )r  r   r  r  )rj  r  r  )r   r   r   )rj  r   r  )r  r   r  r   r   )r   rR   r/  r  r5   ry   r_   r  s    @rv   test_row_opr  M     qA
:9:
:45
:GH
:HI
:KL
:KL
:LM
:LM
:RS
:RS
:ST
:ST
:RS w1-Iy8Y1ZZZZw1-Iy8Y1ZZZZwA3vy)U^>_7````wQ!4	9V_?`8aaaaw1-Iy8Y1ZZZZwQQ769iYbBc;ddddwAA6&)YXaAb:ccccy!Q2fiT]=^6____ya11=T]_hHiAjjjjyqAA>&)U^`iIjBkkkk 	QA3q5)Aw1-1qc!e1DDDDw1-1qc!e1DDDDy!Q2fQA3q56IIIIru   c                    ^ [        S5      m[        [        U4S j5        [        [        U4S j5        [        [        U4S j5        [        [        U4S j5        [        [        U4S j5        [        [        U4S j5        [        [        U4S j5        [        [        U4S	 j5        [        [        U4S
 j5        [        [        U4S j5        [        [        U4S j5        [        [        U4S j5        [        [        U4S j5        TR                  SSS5      [	        / SQ/ SQ/ SQ/5      :X  d   eTR                  SSS5      [	        / SQ/ SQ/ SQ/5      :X  d   eTR                  SSSS9[	        / SQ/ SQ/ SQ/5      :X  d   eTR                  SSSS9[	        / SQ/ SQ/ SQ/5      :X  d   eTR                  SSS5      [	        / SQ/ SQ/ SQ/5      :X  d   eTR                  SSSS9[	        / SQ/ SQ/ SQ/5      :X  d   eTR                  SSSS9[	        / SQ/ SQ/ SQ/5      :X  d   eTR                  SSSS5      [	        / SQ/ SQ/ SQ/5      :X  d   eTR                  SSSSS9[	        / SQ/ SQ/ SQ/5      :X  d   eTR                  SSSSS 9[	        / SQ/ SQ/ SQ/5      :X  d   e[        S!SS/S"-  5      n U R                  " SSS5      [	        S!SS/S"-  5      :X  d   eU R                  " SSS5      [	        S!SS/S"-  5      :X  d   eU R                  " SSSS5      [	        S!SS/S"-  5      :X  d   eg )#Nr   c                  &   > T R                  S5      $ r  elementary_col_opr  s   rv   r   test_col_op.<locals>.<lambda>t  r  ru   c                  $   > T R                  5       $ r}   r  r  s   rv   r   r  u  r  ru   c                  &   > T R                  SSSS9$ )Nr  r   rk  r   r  r  s   rv   r   r  v  r  ru   c                  &   > T R                  SSSS9$ )Nr  r^  r   r  r  r  s   rv   r   r  w  r  ru   c                  &   > T R                  SSSS9$ )Nr  r   r   col1col2r  r  s   rv   r   r  x  r  ru   c                  &   > T R                  SSSS9$ )Nr  r   r   r  r  r  s   rv   r   r  y  r  ru   c                  &   > T R                  SSSS9$ )Nr  r^  r   r  r  r  s   rv   r   r  z  r  ru   c                  &   > T R                  SSSS9$ )Nr  r   r^  r  r  r  s   rv   r   r  {  r  ru   c                  (   > T R                  SSSSS9$ Nr  r   r   r  r  r   r  r  s   rv   r   r  |  r  ru   c                  (   > T R                  SSSSS9$ )Nr  r   r   r  r  r  s   rv   r   r  }  r  ru   c                  (   > T R                  SSSSS9$ )Nr  r^  r   r   r  r  r  s   rv   r   r  ~  r  ru   c                  (   > T R                  SSSSS9$ )Nr  r   r^  r   r  r  r  s   rv   r   r    r  ru   c                  (   > T R                  SSSSS9$ r  r  r  s   rv   r   r    r  ru   r  r   r   r  r  r  r   rZ  r[  r  )r  r   r  r  )rk  r  r  )r   r   r   )rk  r   r  )r  r   r  r   r   )r   rR   r/  r  r5   ry   r  s    @rv   test_col_opr  q  r  ru   c                  (   [        S5      n [        S5      nU R                  (       d   eUR                  (       d   e[        SS/ 5      nUR                  (       d   e[        SS/ SQ5      nUR                  (       d   e[        SS/ SQ5      nUR                  (       a   e[	        S5      n[        SSUSS/5      nUR                  (       d   e[        SSX3S/5      nUR                  (       a   e[        SS/ SQ5      nUR                  (       a   eg )	Nr   r   r   )r   r   r   r   r   r   )r   r   r   r   r   r   rc   r   	r   r   r   r   r   r   r   r   r   )r   r   
is_echelonry   r   )zroidentr_   rc   s       rv   test_is_echelonr    s    
1
C1E>>>Q2&A<<<Q#56A<<<Q#56A||sAQAq!9-A<<<QA!9-A||Q#>?A|||ru   c                  Z  ^ [        S5      n [        S5      nU R                  " 5       U :X  d   eUR                  5       U:X  d   e[        SS/ 5      n U R                  " 5       U :X  d   e[        SSS/5      n U R                  " 5       U :X  d   eU4S jn[        SS/ SQ5      n [	        S/S/S//5      /n[        U R                  5       Vs/ s H  o@US S 24   PM     nnU R                  " 5       mTR                  (       d   eU" XU5        [        SS/ SQ5      n / n[        U R                  5       Vs/ s H  o@US S 24   PM     nnU R                  " 5       mTR                  (       d   eU" XU5        [        SS/ S	Q5      n [	        [        S
S5      /S/S//5      [	        [        SS5      /S/S//5      /n[        U R                  5       Vs/ s H  o@US S 24   PM     nnU R                  " 5       mTR                  (       d   eU" XU5        [        SS/ SQ5      n [	        S/S/S//5      /n[        U R                  5       Vs/ s H  o@US S 24   PM     nnU R                  " 5       mTR                  (       d   eU" XU5        [        SS/ SQ5      n [	        S/S/S//5      [	        S/S
/S//5      /n[        U R                  5       Vs/ s H  o@US S 24   PM     nnU R                  " 5       mTR                  (       d   eU" XU5        [        SS/ SQ5      n [	        S
/S/S//5      /n[        U R                  5       Vs/ s H  o@US S 24   PM     nnU R                  " 5       mTR                  (       d   eU" XU5        g s  snf s  snf s  snf s  snf s  snf s  snf )Nr   r   r   r   c                    > U H  n[        S TU-   5       5      (       a  M   e   U HF  n[        S U 5       5      (       a  M  [        S TUR                  5       -   5       5      (       d  MF   e   g )Nc              3   8   #    U  H  oR                   v   M     g 7fr}   r  r   rf   s     rv   r   Ctest_echelon_form.<locals>.verify_row_null_space.<locals>.<genexpr>  s     6+Qyy+r  c              3   8   #    U  H  oR                   v   M     g 7fr}   r  r  s     rv   r   r    s     ,!Qyy!r  c              3   8   #    U  H  oR                   v   M     g 7fr}   r  r  s     rv   r   r    s     J2IQyy2Ir  )r   r   )r   r   nullsr   	a_echelons       rv   verify_row_null_space0test_echelon_form.<locals>.verify_row_null_space  se    A6)A+66666 A,!,,,J)AKKM2IJJJJJ ru   r  r"  )	r   r   r   r   r   r   r   r   r   )	r   r   r   r   r   r   r   r   r   r  r   r   )	r   r   r   r   r   r   r   r   r   )	r   r   r   r   r   r   r   r   r   )r   r   r   r   r   r   )	r   r   ry  ry   r5   r   r   r  r   )r_   r  r  r  r   r   r  s         @rv   test_echelon_formr    s   
 	AqA >>q   >>q   Q2&A>>q   QA3'A>>q   K 	Q#>?ATTT  E #166]+]adG]D+ I!5) 	Q#>?AE"166]+]adG]D+ I!5)Q#>?Ar1oVV  r1oVV 	E #166]+]adG]D+ I!5) 	Q#>?AVVV  E #166]+]adG]D+ I!5)Q#>?ASSS  TTT 	E #166]+]adG]D+ I!5)Q#56ATSS  E #166]+]adG]D+ I!5)y , , , , , ,s$   N5NNNN#N(c                     [        SS/ 5      n U R                  SS9U :X  d   e[        SSS/5      n [        SSS/5      nU R                  SS9UR                  " SS9s=:X  a  U :X  d   e   e[        SS/ SQ5      nUR                  " SS9[        S/S/S//5      :X  d   e[        SS/ SQ5      nUR                  " SS9[        / SQ/5      :X  d   e[        SS/ SQ5      nUR                  " SS9[        / S	Q/ S
Q/ SQ/5      :X  d   e[        SS/ SQ5      n[        SS/ SQ5      n[        SS/ SQ5      n[        SS/ SQ5      nUR                  " SS9UR                  " SS9s=:X  a1  UR                  " SS9s=:X  a  UR                  " SS9s=:X  a  U:X  d   e   e[        S5      n [	        S5      nU R                  SS9U :X  d   eUR                  " SS9U:X  d   e[        / SQ/ SQ/ SQ/ SQ/5      nUR                  " 5       u  pgU[        / SQ/ SQ/ SQ/ SQ/5      :X  d   eUS:X  d   e[        [        SS5      [        SS5      SS// SQ/ SQ/ SQ/5      nUR                  " SS9[        SSS[        SS5      /SSS[        S S5      /SSS[        S!S5      // S"Q/5      :X  d   e[        S#5      n[        SSUSS[        U5      US/5      n[        UR                  " SS9SS[        U5      U* S-   -  U[        SS5      -  * U-   -  SSS[        U5      U-   S-   -  /5       H#  u  p[        X-
  5      R                  (       a  M#   e   g )$Nr   F)pivotsr   r   r   r   r  )r   r   r  r   r   )	r   r   r   r   r   r   r   r   r   )	r   r   r   r   r   r   r   r   r   r  )	r   r   r   r   r   r   r   r   r   )r   r   r   r   r   r^  r   )r  r   r   r   r   r  r   )r   r   r"  r   r   r   r^  )r  r   r   r  r"  r   r   )r   r^  r   r   r   r   r  )r   r   r   r   r   r  r   )r   r   r   r   r   r"  r   )r   r   r   r   r   r   r   )r   r   r   r  r   r  r  r  i   r^     r  rc   )ry   ra  r5   r   r   r   r   r   r  r)   r  )r  r_   r`   ra   rb   re   r   pivot_offsetsrc   r   r   s              rv   	test_rrefr    s   Q2&A6661$$$QA3'AQA3'A666166#7<1<<<<<Q9-A666A3aS/#::::Q9-A6669+#6666Q#>?A666%/%/%/+1 $2 2 2 2
 	Q#>?AQ#>?AQ#>?AQ#>?A66FF% &FF% & FF% & %&& & & & &
 	qAA6661$$$661$$$''''	) 	*A
 C&----	/ 0 0 0 0
 I%%%x2!QA!L0002 	3A 666*+Q8C3E)F*+QHR4E)F*+Q8C3E)F);	+= $> > > > 	sAQAq!T!Wa#;<AAFF%(47QBF#a!Q&7%7!%;<1aa1q)+, &&&&&,ru   c                  
   [        S5      u  pp#[        SS/SS/SS/SS//5      n[        XX#/5      nUR                  U5      [        SS/SS/SS/SS//5      [        SU-  U-   /SU-  S-  US-  -
  /U /U//5      4:X  d   eg )Nr  r   r   r   r   r   r"  )r   r5   rref_rhs)r_   r`   ra   rb   r   r   s         rv   test_rref_rhsr   P  s    #JA!AAAA/0Aa|A::a=VFFFF	%  
1qMqSUQqS[MMM	 	   ru   c            	        ^ [        / SQ/ SQ/ SQ/ SQ/ SQ/ SQ/5      mTR                  SSS	S
9n TR                  SS	SSS9nTR                  SS	SS9nU S	S S 24   [        / SQ/5      :X  d   eUS	S S 24   [        / SQ/5      :X  d   eUS	S S 24   [        / SQ/5      :X  d   e[        [        U4S j5        [        [        U4S j5        [        [        U4S j5        g )N)r   r   r  r   )r   r   r   r   )r   r   r   r   )r   r   r   r"  )r   r   r   r^  )r   r   r   r   r  r   r   r  r  r   r]  r  r  r  )r   r   r   r  )r   r  r   r   c                  &   > T R                  SSSS9$ )Nr  r   r   r  r  r   s   rv   r   "test_issue_17827.<locals>.<lambda>p  r  ru   c                  &   > T R                  SSSS9$ )Nr  r   r   r  r  r  s   rv   r   r  q  r  ru   c                  (   > T R                  SSSSS9$ )Nr  r  r   r   r  r  r  s   rv   r   r  r  r  ru   )r5   r  rR   r/  )rU  r   rz  r   s      @rv   test_issue_17827r  _  s     	A 	
G!!4A	IAA<A	Ga0AQT7fl^,,-,QT7fm_--.-QT7fo.//0/
:KL
:GH
:STru   c                  
   [        SS/[        SS[        -  -
  //5      n U R                  5       S:X  d   e[        SS[        SS5      5      nUR                  5       S:X  d   e[	        S5      nUR                  5       S:X  d   eg )Nr   r   r   r   r   )r5   rc   r  r   rB   )r   r   r1  s      rv   	test_rankr	  t  st    AA!G%&A668q==q!U1b\"A668q==aA668q==ru   c                      [        S5      u  pp#pEpgpp[        XX
-  X-  S/X#X*-  X:-  S/XEXJ-  XZ-  S/XgXj-  Xz-  S/XSU-  U-  X-  -
  SU	-  U-  X-  -
  S//5      nUR                  5       S:X  d   eg )Nr*  r   r   r   r   )r   r5   r  )r+  r,  r-  r.  r/  r0  r1  r2  r3  r4  r5  r6  r   s                rv   test_issue_11434r  |  s    AB 3BBBBBBq)q)q)q)2b25!B$r'BE/1=	? 	@A
 668q==ru   c            
         [        S5      u  p[        SU -  SSS/SU -  SU -  S-
  SS/SSU -  SU -  U-
  S-
  S/SSX-   S//5      n[        SSSSU S-  U* U -
  -  -  /SSSSX* U -
  -  -  /SSSSU* U -
  -  // S	Q/5      nS
nUR                  5       u  pV[        X5-
  5      [	        UR
                  6 :X  d   eXd:X  d   eg )Nz
nu, lambdar   r   r   r   r"  r   r  r  r   )r   r5   ra  r)   rB   r   )nulambr   expected_reducedexpected_pivotsreducedr  s          rv   test_rank_regression_from_sor    s    |$HBBA:B$2	A:QrTBrET>A#5:BIr:< 	=A 1aBED52:,>)?@ !1aAr52:,?@ !1aTEBJ@@B C  OffhOG$./5!''?BBB$$$ru   c                     [        / SQ/ SQ/ SQ/ SQ/5      n U [         R                  " S5      [        -  -
  nUR                  5       S:X  d   eUS-  R                  5       S:X  d   eUS-  R                  5       S:X  d   eg )Nr  r:  r;  r<  r   r   r   )r5   r9   r
   r  )r   r   s     rv   test_issue_15872r    sn    o~|LMA	FJJqMAA668q==qD;;=AqD;;=Aru   ([  r  concurrent.futuresr  collections.abcr   sympy.core.addr   sympy.core.functionr   r   r   r  r   r	   r
   r   r   r   r   r   sympy.core.powerr   sympy.core.singletonr   sympy.core.symbolr   r   sympy.core.sympifyr   $sympy.functions.elementary.complexesr   &sympy.functions.elementary.exponentialr   r   (sympy.functions.elementary.miscellaneousr   r   r   (sympy.functions.elementary.trigonometricr   r   r   sympy.integrals.integralsr   $sympy.matrices.expressions.transposer   sympy.physics.quantum.operatorr    r!   r"   sympy.polys.polytoolsr#   r$   sympy.polys.rootoftoolsr%   sympy.printing.strr&   sympy.sets.setsr'   r  r(   r)   sympy.simplify.trigsimpr*   sympy.matrices.exceptionsr+   r,   r-   sympy.matrices.matrixbaser/   sympy.matrices.determinantr0   sympy.matrices.utilitiesr1   sympy.matricesr2   r3   r4   r5   r6   r7   r8   r9   r:   r;   r<   r=   r>   r?   r@   rA   rB   rC   rD   rE   rF   rG   rH   rI   rJ   
sympy.corerK   rL   (sympy.functions.special.tensor_functionsrM   sympy.utilities.iterablesrN   rO   rP   sympy.utilities.exceptionsrQ   sympy.testing.pytestrR   rS   rT   rU   rV   rW   sympy.assumptionsrY   sympy.tensor.arrayrZ   $sympy.tensor.array.array_derivativesr[   sympy.matrices.expressionsr\   sympy.algebrasr]   r  r^   r-  r_   r`   ra   rb   rc   rd   re   rf   r   r  rg   rh   sympy.matrices.matricesri   rj   rl   ry   r   r   r   r   r   r   r   r   r   r   r   r1  r4  r<  r>  r@  rL  rR  rX  r[  rb  rg  rl  rq  rw  rz  r}  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r   r  r  r  r   r5  r=  rA  rE  rH  rL  rN  rR  rX  r^  r`  rn  rr  rw  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r!  r/  r5  r8  r=  rD  rK  rN  rS  rV  r^  rb  re  r  r  r  r  r  r  r  r  r  r  r  r  r
  r  r  r  r   r"  r&  r4  r<  r>  rB  rD  rG  rI  rN  rP  rT  r]  r_  ra  rd  rg  rp  r|  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r&  r(  r7  rB  rL  rZ  r_  rc  rg  rm  ro  rr  rw  ry  r  r  r  r  r  r  r  r  r  r  r  r   r  r	  r  r  r  rn   ru   rv   <module>r9     s     $  6 6 L L L   " / & 4 = E E D D / : N N 2 * # % 8 ,  4 C .L L L L L L L 8 " C @ @ 6: :  $ @ - %  , , , <2G
H B E ^_o  
 ~@P  
@6
+
!+
&
9)XDN>^JB?_*JX_
%
'
 
6%
;
5
8GP
y
	8$
)&$<<<<<K&d&K0O2dFD+84P1$
:<7Mt 8!"AG2" "$$-:&>9$"*)  
.	*F!@.6&8G$1&3@E!P
1H%V&&'"$4.L)2
!$;6z"IG
O*4(nP!%IPZz.&"FH $<">JD-;-"8
/(1
(.3(?G4\p&(*&F"7:& 4 5 5))+"*
Z "$ "$J71R$# 	+	#E '
/8	1	1 205&#3*9# 
$I< :;# <#;.!JH!JH6\*~>'BU*%(ij 
 s   Q?#R?
R
R 