a
    lhlH                     @   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s4J d S )NfileFheaderempty )r   r   dump_jlgetvalue)code_genoutputsource r   V/var/www/auris/lib/python3.9/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s2J |d }d}||ksJJ 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s2J |d }d	tj d
 }||ksTJ 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   s    r2   c                  C   s:   dt t f} t| dddd\}|d }d}||ks6J 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    r3   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    	r6   c                  C   s\   t t } td| tt tgdd}t }t }|j|g|dddd | }d}||ksXJ d S )Nr   Z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   Zroutiner   r   r   r*   r   r   r   test_jl_code_argument_orderf   s    r9   c                  C   sR   t t t } t t t }d| |gf}t|dddd\}|d }d}||ksNJ 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sxJ 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    rE   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szJ |d d	 }d
}	||	ksJ d S )Nr=   r>   r   r    Fr   r   r7   r   r!   r"   zffunction test(x, z, y)
    C = z .* (x + y)
    A = z .* (x - y)
    B = 2 * x
    return C, A, B
end
r?   r@   r   r   r   test_results_named_ordered   s    
rG   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sJ |d d	 }d
}||ksJ d S )Nr   )cossintanZ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.trigonometricrH   rI   rJ   r$   r%   r&   expandr   )rH   rI   rJ   r(   r)   r   r*   r   r   r   test_complicated_jl_codegen   s    *	rN   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snJ |d
 }d}||ksJ d S )Nr   )rH   rI   afoor>   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
)rL   rH   rI   r   r$   r
   r%   r   )rH   rI   rO   r(   r)   r   r*   r   r   r   "test_jl_output_arg_mixed_unordered   s    4	rR   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sfJ d S )Nr   r>   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sdJ d S )Nr   rS   r>   r"   rT   rW   r    Fr4   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
rX   rY   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sLJ |d	 d }d}||kshJ d S )NrP   r>   rK   bar   r    Fr   r   rQ   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    (r`   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sLJ |d
 d }dtj d }||ksrJ d S )NrP   r>   rK   r]   r^   r    TFr   r   rQ   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    (ra   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sLJ d S )NrP   r>   rK   r]   r^   r    ZbazF)prefixr   r   r   zbaz.jlr_   )r(   r)   r   r   r   test_jl_filename_match_prefix/  s
    (
rc   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sRJ |d	 d }d}||ksnJ d S )Nr>   r   myout1r"   rK   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    rg   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s`J d S )Nrd   r"   rK   r>   r   FrU   r    r   re   )r   r   r$   r%   r   r&   r
   r   )rd   rf   r(   r)   r   r*   r   r   r   test_jl_matrix_named_matsymE  s    rh   c                  C   sJ   t ttt dgg} d| f}t|dddd\}|d }d}||ksFJ d S )NrK   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    ri   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sJ d S )	Nr>      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   )e1rf   Ze3Ze4r(   r)   r   r*   r   r   r    test_jl_matrix_output_autoname_2b  s    
rl   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sJ d S )NzB,CrA   r"   rK   r>   r   r    FrF   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   )
rB   rC   rA   r:   r;   rD   r(   r)   r   r*   r   r   r   $test_jl_results_matrix_named_orderedw  s    
rm   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sJ d S )NrA   r>   rK   rB   r"   rC   Dr   r   r    Fr   zUfunction test(A)
    B = A[1,:]
    C = A[2,:]
    D = A[:,3]
    return B, C, D
end
r   r
   r   )rA   rB   rC   rn   r(   r)   r   r*   r   r   r   test_jl_matrixsymbol_slice  s    rp   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sJ d S )NrA   rK   r^   rB   r>   rC   r   r   r"   r    Fr   zKfunction test(A)
    B = A[1:2,1:2]
    C = A[1:2,2:3]
    return B, C
end
ro   rA   rB   rC   r(   r)   r   r*   r   r   r   test_jl_matrixsymbol_slice2  s    rr   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sJ d S )NrA         rB   r>   rC   r^   r      r"   rK   r    Fr   zYfunction test(A)
    B = A[7:end,2:3:end]
    C = A[1:2:end,1:3:end]
    return B, C
end
ro   rq   r   r   r   test_jl_matrixsymbol_slice3  s    rv   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sJ d S )NrA   r>   rK   rB   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
ro   )rA   rB   r(   r)   r   r*   r   r   r   #test_jl_matrixsymbol_slice_autoname  s    F	rw   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s||dd||	f i ksJ d S )Nr   IndexedBaseIdxr   zn mTintegerrA   r$   r%   ijZ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]Zsympy.tensorry   rz   Zsympy.core.symbolr   r   r   )ry   rz   r   nmrA   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sJ d S )Nr   rx   r{   zn m o pTr|   rA   rB   r%   r~   r   klZ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   )ry   rz   r   r   r   oprA   rB   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 )Nr>   Zmysqrr    Fr   r"   z2function mysqr(x)
    x = x .^ 2
    return x
end
)r
   r$   r   r0   r   r   r   test_jl_InOutArgument  s    r   c                  C   s   t ttd t } d| f}t|dddttfd\}|d }d}||ksJJ t ttd t } d| f}t|dddd\}|d }d}||ksJ d S )	Nr>   r   r    FrF   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sJJ 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   Z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sHJ td| | | fddd| |f||fd	}|d d }d
}||ksJ 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   r7   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   Z
sympy.corer   r   r   r   r   r   r	   Zsympy.core.relationalr
   Z$sympy.functions.elementary.piecewiser   Zsympy.matricesr   r   Zsympy.utilities.codegenr   r   r   Zsympy.testing.pytestr   r-   r$   r%   r&   r   r+   r/   r2   r3   r6   r9   r<   rE   rG   rN   rR   r[   r\   r`   ra   rc   rg   rh   ri   rl   rm   rp   rr   rv   rw   r   r   r   r   r   r   r   r   r   r   <module>   sT   $

!#