a
    rh(                     @   s   d dl 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 d dlmZmZ d dlmZ d dlm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d Zdd Z dS )    )purestrstyleof	attrprintdotnodedotedgesdotprint)Basic)Expr)FloatInteger)S)Symbolsymbols)srepr)xc                   C   s   t tddksJ t ttdtddks2J t tddksFJ t tdddd	ks^J t ttdtdddd
ksJ t tddddksJ d S )Nr   Symbol('x')      Basic(Integer(1), Integer(2))Float('2.0', precision=53)T)Z	with_args)r    )r   )z
Integer(1)
Integer(2))r   r   )r   r   r   r   r
   r   r   r   Y/var/www/html/assistant/venv/lib/python3.9/site-packages/sympy/printing/tests/test_dot.pytest_purestr   s    r   c                  C   sZ   t dddftddifg} tt td| dddks:J ttd | dddksVJ d S )Nblueellipsecolorshaper   blackr   )r   r	   r   r   r   )stylesr   r   r   test_styleof   s
    
 r!   c                   C   s   t ddddksJ d S )Nr   r   r   z!"color"="blue", "shape"="ellipse")r   r   r   r   r   test_attrprint    s    r"   c                   C   sx   t tdddksJ t td dddks<J t td ddt ttd  dddksXJ t ttd  ddd	kstJ d S )
NFrepeatz@"Symbol('x')" ["color"="black", "label"="x", "shape"="ellipse"];r   zS"Add(Integer(2), Symbol('x'))" ["color"="black", "label"="Add", "shape"="ellipse"];r   ze"Add(Symbol('x'), Pow(Symbol('x'), Integer(2)))" ["color"="black", "label"="Add", "shape"="ellipse"];Tzh"Add(Symbol('x'), Pow(Symbol('x'), Integer(2)))_()" ["color"="black", "label"="Add", "shape"="ellipse"];)r   r   r   r   r   r   test_dotnode$   s    
r%   c                   C   sD   t ttd ddddgks J t ttd ddddgks@J d S )	Nr   Fr#   z/"Add(Integer(2), Symbol('x'))" -> "Integer(2)";z0"Add(Integer(2), Symbol('x'))" -> "Symbol('x')";Tz7"Add(Integer(2), Symbol('x'))_()" -> "Integer(2)_(0,)";z8"Add(Integer(2), Symbol('x'))_()" -> "Symbol('x')_(1,)";)sortedr   r   r   r   r   r   test_dotedges4   s    
r'   c                      s  t td dd t fddttd ddD s6J t fdddd ttdtd fD D shJ d	 v stJ t ttd  dd t fd
dtttd  ddD sJ t fdddd ttdtd fD D sJ d	 v sJ t ttd  dd t fddtttd  ddD s0J t fdddd ttd  fD D s`J t tt dd t fddttt ddD sJ t fddttddttddfD sJ d	 v sJ d S )Nr   Fr#   c                 3   s   | ]}| v V  qd S Nr   .0etextr   r   	<genexpr>@       z test_dotprint.<locals>.<genexpr>c                 3   s   | ]}| v V  qd S r(   r   r*   nr,   r   r   r.   A   s   c                 S   s   g | ]}t |d dqS Fr#   r   r*   exprr   r   r   
<listcomp>B   s   z!test_dotprint.<locals>.<listcomp>Zdigraphc                 3   s   | ]}| v V  qd S r(   r   r)   r,   r   r   r.   G   r/   c                 3   s   | ]}| v V  qd S r(   r   r0   r,   r   r   r.   H   s   c                 S   s   g | ]}t |d dqS r2   r3   r4   r   r   r   r6   I   s   Tc                 3   s   | ]}| v V  qd S r(   r   r)   r,   r   r   r.   N   r/   c                 3   s   | ]}| v V  qd S r(   r   r0   r,   r   r   r.   O   s   c                 S   s   g | ]}t |d dqS )r   posr3   r4   r   r   r   r6   P   s   c                 3   s   | ]}| v V  qd S r(   r   r)   r,   r   r   r.   T   r/   c                 3   s   | ]}| v V  qd S r(   r   r0   r,   r   r   r.   U   s   )r   r7   )r   )r   r   allr   r   r   r   r   r,   r   test_dotprint>   s:    &*,(r:   c                  C   s\   t dt d dd} tdt d | v s,J tt| vs<J t dt d } d| vsXJ d S )N   r   r   )depthr<   )r   r   r   r,   r   r   r   test_dotprint_depthY   s
    r=   c                  C   s0   ddl m}  td}t| d||dks,J d S )Nr   )MatrixSymbolr1   Xa  digraph{

# Graph style
"ordering"="out"
"rankdir"="TD"

#########
# Nodes #
#########

"MatrixSymbol(Str('X'), Symbol('n'), Symbol('n'))_()" ["color"="black", "label"="MatrixSymbol", "shape"="ellipse"];
"Str('X')_(0,)" ["color"="blue", "label"="X", "shape"="ellipse"];
"Symbol('n')_(1,)" ["color"="black", "label"="n", "shape"="ellipse"];
"Symbol('n')_(2,)" ["color"="black", "label"="n", "shape"="ellipse"];

#########
# Edges #
#########

"MatrixSymbol(Str('X'), Symbol('n'), Symbol('n'))_()" -> "Str('X')_(0,)";
"MatrixSymbol(Str('X'), Symbol('n'), Symbol('n'))_()" -> "Symbol('n')_(1,)";
"MatrixSymbol(Str('X'), Symbol('n'), Symbol('n'))_()" -> "Symbol('n')_(2,)";
})Z"sympy.matrices.expressions.matexprr>   r   r   )r>   r1   r   r   r   test_Matrix_and_non_basics`   s
    r@   c                  C   s,   t td td} d| v sJ d| v s(J d S )Nr   )Z	labelfuncr   r   )r   r   r   r,   r   r   r   test_labelfunc}   s    rA   c                  C   sL   t ddd\} }t| | t||  ks,J t| | t||  ksHJ d S )Nzx yF)Zcommutative)r   r   )r   yr   r   r   test_commutative   s    rC   N)!Zsympy.printing.dotr   r   r   r   r   r   Zsympy.core.basicr   Zsympy.core.exprr	   Zsympy.core.numbersr
   r   Zsympy.core.singletonr   Zsympy.core.symbolr   r   Zsympy.printing.reprr   Z	sympy.abcr   r   r!   r"   r%   r'   r:   r=   r@   rA   rC   r   r   r   r   <module>   s"    
