o
    g(                    @   s~  d dl Zd dlZd dlZd dlZd dlZd dlmZ d dl	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 d dlmZmZmZmZ ee Zd dddd	d
dd	dddddd	ddd	dg ddddd	ddd	dgZejdddgddd ZG dd  d ZG d!d" d"Z G d#d$ d$Z!G d%d& d&Z"G d'd( d(Z#G d)d* d*Z$G d+d, d,Z%G d-d. d.Z&ej'j(ed/d0G d1d2 d2Z)G d3d4 d4Z*ej'+d5ed6d7 Z,d8d9 Z-d:d; Z.d<d= Z/ej'+d>d?d?ggej'+dddgd@dA Z0ej'+dBdCdDgdEdF Z1ej'+dBdCdDgej'+dGdHdIgej'+dJej2ejgdKdL Z3dMdN Z4dOdP Z5ej'+dQdRdSgdTdU Z6dS )V    N)	AxisError)LinAlgError)
assert_assert_raisesassert_equalassert_allcloseassert_warnsassert_no_warningsassert_array_equalassert_array_almost_equalsuppress_warningsIS_WASM)	GeneratorMT19937SeedSequenceRandomState
   @bb1636883c2707b51c5b7fc26c6927af4430f2e0785a8c7bc886337f919f9edf	   )
key_sha256pos@ff682ac12bb140f2d72fba8d3506cf4e46817a0db27aae1683867629031d8d55iV  )seedstepsinitialjumpedi$<i8  @16b791a1e04886ccbbb4d448d6ff791267dc458ae599475d08d5cced29d11614i7  @a0110a2cf23b56be0feaed8f787a7fc84bef0cb5623003d75b26bdfa1c18002ci  )i|2iEm:iS43i5  i  @d306cf01314d51bd37892d874308200951a35265ede54d200f1e065004c3e9eai  @0e00ab449f01a5195a83b4aee0dfbc2ce8d46466a640b92e33977d2e42f777f8i  moduleTF)scopeparamsc                 C   s   | j S N)param)request r&   c/var/www/html/api-tag/env/lib/python3.10/site-packages/numpy/random/tests/test_generator_mt19937.pyendpoint)   s   r(   c                   @   s<   e Zd Zdd Zdd Zdd Zdd Zd	d
 Zdd ZdS )TestSeedc                 C   s<   t td}t|dd t td}t|dd d S )Nr           D  )r   r   r   integersselfsr&   r&   r'   test_scalar/   s   zTestSeed.test_scalarc                 C   s   t ttd}t|dd t ttd}t|dd t tdg}t|dd t tdg}t|dd d S )Nr   r*   i  r   r+   r,   r-   )r   r   ranger   r.   nparanger/   r&   r&   r'   
test_array5   s   zTestSeed.test_arrayc                 C   s    t td}t|dd d S )Nr      iz)r   r   r   
random_rawr/   r&   r&   r'   test_seedsequence?   s   zTestSeed.test_seedsequencec                 C   s   t ttd t ttd d S )N      r   	TypeErrorr   
ValueErrorr0   r&   r&   r'   test_invalid_scalarC   s   zTestSeed.test_invalid_scalarc                 C   s0   t ttdg t ttdg t ttg d d S )Nr:   r;   )r7           r<   r?   r&   r&   r'   test_invalid_arrayH   s   zTestSeed.test_invalid_arrayc                 C   s   t ttt d S r#   )r   r>   r   r   r?   r&   r&   r'   test_noninstantized_bitgenN   s   z#TestSeed.test_noninstantized_bitgenN)	__name__
__module____qualname__r2   r6   r9   r@   rC   rD   r&   r&   r&   r'   r)   .   s    
r)   c                   @   s   e Zd Zdd Zdd ZdS )TestBinomialc                 C   sB   t jddd}dD ]}ttd|dk tt||| q	d S )N   intdtype)r         ?r7   r   )r4   zerosr   randombinomialr
   )r0   rN   pr&   r&   r'   test_n_zeroS   s
   zTestBinomial.test_n_zeroc                 C   s   t ttjdtj d S )Nr7   )r   r>   rO   rP   r4   nanr?   r&   r&   r'   test_p_is_nan\   s   zTestBinomial.test_p_is_nanN)rE   rF   rG   rR   rT   r&   r&   r&   r'   rH   R   s    	rH   c                   @   sL   e Z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 )TestMultinomialc                 C   s   t dddg d S )Nd   皙?皙?rO   multinomialr?   r&   r&   r'   
test_basicb      zTestMultinomial.test_basicc                 C   s   t dg d d S )NrV   )rW   rX           r]   r]   rY   r?   r&   r&   r'   test_zero_probabilitye   r\   z%TestMultinomial.test_zero_probabilityc                 C   sZ   t dtdd  kodk n   tddd}t td|k t t|dk  d S )Nr;      )r   rO   r.   r4   allr0   xr&   r&   r'   test_int_negative_intervalh   s   $z*TestMultinomial.test_int_negative_intervalc                 C   s   ddg}t td|tdjd t td|tdjd t td|tdjd t td|ddgjd t td|djd t td|tdjd tttjd|t	d d S )NrM   r7   r7   rI   rI   rI   rI   rI   rI   rI   )
r   rO   rZ   r4   uint32shapearrayr   r=   floatr0   rQ   r&   r&   r'   	test_sizen   s   zTestMultinomial.test_sizec                 C   s,   t ttjdddg t ttjdddg d S )NrV   皙?rW   皙?r   r>   rO   rZ   r?   r&   r&   r'   test_invalid_prob|   s   z!TestMultinomial.test_invalid_probc                 C   s2   t ttjdddg t ttjdgd ddg d S )Nr;   rX   rW   r   rq   r?   r&   r&   r'   test_invalid_n   s   zTestMultinomial.test_invalid_nc                 C   sx   t d}|t |dd d  }|dd d }ttd}|jd|d}ttd}|jdt |d}t|| d S )Ng      .@r7      ۠iUrV   )pvals)r4   r5   sumr   r   rZ   ascontiguousarrayr
   )r0   rQ   rv   rO   
non_contigcontigr&   r&   r'   test_p_non_contiguous   s   
z%TestMultinomial.test_p_non_contiguousc                 C   sp   t jg dt jd}||  }ttd}d}tjt|d |	d| W d    d S 1 s1w   Y  d S )N)
Gz?r|   &.>r}   r}   r}   r}   r}   r}   r}   rK   ru   z-[\w\s]*pvals array is cast to 64-bit floatingmatchr7   )
r4   rj   float32rw   r   r   pytestraisesr>   rZ   )r0   rc   rv   rO   r   r&   r&   r'   test_multinomial_pvals_float32   s   
"z.TestMultinomial.test_multinomial_pvals_float32N)rE   rF   rG   r[   r^   rd   rm   rr   rs   r{   r   r&   r&   r&   r'   rU   a   s    
rU   c                   @   s   e Zd Zdd Zdd Zejdddgdd	 Zejd
g dejdddgejdg ddd Z	dd Z
dd Zdd ZdS )TestMultivariateHypergeometricc                 C   
   d| _ d S )Ni_ r   r?   r&   r&   r'   setup_method      
z+TestMultivariateHypergeometric.setup_methodc                 C   s   t ttjdd t ttjg dd t ttjg dd t ttjg dd t ttjg d t ttjdd	gd
dd ttj}|j}||jj	 }t ttj|d d	gd
dd d S )Nr      )rI   rt   r   r;   )r;   rI   rt   rI   r7   iɚ;e   r`   	marginalsrV   count)
r   r>   rO   multivariate_hypergeometricr4   iinfoint64maxrL   itemsize)r0   
int64_info	max_int64max_int64_indexr&   r&   r'   test_argument_validation   s0   z7TestMultivariateHypergeometric.test_argument_validationmethodr   r   c                 C   s
  t t| j}|jg dd|d}t|g d |jg d|d}t|g  |jg dd|d}t|tjdtjd |jg dd|d}t|g d |jg d	d
|d}t|g d g d}|j|t||d}t|| |jg ddd
|d}t|g dgd
  d S )Nr   r   r   r   r   r7   sizer   )r7   r   rK   r7   rI   rt   )r   r   r   rt   )rt   r   r   )r7   r7   r   r7   r7   rt   r   r`      )	r   r   r   r   r
   r4   emptyr   rw   )r0   r   rO   rc   colorsr&   r&   r'   test_edge_cases   s(   

z.TestMultivariateHypergeometric.test_edge_casesnsample)      -   7   r   )r`   rI   rt   iI c                 C   s   t t| j}tg d}|j||||d}t|tr#|f|j }n||j }t	|j| t
|dk  t
||k  t|jddtj||td t|trj|dkrlt|jdd|| |  dd	d
 d S d S d S )N)r   r`      r   r   r   r;   axis)
fill_valuerL   順 MbP?{Gzt?)rtolatol)r   r   r   r4   rj   r   
isinstancerJ   ri   r   r   ra   r
   rw   fullr   mean)r0   r   r   r   rO   r   sampleexpected_shaper&   r&   r'   test_typical_cases   s(   



