o
    jgoH                     @   s  d dl mZ d dlmZmZmZmZmZmZm	Z	 d dl
mZ d dlmZ d dlmZmZ d dlmZmZmZ d dlmZ d dlZed	\ZZZd
d Zdd Zdd Zdd Zdd Zedd Z dd Z!dd Z"dd Z#dd Z$dd Z%d d! Z&d"d# Z'ed$d% Z(d&d' Z)d(d) Z*d*d+ Z+d,d- Z,d.d/ Z-d0d1 Z.d2d3 Z/d4d5 Z0d6d7 Z1d8d9 Z2d:d; Z3d<d= Z4d>d? Z5d@dA Z6dBdC Z7dDdE Z8dFdG Z9dHdI Z:dS )J    )StringIO)SsymbolsEqpiCatalan
EulerGammaFunction)Equality)	Piecewise)MatrixMatrixSymbol)JuliaCodeGencodegenmake_routine)XFAILNzx,y,zc                  C   s8   t  } t }| jg |dddd | }|dksJ d S )NfileFheaderempty )r   r   dump_jlgetvalue)code_genoutputsource r   `/var/www/html/zoom/venv/lib/python3.10/site-packages/sympy/utilities/tests/test_codegen_julia.pytest_empty_jl_code   s
   r   c                  C   sN   dt t t f} t| dddd\}|d dksJ |d }d}||ks%J d S )	NtestJuliaFr   r   test.jl   zCfunction test(x, y, z)
    out1 = z .* (x + y)
    return out1
end
xyzr   	name_exprresultr   expectedr   r   r   test_jl_simple_code   s   r+   c                  C   sX   dt t t f} t| dddd\}|d dksJ |d }d	tj d
 }||ks*J d S )Nr   r    TFr   r   r!   r"   #   Code generated with SymPy z
#
#   See http://www.sympy.org/ for more information.
#
#   This file is part of 'project'
function test(x, y, z)
    out1 = z .* (x + y)
    return out1
end
)r$   r%   r&   r   sympy__version__r'   r   r   r   test_jl_simple_code_with_header%   s   r/   c                  C   sD   t ttt } d| f}t|dddd\}|d }d}||ks J d S )Nr   r    Fr   r"   z3function test(x, y)
    z = x + y
    return z
end
)r
   r&   r$   r%   r   exprr(   r)   r   r*   r   r   r   test_jl_simple_code_nameout8      r2   c                  C   s:   dt t f} t| dddd\}|d }d}||ksJ d S )Nr   r    Fr   r"   z<function test()
    out1 = pi ^ catalan
    return out1
end
)r   r   r   r'   r   r   r   test_jl_numbersymbolF   s   r4   c                  C   s@   dt t tgf} t| ddddd\}|d }d}||ksJ d S )Nr   r    Fr   r   inliner"   zfunction test()
    Catalan = 0.915965594177219
    EulerGamma = 0.5772156649015329
    out1 = pi ^ Catalan
    out2 = EulerGamma
    return out1, out2
end
)r   r   r   r   r'   r   r   r   test_jl_numbersymbol_no_inlineS   s   	r7   c                  C   s\   t t } td| tt tgdd}t }t }|j|g|dddd | }d}||ks,J d S )Nr   julia)argument_sequencelanguageFr   z<function test(z, x, y)
    out1 = x + y
    return out1
end
)r$   r%   r   r&   r   r   r   r   )r1   routiner   r   r   r*   r   r   r   test_jl_code_argument_orderf   s   r<   c                  C   sR   t t t } t t t }d| |gf}t|dddd\}|d }d}||ks'J d S )Nr   r    Fr   r"   zafunction test(x, y, z)
    out1 = z .* (x + y)
    out2 = z .* (x - y)
    return out1, out2
end
r#   )expr1expr2r(   r)   r   r*   r   r   r   test_multiple_results_mv   s   r?   c            
      C   s|   t d\} }}t|tt t }t| tt t }t|dt }d|||gf}t|dddd\}|d }d}	||	ks<J d S )	NA,B,C   r   r    Fr   r"   zffunction test(x, y, z)
    C = z .* (x + y)
    A = z .* (x - y)
    B = 2 * x
    return C, A, B
end
r   r
   r$   r%   r&   r   
ABCr=   r>   expr3r(   r)   r   r*   r   r   r   test_results_named_unordered   s   rH   c            
      C   s   t d\} }}t|tt t }t| tt t }t|dt }d|||gf}t|dddtttfd}|d d dks=J |d d	 }d
}	||	ksKJ d S )Nr@   rA   r   r    Fr   r   r9   r   r!   r"   zffunction test(x, z, y)
    C = z .* (x + y)
    A = z .* (x - y)
    B = 2 * x
    return C, A, B
end
rB   rC   r   r   r   test_results_named_ordered   s   
rJ   c                  C   s   ddl m} m}m} d|t| t |t d  | | | | | | | | tt t gf}t|dddd}|d d dksDJ |d d	 }d
}||ksRJ d S )Nr   )cossintantestlong   r    Fr   ztestlong.jlr"   an  function testlong(x, y, z)
    out1 = sin(x) .^ 3 + 3 * sin(x) .^ 2 .* cos(y) + 3 * sin(x) .^ 2 .* tan(z) + 3 * sin(x) .* cos(y) .^ 2 + 6 * sin(x) .* cos(y) .* tan(z) + 3 * sin(x) .* tan(z) .^ 2 + cos(y) .^ 3 + 3 * cos(y) .^ 2 .* tan(z) + 3 * cos(y) .* tan(z) .^ 2 + tan(z) .^ 3
    out2 = cos(cos(cos(cos(cos(cos(cos(cos(x + y + z))))))))
    return out1, out2
end
)	(sympy.functions.elementary.trigonometricrK   rL   rM   r$   r%   r&   expandr   )rK   rL   rM   r(   r)   r   r*   r   r   r   test_complicated_jl_codegen   s   *	rR   c               	   C   s   ddl m} m} td}d| dt tt|t| tt||dt gf}t|dddd\}|d d	ks7J |d
 }d}||ksCJ d S )Nr   )rK   rL   afoorA   r    Fr   foo.jlr"   zzfunction foo(x)
    out1 = cos(2 * x)
    y = sin(x)
    out3 = cos(x)
    a = sin(2 * x)
    return out1, y, out3, a
end
)rP   rK   rL   r   r$   r
   r%   r   )rK   rL   rS   r(   r)   r   r*   r   r   r   "test_jl_output_arg_mixed_unordered   s   4	rV   c                  C   sj   t dtdk ftd tdkft d tdkfddd} d| f}t|d	ddd
\}|d }d}||ks3J d S )Nr   rA   r"   r"   TFevaluatepwtestr    r   z{function pwtest(x)
    out1 = ((x < -1) ? (0) :
    (x <= 1) ? (x .^ 2) :
    (x > 1) ? (2 - x) : (1))
    return out1
end
r   r$   r   pwr(   r)   r   r*   r   r   r   test_jl_piecewise_   s   4r_   c                  C   sh   t dtdk ftd tdkft d tdkfd} d| f}t|ddddd	\}|d }d
}||ks2J d S )Nr   rW   rA   r"   rX   r[   r    Fr5   zfunction pwtest(x)
    if (x < -1)
        out1 = 0
    elseif (x <= 1)
        out1 = x .^ 2
    elseif (x > 1)
        out1 = -x + 2
    else
        out1 = 1
    end
    return out1
end
r\   r]   r   r   r   test_jl_piecewise_no_inline   s   0
r`   c                  C   sl   ddt  dt gfdtd dt gfg} t| dddd}|d	 d	 d
ks&J |d	 d }d}||ks4J d S )NrT   rA   rO   bar   r    Fr   r   rU   r"   zfunction foo(x, y)
    out1 = 2 * x
    out2 = 3 * y
    return out1, out2
