a
    kh(                     @   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   K/var/www/auris/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   Zblackr   )r   r	   r   r   r   )Z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   r.   r*   r   r   r,   H   s   c                 S   s   g | ]}t |d dqS r0   r1   r2   r   r   r   r4   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   r.   r*   r   r   r,   O   s   c                 S   s   g | ]}t |d dqS )r   posr1   r2   r   r   r   r4   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   r.   r*   r   r   r,   U   s   )r   r5   )r   )r   r   allr   r   r   r   r   r*   r   test_dotprint>   s:    &*,(r8   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   )MatrixSymbolr/   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<   r/   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    r?   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    rA   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%   r8   r;   r>   r?   rA   r   r   r   r   <module>   s"    