z1TestMultivariateHypergeometric.test_typical_casesc                 C   sZ   t t| j}|jg ddddd}tg dg dg dg dg dg}t|| d S )Nr   r`   r   r   )rI   r7   rI   r7   r7   rt   rI   r   rt   r   r   r   r   r4   rj   r
   r0   rO   r   expectedr&   r&   r'   test_repeatability1   s   
z2TestMultivariateHypergeometric.test_repeatability1c                 C   sZ   t t| j}|jg ddddd}tg dg dg dg dg d	g}t|| d S )
Nr      2   r   r`   r   r   )r         )      r   )r         )r      r   r   r   r&   r&   r'   test_repeatability2     
z2TestMultivariateHypergeometric.test_repeatability2c                 C   sZ   t t| j}|jg ddddd}tg dg dg dg dg d	g}t|| d S )
Nr   r   r`   r   r   )rI   rt   r   )r`   rt   r   )rI   r`   r`   )r7   r`      r   r   r&   r&   r'   test_repeatability3  r   z2TestMultivariateHypergeometric.test_repeatability3N)rE   rF   rG   r   r   r   markparametrizer   r   r   r   r   r&   r&   r&   r'   r      s    !
"r   c                   @   s,   e Zd Zdd Zdd Zdd Zdd Zd	S )
TestSetStatec                 C   sT   d| _ tt| j | _| jj| _| jj| _| jd | jd d | jd d f| _d S )NIbit_generatorstatekeyr   )r   r   r   rgr   r   legacy_stater?   r&   r&   r'   r     s   


zTestSetState.setup_methodc                 C   s<   | j jdd}| j| j_| j jdd}tt||k d S Nrt   r   )r   standard_normalr   r   r   r4   ra   )r0   oldnewr&   r&   r'   test_gaussian_reset(  s   
z TestSetState.test_gaussian_resetc                 C   sL   | j   | jj}| j jdd}|| j_| j jdd}tt||k d S r   )r   r   r   r   r   r4   ra   )r0   r   r   r   r&   r&   r'    test_gaussian_reset_in_media_res/  s   
z-TestSetState.test_gaussian_reset_in_media_resc                 C   s   | j dd d S NrM   )r   negative_binomialr?   r&   r&   r'   test_negative_binomial:  s   z#TestSetState.test_negative_binomialN)rE   rF   rG   r   r   r   r   r&   r&   r&   r'   r     s
    	r   c                   @   s\  e Zd ZejZeejej	ej
ejejejejejg	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d Zejddeg dfdeg dfdeg dfgdd Z d d! Z!d"d# Z"d$d% Z#d&d' Z$d(d) Z%d*d+ Z&d,d- Z'ejj(ejd.d/d0ejd1fd/d2ej	d3fd4d5ej
d6fd7d8ejd9fgd:d; Z)d<S )=TestIntegersc                 C   s   t t| jd|td d S Nr7   r(   rL   )r   r=   rfuncrk   )r0   r(   r&   r&   r'   test_unsupported_typeG  s   z"TestIntegers.test_unsupported_typec              	   C   s>  | j D ]}|tu rdnt|j}|tu rdnt|jd }|r%|d n|}tt| j|d |||d tt| j||d ||d tt| j||||d tt| jdd||d tt| j|d g|||d tt| j|g|d g||d tt| j|g|g||d tt| jddg||d tt| j|d g|g||d qd S Nr   rI   r7   r   	itypeboolr4   r   minr   r   r>   r   r0   r(   dtlbndubndr&   r&   r'   test_bounds_checkingJ  s@   
z!TestIntegers.test_bounds_checkingc              	   C   s   | j D ]_}|tu rdnt|j}|tu rdnt|j|  }tt| j|d gd |gd ||d tt| j|gd |d gd ||d tt| j||gd ||d tt| jdgd d||d qd S r   r   r   r&   r&   r'   test_bounds_checking_arrayc  s    
z'TestIntegers.test_bounds_checking_arrayc              	   C   s.  | j D ]}|tu rdnt|j}|tu rdnt|jd }|r%|d n|}| }|d }t| j||| d||d| t| j|g|| d||d| |}t| j||| d||d| t| j||| gd||d| || d }t| j||| d||d| t| j|g|| gd||d| qd S )Nr   rI   r7   r*   r   r(   rL   r   r   r4   r   r   r   r   r   )r0   r(   r   r   r   is_opentgtr&   r&   r'   test_rng_zero_and_extremesq  sN   
z'TestIntegers.test_rng_zero_and_extremesc                 C   s  d}| j D ]}|tu rdnt|j}|tu rdnt|jd }|r'|d n|}|d }t| j|g|d g||d| t| j|g| |d g| |d| t| j|g| |d g| ||d| |}t| j|g|d g||d| t| j|g| |d g| |d| t| j|g| |d g| ||d| || d }t| j|g|d g||d| t| j|g| |d g| |d| t| j|g| |d g| ||d| qd S )Nr*   r   rI   r7   r   rL   rK   r   )r0   r(   r   r   r   r   r   r&   r&   r'    test_rng_zero_and_extremes_array  sl   
z-TestIntegers.test_rng_zero_and_extremes_arrayc                 C   s   | j D ]C}|tu rdnt|j}|tu rdnt|jd }|r%|d n|}z| j||||d W q tyF } ztdt	| d }~ww d S Nr   rI   r7   r   zMNo error should have been raised, but one was with the following message:

%s
r   r   r4   r   r   r   r   	ExceptionAssertionErrorstrr0   r(   r   r   r   er&   r&   r'   test_full_range  s   
zTestIntegers.test_full_rangec                 C   s   | j D ]G}|tu rdnt|j}|tu rdnt|jd }|r%|d n|}z| j|gd |g||d W q tyJ } ztdt	| d }~ww d S r   r   r   r&   r&   r'   test_full_range_array  s   
z"TestIntegers.test_full_range_arrayc              	   C   s   t t }| jdd  D ]#}dD ]}| jd|| d||d}t| |k  t| dk qq| jdd| d|td}t| dk  t| dk d S )Nr7   )r   r      rI   i   r   r   )r   r   r   r   r   r   r   r   )r0   r(   rO   r   r   valsr&   r&   r'   test_in_bounds_fuzz  s   
z TestIntegers.test_in_bounds_fuzzc           
      C   s   | j D ]h}|tu rdnt|j}|tu rdnt|jd }|r%|d n|}d}ttd}|j|||||d}ttd}|j|g|g|||d}ttd}|j|g| |g| |||d}	t	|| t	||	 qd S )Nr   rI   r7   r*     r   
r   r   r4   r   r   r   r   r   r.   r
   )
r0   r(   r   r   r   r   rO   scalarscalar_arrayrj   r&   r&   r'   test_scalar_array_equiv  s,   

z$TestIntegers.test_scalar_array_equivc              
   C   s   dddddddddd	}| j dd  D ];}ttd}tjd	kr-|jd
d| d||d}n|jd
d| d||d }t|	 }t
|t|j |k qttd}|jd
d| d|tdtj}t|	 }t
|ttj |k d S )N@053594a9b82d656f967c54869bc6970aa0358cf94ad469c81478459c6a90eee3@54de9072b6ee9ff7f20b58329556a46a447a8a29d67db51201bf88baa6e4e5d4@d3a0d5efb04542b25ac712e50d21f39ac30f312a5052e9bbb1ad3baa791ac84b@14e224389ac4580bfbdccb5697d6190b496f91227cf67df60989de3d546389b1@0e203226ff3fbbd1580f15da4621e5f7164d0d8d6b51696dd42d004ece2cbec1)	r   int16int32r   int8uint16rh   uint64uint8r7   r   littler   r   r*   r   rI   )r   r   r   sys	byteorderr.   byteswaphashlibsha256	hexdigestr   r4   rL   namer   viewr  )r0   r(   r   r   rO   valresr&   r&   r'   test_repeatability  s>   

zTestIntegers.test_repeatabilityc                 C   s   | j D ]k}|ttjfv rdnt|j}|ttjfv rdnt|jd }|r+|d n|}ttd}|j||d||d}ttd}|j|gd |||d}t	|| ttd}|j|gd |gd ||d}t	|| qd S )Nr   rI   r7   r   r*   r   r   r  )r0   r(   r   r   r   rO   r  val_bcr&   r&   r'   test_repeatability_broadcasting  s&   
"
z,TestIntegers.test_repeatability_broadcastingzbound, expectedr,   )iui,YQiXgi$#Pl   bA i{El   /Yi rB   )ui,YQXgi%#Pl   bA i|El   0Yi        )r  r  l   bA l   1Yi i{,miuHl   HM c                 C   sJ   d t |fD ]}ttd}|j||d}t||d ur|n|d  qd S )Nr   r   r   )lenr   r   r.   r   )r0   boundr   r   rO   rc   r&   r&   r'   !test_repeatability_32bit_boundary'  s
   
z.TestIntegers.test_repeatability_32bit_boundaryc              
   C   s   t g dg dg dgg dg dg dgg dg dg d	gg d
g dg dgg dg dg dgg}dD ]%}ttd}|jdgdgdggg d|d}t||d urY|n|d  q9d S )N)i
`l   Y/ i0b)i)H{TiP-iTq)l   C iZ'l   !g )l   k40 l   n2c l   DBJ )i|(iy+l   _&A )ip@GiG^l   J|xK )l   
f l   Dmv l   E"g )i>{l   wT2L iJQ)iQ//itLol   k )i\siJi)i=l   }D l   E9l )l   
+x i#Jl   b )i0i7Ol   rn )ixiiAi.t)l   q/q i;-/i)N)r`   rt   rt   i90  r;   r   r7   )r,   rB   r   r   )r4   rj   r   r   r.   r
   )r0   desiredr   rO   rc   r&   r&   r'   .test_repeatability_32bit_boundary_broadcasting6  s:   
z;TestIntegers.test_repeatability_32bit_boundary_broadcastingc              
   C   s2  t jddd fdddft jdi}|D ]}|| D ]}}|\}}|| }t |gd g}t |gd }tttj||||d	 tttj||||d	 tttj||||d	 tttj||||d	 t j|gd gtd
}	t j|gd td
}
tttj|	|||d	 tttj||
||d	 tttj|	|
||d	 qqd S )Nr   rI   A   )r;               r   r   r   r   ))r   l            )l         r'  r(  r)  )        r*  r   r   rK   )	r4   r  r   rj   r   r>   rO   r.   object)r0   r(   configsrL   configlowhighlow_ahigh_alow_ohigh_or&   r&   r'   &test_int64_uint64_broadcast_exceptionsM  sD   z3TestIntegers.test_int64_uint64_broadcast_exceptionsc                 C   sd   t j}t t jj}t t t jj}t t t jjd | }tj||||d}t|| d S r   )r4   r   r   r   r  rO   r.   r   )r0   r(   r   r   r   r   actualr&   r&   r'   test_int64_uint64_corner_casei  s   z*TestIntegers.test_int64_uint64_corner_casec                 C   s  | j D ]<}|tu rdnt|j}|tu rdnt|jd }|r%|d n|}|tu r.tjn|}| j||||d}t|j| qtt	fD ];}|tu rLdnt|j}|tu rXdnt|jd }|rf|d n|}| j||||d}t
|drxJ tt|| qDd S )Nr   rI   r7   r   rL   )r   r   r4   r   r   r   r   r   rL   rJ   hasattrtyper0   r(   r   r   r   r   r&   r&   r'   test_respect_dtype_singleton  s   
z)TestIntegers.test_respect_dtype_singletonc                 C   s   | j D ]S}|tu rdnt|j}|tu rdnt|jd }|r%|d n|}|tu r.tjn|}| j|g|g||d}t|j| | j|gd |gd ||d}t|j| qd S r   )	r   r   r4   r   r   r   r   r   rL   r9  r&   r&   r'   test_respect_dtype_array  s   
z%TestIntegers.test_respect_dtype_arrayc                 C   s   | j D ]M}| jddd||d}|jdksJ |j|ksJ | jddd||djdks,J ttjddddjd ttjddddjd ttjddddjd qd S )Nr   rt   r   r   r   r   r   r   )r   r   ri   rL   r   rO   r.   )r0   r(   r   r   r&   r&   r'   test_zero_size  s   
zTestIntegers.test_zero_sizec                 C   sT   t jdkrdnd}tt tjddd|d W d    d S 1 s#w   Y  d S )Nbigz<i4z>i4r      r   r   )r  r  r   r   r>   rO   r.   )r0   other_byteord_dtr&   r&   r'   test_error_byteorder  s   "z!TestIntegers.test_error_byteorderzsample_size,high,dtype,chi2maxi@KL r`   g     @_@r   g     b@i i	  g     ȩ@i  g     d@c           
      C   sN   t j|||d}tj|dd\}}|| }|| d |  }	|	|k s%J d S )Nr   T)return_countsrI   )rO   r.   r4   uniquerw   )
r0   sample_sizer/  rL   chi2maxsamplesvaluescountsr   chi2r&   r&   r'   $test_integers_small_dtype_chisquared  s
   
z1TestIntegers.test_integers_small_dtype_chisquaredN)*rE   rF   rG   rO   r.   r   r   r4   r  r  r
  r  r  rh   r   r  r   r   r   r   r   r   r   r   r   r  r  r  r   r   r   rj   r#  r%  r4  r6  r:  r;  r?  rC  slowrM  r&   r&   r&   r'   r   @  sP    #
	r   c                   @   sr  e Z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
