U
    ˜9%eº	  ã                   @   s¤   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d„ Zdd	„ Zd
d„ Zdd„ Zdd„ Zdd„ Zdd„ ZdS )é    )Úsymbols)ÚbetaÚEiÚzetaÚMaxÚMinÚsqrtÚ
riemann_xiÚfrac)ÚCXX98CodePrinterÚCXX11CodePrinterÚCXX17CodePrinterÚcxxcode)Úlog1pzx y u vc                  C   s|   t ƒ  ttdƒ¡dkst‚t ƒ  ttdttƒƒ¡dks:t‚t ƒ } | jdksNt‚| jdks\t‚d| j	ksjt‚d| j	ksxt‚d S )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ÚtemplateZalignas)
r   Údoprintr   ÚxÚAssertionErrorr   r   ÚlanguageÚstandardÚreserved_words)Zcxx98printer© r   ú\/var/www/html/Darija-Ai-API/env/lib/python3.8/site-packages/sympy/printing/tests/test_cxx.pyÚtest_CXX98CodePrinter
   s     r   c                  C   sh   t ƒ  ttƒ¡dkst‚t ƒ } | jdks,t‚| jdks:t‚d| jksHt‚d| jksVt‚d| jksdt‚d S )Nústd::log1p(x)r   zC++11ÚoperatorZnoexceptZconcept)r   r   r   r   r   r   r   r   )Zcxx11printerr   r   r   Útest_CXX11CodePrinter   s    r   c                  C   s,   G dd„ dt ƒ} | ƒ  ttƒ¡dks(t‚d S )Nc                   @   s   e Zd Zdd„ ZdS )z-test_subclass_print_method.<locals>.MyPrinterc                 S   s   dd  t| j|jƒ¡ S )Nzmy_library::log1p(%s)z, )ÚjoinÚmapZ_printÚargs)ÚselfÚexprr   r   r   Ú_print_log1p!   s    z:test_subclass_print_method.<locals>.MyPrinter._print_log1pN)Ú__name__Ú
__module__Ú__qualname__r$   r   r   r   r   Ú	MyPrinter    s   r(   úmy_library::log1p(x)©r   r   r   r   r   )r(   r   r   r   Útest_subclass_print_method   s    r+   c                  C   sL   G dd„ dt ƒ} t ƒ }| ƒ }| ttƒ¡dks2t‚| ttƒ¡dksHt‚d S )Nc                   @   s   e Zd ZdZdS )z1test_subclass_print_method__ns.<locals>.MyPrinterzmy_library::N)r%   r&   r'   Z_nsr   r   r   r   r(   (   s   r(   r   r)   r*   )r(   ÚpZmypr   r   r   Útest_subclass_print_method__ns'   s
    r-   c                   C   s~   t ƒ  tttƒ¡dkst‚t ƒ  ttƒ¡dks2t‚t ƒ  ttƒ¡dksJt‚t ƒ  ttƒ¡dksbt‚t ƒ  t	tƒ¡dkszt‚d S )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
   r	   r   r   r   r   Útest_CXX17CodePrinter2   s
    r/   c                   C   s.   t tttƒd ƒ d¡ƒt ddgƒks*t‚d S )Ng      à?Ú*z0.5zstd::sqrt(x))Úsortedr   r   r   Úsplitr   r   r   r   r   Útest_cxxcode<   s    r3   c                   C   sH   t ttttƒtttƒƒƒdks"t‚t ttttƒtttƒƒƒdksDt‚d S )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   r.   ÚuÚvr   r   r   r   r   Útest_cxxcode_nested_minmax?   s    ÿÿr6   N)Zsympy.core.symbolr   Zsympy.functionsr   r   r   r   r   r   r	   r
   Zsympy.printing.cxxr   r   r   r   Zsympy.codegen.cfunctionsr   r   r.   r4   r5   r   r   r+   r-   r/   r3   r6   r   r   r   r   Ú<module>   s   (

