o
    ohi,                     @   s  d dl mZmZmZmZmZmZmZmZm	Z	m
Z
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mZmZmZmZ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( d dl)m*Z*m+Z+ d dl,m-Z-m.Z. d dl%m/Z/ ed	\Z0Z1Z2d
d Z3dd Z4dd Z5dd Z6dd Z7dd Z8dd Z9dd Z:dd Z;dd Z<dd Z=d d! Z>d"d# Z?d$d% Z@d&d' ZAd(d) ZBd*d+ ZCd,d- ZDd.d/ ZEd0d1 ZFd2d3 ZGd4d5 ZHd6d7 ZId8d9 ZJd:d; ZKd<S )=    )pioosymbolsRationalIntegerGoldenRatio
EulerGammaCatalanLambdaDummySEqNeLeLtGtGeMod)	PiecewisesincosAbsexpceilingsqrtsinhcoshtanhasinacosacoshMaxMin)raises)JavascriptCodePrinter)implemented_function)IndexedBaseIdx)MatrixMatrixSymboljscodezx,y,zc                   C   s   t ttdks
J d S )NMath.abs(x))r+   r   x r.   r.   t/var/www/html/construction_image-detection-poc/venv/lib/python3.10/site-packages/sympy/printing/tests/test_jscode.pytest_printmethod   s   r0   c                   C   sF   t ttdks
J t td dksJ t ttjd  dks!J d S )NzMath.sqrt(x)g      ?   zMath.cbrt(x))r+   r   r-   r   Oner.   r.   r.   r/   test_jscode_sqrt   s   r3   c                  C   s   t dttdt } ttd dksJ tttd  dks J td| td ttt    td t  dks:J ttd	 d
ksDJ d S )Ng   r1   zMath.pow(x, 3)zMath.pow(x, Math.pow(y, 3))   g      @z;Math.pow(3.5*2*x, -x + Math.pow(y, x))/(Math.pow(x, 2) + y)g      z1/x)r%   r
   r-   r+   y)r4   r.   r.   r/   test_jscode_Pow   s   *r8   c                   C   sJ   t tddks
J t tdksJ t tdksJ t t dks#J d S )Nr6   zMath.EzMath.PIzNumber.POSITIVE_INFINITYzNumber.NEGATIVE_INFINITY)r+   r   r   r   r.   r.   r.   r/   test_jscode_constants_mathh$   s   r9   c                   C   s^   t dt dtd ksJ t dt dtd ksJ t dt dtd ks-J d S )Nr5   z#var GoldenRatio = %s;
2*GoldenRatio   zvar Catalan = %s;
2*Catalanz!var EulerGamma = %s;
2*EulerGamma)r+   r   evalfr	   r   r.   r.   r.   r/   test_jscode_constants_other+   s   r<   c                   C   s\   t tdddksJ t tdddksJ t tdddks!J t td	ddks,J d S )
Nr1      z3/7   	   2z-3/7)r+   r   r.   r.   r.   r/   test_jscode_Rational3   s   rC   c                   C   s   t tttdksJ t tttdksJ t tttdks!J t tttdks,J t tttdks7J t tttdksBJ d S )Nzx == yzx != yzx <= yzx < yzx > yzx >= y)	r+   r   r-   r7   r   r   r   r   r   r.   r.   r.   r/   test_Relational:   s   rD   c                  C   s   t tttdksJ t tttt dksJ tddd\} }t t| |dks+J t t| |d dks8J t td	d
dddksEJ t t| | dksQJ t tt| | dks^J d S )Nz((x % y) + y) % yz#((x % (x + y)) + (x + y)) % (x + y)zp1 p2T)positivezp1 % p2r1   zp1 % (p2 + 3)rB   rA   F)evaluatez(-3) % (-7)z
-(p1 % p2)zx*(p1 % p2))r+   r   r-   r7   r   )p1p2r.   r.   r/   test_ModC   s   rI   c                   C   s,   t tddks
J t tddksJ d S )NC   67z-1)r+   r   r.   r.   r.   r/   test_jscode_IntegerN      rM   c                   C   s   t tttt dksJ t tttt dksJ t tttttt dks,J t t	tt
t dks:J t tttt dksHJ d S )Nz"Math.pow(Math.sin(x), Math.cos(x))zMath.sinh(x)*Math.cosh(x)zMath.max(x, y) + Math.min(x, y)zMath.tanh(x)*Math.acosh(y)z-Math.acos(y) + Math.asin(x))r+   r   r-   r   r   r   r!   r7   r"   r   r    r   r   r.   r.   r.   r/   test_jscode_functionsS   s
     rO   c                  C   s   t d} tdt| d|  }t|| dksJ tdt| d|  t }t|| dtd ks3J td}tdt d	d