ejdejejfejejfg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&d' Zd(d) Zd*d+ Zd,d- Z d.d/ Z!d0d1 Z"d2d3 Z#d4d5 Z$d6d7 Z%d8d9 Z&d:d; Z'd<d= Z(d>d? Z)d@dA Z*dBdC Z+dDdE Z,dFdG Z-ejdHe.e/gejdIdJe0g dKg dLgfdMe0g dNg dOgfdPe0g dQg dRgfgdSdT Z1dUdV Z2dWdX Z3ejdYdZd[gd\d] Z4d^d_ Z5d`da Z6dbdc Z7ddde Z8dfdg Z9dhdi Z:djdk Z;dldm Z<dndo Z=dpdq Z>ejj?drds Z@ejdtg dug dvg dwg dxg dyg dzd{gg d|gd}d~ ZAdd ZBdd ZCdd ZDdd ZEdd ZFdd ZGdd ZHdd ZIdd ZJdd ZKdd ZLdd ZMdd ZNdd ZOdd ZPdd ZQdd ZRejdeSd{ddejTdgdd ZUdd ZVejjWeXddejdg ddd ZYejddMgdggfdgdPggfgdd ZZejdg ddd Z[dd Z\dd Z]dd Z^dd Z_dd Z`dd ZaddÄ Zbddń ZcddǄ ZdddɄ Zedd˄ Zfdd̈́ Zgddτ Zhddф Ziddӄ ZjddՄ Zkddׄ Zlddل Zmddۄ Zndd݄ Zodd߄ Zpdd Zqdd Zrdd Zsdd Ztdd Zudd Zvdd Zwdd Zxdd Zydd Zzdd Z{dd Z|dd Z}dd Z~dd Zdd Zejd ddgdd Zejddej dejdgejd g d	d
d Zdd Zdd Zdd Zdd ZdJS (  TestRandomDistc                 C   r   )Nr   r   r?   r&   r&   r'   r     r   zTestRandomDist.setup_methodc                 C   H   t t| j}|jdddd}tddgddgd	d
gg}t|| d S )Nc   rt   rI   r   )   %   ir   r   r   r.   r4   rj   r
   r0   rO   r5  r$  r&   r&   r'   test_integers  s   zTestRandomDist.test_integersc                 C   sR   t t| j}|jdddtjd}tjddgddgd	d
ggtjd}t|| d S )Nr   rR  rS  r   r      F   D   r   rV  rK   )r   r   r   r.   r4   rh   rj   r
   rZ  r&   r&   r'   test_integers_masked  s   "z#TestRandomDist.test_integers_maskedc                 C   sJ   t t| j}|jddddd}tddgdd	gd
dgg}t|| d S )NrQ  rR  rS  T)r   r(   rT  rU  rV  &   rX  irY  rZ  r&   r&   r'   test_integers_closed  s   z#TestRandomDist.test_integers_closedc                 C   s:   t jtdjtdjdd}tdj}t|| d S )NlTr(   )rO   r.   r4   r   r   r   )r0   r5  r$  r&   r&   r'   test_integers_max_int  s
   z$TestRandomDist.test_integers_max_intc                 C   sn   t t| j}|d}tddgddgddgg}t||dd	 t t| j}| }t||d
 dd	 d S )NrS  gG0Ը?gæ?g2?gu	A?gH
>H?g;dE?r   decimalr)  r   r   r   rO   r4   rj   r   rZ  r&   r&   r'   test_random  s   

zTestRandomDist.test_randomc                 C   sF   t t| j}|d}tddgddgddgg}t||dd	 d S )
NrS  CԸ?gP?gtX?g81
A?grO>H?g88dE?r   re  rg  rZ  r&   r&   r'   test_random_float  s   

z TestRandomDist.test_random_floatc                 C   s2   t t| j}|jtjd}d}t||dd d S )NrK   ri  r   re  )r   r   r   rO   r4   r   r   rZ  r&   r&   r'   test_random_float_scalar  s   z'TestRandomDist.test_random_float_scalarzdtype, uint_view_typec                 C   sP   t t| j}|jd|d}t||d@ }d|  k r#dk s&J  J d S )Nr   rK   r7   i$^  i,e  )r   r   r   rO   r4   count_nonzeror  )r0   rL   uint_view_typerO   r   num_ones_in_lsbr&   r&   r'   test_random_distribution_of_lsb	  s    z.TestRandomDist.test_random_distribution_of_lsbc                 C   s   t ttjdd d S )Nr  rK   )r   r=   rO   r?   r&   r&   r'   test_random_unsupported_type  r\   z+TestRandomDist.test_random_unsupported_typec                 C   s<   t t| j}|dd}tjg dtjd}t|| d S )Nr   )r   r   rI   rI   rK   r   r   r   choicer4   rj   r   r
   rZ  r&   r&   r'   test_choice_uniform_replace  s   z*TestRandomDist.test_choice_uniform_replacec                 C   sD   t t| j}|jddg dd}tjg dtjd}t|| d S )Nr   )皙?rt  皙?ru  rQ   )r   r7   r   r7   rK   rq  rZ  r&   r&   r'   test_choice_nonuniform_replace  s   z-TestRandomDist.test_choice_nonuniform_replacec                 C   sl   t t| j}|jdddd}tjg dtjd}t|| |jddddd}tjdtjd}t|| d S )Nr   rt   Freplacer   rK   )ry  shuffle)	r   r   r   rr  r4   rj   r   r
   r5   rZ  r&   r&   r'   test_choice_uniform_noreplace$  s   
z,TestRandomDist.test_choice_uniform_noreplacec                 C   sF   t t| j}|jdddg dd}tjg dtjd}t|| d S )Nr   rt   F)ru  333333?rM   ru  ry  rQ   )r   rI   rt   rK   rq  rZ  r&   r&   r'    test_choice_nonuniform_noreplace-  s   z/TestRandomDist.test_choice_nonuniform_noreplacec                 C   s:   t t| j}|g dd}tg d}t|| d S )N)abcdr   )r  r  r  r  r   r   r   rr  r4   rj   r
   rZ  r&   r&   r'   test_choice_noninteger3  s   z%TestRandomDist.test_choice_nonintegerc                 C   s\   t t| j}|ddgddgddgddggd}tddgddgddgg}t|| d S )	Nr   r7   rI   rt   r   r`   r   r   r  rZ  r&   r&   r'   )test_choice_multidimensional_default_axis9  s   $z8TestRandomDist.test_choice_multidimensional_default_axisc                 C   s^   t t| j}|jddgddgddgddggddd	}tdgdgdgdgg}t|| d S )
Nr   r7   rI   rt   r   r`   r   r   r   r  rZ  r&   r&   r'   (test_choice_multidimensional_custom_axis?  s   (z7TestRandomDist.test_choice_multidimensional_custom_axisc                 C   s  t j}tt|dd tt|dd tt|g d tt|g ddddgddggd tt|ddgdg d	d tt|ddgdd
dgd tt|ddgdddgd tt|g dddd tt|g dddd tt|g dddd tt|g dddd tt|g dddg dd d S )Nr;   rt         @)r7   rI   rt   r         ?rv  r7   rI   )rt  rt  rW   rn   ro   rt  r   r   Frx  rA   )r;   )r;   r7   )r7   r   r   r}  )rO   rr  r   r>   )r0   r   r&   r&   r'   test_choice_exceptionsE  s"   
z%TestRandomDist.test_choice_exceptionsc              	   C   s   ddg}t ttjddd t ttjddd t ttjdd|d t ttjdd|d t ttjddgdd t tjd gddd u  tddg}tjdtd	}||d
< t tj|dd|u  t }t ttjd|dd  t ttjd|dd  t ttjd|d|d  t ttjd|d|d  t ttjddg|dd  t tjd g|ddj	d
k tddg}tjdtd	}||d
< t tj||dd
 |u  d}g d}ttjd|ddj| ttjd|ddj| ttjd|d|dj| ttjd|d|dj| ttjtd|ddj| ttjd
d
ddjd ttjd
dd
djd ttjddd
djd ttjd
d
djd ttjg ddjd ttjddgddjd tttjg d d S )Nru  rp   rI   Trx  Fr}  r7   rK   r   r   )ru  ru  ru  ru  rt  rW   r   r<  r   r=  r>  r   r  r  )r   r4   isscalarrO   rr  rj   r   r+  tuplendimitemr   ri   r5   r.   r   r>   )r0   rQ   r  arrr1   r&   r&   r'   test_choice_return_shapeW  sL    z'TestRandomDist.test_choice_return_shapec                 C   s,   t g d}g d}tttj||d d S )N)*   r7   rI   )NNNrv  )r4   rj   r   r>   rO   rr  )r0   r  rQ   r&   r&   r'   test_choice_nan_probabilities  s   z,TestRandomDist.test_choice_nan_probabilitiesc              	   C   s   t dd }d|dd d< tt| j}|jdd|d d d d}tt| j}|jddt |d d d d}t|| d S )Nr   r`   r  r7   rI   rt   rv  )r4   onesr   r   r   rr  rx   r
   )r0   rQ   rO   ry   rz   r&   r&   r'   test_choice_p_non_contiguous  s    z+TestRandomDist.test_choice_p_non_contiguousc                 C   s   t dd }tdd}|jt jksJ tjdddd}|jt jks%J tjdd|d}|jt jks5J tjdd|dd}|jt jksFJ d S )Nr   g      @rI   Frx  rv  )rQ   ry  )r4   r  rO   rr  rL   r   )r0   rQ   r5  r&   r&   r'   test_choice_return_type  s   z&TestRandomDist.test_choice_return_typec                 C   sZ   d}t t| j}|jdddd}tjdkr| }t|	t
j }t||k d S )N@4266599d12bfcfb815213303432341c06b4349f5455890446578877bb322e222'  rD  Frx  r  )r   r   r   rr  r  r  r  r  r  r  r4   r  r  r   )r0   choice_hashrO   r5  r  r&   r&   r'   test_choice_large_sample  s   
z'TestRandomDist.test_choice_large_samplec                 C   s   t t| j}t|jg dddtddd t|jg dgddg d t|jdggdddgdd t|jdggddddgdd d S )Nr   r&   r   r7   T)strict)r   r   )r   r   r   r
   rr  r4   rj   r0   rO   r&   r&   r'   "test_choice_array_size_empty_tuple  s   
z1TestRandomDist.test_choice_array_size_empty_tuplec                 C   s*   t t| j}|d}d}t|| d S )Nr   s
   	8%)r   r   r   bytesr   rZ  r&   r&   r'   
test_bytes  s   
zTestRandomDist.test_bytesc                 C   s   dd dd dd dd dd dd dd d	d d
d dd dd fD ]!}t t| j}|g d}|| |}|g d}t|| q#d S )Nc                 S   s
   t g S r#   )r4   rj   rc   r&   r&   r'   <lambda>  s   
 z-TestRandomDist.test_shuffle.<locals>.<lambda>c                 S   s   | S r#   r&   r  r&   r&   r'   r    s    c                 S      t | t jS r#   )r4   asarrayastyper  r  r&   r&   r'   r        c                 S   r  r#   )r4   r  r  r   r  r&   r&   r'   r    r  c                 S   r  r#   )r4   r  r  	complex64r  r&   r&   r'   r    r  c                 S   s   t | tS r#   )r4   r  r  r+  r  r&   r&   r'   r        c                 S   s   dd | D S )Nc                 S      g | ]}||fqS r&   r&   .0ir&   r&   r'   
<listcomp>      ATestRandomDist.test_shuffle.<locals>.<lambda>.<locals>.<listcomp>r&   r  r&   r&   r'   r    s    c                 S   s   t dd | D S )Nc                 S   s   g | ]}||gqS r&   r&   r  r&   r&   r'   r    r  r  )r4   r  r  r&   r&   r'   r    r  c                 S   s   t | | gjS r#   )r4   vstackTr  r&   r&   r'   r    r  c                 S   s*   t dd | D dtfdtfgt jS )Nc                 S   r  r&   r&   r  r&   r&   r'   r    r  r  r  r  )r4   r  rJ   r  recarrayr  r&   r&   r'   r    s    
c                 S   s(   t dd | D dtdfdt jdfgS )Nc                 S   r  r&   r&   r  r&   r&   r'   r    r  r  r  r7   r  )r4   r  r+  r  r  r&   r&   r'   r    s
    