end
function bar(y)
    out1 = y .^ 2
    out2 = 4 * y
    return out1, out2
end
r$   r%   r   r'   r   r   r   test_jl_multifcns_per_file  s   (rd   c                  C   sv   ddt  dt gfdtd dt gfg} t| dddd	}|d
 d
 dks&J |d
 d }dtj d }||ks9J d S )NrT   rA   rO   ra   rb   r    TFr   r   rU   r"   r,   z
#
#   See http://www.sympy.org/ for more information.
#
#   This file is part of 'project'
function foo(x, y)
    out1 = 2 * x
    out2 = 3 * y
    return out1, out2
end
function bar(y)
    out1 = y .^ 2
    out2 = 4 * y
    return out1, out2
end
)r$   r%   r   r-   r.   r'   r   r   r   #test_jl_multifcns_per_file_w_header  s   (re   c                  C   sP   ddt  dt gfdtd dt gfg} t| ddddd	\}|d
 dks&J d S )NrT   rA   rO   ra   rb   r    bazF)prefixr   r   r   zbaz.jlrc   )r(   r)   r   r   r   test_jl_filename_match_prefix/  s
   (
rh   c                  C   sr   t tdt tt gg} dttddd| f}t|dddd}|d	 d	 d
ks)J |d	 d }d}||ks7J d S )NrA   r   myout1r"   rO   r    Fr   r   r!   Kfunction test(x, y, z)
    myout1 = [x 2 * y pi * z]
    return myout1
