o
    oÇho  ã                   @   sÀ   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d„ Zd	d
„ Zdd„ Zdd„ Zdd„ Zdd„ Zdd„ Z dd„ Z!dS )é    )ÚFloatÚIntegerÚRational)Ú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v sJ ‚t ƒ  ttdttƒƒ¡dksJ ‚t ƒ } | jdks'J ‚| jdks.J ‚d| jv s5J ‚d| jvs<J ‚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ÚtemplateÚalignas)	r   Údoprintr	   Úxr
   r   ÚlanguageÚstandardÚreserved_words)Úcxx98printer© r   úq/var/www/html/construction_image-detection-poc/venv/lib/python3.10/site-packages/sympy/printing/tests/test_cxx.pyÚtest_CXX98CodePrinter   s    r   c                  C   sh   t ƒ  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s2J ‚d S )Nústd::log1p(x)r   zC++11ÚoperatorÚnoexceptÚconcept)r   r   r   r   r   r   r   )Úcxx11printerr   r   r   Útest_CXX11CodePrinter   s   r%   c                  C   s,   G dd„ dt ƒ} | ƒ  ttƒ¡dksJ ‚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ÚmapÚ_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    r0   úmy_library::log1p(x)©r   r   r   r   )r0   r   r   r   Útest_subclass_print_method    s   r3   c                  C   sL   G dd„ dt ƒ} t ƒ }| ƒ }| ttƒ¡dksJ ‚| ttƒ¡dks$J ‚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/   Ú_nsr   r   r   r   r0   )   s    r0   r    r1   r2   )r0   ÚpÚmypr   r   r   Útest_subclass_print_method__ns(   s
   r7   c                   C   s~   t ƒ  tttƒ¡dksJ ‚t ƒ  ttƒ¡dksJ ‚t ƒ  ttƒ¡dks%J ‚t ƒ  ttƒ¡dks1J ‚t ƒ  ttƒ¡dks=J ‚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   Útest_CXX17CodePrinter3   s
   r9   c                   C   s.   t tttƒd ƒ d¡ƒt ddgƒksJ ‚d S )Nç      à?Ú*z0.5zstd::sqrt(x))Úsortedr   r   r   Úsplitr   r   r   r   Útest_cxxcode=   s   .r>   c                   C   sH   t ttttƒtttƒƒƒdksJ ‚t ttttƒtttƒƒƒdks"J ‚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   r8   ÚuÚvr   r   r   r   Útest_cxxcode_nested_minmax@   s   ÿÿrA   c                  C   sj   G dd„ dt ƒ} | ƒ }tdƒD ]}| |¡d| ksJ ‚q| tdƒ¡dks(J ‚| td ¡dks3J ‚d S )	Nc                       s$   e Zd Z‡ fdd„Zdd„ Z‡  ZS )z.test_subclass_Integer_Float.<locals>.MyPrinterc                    s   dt ƒ  |¡ S )NzbigInt("%s"))ÚsuperÚ_print_Integer)r*   Úarg©Ú	__class__r   r   rC   H   s   z=test_subclass_Integer_Float.<locals>.MyPrinter._print_Integerc                 S   s,   t |ƒ}d|  t|jƒ¡|  t|jƒ¡f S )NzbigFloat(%s, %s))r   r(   r   r5   Úq)r*   rD   Úratr   r   r   Ú_print_FloatK   s
   þz;test_subclass_Integer_Float.<locals>.MyPrinter._print_Float)r-   r.   r/   rC   rI   Ú__classcell__r   r   rE   r   r0   G   s    r0   é   zbigInt("%d")r:   z"bigFloat(bigInt("1"), bigInt("2"))g      ð¿z$bigFloat(bigInt("1"), bigInt("1"))/x)r   Úranger   r   r   )r0   r5   Úir   r   r   Útest_subclass_Integer_FloatF   s   rN   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   r8   r?   r@   r   r%   r3   r7   r9   r>   rA   rN   r   r   r   r   Ú<module>   s    (