r7   rI   rt   r   r`   r   r   r   r   r   
r   r7   r   r   r   r`   rt   r   rI   r   )r   r   r   rz  r
   )r0   convrO   alistr5  r$  r&   r&   r'   test_shuffle  s&   
zTestRandomDist.test_shufflec                 C   s   t t| j}tdd}|j|dd tg dg dg dg dg}t|| t t| j}tdd}|j|d	d t|| d S )
Nr   r   r   r7   r   r   rt   r7   rI   r   r   r`   r   r      r   r   r   r   r   r   r;   )	r   r   r   r4   r5   reshaperz  rj   r
   rZ  r&   r&   r'   test_shuffle_custom_axis  s   

z'TestRandomDist.test_shuffle_custom_axisc                 C   sT   t t| j}tg d}dD ]}tg d}|j||d t|| qd S )N)r   r   )r   r7   r   )r   r   r   r4   rj   r  rz  r
   )r0   rO   r$  r   r5  r&   r&   r'   test_shuffle_custom_axis_empty  s   z-TestRandomDist.test_shuffle_custom_axis_emptyc                 C   s^   t ddd}| }tt| j}|j|dd tt| j}||j t	|| d S )Nr   rI   r   r7   r   )
r4   r5   r  copyr   r   r   rz  r  r
   )r0   y1y2rO   r&   r&   r'   test_shuffle_axis_nonsquare  s   z*TestRandomDist.test_shuffle_axis_nonsquarec                 C   s   t jt tddd d d}t jt dd d d}| }| }tdD ]2}t| t	t
|j|j  t
|j|j   t| t	t
|j|j  t
|j|j   q+d S )Nr   )r`   r   rt   r7   r;   r   )r4   mamasked_valuesr  r3   r5   r  rO   rz  r   sorteddatamask)r0   r  r  a_origb_origr  r&   r&   r'   test_shuffle_masked  s   "
 
 z"TestRandomDist.test_shuffle_maskedc                 C   s   t t| j}td}tt|j|d tdd}tt|j|d tt	|j|t
ddd  g dg dg}tt|j|d td}tt	|j| td	}tt|j|d d S )
Nr   r7   r   rt   rt   rt   rI   r   )r   r`   r   rS  )r   r   r   r4   r5   r   r   rz  r  r=   sliceNotImplementedErrorrj   r  r0   rO   r  r&   r&   r'   test_shuffle_exceptions  s   


z&TestRandomDist.test_shuffle_exceptionsc                 C   s^   t t| j}td}d|j_tjt	dd |
| W d    d S 1 s(w   Y  d S )Nr`   F	read-onlyr~   )r   r   r   r4   rN   flags	writeabler   r   r>   rz  )r0   rO   r  r&   r&   r'   test_shuffle_not_writeable  s   
"z)TestRandomDist.test_shuffle_not_writeablec           	      C   s   t t| j}g d}||}g d}t|| t t| j}tg dj}||}t|t|j d}tt	|j| d}tt	|j| t t| j}d}g d}||}t|| d S )Nr  r  abcdg333333?r   )
rt   r   r   r   r   r   rI   r`   r7   r   )
r   r   r   permutationr
   r4   
atleast_2dr  r   r   )	r0   rO   r  r5  r$  arr_2d	bad_x_strbad_x_floatinteger_valr&   r&   r'   test_permutation  s$   



zTestRandomDist.test_permutationc                 C   s   t dd}t g dg dg dg dg}tt| j}|j|dd}t|| tt| j}|j|d	d}t|| d S )
Nr   r  r  r  r  r  r7   r   r;   )	r4   r5   r  rj   r   r   r   r  r
   )r0   r  r$  rO   r5  r&   r&   r'   test_permutation_custom_axis.  s   

z+TestRandomDist.test_permutation_custom_axisc                 C   sd   t t| j}td}tt|j|d tdd}tt|j|d tt	|j|t
ddd  d S )Nr   r7   r   r  rt   rI   )r   r   r   r4   r5   r   r   r  r  r=   r  r  r&   r&   r'   test_permutation_exceptions;  s   
z*TestRandomDist.test_permutation_exceptionsrL   zaxis, expectedN)rt   r   r   r   r   r  )r   r   rI   r`   r7   r   r   )r   r7   rI   r   r   r  )r   r   r   rt   r   r`   r7   )r`   rt   r   r   rI   r7   )r  r   r   r   r   r   c                 C   s   t t| j}tddd|}|j|||d t|| t t| j}tddd|}|j||d}|j	|ksAJ t|| d S )Nr   rI   r   r   outr   )
r   r   r   r4   r5   r  r  permutedr
   rL   )r0   rL   r   r   rO   rc   yr&   r&   r'   test_permutedC  s   	
zTestRandomDist.test_permutedc                 C   s   t t| j}tddd}| }|d d d d df }|j|d|d}tg dg dg}t	|| ||d d d d df< t	|| d S )	N   rI   r  rt   r7   r  )r   r   rt   r   )r   r   r  r   )
r   r   r   r4   r5   r  r  r  rj   r
   )r0   rO   x0x1rc   r  r   r&   r&   r'   test_permuted_with_stridesW  s   

z)TestRandomDist.test_permuted_with_stridesc                 C   s   t g }t|g  d S r#   )rO   r  r
   )r0   r  r&   r&   r'   test_permuted_emptyd  s   
z"TestRandomDist.test_permuted_emptyoutshaper   r`   c                 C   s`   t g d}t j||jd}tjtdd tj||d W d    d S 1 s)w   Y  d S )Nr   rK   z
same shaper~   r  )	r4   rj   rN   rL   r   r   r>   rO   r  )r0   r  r  r  r&   r&   r'   "test_permuted_out_with_wrong_shapeh  s
   "z1TestRandomDist.test_permuted_out_with_wrong_shapec                 C   s^   t jdt jd}t d}tjtdd tj|d|d W d    d S 1 s(w   Y  d S )N)rt   r`   rK   zCannot castr~   r7   r  )	r4   rN   r  r  r   r   r=   rO   r  )r0   r  rc   r&   r&   r'   !test_permuted_out_with_wrong_typeo  s
   
"z0TestRandomDist.test_permuted_out_with_wrong_typec                 C   sV   t d}d|j_tjtdd tj|d|d W d    d S 1 s$w   Y  d S )N)rI   r`   Fr  r~   r7   r  )	r4   rN   r  r  r   r   r>   rO   r  rb   r&   r&   r'   test_permuted_not_writeableu  s
   
"z*TestRandomDist.test_permuted_not_writeablec                 C   L   t t| j}|jdddd}tddgddgd	d
gg}t||dd d S )Nru  rp   rS  r   gW<$=g^
=g/:Ћ?gG!Gc>g'`2?gU?r   re  )r   r   r   betar4   rj   r   rZ  r&   r&   r'   	test_beta{  s   zTestRandomDist.test_betac                 C   sp   t t| j}|jdddd}tddgddgdd	gg}t|| t t| j}|dd}d}t|| d S )
NgZd;Y@gv/?rS  r   r  rV  0   ,   r   )r   r   r   rP   r4   rj   r
   rZ  r&   r&   r'   test_binomial  s   

zTestRandomDist.test_binomialc                 C   J   t t| j}|jddd}tddgddgdd	gg}t||d
d d S )Nr   rS  r   gmE~@@g
1ςC@grӳL@gm%xL@g<kQK@gtK@r   re  )r   r   r   	chisquarer4   rj   r   rZ  r&   r&   r'   test_chisquare     
zTestRandomDist.test_chisquarec                 C   s   t t| j}tddg}|j|dd}tddgddggd	d
gddggddgddggg}t||dd tddg}tt|j| t t| j}tddg}||}t||d dd d S )NI<I@EZC@rS  r   g28\h?gɎG/?gAp?g|);?gLX?gfOh?g됷W?g(ސP?gz$Q?gmWt ?g搝K?g4hz?r   re  HzG?缉ؗҜr)  )	r   r   r   r4   rj   	dirichletr   r   r>   )r0   rO   alphar5  r$  	bad_alphar&   r&   r'   test_dirichlet  s(   

zTestRandomDist.test_dirichletc                 C   s   t ddg}tt|t djd tt|t djd tt|t djd tt|ddgjd tt|djd tt|t djd tttj|t	d d S )Nr  r  r7   re   rI   rf   rg   )
r4   rj   r   rO   r  rh   ri   r   r=   rk   rl   r&   r&   r'   test_dirichlet_size  s   z"TestRandomDist.test_dirichlet_sizec                 C   s   t ddg}tttj| tttjddgg tttjdgdgg tttjdgdggdgdggg tttjt ddgddgg d S )Nr  r  r`   r7   )r4   rj   r   r>   rO   r  )r0   r  r&   r&   r'   test_dirichlet_bad_alpha  s   "$z'TestRandomDist.test_dirichlet_bad_alphac                 C   sh   t g d}|d d d }tt| j}|j|dd}tt| j}|jt |dd}t|| d S )N)r  g      r  rI   rS  r   )r4   rj   r   r   r   r  rx   r   )r0   r  r  rO   ry   rz   r&   r&   r'   #test_dirichlet_alpha_non_contiguous  s   z2TestRandomDist.test_dirichlet_alpha_non_contiguousc                 C   sx   d}|t ddg }tt| j}|j|dd}t ddgddggddgddggddgddggg}t||dd d S )	Nr}         ?r   rS  r   r]   r   re  )r4   rj   r   r   r   r  r   )r0   epsr  rO   r5  r   r&   r&   r'   test_dirichlet_small_alpha  s    z)TestRandomDist.test_dirichlet_small_alphac                 C   sT   t ddg}||  }tt| j}|j|dd}|jdd}t||dd d S )	Ng{Gz?{Gz?i -1r   r   r   r   )r   )	r4   rj   rw   r   r   r   r  r   r   )r0   r  
exact_meanrO   r   sample_meanr&   r&   r'   %test_dirichlet_moderately_small_alpha  s   z4TestRandomDist.test_dirichlet_moderately_small_alphar  )r`   r   r   r   )rM   r   r   r   )r7   r`   r   r         ?r   r   r   )g{Gz?gQ?r   r   )gh㈵>r   r   r   )gMb`?gQ?r   r   r  r   r   r   r]   r   c                 C   s*   t |}t|}t||dk d d S )Nr   r]   )r4   rj   rO   r  r   )r0   r  r  r&   r&   r'   &test_dirichlet_multiple_zeros_in_alpha  s   