end
)r   r$   r%   r   r&   r
   r   r   )e2r(   r)   r   r*   r   r   r   test_jl_matrix_named6  s   rl   c                  C   sd   t ddd} ttdt tt gg}dt| |ddf}t|dddd	\}|d }d
}||ks0J d S )Nri   r"   rO   rA   r   FrY   r    r   rj   )r   r   r$   r%   r   r&   r
   r   )ri   rk   r(   r)   r   r*   r   r   r   test_jl_matrix_named_matsymE  s   rm   c                  C   sJ   t ttt dgg} d| f}t|dddd\}|d }d}||ks#J d S )NrO   r   r    Fr   r"   z?function test(x, y)
    out1 = [x x + y 3]
    return out1
end
)r   r$   r%   r   r0   r   r   r   test_jl_matrix_output_autonameT  s   rn   c                  C   s   t t } tdt  dt dt gg}tt gtgtgg}tt tgtdgg}d| |||ff}t|dddd\}|d }d}||ksCJ d S )	NrA      r   r    Fr   r"   zfunction test(x, y, z)
    out1 = x + y
    out2 = [2 * x 2 * y 2 * z]
    out3 = [x, y, z]
    out4 = [x  y;
    z 16]
    return out1, out2, out3, out4
end
)r$   r%   r   r&   r   )e1rk   e3e4r(   r)   r   r*   r   r   r    test_jl_matrix_output_autoname_2b  s   
rs   c            
      C   s   t d\} }tddd}t|tt t }t|tddtgg}t| dt }d|||gf}t|dddtttfd	\}|d }d
}	||	ksGJ d S )NzB,CrD   r"   rO   rA   r   r    FrI   zafunction test(x, z, y)
    C = z .* (x + y)
    A = [1 2 x]
    B = 2 * x
    return C, A, B
end
)r   r   r
   r$   r%   r&   r   r   )
rE   rF   rD   r=   r>   rG   r(   r)   r   r*   r   r   r   $test_jl_results_matrix_named_orderedw  s   
rt   c                  C   s   t ddd} t ddd}t ddd}t ddd}dt|| d	d d f t|| dd d f t|| d d df gf}t|d
ddd\}|d }d}||ksOJ d S )NrD   rA   rO   rE   r"   rF   Dr   r   r    Fr   zUfunction test(A)
    B = A[1,:]
    C = A[2,:]
    D = A[:,3]
    return B, C, D
end
r   r
   r   )rD   rE   rF   ru   r(   r)   r   r*   r   r   r   test_jl_matrixsymbol_slice  s   rw   c                  C   s   t ddd} t ddd}t ddd}dt|| ddddf t|| ddd	df gf}t|d
ddd\}|d	 }d}||ksCJ d S )NrD   rO   rb   rE   rA   rF   r   r   r"   r    Fr   zKfunction test(A)
    B = A[1:2,1:2]
    C = A[1:2,2:3]
    return B, C
end
rv   rD   rE   rF   r(   r)   r   r*   r   r   r   test_jl_matrixsymbol_slice2  s   ry   c               	   C   s   t ddd} t ddd}t ddd}dt|| d	d d
d df t|| d d dd d df gf}t|dddd\}|d
 }d}||ksFJ d S )NrD         rE   rA   rF   rb   r      r"   rO   r    Fr   zYfunction test(A)
    B = A[7:end,2:3:end]
    C = A[1:2:end,1:3:end]
    return B, C