d}tdt| | d|   d|   }t||| || ddks`J d S )Nr-   r4   r5   z2*xzvar Catalan = %s;
2*x/Catalanr:   AinTintegerr6   	assign_toz@for (var i=0; i<n; i++){
   A[i] = (A[i] + 1)*(A[i] + 2)*A[i];
})r   r%   r
   r+   r	   r;   r&   r'   )r-   r4   rP   rQ   r.   r.   r/   test_jscode_inline_function[   s    rW   c                   C   s,   t ttdks
J t ttdksJ d S )NzMath.ceil(x)r,   )r+   r   r-   r   r.   r.   r.   r/   test_jscode_exceptionsk   rN   rX   c                   C   s   t tt@ dks
J t ttB dksJ t t dksJ t tt@ t@ dks)J t ttB tB dks5J t tt@ tB dksAJ t ttB t@ dksMJ d S )Nzx && yzx || yz!xzx && y && zzx || y || zzz || x && yzz && (x || y))r+   r-   r7   zr.   r.   r.   r/   test_jscode_booleanp   s   rZ   c                     s   t ttdk ftd df t } d}| |ksJ t dddks#J t ttdk ftd tdkftttdkf tt fd	d
 d S )Nr6   r5   Tz,((x < 1) ? (
   x
)
: (
   Math.pow(x, 2)
))crU   z8if (x < 1) {
   c = x;
}
else {
   c = Math.pow(x, 2);
}r   c                      s   t  S )Nr*   r.   exprr.   r/   <lambda>   s    z'test_jscode_Piecewise.<locals>.<lambda>)r   r-   r+   r   r#   
ValueErrorpsr.   r\   r/   test_jscode_Piecewisez   s   	
,rc   c                  C   s6   t dtttdk ftd df } d}| |ksJ d S )Nr5   r6   Tz.2*((x < 1) ? (
   x
)
: (
   Math.pow(x, 2)
)))r+   r   r-   r`   r.   r.   r/   test_jscode_Piecewise_deep   s   "	rd   c                   C   s   t tdd  d S )Nc                   S   s   t ttddS )Ngarbage)method)r+   r   r-   r.   r.   r.   r/   r^      s    z&test_jscode_settings.<locals>.<lambda>)r#   	TypeErrorr.   r.   r.   r/   test_jscode_settings   s   rh   c            
      C   s   t ddd\} }}td| td|td|}}}t }t |_td| }||dks0J td	||f }||d
|| |  ksGJ td|||f }	||	d|| | ||  |  kseJ |jt ksmJ d S )Nzn m oTrS   rQ   jkr-   zx[j]rP   zA[%s]BzB[%s])r   r'   r$   set_not_cr&   _print_Indexed)
rR   morQ   ri   rj   ra   r-   rP   rk   r.   r.   r/   test_jscode_Indexed   s   "*rq   c            	      C   sp   t ddd\} }td}td}td}td|}td| }d	}t|||f ||  || d
}||ks6J d S )Nn mTrS   rP   r-   r7   rQ   ri   zfor (var i=0; i<m; i++){
   y[i] = 0;
}
for (var i=0; i<m; i++){
   for (var j=0; j<n; j++){
      y[i] = A[n*i + j]*x[j] + y[i];
   }
}rU   r   r&   r'   r+   )	rR   ro   rP   r-   r7   rQ   ri   rb   r[   r.   r.   r/   test_jscode_loops_matrix_vector   s   

 
rt   c                  C   sd   t ddtd\} }td}td}t| |} d| jj|jd }t||  ||  d}||ks0J d S )	Nzi mT)rT   clsr-   r7   zlfor (var i_%(icount)i=0; i_%(icount)i<m_%(mcount)i; i_%(icount)i++){
   y[i_%(icount)i] = x[i_%(icount)i];
})icountmcountrU   )r   r   r&   r'   labeldummy_indexr+   )rQ   ro   r-   r7   expectedcoder.   r.   r/   test_dummy_loops   s   
r|   c            
      C   s   t ddd\} }td}td}td}td}td|}td	| }d
}t|||f ||  ||  ||  || d}	|	|ksBJ d S )Nrr   TrS   rP   r-   r7   rY   rQ   ri   zfor (var i=0; i<m; i++){
   y[i] = x[i] + z[i];
}
for (var i=0; i<m; i++){
   for (var j=0; j<n; j++){
      y[i] = A[n*i + j]*x[j] + y[i];
   }
}rU   rs   )
rR   ro   rP   r-   r7   rY   rQ   ri   rb   r[   r.   r.   r/   test_jscode_loops_add   s   

0
r}   c                  C   s   t ddd\} }}}td}td}td}td|}td| }td	|}	td
|}
d||  | | || |  |	|  |
 || | |	|  |
 f d }t|||	|