z5TestRandomDist.test_dirichlet_multiple_zeros_in_alphac                 C   r  )Ng8EGr?rS  r   gvM?g?g#c?gQ:N?gAP?gE_9@r   re  )r   r   r   exponentialr4   rj   r   rZ  r&   r&   r'   test_exponential  r  zTestRandomDist.test_exponentialc                 C   &   t tjddd tttjdd d S Nr   scale       )r   rO   r  r   r>   r?   r&   r&   r'   test_exponential_0     z!TestRandomDist.test_exponential_0c                 C   r  )Nr   M   rS  r   g}(Ҍ?gi?g=r?g]hDA?gjӨ?g8k*u?r   re  )r   r   r   fr4   rj   r   rZ  r&   r&   r'   test_f     
zTestRandomDist.test_fc                 C   r  )Nr`   rt   rS  r   g,שn'@gt@g<e2@g1a3@g3r
y-2@gs1-2@r   re  )r   r   r   gammar4   rj   r   rZ  r&   r&   r'   
test_gamma  r  zTestRandomDist.test_gammac                 C   s*   t tjdddd tttjddd d S )Nr   )ri   r  r  )r   rO   r  r   r>   r?   r&   r&   r'   test_gamma_0  s   zTestRandomDist.test_gamma_0c                 C   sF   t t| j}|jddd}tddgddgddgg}t|| d S )N_c97ݚ?rS  r   r7   r  r   r   )r   r   r   	geometricr4   rj   r
   rZ  r&   r&   r'   test_geometric     
zTestRandomDist.test_geometricc                 C   s   t ttjd t ttjdgd  t ttjd t ttjdgd  tjdd t ttjtj t ttjtjgd  W d    d S 1 sGw   Y  d S )Nrn   r   ro   ignoreinvalid)r   r>   rO   r  r4   errstaterS   r?   r&   r&   r'   test_geometric_exceptions!  s   "z(TestRandomDist.test_geometric_exceptionsc                 C   r  )Nr         @rS  locr  r   gA7G@g1Fiҿgei@g_Cg0cPg`(_տr   re  )r   r   r   gumbelr4   rj   r   rZ  r&   r&   r'   test_gumbel*  r  zTestRandomDist.test_gumbelc                 C   r  r  )r   rO   r'  r   r>   r?   r&   r&   r'   test_gumbel_02  r  zTestRandomDist.test_gumbel_0c                 C   s   t t| j}|jddddd}tddgddgddgg}t|| |jdd	d
dd}tg d}t|| |jdd	ddd}tg d}t|| |jd	dd
dd}tg d}t|| |jd	dddd}tg d}t|| d S )Ng333333$@g      @r   rS  r   r   r   r`   r   rt   r   )rt   rt   rt   rt   r   r   )r   r   r   r   )r   r   r   r   )r   r   r   hypergeometricr4   rj   r
   rZ  r&   r&   r'   test_hypergeometric6  s&   




z"TestRandomDist.test_hypergeometricc                 C   r  )Nr  r$  rS  r%  g6@	ga@bDA"?g*[r{g>K?g(?g<?r   re  )r   r   r   laplacer4   rj   r   rZ  r&   r&   r'   test_laplaceP  r  zTestRandomDist.test_laplacec                 C   r  r  )r   rO   r,  r   r>   r?   r&   r&   r'   test_laplace_0X  r  zTestRandomDist.test_laplace_0c                 C   r  )Nr  r$  rS  r%  gbZgHʊg$>?g>&gQh@g%?n?gĉ8|?r   re  )r   r   r   logisticr4   rj   r   rZ  r&   r&   r'   test_logistic\  r  zTestRandomDist.test_logisticc                 C   r  )Nr  r$  rS  )r   sigmar   gܒx?gk*+@g<Ҿ?g
@g5a@g%jz(@r   re  )r   r   r   	lognormalr4   rj   r   rZ  r&   r&   r'   test_lognormald  r  zTestRandomDist.test_lognormalc                 C   s&   t tjddd tttjdd d S )Nr   )r1  r7   r  )r   rO   r2  r   r>   r?   r&   r&   r'   test_lognormal_0l  r  zTestRandomDist.test_lognormal_0c                 C   sF   t t| j}|jddd}tddgddgdd	gg}t|| d S )
Ngƀ@?rS  )rQ   r   r   r   rt      r`   r7   )r   r   r   	logseriesr4   rj   r
   rZ  r&   r&   r'   test_logseriesp  r  zTestRandomDist.test_logseriesc                 C   s$   t t| j}|ddksJ d S )Nr   r7   )r   r   r   r6  r  r&   r&   r'   test_logseries_zerox  s   z"TestRandomDist.test_logseries_zerovaluer;   r  g      @c              	   C   s  t t| j}tjddp tt || W d    n1 s#w   Y  tt |t	|gd  W d    n1 sCw   Y  tt |t	|gd d d d  W d    n1 shw   Y  W d    d S W d    d S 1 sw   Y  d S )Nr  r   r   rI   )
r   r   r   r4   r"  r   r   r>   r6  rj   )r0   r9  rO   r&   r&   r'   test_logseries_exceptions|  s   ""z(TestRandomDist.test_logseries_exceptionsc                 C   sf   t t| j}|jddgd dd}tg dg dgg dg d	gg d
g dgg}t|| d S )Nr   UUUUUU?r   rS  r   )r7   r`   r7   r   r   rt   )r   rI   r   rI   r   rI   )r`   rt   rI   r   rt   r7   )r   r   r   rI   rt   r   )r   rt   r7   r`   rt   rI   )r`   r`   rt   r7   rI   r   )r   r   r   rZ   r4   rj   r
   rZ  r&   r&   r'   test_multinomial  s   
zTestRandomDist.test_multinomialzfp errors don't work in wasmreasonr   )svdeighcholeskyc                 C   s  t t| j}d}ddgddgg}d}|j||||d}tddgdd	ggd
dgddggddgddggg}t||dd |j|||d}tddg}t||dd ddg}ddgddgg}tt|j||dd ddgddgg}t	t
|j|| t	t
|j||dd tt|j||dd t|j||dd tt|j||dd tt|j||ddd ddgddgg}|dv r|j||d|d}t|d |d  d!d n
tt|j||dd tjdd"gd"dggtjd#}t }	|j|||d |	t
}
t|
dksJ W d    n	1 sw   Y  td}td}tt|j||d$d tt|jtd%| tt|j|td tt|j|td& d S )'N)r  r   r7   r   rS  r   gtg$&@g&بO=g!$@gDo?g\&@g,R{?g
f!@g?ժ?gT^o#@g`R?gP'@r   re  gl?g$("@rI   raise)check_validr@  rA  r  )rC  r   )r?  r@  r   ).r   ).r7   r   ru  rK   other)rI   r7   r7   rt   )r   r   r   multivariate_normalr4   rj   r   r   r>   r   RuntimeWarningr   r	   r   r   recordr!  rN   eyer   )r0   r   rO   r   covr   r5  r$  rI  supwmur&   r&   r'   test_multivariate_normal  s   








z'TestRandomDist.test_multivariate_normalz	mean, covy      ?      ?y                c                 C   sN   t t| j}tjtdd ||| W d    d S 1 s w   Y  d S )Nzmust not be complexr~   )r   r   r   r   r   r=   rE  )r0   r   rI  rO   r&   r&   r'   )test_multivariate_normal_disallow_complex  s   "z8TestRandomDist.test_multivariate_normal_disallow_complexc           	      C   s   t t| j}d}tddg}tddgddgg}|j|||f|d}|| }|j| |d  }tt|	ddk sAJ tt|| dk sOJ d S )Nr*   r7   rI   r   rA   ru  rW   )
r   r   r   r4   rj   rE  r  ra   absr   )	r0   r   rO   n_sr   rI  r1   s_centercov_empr&   r&   r'   $test_multivariate_normal_basic_stats  s    z3TestRandomDist.test_multivariate_normal_basic_statsc                 C   rP  )NrV   g|Pk?rS  )nrQ   r   i  i  i  i  iX  i  )r   r   r   r   r4   rj   r
   rZ  r&   r&   r'   r     s   
z%TestRandomDist.test_negative_binomialc                 C   s\   t jdd tttjdt j tttjdt jgd  W d    d S 1 s'w   Y  d S )Nr  r   rV   r   )r4   r"  r   r>   rO   r   rS   r?   r&   r&   r'   !test_negative_binomial_exceptions  s   

"z0TestRandomDist.test_negative_binomial_exceptionsc                 C   s:   t t tdd}W d    d S 1 sw   Y  d S Nr7   r   )r   r>   rO   r   rb   r&   r&   r'   #test_negative_binomial_p0_exception   s   
"z2TestRandomDist.test_negative_binomial_p0_exceptionc                 C   sV   t jdd tttjdd tttjdgdg W d    d S 1 s$w   Y  d S )Nr  r   r'  ru  )r4   r"  r   r>   rO   r   r?   r&   r&   r'   .test_negative_binomial_invalid_p_n_combination  s   "z=TestRandomDist.test_negative_binomial_invalid_p_n_combinationc                 C   s   t t| j}|jdddd}tddgddgdd	gg}t||d
d |jdddd}tddgddgddgg}t||d
d t t| j}|jdddd}tddgddgddgg}t||d
d d S )Nr`   rS  )dfnoncr   gs؀3J?gugو/@gNJm+@gA}-4@gq=&@gjhn@r   re  rM   rW   gZօDN?gE!X&?gt%T?gQ)V?g5Zlf?gΎ{?r   gmK?gZ?g%yKY@g@W@gĈ{>@g&BB=@)r   r   r   noncentral_chisquarer4   rj   r   rZ  r&   r&   r'   test_noncentral_chisquare  s(   


z(TestRandomDist.test_noncentral_chisquarec                 C   N   t t| j}|jddddd}tddgdd	gd
dgg}t||dd d S )Nr`   rI   r7   rS  )dfnumdfdenrZ  r   gHP
?gn?g%f?gch?gzƎ?g]?:?r   re  )r   r   r   noncentral_fr4   rj   r   rZ  r&   r&   r'   test_noncentral_f!     

