
    sgo                         d dl mZmZmZ d dlmZ d dlmZmZm	Z	m
Z
mZmZmZmZ d dlmZmZmZmZ d dlmZ  ed      \  ZZZZd Zd Zd	 Zd
 Zd Zd Zd Z d Z!y)    )FloatIntegerRational)symbols)betaEizetaMaxMinsqrt
riemann_xifrac)CXX98CodePrinterCXX11CodePrinterCXX17CodePrintercxxcode)log1pzx y u vc            	      f   t               j                  t        t        d            dv sJ t               j                  t	        t        dt        t                          dk(  sJ t               } | j                  dk(  sJ | j                  dk(  sJ d| j                  v sJ d| j                  vsJ y )N   )zstd::max(x, 3)zstd::max(3, x)z&std::min(3, std::min(x, std::sqrt(x)))C++zC++98templatealignas)	r   doprintr
   xr   r   languagestandardreserved_words)cxx98printers    P/var/www/html/venv/lib/python3.12/site-packages/sympy/printing/tests/test_cxx.pytest_CXX98CodePrinterr       s    %%c!Qi04XXXX%%c!QQ&89=eeee#%L  E)))  G+++44444L77777    c                     t               j                  t        t                    dk(  sJ t               } | j                  dk(  sJ | j
                  dk(  sJ d| j                  v sJ d| j                  v sJ d| j                  vsJ y )Nstd::log1p(x)r   zC++11operatornoexceptconcept)r   r   r   r   r   r   r   )cxx11printers    r   test_CXX11CodePrinterr(      s    %%eAh/?BBB#%L  E)))  G+++4444444444L77777r!   c                  r     G d dt               }  |        j                  t        t                    dk(  sJ y )Nc                       e Zd Zd Zy)-test_subclass_print_method.<locals>.MyPrinterc                 f    ddj                  t        | j                  |j                              z  S )Nzmy_library::log1p(%s), )joinmap_printargs)selfexprs     r   _print_log1pz:test_subclass_print_method.<locals>.MyPrinter._print_log1p"   s%    *TYYs4;;		7R-SSSr!   N)__name__
__module____qualname__r4    r!   r   	MyPrinterr+   !   s    	Tr!   r9   my_library::log1p(x)r   r   r   r   )r9   s    r   test_subclass_print_methodr<       s3    T$ T ;uQx(,BBBBr!   c                       G d dt               } t               } |        }|j                  t        t                    dk(  sJ |j                  t        t                    dk(  sJ y )Nc                       e Zd ZdZy)1test_subclass_print_method__ns.<locals>.MyPrinterzmy_library::N)r5   r6   r7   _nsr8   r!   r   r9   r?   )   s    r!   r9   r#   r:   r;   )r9   pmyps      r   test_subclass_print_method__nsrC   (   sW    $  	A
+C99U1X/111;;uQx $::::r!   c                     t               j                  t        t        t                    dk(  sJ t               j                  t        t                    dk(  sJ t               j                  t        t                    dk(  sJ t               j                  t        t                    dk(  sJ t               j                  t        t                    dk(  sJ y )Nzstd::beta(x, y)zstd::expint(x)zstd::riemann_zeta(x)z(x - std::floor(x))z^((1.0/2.0)*std::pow(M_PI, -1.0/2.0*x)*x*(x - 1)*std::tgamma((1.0/2.0)*x)*std::riemann_zeta(x)))	r   r   r   r   yr   r	   r   r   r8   r!   r   test_CXX17CodePrinterrF   3   s    %%d1aj15FFFF%%be,0@@@@%%d1g.2HHHH %%d1g.2GGGG%%jm4  9Y  Y  Y  Yr!   c                      t        t        t        t              dz        j	                  d            t        ddg      k(  sJ y )N      ?*z0.5zstd::sqrt(x))sortedr   r   r   splitr8   r!   r   test_cxxcoderL   =   s7    '$q'"*%++C01VUN<S5TTTTr!   c            	          t        t        t        t        t              t        t
        t                          dk(  sJ t        t        t        t        t              t        t
        t                          dk(  sJ y )Nz(std::max(std::min(u, v), std::min(x, y))z(std::min(std::max(u, v), std::max(x, y)))r   r
   r   r   rE   uvr8   r!   r   test_cxxcode_nested_minmaxrP   @   s\    3s1ay#a),-56 6 63s1ay#a),-56 6 6r!   c                       G d dt               }  |        }t        d      D ]  }|j                  |      d|z  k(  rJ  |j                  t        d            dk(  sJ |j                  t        dz        dk(  sJ y )	Nc                   $     e Zd Z fdZd Z xZS ).test_subclass_Integer_Float.<locals>.MyPrinterc                 (    dt         |   |      z  S )NzbigInt("%s"))super_print_Integer)r2   arg	__class__s     r   rV   z=test_subclass_Integer_Float.<locals>.MyPrinter._print_IntegerH   s    !EG$:3$???r!   c                     t        |      }d| j                  t        |j                              d| j                  t        |j                              dS )Nz	bigFloat(r-   ))r   r0   r   rA   q)r2   rW   rats      r   _print_Floatz;test_subclass_Integer_Float.<locals>.MyPrinter._print_FloatK   s=    3-CGCEEN+GCEEN+ r!   )r5   r6   r7   rV   r]   __classcell__)rX   s   @r   r9   rS   G   s    	@	r!   r9      zbigInt("%d")rH   z"bigFloat(bigInt("1"), bigInt("2"))g      z$bigFloat(bigInt("1"), bigInt("1"))/x)r   ranger   r   r   )r9   rA   is      r   test_subclass_Integer_Floatrb   F   s~    	$ 	 	A2Y 2yy|~1111299U3Z $HHHH99QW!GGGGr!   N)"sympy.core.numbersr   r   r   sympy.core.symbolr   sympy.functionsr   r   r	   r
   r   r   r   r   sympy.printing.cxxr   r   r   r   sympy.codegen.cfunctionsr   r   rE   rN   rO   r    r(   r<   rC   rF   rL   rP   rb   r8   r!   r   <module>rh      s`    7 7 % L L L \ \ * Y
1a88C;YU6Hr!   