f ||||	|
f  || d}||ksiJ d S )Nn m o pTrS   abr7   rQ   ri   rj   lzfor (var i=0; i<m; i++){
   y[i] = 0;
}
for (var i=0; i<m; i++){
   for (var j=0; j<n; j++){
      for (var k=0; k<o; k++){
         for (var l=0; l<p; l++){
            y[i] = a[%s]*b[%s] + y[i];
         }
      }
   }
}rU   rs   )rR   ro   rp   ra   r   r   r7   rQ   ri   rj   r   rb   r[   r.   r.   r/   'test_jscode_loops_multiple_contractions   s    



>*r   c                  C   s  t ddd\} }}}td}td}td}td}td|}td	| }	td
|}
td|}d||  | | |	| |  |
|  | ||  | | |	| |  |
|  | |	| | |
|  | f d }t|||	|
|f |||	|
|f  ||	|
|f  || d}||ksJ d S )Nr~   TrS   r   r   r[   r7   rQ   ri   rj   r   zfor (var i=0; i<m; i++){
   y[i] = 0;
}
for (var i=0; i<m; i++){
   for (var j=0; j<n; j++){
      for (var k=0; k<o; k++){
         for (var l=0; l<p; l++){
            y[i] = (a[%s] + b[%s])*c[%s] + y[i];
r   rU   rs   )rR   ro   rp   ra   r   r   r[   r7   rQ   ri   rj   r   rb   r.   r.   r/   test_jscode_loops_addfactor  s"   



d:r   c                  C   s  t ddd\} }}}td}td}td}td}td|}td	| }	td
|}
d}d||  | |	|  |
  d }d|| |
  d }d||  |	  d }t||	 |||	f  ||
 |||
f   ||	 ||
  |||	|
f   || d}||| | |d d  ks||| | |d d  ks||| | |d d  ks||| | |d d  ks||| | |d d  ks||| | |d d  ksJ d S d S d S d S d S d S )Nr~   TrS   r   r   r[   r7   rQ   ri   rj   z(for (var i=0; i<m; i++){
   y[i] = 0;
}
z|for (var i=0; i<m; i++){
   for (var j=0; j<n; j++){
      for (var k=0; k<o; k++){
         y[i] = b[j]*b[k]*c[%s] + y[i];
z      }
   }
}
zUfor (var i=0; i<m; i++){
   for (var k=0; k<o; k++){
      y[i] = a[%s]*b[k] + y[i];
z   }
}
zUfor (var i=0; i<m; i++){
   for (var j=0; j<n; j++){
      y[i] = a[%s]*b[j] + y[i];
rU   rL   rs   )rR   ro   rp   ra   r   r   r[   r7   rQ   ri   rj   s0s1s2s3r.   r.   r/    test_jscode_loops_multiple_terms*  sV   





J r   c                  C   s  t tt tdt tdkftdfttg} tddd}t| |dks%J td|d  tdkf|d dft|d	  |d
  }t|dksHJ tddd}tddd}t t|d	 dt|d g|d	 |d  |d dgd|d  |d	  t	|d
 d dgg}t||dksJ d S )Nr5   r   TrP   r1   r6   zUA[0] = x*y;
if (y > 0) {
   A[1] = x + 2;
}
else {
   A[1] = y;
}
A[2] = Math.sin(z);)r5   r   )r6   r   r   r   z?((x > 0) ? (
   2*A[2]
)
: (
   A[2]
)) + Math.sin(A[1]) + A[0]q   M)r1   r   )   r   r   zM[0] = Math.sin(q[1]);
M[1] = 0;
M[2] = Math.cos(q[2]);
M[3] = q[1] + q[2];
M[4] = q[3];
M[5] = 5;
M[6] = 2*q[4]/q[1];
M[7] = Math.sqrt(q[0]) + 4;
M[8] = 0;)
r(   r-   r7   r   r   rY   r)   r+   r   r   )matrP   r]   r   r   ro   r.   r.   r/   test_Matrix_printingZ  s$   ,6
$r   c                  C   sx   t ddd} t ddd}t ddd}t| d dksJ td| d  dks(J |d || | }t|d	ks:J d S )
NrP   r6   r1   rk   Cr   zA[0]z3*A[0]z
(A - B)[0])r)   r+   subs)rP   rk   r   Fr.   r.   r/   test_MatrixElement_printing  s   r   N)L
sympy.corer   r   r   r   r   r   r   r	   r
   r   r   r   r   r   r   r   r   r   sympy.functionsr   r   r   r   r   r   r   r   r   r   r   r   r    r!   r"   sympy.testing.pytestr#   sympy.printing.jscoder$   sympy.utilities.lambdifyr%   sympy.tensorr&   r'   sympy.matricesr(   r)   r+   r-   r7   rY   r0   r3   r8   r9   r<   rC   rD   rI   rM   rO   rW   rX   rZ   rc   rd   rh   rq   rt   r|   r}   r   r   r   r   r   r.   r.   r.   r/   <module>   sD   P D		
0(