z TestRandomDist.test_noncentral_fc                 C   s2   t t| j}|jddtjd}t|sJ d S )Nr`   rI   )r^  r_  rZ  )r   r   r   r`  r4   rS   isnanr0   rO   r5  r&   r&   r'   test_noncentral_f_nan*  s   z$TestRandomDist.test_noncentral_f_nanc                 C   r  )Nr  r$  rS  r%  g?`xg\P@g/7u g0aj?gi%?gog@r   re  )r   r   r   normalr4   rj   r   rZ  r&   r&   r'   test_normal/  r  zTestRandomDist.test_normalc                 C   r  r  )r   rO   rf  r   r>   r?   r&   r&   r'   test_normal_07  r  zTestRandomDist.test_normal_0c                 C   sN   t t| j}|jddd}tddgddgdd	gg}tjj||d
d d S )Nr  rS  r  r   gá?gƫh@gi`>?g0"&Agc@g=fAr   )nulp)r   r   r   paretor4   rj   testingassert_array_almost_equal_nulprZ  r&   r&   r'   test_pareto;  s   
	zTestRandomDist.test_paretoc                 C   sF   t t| j}|jddd}tddgddgddgg}t|| d S )Nr  rS  )lamr   r   )r   r   r   poissonr4   rj   r
   rZ  r&   r&   r'   test_poissonI  r  zTestRandomDist.test_poissonc                 C   s   t dj}d}tttj| tttj|gd  tttj| tttj|gd  t jdd tttjt j tttjt jgd  W d    d S 1 sOw   Y  d S )Nr   r;   r   r  r   )	r4   r   r   r   r>   rO   rp  r"  rS   )r0   lambiglamnegr&   r&   r'   test_poisson_exceptionsQ  s   "z&TestRandomDist.test_poisson_exceptionsc                 C   r  )Nr  rS  ri  gZ >g?gÄ(=g҇?gŚE?gߢH?r   re  )r   r   r   powerr4   rj   r   rZ  r&   r&   r'   
test_power\  r  zTestRandomDist.test_powerc                 C   r  )Nr   rS  )r  r   gry@gtQP0@gAI_@g@u81@g	G0@g"wc5@r   re  )r   r   r   rayleighr4   rj   r   rZ  r&   r&   r'   test_rayleighd  r  zTestRandomDist.test_rayleighc                 C   r  r  )r   rO   rw  r   r>   r?   r&   r&   r'   test_rayleigh_0l  r  zTestRandomDist.test_rayleigh_0c                 C   H   t t| j}|jdd}tddgddgddgg}t||d	d
 d S )NrS  r   gH1gW|3
g\?gLeg5P	gFA?r   re  )r   r   r   standard_cauchyr4   rj   r   rZ  r&   r&   r'   test_standard_cauchyp     
z#TestRandomDist.test_standard_cauchyc                 C   r  )NrS  invr   ga\5?gr7k?g8PC*?g5$[?gW3T?g*?r   re  )r   r   r   standard_exponentialr4   rj   r   rZ  r&   r&   r'   test_standard_exponentialx  r  z(TestRandomDist.test_standard_exponentialc                 C      t ttjtjd d S NrK   )r   r=   rO   r  r4   r  r?   r&   r&   r'   #test_standard_expoential_type_error     z2TestRandomDist.test_standard_expoential_type_errorc                 C   r  )Nrt   rS  ri   r   gΈ̏&?gTϿ?g1n21@gDb<z@gBv@gc^@r   re  r   r   r   standard_gammar4   rj   r   rZ  r&   r&   r'   test_standard_gamma  r  z"TestRandomDist.test_standard_gammac                 C   s4   t t| j}|jdtjd}d}t||dd d S )Nrt   rK   g   d@r   re  )r   r   r   r  r4   r   r   rZ  r&   r&   r'   !test_standard_gammma_scalar_float  s   z0TestRandomDist.test_standard_gammma_scalar_floatc                 C   r  )Nrt   rS  r  gf&?gMO?g1@g):@g@g;i@r`   re  r  rZ  r&   r&   r'   test_standard_gamma_float  r  z(TestRandomDist.test_standard_gamma_floatc                 C   s   t jdt jd}tt| j}|jd|t jd t jddgddgd	d
ggt jd}t||dd tt| j}|jd|dt jd t||dd d S )NrS  rK         $@r  rL   gM»L$@ga {@gN]"@gPS")@g_+@gmB@r`   re  r  r   rL   )	r4   rN   r   r   r   r   r  rj   r   )r0   r5  rO   r$  r&   r&   r'   test_standard_gammma_float_out  s   
z-TestRandomDist.test_standard_gammma_float_outc                 C   s   t ttjddd d S )Nr  r  rK   )r   r=   rO   r  r?   r&   r&   r'    test_standard_gamma_unknown_type  s   

z/TestRandomDist.test_standard_gamma_unknown_typec                 C   s6   t d}tttjdd|d tttjdd|d d S )Nr   r  r   )r   r  )r   r7   )r4   rN   r   r>   rO   r  )r0   r  r&   r&   r'   test_out_size_mismatch  s   

z%TestRandomDist.test_out_size_mismatchc                 C   r  )Nr   )ri   r  )r   rO   r  r   r>   r?   r&   r&   r'   test_standard_gamma_0  r  z$TestRandomDist.test_standard_gamma_0c                 C   rz  )NrS  r   g
bYg? ?gGH{Lgz\?gc`+?gT}?r   re  )r   r   r   r   r4   rj   r   rZ  r&   r&   r'   test_standard_normal  r}  z#TestRandomDist.test_standard_normalc                 C   r  r  )r   r=   rO   r   r4   r  r?   r&   r&   r'   %test_standard_normal_unsupported_type  r  z4TestRandomDist.test_standard_normal_unsupported_typec                 C   r  )Nr   rS  )rY  r   gV1g	|ڙ(?g-?g NhڿgMc?g!uLM r   re  )r   r   r   
standard_tr4   rj   r   rZ  r&   r&   r'   test_standard_t  r  zTestRandomDist.test_standard_tc                 C   r]  )Ng{Gz@g(\u$@gףp=
W4@rS  )leftmoderightr   gEpw@g4DC+@gŋ@g/,@gkuR*@gHNPcr+@r   re  )r   r   r   
triangularr4   rj   r   rZ  r&   r&   r'   test_triangular  rb  zTestRandomDist.test_triangularc                 C   r  )NGz?gGz%@rS  )r.  r/  r   gm2@gJaD@g: @g
Q @g@T{e@gb@r   re  r   r   r   uniformr4   rj   r   rZ  r&   r&   r'   test_uniform  r  zTestRandomDist.test_uniformc                 C   s   t dj}t dj}tj}tt|t j d tt|dt j tt||| tt|t j gdg tt|dgt jg tjt 	|d|d d d S )Nrk   r   r7   g ؅W4vC)r.  r/  )
r4   finfor   r   rO   r  r   OverflowErrorinf	nextafter)r0   fminfmaxfuncr&   r&   r'   test_uniform_range_bounds  s   z(TestRandomDist.test_uniform_range_boundsc                 C   sn   t j}|dd}t|d |dtjgdtjg}t|dtjg |dgdggddg}t|dtd  d S )Nr	  r]   g
ףp= @rg   )rO   r  r   r4   pirN   )r0   r  resultr&   r&   r'   test_uniform_zero_range  s   

z&TestRandomDist.test_uniform_zero_rangec                 C   sH   t j}tt|dd tt|ddgddg tt|ddgddggd d S )NrI   r7   r   rt   )rO   r  r   r>   )r0   r  r&   r&   r'   test_uniform_neg_range  s   z%TestRandomDist.test_uniform_neg_rangec                 C   sj   G dd dt j}t d|}tttj|| G dd dt j}t d|}tttj|dd d S )Nc                   @      e Zd Zdd ZdS )zGTestRandomDist.test_scalar_exception_propagation.<locals>.ThrowingFloatc                 S      t r#   r=   r?   r&   r&   r'   	__float__      zQTestRandomDist.test_scalar_exception_propagation.<locals>.ThrowingFloat.__float__N)rE   rF   rG   r  r&   r&   r&   r'   ThrowingFloat      r  r  c                   @   r  )zITestRandomDist.test_scalar_exception_propagation.<locals>.ThrowingIntegerc                 S   r  r#   r  r?   r&   r&   r'   __int__  r  zQTestRandomDist.test_scalar_exception_propagation.<locals>.ThrowingInteger.__int__N)rE   rF   rG   r  r&   r&   r&   r'   ThrowingInteger  r  r  r7   )	r4   ndarrayrj   r  r   r=   rO   r  r*  )r0   r  throwing_floatr  throwing_intr&   r&   r'   !test_scalar_exception_propagation  s   
z0TestRandomDist.test_scalar_exception_propagationc                 C   r  )Nr  p=
ף?rS  rL  kappar   gLA?gxyw@gzVR?gpE ?g8&Aпgv @r   re  )r   r   r   vonmisesr4   rj   r   rZ  r&   r&   r'   test_vonmises  r  zTestRandomDist.test_vonmisesc                 C   s4   t t| j}|jdddd}tt|  d S )Nr]   gg5_PG>i@B r  )r   r   r   r  r   r4   isfinitera   r0   rO   rr&   r&   r'   test_vonmises_small  s   z"TestRandomDist.test_vonmises_smallc                 C   s0   t t| j}|jdtjd}tt| d S )Nr]   )rL  r  )r   r   r   r  r4   rS   r   rc  r  r&   r&   r'   test_vonmises_nan  s   z TestRandomDist.test_vonmises_nanr  g     @  4&kCc                 C   st   t t| j}t|j}|jj}|jd|dd}||j_|jd|dd}|dk r/t|| d S t	||ks8J d S )Nr   r   r   g    .A)
r   r   r   r   r   r   r  r   r4   ra   )r0   r  rO   rsr   random_state_valsgen_valsr&   r&   r'   test_vonmises_large_kappa!  s   
z(TestRandomDist.test_vonmises_large_kapparL  g      gg	@)r}   gư>r7   g     @@r  c                 C   sF   t t| j}|||d}tt|tj kot|tjk d S )Nr   )r   r   r   r  r   r4   ra   r  )r0   rL  r  rO   r  r&   r&   r'   test_vonmises_large_kappa_range/  s   *z.TestRandomDist.test_vonmises_large_kappa_rangec                 C   r  )Nr  r  rS  )r   r  r   g*س2?gt	@g;S@g\ F@gxF @g6b?r   re  )r   r   r   waldr4   rj   r   rZ  r&   r&   r'   	test_wald6  r  zTestRandomDist.test_waldc                 C   r  )Nr  rS  ri  gnJZ?g*/F?gs(RY?g]'%?g,qD?g8 ?r   re  )r   r   r   weibullr4   rj   r   rZ  r&   r&   r'   test_weibull>  r  zTestRandomDist.test_weibullc                 C   s<   t t| j}t|jdddtd tt|jdd d S )Nr   r   ri  r  )r  )	r   r   r   r   r  r4   rN   r   r>   r  r&   r&   r'   test_weibull_0F  s   zTestRandomDist.test_weibull_0c                 C   sF   t t| j}|jddd}tddgddgddgg}t|| d S )	Nr  rS  ri  r7   r   ic  ib  rI   )r   r   r   zipfr4   rj   r
   rZ  r&   r&   r'   	test_zipfK  r  zTestRandomDist.test_zipf)rE   rF   rG   r   r[  r_  ra  rd  rh  rj  rk  r   r   r   r4   r   rh   float64r  ro  rp  rs  rw  r{  r~  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  rJ   r+  rj   r  r  r  r  r  r  r  r  r  r  r  r   r  r  rN  r  r
  r  r  r  r  r  r  r#  r(  r)  r+  r-  r.  r0  r3  r4  r7  r8  r  rS   r:  r<  skipifr   rM  rN  rS  r   rU  rW  rX  r\  ra  re  rg  rh  rn  rq  rt  rv  rx  ry  r|  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r&   r&   r&   r'   rO    s:   


		.				
	


	
$I

			$rO  c                	   @   sT  e Z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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'd( Zd)d* Zd+d, Zd-d. Zd/d0 Zd1d2 Zd3d4 Zd5d6 Zd7d8 Zd9d: Zd;d< Z d=d> Z!d?d@ Z"e#j$%dAdBe&'dBdBge&'dBggdBggggdCdD Z(dEdF Z)dGdH Z*dIS )JTestBroadcastc                 C   r   )Ni[r   r?   r&   r&   r'   r   W  r   zTestBroadcast.setup_methodc                 C   s   t t| j}dg}dg}|j}tg d}t t| j}||d |}t||dd t t| j}|||d }t||dd d S )Nr   r7   )g4
