HEX
Server: Apache
System: Linux zacp120.webway.host 4.18.0-553.50.1.lve.el8.x86_64 #1 SMP Thu Apr 17 19:10:24 UTC 2025 x86_64
User: govancoz (1003)
PHP: 8.3.26
Disabled: exec,system,passthru,shell_exec,proc_close,proc_open,dl,popen,show_source,posix_kill,posix_mkfifo,posix_getpwuid,posix_setpgid,posix_setsid,posix_setuid,posix_setgid,posix_seteuid,posix_setegid,posix_uname
Upload Files
File: //usr/local/lib/python3.7/test/__pycache__/sortperf.cpython-37.opt-1.pyc
B

��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.

�Ncs6tj�td|�}yt|d�}Wn�tk
r�tj��fdd�t|�D�}yVz&t|d�}t�	||�|�
�d}Wd|r�yt�|�Wntk
r�YnXXWn0tk
r�}ztd|d|�Wdd}~XYnXYnZXt�
|�}|�
�xDtd	�D]8}t�|�}|d|�}|d|�=|��|�|�~q�W|S)
z+Return a list of n random floats in [0, 1).zrr%06d�rbcsg|]
}���qS�r)�.0�i)�rr�)/usr/local/lib/python3.7/test/sortperf.py�
<listcomp>szrandfloats.<locals>.<listcomp>�wbNzcan't write�:�
)�os�path�join�td�open�OSError�random�range�marshal�dump�close�unlink�print�load�	randrange�reverse�extend)�n�fn�fp�result�msgrZtempr)rr�
randfloatss:
&



r"cCstj��dS)N)�sys�stdout�flushrrrrr%8sr%cCs6t��}|��t��}td||dd�t�dS)Nz%6.2f� )�end)�timeZperf_counter�sortrr%)�LZt0Zt1rrr�doit;s
r+c
Cs�tdd�dD��}ddt|�}t|d|��x�|D�]�}d|>}t|�}td||fd	d
�t�t|�|��t|�t|�x>td�D]2}t�	|�}t�	|�}||||||<||<q�Wt|�|dkr�d
d�td�D�|dd�<t|�x(t|d�D]}t��|t�	|�<�q
Wt|�|dk�r`|dd�=||d}t
tdd�|��}t|�~t
ttdg|��}t|�~|d}	t
t|	ddd��}|�
t|	��t
tt|��}t|�t�q:WdS)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)rZchrrrrUsztabulate.<locals>.<listcomp>z	*\/3+%~=!z%2s %7sz %6s)rz2**i�z%2d %7dr&)r'�rcSsg|]}t���qSr)r)r�dummyrrrrksi����N�d�cSs|S)Nr)�xrrr�<lambda>y�ztabulate.<locals>.<lambda>g�����)�tuple�lenrr"r%r+rrrr�list�map�absr�float)
rZcasesZfmtrrr*r.Zi1Zi2Zhalfrrr�tabulateBsL



r<cCs�d}d}tjdd�r�ttjd�}}tjdd�r�ttjd�}tjdd�r�d}x&tjdd�D]}d|t|�}qfWt�|�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.

    ��r,Nr4r-i�
)r#�argv�int�hashrZseedrr<)Zk1Zk2r1�arrrr�main�s	
rC�__main__)�__doc__r#r(rrZtempfilerZ
gettempdirrr"r%r+r<rC�__name__rrrr�<module>s'L