Sindbad~EG File Manager

Current Path : /usr/local/lib/python3.9/test/__pycache__/
Upload File :
Current File : //usr/local/lib/python3.9/test/__pycache__/sortperf.cpython-39.pyc

a

��g��@svdZddlZddlZddlZddlZddlZddlZe��Zdd�Z	dd�Z
dd�Zd	d
�Zdd�Z
ed
krre
�dS)z_Sort performance test.

See main() for command line syntax.
See tabulate() for output format.

�Ncsjtj�td|�}zt|d�}Wn�ty�tj��fdd�t|�D�}zzzLt|d�}t�	||�|�
�d}W|r�zt�|�Wq�ty�Yq�0n(|r�zt�|�Wnty�Yn00Wn2ty�}ztd|d|�WYd}~n
d}~00YnX0t�
|�}|�
�td	�D]:}t�|�}|d|�}|d|�=|��|�|�~�qt|�|k�sfJ�|S)
z+Return a list of n random floats in [0, 1).zrr%06d�rbcsg|]
}���qS�r)�.0�i��rr�)/usr/local/lib/python3.9/test/sortperf.py�
<listcomp>�zrandfloats.<locals>.<listcomp>�wbNzcan't write�:�
)�os�path�join�td�open�OSError�random�range�marshal�dump�close�unlink�print�load�	randrange�reverse�extend�len)�n�fn�fp�result�msgrZtemprrr�
randfloatssF
�*



r%cCstj��dS�N)�sys�stdout�flushrrrrr)8sr)cCs6t��}|��t��}td||dd�t�dS)Nz%6.2f� ��end)�time�perf_counter�sortrr))�L�t0�t1rrr�doit;s
r3c
Cs�tdd�dD��}ddt|�}t|d|�|D�]�}d|>}t|�}td||fd	d
�t�t|�|��t|�t|�td�D]2}t�	|�}t�	|�}||||||<||<q�t|�|dkr�d
d�td�D�|dd�<t|�t|d�D]}t��|t�	|�<�qt|�|dk�rT|dd�=||d}t
tdd�|��}t|�~t
ttdg|��}t|�~|d}	t
t|	ddd��}|�
t|	��t
tt|��}t|�t�q6dS)a:Tabulate sort speed for lists of various sizes.

    The sizes are 2**i for i in r (the argument, a list).

    The output displays i, 2**i, and the time to sort arrays of 2**i
    floating point numbers with the following properties:

    *sort: random data
    \sort: descending data
    /sort: ascending data
    3sort: ascending, then 3 random exchanges
    +sort: ascending, then 10 random at the end
    %sort: ascending, then randomly replace 1% of the elements w/ random values
    ~sort: many duplicates
    =sort: all equal
    !sort: worst case scenario

    cSsg|]}|d�qS)r/r)rZchrrrr	Ur
ztabulate.<locals>.<listcomp>z	*\/3+%~=!z%2s %7sz %6s)rz2**i�z%2d %7dr*r+�r
cSsg|]}t���qSr)r)r�dummyrrrr	kr
i����N�d�cSs|Sr&r)�xrrr�<lambda>yr
ztabulate.<locals>.<lambda>g�����)�tuplerrr%r)r3rrrr�list�map�absr�float)
rZcases�fmtrr r0r6Zi1Zi2Zhalfrrr�tabulateBsL




rCcCs�d}d}tjdd�r�ttjd�}}tjdd�r�ttjd�}tjdd�r�d}tjdd�D]}d|t|�}qdt�|�t||d�}t|�dS)z�Main program when invoked as a script.

    One argument: tabulate a single row.
    Two arguments: tabulate a range (inclusive).
    Extra arguments are used to seed the random generator.

    ��r4Nr;r5i�
)r'�argv�int�hashr�seedrrC)Zk1Zk2r9�arrrr�main�s	
rK�__main__)�__doc__r'r-rr�tempfiler�
gettempdirrr%r)r3rCrK�__name__rrrr�<module>s'L

Sindbad File Manager Version 1.0, Coded By Sindbad EG ~ The Terrorists