7^?gF]
"?g .?rt   r   re  r  )r0   rO   r.  r/  r  r$  r5  r&   r&   r'   r  Z  s   zTestBroadcast.test_uniformc                 C   s   dg}dg}dg}t t| j}tg d}t t| j}||d |}t||dd tt|j|d | t t| j}|j}|||d }t||dd tt|||d  d S )Nr   r7   r;   )gw-Dؿgn0_x?gʊ;<.?rt   r   re  )	r   r   r   r4   rj   rf  r   r   r>   )r0   r&  r  	bad_scalerO   r$  r5  rf  r&   r&   r'   rg  i  s   zTestBroadcast.test_normalc           	      C   s   dg}dg}dg}dg}t g d}tt| j}|j}||d |}t||dd tt||d | tt||d | tt| j}|||d }t||dd d S )	Nr7   rI   r;   rA   )gf8?g%eo?g$q??rt   r   re  )	r4   rj   r   r   r   r  r   r   r>   )	r0   r  r  bad_abad_br$  rO   r  r5  r&   r&   r'   r  {  s   zTestBroadcast.test_betac                 C   Z   dg}dg}t g d}tt| j}||d }t||dd tt|j|d  d S Nr7   r;   )g`ʄ?gE]?g?rt   r   re  )	r4   rj   r   r   r   r  r   r   r>   r0   r  r  r$  rO   r5  r&   r&   r'   r       zTestBroadcast.test_exponentialc                 C   s\   dg}dg}t g d}tt| j}|j}||d }t||dd tt||d  d S r  )	r4   rj   r   r   r   r  r   r   r>   )r0   ri   	bad_shaper$  rO   	std_gammar5  r&   r&   r'   r    s   z!TestBroadcast.test_standard_gammac           	      C      dg}dg}dg}dg}t g d}tt| j}|j}||d |}t||dd tt||d | tt||d | tt| j}|j}|||d }t||dd tt|||d  tt|||d  d S )	Nr7   rI   r;   rA   )g3ʄ?gJE]?g?rt   r   re  )	r4   rj   r   r   r   r  r   r   r>   )	r0   ri   r  r  r  r$  rO   r  r5  r&   r&   r'   r    "   zTestBroadcast.test_gammac           	      C   r  )	Nr7   rI   r;   rA   )gM3B?gybi@g0?rt   r   re  )	r4   rj   r   r   r   r  r   r   r>   )	r0   r^  r_  	bad_dfnum	bad_dfdenr$  rO   r  r5  r&   r&   r'   r    r  zTestBroadcast.test_fc              	   C   s  dg}dg}dg}dg}dg}dg}t g d}tt| j}|j}	|	|d ||}
t|
|dd	 t t |	||t j	gd sDJ t
t|	|d || t
t|	|d || t
t|	|d || tt| j}|j}	|	||d |}
t|
|dd	 t
t|	||d | t
t|	||d | t
t|	||d | tt| j}|j}	|	|||d }
t|
|dd	 t
t|	|||d  t
t|	|||d  t
t|	|||d  d S )
NrI   rt   r   r   r;   rA   )gŜ,n1 @g!6)@g9?r   re  )r4   rj   r   r   r   r`  r   ra   rc  rS   r   r>   )r0   r^  r_  rZ  r  r  bad_noncr$  rO   nonc_fr5  r&   r&   r'   ra    s:   $zTestBroadcast.test_noncentral_fc                 C   s@   t t| j}tddg}|jddddd}t||dd d S )NgZ\#?gDqw?rp   rI   r   r   re  )r   r   r   r4   rj   r`  r   )r0   rO   r$  r5  r&   r&   r'   test_noncentral_f_small_df  s   z(TestBroadcast.test_noncentral_f_small_dfc                 C   r  )Nr7   r;   )gC{?g7Q#?g%h1T@rt   r   re  )	r4   rj   r   r   r   r  r   r   r>   r0   rY  bad_dfr$  rO   r5  r&   r&   r'   r    r  zTestBroadcast.test_chisquarec           	      C   r  )	Nr7   rI   r;   rA   )g-S?g[@gr3/.?rt   r   re  )	r4   rj   r   r   r   r[  r   r   r>   )	r0   rY  rZ  r  r  r$  rO   nonc_chir5  r&   r&   r'   r\    r  z'TestBroadcast.test_noncentral_chisquarec                 C   r  )Nr7   r;   )g>Qg{g,e?rt   r   re  )	r4   rj   r   r   r   r  r   r   r>   r  r&   r&   r'   r    r  zTestBroadcast.test_standard_tc                 C   s   dg}dg}dg}t g d}tt| j}||d |}t||dd tt|j|d | tt| j}|||d }t||dd tt|j||d  d S )NrI   r7   r;   )gD()@g,)ʸ@gPort   r   re  )	r4   rj   r   r   r   r  r   r   r>   )r0   rL  r  	bad_kappar$  rO   r5  r&   r&   r'   r    s   zTestBroadcast.test_vonmisesc                 C   r  )Nr7   r;   )g/h?gcE?g/gV?rt   r   re  )	r4   rj   r   r   r   rk  r   r   r>   r0   r  r  r$  rO   r5  r&   r&   r'   rn  .  r  zTestBroadcast.test_paretoc                 C   r  r  )	r4   rj   r   r   r   r  r   r   r>   r  r&   r&   r'   r  8  r  zTestBroadcast.test_weibullc                 C   r  )Nr7   r;   )gT?gʥ?gKܮc?rt   r   re  )	r4   rj   r   r   r   ru  r   r   r>   r  r&   r&   r'   rv  B  r  zTestBroadcast.test_powerc                 C      dg}dg}dg}t g d}tt| j}|j}||d |}t||dd tt||d | tt| j}|j}|||d }t||dd tt|||d  d S )Nr   r7   r;   )gh&BgsgR#?rt   r   re  )	r4   rj   r   r   r   r,  r   r   r>   )r0   r&  r  r  r$  rO   r,  r5  r&   r&   r'   r-  L     zTestBroadcast.test_laplacec                 C   r  )Nr   r7   r;   )gs4?g$Cw%T?gտrt   r   re  )	r4   rj   r   r   r   r'  r   r   r>   )r0   r&  r  r  r$  rO   r'  r5  r&   r&   r'   r(  ^  r  zTestBroadcast.test_gumbelc                 C   s   dg}dg}dg}t g d}tt| j}||d |}t||dd tt|j|d | tt| j}|||d }t||dd tt|j||d  t	|dd	d d S )
Nr   r7   r;   )g$DgXPg,?rt   r   re  r  r]   )
r4   rj   r   r   r   r/  r   r   r>   r   )r0   r&  r  r  r$  rO   r5  r&   r&   r'   r0  p  s   zTestBroadcast.test_logisticc                 C   s   dg}dg}dg}t g d}tt| j}|j}||d |}t||dd tt||d | tt| j}|||d }tt|j||d  d S )Nr   r7   r;   )g c?gu@gVQ?rt   r   re  )	r4   rj   r   r   r   r2  r   r   r>   )r0   r   r1  	bad_sigmar$  rO   r2  r5  r&   r&   r'   r3    s   zTestBroadcast.test_lognormalc                 C   r  )Nr7   r;   )gs(?g4mK?gVk+?rt   r   re  )	r4   rj   r   r   r   rw  r   r   r>   r  r&   r&   r'   rx    s   zTestBroadcast.test_rayleighc                 C   s   dg}dg}dg}dg}t g d}tt| j}||d |}t||dd tt|j|d | tt|j|d | tt| j}|||d }t||dd tt|j||d  tt|j||d  d S )	NrM   r7   r   rA   )gk7Z?g*}z9?gc-	?rt   r   re  )	r4   rj   r   r   r   r  r   r   r>   )r0   r   r  bad_meanr  r$  rO   r5  r&   r&   r'   r    s   zTestBroadcast.test_waldc                 C   s  dg}dg}dg}dg}dg}|d \}}t g d}tt| j}	|	j}
|
|d ||}t||dd tt|
|d || tt|
|d || tt|
|d || tt| j}	|	j}
|
||d |}t||dd tt|
||d | tt|
||d | tt|
||d | tt| j}	|	j}
|
|||d }t||dd tt|
|||d  tt|
|||d  tt|
|||d  tt|
dd	d
 tt|
ddd
 tt|
ddd d S )Nr7   rt   rI   r   )gR8T>?gK?g;>h@r   re  r  r]   g      4@g      9@)	r4   rj   r   r   r   r  r   r   r>   )r0   r  r  r  bad_left_onebad_mode_onebad_left_twobad_mode_twor$  rO   r  r5  r&   r&   r'   r    sJ   
zTestBroadcast.test_triangularc           
      C   s   dg}dg}dg}dg}dg}t g d}tt| j}|j}||d |}	t|	| tt||d | tt||d | tt||d | tt| j}|||d }	t|	| tt|||d  tt|||d  tt|||d  d S )Nr7   rM   r;   r	  r   r   r7   rt   )	r4   rj   r   r   r   rP   r
   r   r>   )
r0   rT  rQ   bad_n	bad_p_one	bad_p_twor$  rO   binomr5  r&   r&   r'   r    s&   

zTestBroadcast.test_binomialc           
      C   s   dg}dg}dg}dg}dg}t jg dt jd}tt| j}|j}||d |}	t|	| tt	||d | tt	||d | tt	||d | tt| j}|j}|||d }	t|	| tt	|||d  tt	|||d  tt	|||d  d S )Nr7   rM   r;   r	  )r   rI   r7   rK   rt   )
r4   rj   r   r   r   r   r   r
   r   r>   )
r0   rT  rQ   r  r  r  r$  rO   	neg_binomr5  r&   r&   r'   r     s(   

z$TestBroadcast.test_negative_binomialc           	      C   sx   dg}dg}t g d}tt| j}|j}|d g}|j}||d }t|| tt	||d  tt	||d  d S )Nr7   r;   )r   r   rt   rI   rt   )
r4   rj   r   r   r   _poisson_lam_maxrp  r
   r   r>   )	r0   ro  bad_lam_oner$  rO   max_lambad_lam_tworp  r5  r&   r&   r'   rq  		  s   

zTestBroadcast.test_poissonc                 C   s   dg}dg}t g d}tt| j}|j}||d }t|| tt||d  t j	dd tt|t j
 tt|ddt j
g W d    d S 1 sMw   Y  d S )NrI   r   )r7   r   r7   rt   r  r   )r4   rj   r   r   r   r  r
   r   r>   r"  rS   )r0   r  r  r$  rO   r  r5  r&   r&   r'   r  	  s   
"zTestBroadcast.test_zipfc                 C   n   dg}dg}dg}t g d}tt| j}|j}||d }t|| tt||d  tt||d  d S )NrM   r;   r	  r   rt   )	r4   rj   r   r   r   r  r
   r   r>   )r0   rQ   r  r  r$  rO   r  r5  r&   r&   r'   r  &	     
zTestBroadcast.test_geometricc                 C   s2  dg}dg}dg}dg}dg}dg}dg}t g d}tt| j}	|	|d ||}
t|
| tt|	j|d || tt|	j|d || tt|	j|d || tt|	j|d || tt| j}	|	||d |}
t|
| tt|	j||d | tt|	j||d | tt|	j||d | tt|	j||d | tt| j}	|	j}||||d }
t|
| tt||||d  tt||||d  tt||||d  tt||||d  tt|ddd	 tt|ddd	 tt|ddd tt|ddd
 tt|ddd	 tt|ddd tt|dddgd d S )Nr7   rI   r;   rA   r   r  rt   r   r   r   i   @i  l        r   i    r*   )	r4   rj   r   r   r   r*  r
   r   r>   )r0   ngoodnbadr   	bad_ngoodbad_nbadbad_nsample_onebad_nsample_twor$  rO   r5  	hypergeomr&   r&   r'   r+  3	  sJ   


z!TestBroadcast.test_hypergeometricc                 C   r  )NrM   rI   r;   )r7   r7   r7   rt   )	r4   rj   r   r   r   r6  r
   r   r>   )r0   rQ   r  r  r$  rO   r6  r5  r&   r&   r'   r7  `	  r  zTestBroadcast.test_logseriesc                 C   sn  t t| j}|jddgdgd dd}tjg dg dgg d	g d