end
rv   rx   r   r   r   test_jl_matrixsymbol_slice3  s   r}   c                  C   s   t ddd} t ddd}dt|| dd d f | dd d f | d d df | d d df gf}t|dd	d	d
\}|d }d}||ksDJ d S )NrD   rA   rO   rE   r"   r   r   r    Fr   zyfunction test(A)
    B = A[1,:]
    out2 = A[2,:]
    out3 = A[:,1]
    out4 = A[:,2]
    return B, out2, out3, out4
end
rv   )rD   rE   r(   r)   r   r*   r   r   r   #test_jl_matrixsymbol_slice_autoname  s   F	r~   c                  C   s   ddl m} m} ddlm} |ddd\}}| d}| d}| d	}|d
|}|d|}	tdt|| |||	f ||	  fdddd\}
|
d }d}||dd||	f i ksd||dd||	f i ksfJ d S d S )Nr   IndexedBaseIdxr   zn mTintegerrD   r$   r%   ijmat_vec_multr    Fr   r"   zfunction mat_vec_mult(y, A, m, n, x)
    for i = 1:m
        y[i] = 0
    end
    for i = 1:m
        for j = 1:n
            y[i] = %(rhs)s + y[i]
        end
    end
    return y
end
rhszA[%s,%s] .* x[j]zx[j] .* A[%s,%s]sympy.tensorr   r   sympy.core.symbolr   r   r   )r   r   r   nmrD   r$   r%   r   r   r)   r   r*   r   r   r   test_jl_loops  s$   

$r   c               
   C   s   ddl m} m} ddlm} |ddd\}}}}| d}| d}| d	}	|d
|}
|d|}|d|}|d|}tdt|	|
 ||||f ||
|||f  fdddd\}|d }d}||ksaJ d S )Nr   r   r   zn m o pTr   rD   rE   r%   r   r   kltensorthingr    Fr   r"   a-  function tensorthing(y, A, B, m, n, o, p)
    for i = 1:m
        y[i] = 0
    end
    for i = 1:m
        for j = 1:n
            for k = 1:o
                for l = 1:p
                    y[i] = A[i,j,k,l] .* B[j,k,l] + y[i]
                end
            end
        end
    end
    return y
end
r   )r   r   r   r   r   oprD   rE   r%   r   r   r   r   r)   r   r*   r   r   r   *test_jl_tensor_loops_multiple_contractions  s"   



,r   c                  C   sD   t ttd } d| f}t|dddd\}|d }d}||ks J d S )NrA   mysqrr    Fr   r"   z2function mysqr(x)
    x = x .^ 2
    return x
end
)r
   r$   r   r0   r   r   r   test_jl_InOutArgument  r3   r   c                  C   s   t ttd t } d| f}t|dddttfd\}|d }d}||ks%J t ttd t } d| f}t|dddd\}|d }d}||ksGJ d S )	NrA   r   r    FrI   r"   z8function test(x, y)
    x = x .^ 2 + y
    return x
end
r   )r
   r$   r%   r   r0   r   r   r   test_jl_InOutArgument_order)  s    r   c                  C   sN   t d} d| tttjgf}t|dddd\}|d }d}||ks%J d S )Nfr   r    Fr   r"   zfunction test(x)
    # unsupported: Derivative(f(x), x)
    # unsupported: zoo
    out1 = Derivative(f(x), x)
    out2 = zoo
    return out1, out2
end
)r	   r$   diffr   ComplexInfinityr   )r   r(   r)   r   r*   r   r   r   test_jl_not_supportedE  s   	r   c                  C   s   t d\} }}}td| | fddd|fd}|d d }d}||ks$J td| | | fddd| |f||fd	}|d d }d
}||ksFJ d S )Nzx y z tr   r    F)r   r   global_varsr   r"   z4function f(x)
    out1 = x .* y
    return out1
end
)r   r   r9   r   z;function f(x, y)
    out1 = x .* y + z
    return out1
end
)r   r   )r$   r%   r&   tr)   r   r*   r   r   r   test_global_vars_octaveV  s   r   );ior   
sympy.corer   r   r   r   r   r   r	   sympy.core.relationalr
   $sympy.functions.elementary.piecewiser   sympy.matricesr   r   sympy.utilities.codegenr   r   r   sympy.testing.pytestr   r-   r$   r%   r&   r   r+   r/   r2   r4   r7   r<   r?   rH   rJ   rR   rV   r_   r`   rd   re   rh   rl   rm   rn   rs   rt   rw   ry   r}   r~   r   r   r   r   r   r   r   r   r   r   <module>   sV    $

!#