gg dg dggtjd}t|| t t| j}|ddgdgd }tjg dg dgtjd}t|| t t| j}|ddgdgd gd }tjg dg dgtjd}t|| t t| j}|dgdggdgd gd }tjg dg dgg dg d
ggtjd}t|| d S )Nr`   r   r;  r   rS  r   )r   r   rI   r7   rI   r   )rI   rt   r   r   rI   rt   )r7   r   r7   r   rI   r7   )r   rI   rI   r7   r   r   )r   rI   r   r7   rI   r   )rt   rI   rt   rt   r   r`   rK   rI   )r   r   rI   r7   r7   r7   )r   rI   rt   rt   r`   rt   )r   r   r   rZ   r4   rj   r   r
   rZ  r&   r&   r'   r<  m	  sV   





 
zTestBroadcast.test_multinomialrT  r   c                 C   sH  t t| j}tdgd }|||}t|trt n|j	}|d }|j	|ks+J t
||g}|||}t||j	d d d }|j	|ksLJ t
|g|gg}|||}t||j	d d }|j	|d ksoJ |j||d| d}|j	d| d ksJ tt |j||dd}W d    d S 1 sw   Y  d S )Nr  r   )r   r;   rS  r   )r7   r7   r7   r7   r7   r7   )r   r   r   r4   rj   rZ   r   rJ   r  ri   r  broadcast_shapesr   r   r>   )r0   rT  rO   rv   r5  n_shaper   r&   r&   r'   test_multinomial_pval_broadcast	  s&   "z-TestBroadcast.test_multinomial_pval_broadcastc                 C   sF   t t| j}dgd dgd g}tt|jd| tt|jdd d S )Nr;  r   r  r7   rM   )r   r   r   r   r>   rZ   )r0   rO   rv   r&   r&   r'   test_invalid_pvals_broadcast	  s   z*TestBroadcast.test_invalid_pvals_broadcastc                 C   s   t t| j}|tdddgd }|jdksJ |dtd}|jdks+J |tddtd	}|jd	ks?J d S )
N)r   r   r   i8r;  r   )r   r   r   r   r   )r   r   r   )rt   r   r   )rt   r   r   r   )r   r   r   rZ   r4   r   ri   rd  r&   r&   r'   test_empty_outputs	  s   z TestBroadcast.test_empty_outputsN)+rE   rF   rG   r   r  rg  r  r  r  r  r  ra  r  r  r\  r  r  rn  r  rv  r-  r(  r0  r3  rx  r  r  r  r   rq  r  r  r+  r7  r<  r   r   r   r4   rj   r  r  r  r&   r&   r&   r'   r  T  sP    
#




(-

r  zcan't start threadr=  c                   @   4   e Zd Zdd Zdd Zdd Zdd Zd	d
 ZdS )
TestThreadc                 C   s   t d| _d S )Nr   )r3   seedsr?   r&   r&   r'   r   	  s   zTestThread.setup_methodc                    s   ddl m  tt| jf| }tt| jf| } fddt| j|D }dd |D  dd |D  t| j|D ]\}}tt|| q>t	 j
jdkr`tjdkr`t|| d S t|| d S )	Nr   )Threadc                    s(   g | ]\}} t t||fd qS ))targetargs)r   r   )r  r1   or  functionr&   r'   r  	  s    z-TestThread.check_function.<locals>.<listcomp>c                 S      g | ]}|  qS r&   )startr  rc   r&   r&   r'   r  	  r  c                 S   r  r&   )joinr  r&   r&   r'   r  	  r  r   win32)	threadingr  r4   r   r!  r
  zipr   r   intprL   r   r  platformr   r
   )r0   r  szout1out2tr1   r  r&   r  r'   check_function	  s   
zTestThread.check_functionc                 C      dd }| j |dd d S )Nc                 S   s   | j dd|d< d S )Nr  r   .)rf  r   r  r&   r&   r'   
gen_random	  r\   z*TestThread.test_normal.<locals>.gen_random)r  r  r  r0   r!  r&   r&   r'   rg  	     zTestThread.test_normalc                 C   r  )Nc                 S   s   | j tdd|d< d S )NrV   r*   r  .)r  r4   r  r   r&   r&   r'   r!  	  s   z'TestThread.test_exp.<locals>.gen_randomr&  r"  r#  r$  r&   r&   r'   test_exp	  r%  zTestThread.test_expc                 C   r  )Nc                 S   s   | j ddgd dd|d< d S )Nr   r;  r   r  r   .)rZ   r   r&   r&   r'   r!  	  s   z/TestThread.test_multinomial.<locals>.gen_random)r  r   r"  r#  r$  r&   r&   r'   r<  	  r%  zTestThread.test_multinomialN)rE   rF   rG   r   r  rg  r'  r<  r&   r&   r&   r'   r	  	  s    r	  c                   @   r  )TestSingleEltArrayInputc                 C   s4   t dg| _t dg| _t dg| _d| _d S )NrI   rt   r   r  )r4   rj   argOneargTwoargThreetgtShaper?   r&   r&   r'   r   	  s   
z$TestSingleEltArrayInput.setup_methodc                 C   s   t jt jt jt jt jt jt jt jt j	t j
t jt jf}t jt jf}|D ]}||v r1|tdg}n|| j}t|j| j q"d S r   )rO   r  r  r  r  rk  r  ru  rw  rp  r  r  r6  r4   rj   r)  r   ri   r,  )r0   funcs	probfuncsr  r  r&   r&   r'   test_one_arg_funcs	  s   
z*TestSingleEltArrayInput.test_one_arg_funcsc                 C   s   t jt jt jt jt jt jt jt jt j	t j
t jt jt jt jf}t jt jf}|D ];}||v r3tdg}n| j}|| j|}t|j| j || jd |}t|j| j || j|d }t|j| j q&d S )NrM   r   )rO   r  rf  r  r  r  r[  r  r,  r'  r/  r2  r  rP   r   r4   rj   r*  r)  r   ri   r,  )r0   r-  r.  r  r*  r  r&   r&   r'   test_two_arg_funcs
  s(   z*TestSingleEltArrayInput.test_two_arg_funcsc              	   C   s   t jt jt jt jt jt jt jt jt j	g	}t
j}t dg}t dg}|D ]3}|||||d}t|j| j ||d |||d}t|j| j |||d ||d}t|j| j q%d S )Nr7   r   r   )r4   r   r  r  r
  r  r  rh   r   r  rO   r.   rj   r   ri   r,  )r0   r(   r   r  r/  r.  r   r  r&   r&   r'   r[  
  s   z%TestSingleEltArrayInput.test_integersc                 C   s   t jt jt jg}|D ]6}|| j| j| j}t|j| j	 || jd | j| j}t|j| j	 || j| jd | j}t|j| j	 q
d S )Nr   )
rO   r`  r  r*  r)  r*  r+  r   ri   r,  )r0   r-  r  r  r&   r&   r'   test_three_arg_funcs/
  s   z,TestSingleEltArrayInput.test_three_arg_funcsN)rE   rF   rG   r   r/  r0  r[  r1  r&   r&   r&   r'   r(  	  s    r(  r-  c                 C   s   | d }| d }t |}|| |jd d }tjdkr!| }t|}|jd d | d d ks5J | | d d ksAJ |	 }|jd d }tjdkrU| }t|}|jd d | d	 d ksiJ | | d	 d ksuJ d S )
Nr   r   r   r   r@  r   r   r   r   )
r   r8   r   r  r  r  r  r  r  r   )r-  r   r   mt19937r   r  r   r&   r&   r'   test_jumped>
  s"   




r3  c                  C   sh  t d} t d}d}tj| |ddjdksJ tt tj| ||d W d    n1 s1w   Y  tt tj| |dd W d    n1 sNw   Y  tt tj| |dd W d    n1 skw   Y  t d}tt tj||d W d    n1 sw   Y  tt tj|dd W d    n1 sw   Y  tt tj|dd W d    n1 sw   Y  t 	|}tt tj||d	 W d    n1 sw   Y  tt tj
d
ddgdd W d    n	1 sw   Y  tt tj
d
dgddd W d    n	1 s%w   Y  tt tj
d
dgddgdd W d    n	1 sGw   Y  tt tjddgddgdd W d    n	1 siw   Y  tjddd}tjddd}tjddd}t|||jdksJ tjtdd tj|||dd W d    d S 1 sw   Y  d S )Nrt   )r   rt   )r   r   rI   )r`   r   rt   r   )r7   rt   )r   r7   r7   )rt   r  r7   r|  gffffff?)rI   r7   rI   r`   zOutput size \(6, 5, 1, 1\) isr~   )r   r`   r7   r7   )r4   r  rO   rf  ri   r   r   r>   r  r   rP   rZ   r  r`  )rL  r1  r   ri   r  r  r  r  r&   r&   r'   test_broadcast_size_errorZ
  s\   



$r4  c                  C   sd   t d} t d}tj| |dd tt tj| |dd W d    d S 1 s+w   Y  d S )Nrt   r   rI   )r4   r  rO   rf  r   r   r>   )rL  r1  r&   r&   r'   test_broadcast_size_scalar
  s   

"r5  c                  C   s8   g g dg} t td}t|j|  | dg g gksJ d S rV  )r   r   r	   rz  )seqgenr&   r&   r'   test_ragged_shuffle
  s   
r8  r/  rA   c                 C   s   t td}|r
dnd}tjt|d |j| |d W d    n1 s%w   Y  |r.dnd}tjt|d |jd| |d W d    n1 sJw   Y  tjt|d |jdg| |d W d    d S 1 skw   Y  d S )	Nr   zhigh < 0z	high <= 0r~   rc  z
low > highzlow >= highr;   )r   r   r   r   r>   r.   )r/  r(   r7  msgr&   r&   r'   !test_single_arg_integer_exception
  s   "r:  rL   f4f8c                 C   s   t jdd| d}g d}tjtdd tj||| d W d    n1 s&w   Y  tjtdd tj|||j| d W d    d S 1 sHw   Y  d S )	Nr   F)orderrL   r   zSupplied output arrayr~   r  r  )r4   r   r   r   r>   rO   r  ri   )rL   r  ri   r&   r&   r'   test_c_contig_req_out
  s   "r?  r>  r=  Cdistc                 C   sH   t jd||d}| ||d}||u sJ | |||jd}||u s"J d S )Nr   )rL   r>  r  )r  rL   r   )r4   r   ri   )rA  r>  rL   r  variatesr&   r&   r'   test_contig_req_out
  s
   rC  c                  C   sz   t jt jd} | d |  \}\}}|jjdksJ t| |d }t| |j	|j
_	|j
j	}|j	|ks;J d S )Nr   r7   	PCG64DXSM)rD  )r4   rO   r   rD  r   
__reduce__	__class__rE   printr   r   )r   ctorbit_gen_r  state_br&   r&   r'   $test_generator_ctor_old_style_pickle
  s   

rL  c                  C   s   dd l } tjtjd}|jj}| | |}|jj}t	|j
|j
 t	|j|j |jjd | | |}|jj}t	|j
|j
 d S )Nr   i4r   )pickler4   rO   r   rD  r   seed_seqloadsdumpsr   r   poolspawn)rM  r   ssrg_plkss_plkr&   r&   r'   #test_pickle_preserves_seed_sequence
  s   rV  versiony   ~   c                 C   s   dd l }dd l}tjtjtd }tj|dd|  d}||}|	|}W d    n1 s5w   Y  |j
jd }t|tsGJ t|j
tjjsQJ |d dksYJ |d dksaJ d S )	Nr   r  generator_pcg64_npz.pkl.gzr   l	   a*MzJR2MP incl	   sN	D%(^6FA )rM  gzipospathsplitabspath__file__r  openloadr   r   r   r   r4   rO   PCG64)rW  rM  r\  	base_pathpkl_filegzr   r   r&   r&   r'   test_legacy_pickle
  s   rh  )7os.pathr]  r  r  r   numpyr4   numpy.exceptionsr   numpy.linalgr   numpy.testingr   r   r   r   r   r	   r
   r   r   r   numpy.randomr   r   r   r   rO   JUMP_TEST_DATAfixturer(   r)   rH   rU   r   r   r   rO  r  r   r  r	  r(  r   r3  r4  r5  r8  r:  r?  r   rC  rL  rV  rh  r&   r&   r&   r'   <module>   s    0

$7 "                i/U
+

	