
    h                         d Z ddlZddlmZ ddlZddlmZ ddlmZ 	 ddlZ	d
dZd
dZd Zed	k(  r e        yy# e
$ r Y  w xY w)a  Compute gammainc and gammaincc for large arguments and parameters
and save the values to data files for use in tests. We can't just
compare to mpmath's gammainc in test_mpmath.TestSystematic because it
would take too long.

Note that mpmath's gammainc is computed using hypercomb, but since it
doesn't allow the user to increase the maximum number of terms used in
the series it doesn't converge for many arguments. To get around this
we copy the mpmath implementation but use more terms.

This takes about 17 minutes to run on a 2.3 GHz Macbook Pro with 4GB
ram.

Sources:
[1] Fredrik Johansson and others. mpmath: a Python library for
    arbitrary-precision floating-point arithmetic (version 0.19),
    December 2013. http://mpmath.org/.

    N)time)pi)	mpf2floatc                 h  	 t        j                  |      5  t        j                  |       t        j                  |      t        j                  |      c}} |gt        j                  d      		fd}t        j                  ||g|      }t        |      cddd       S # 1 sw Y   yxY w)zCompute gammainc exactly like mpmath does but allow for more
    summands in hypercomb. See

    mpmath/functions/expintegrals.py#L134

    in the mpmath GitHub repository.

    Texactc                 X    t        j                        | gd| dgg dgd| z   gf}|fS )N   mpexp)zT1Gbnegbs     e/var/www/html/eduruby.in/venv/lib/python3.12/site-packages/scipy/special/_precompute/gammainc_data.pyhzgammainc.<locals>.h/   s;    &&,1%1bz2q1#!uaGB5L    maxtermsN)r   workdpsmpffneg	hypercombr   )
axdpsr   r   r   resr   r   r   s
          @@@r   gammaincr!   !   s     
C 
&&)RVVAYq	1aCwwq%	 ll1qcH5~
 
 
s   BB((B1c           	      `    t        j                  |      5   |c} t        j                  |      r+	 t        t        j                  | d            cddd       S t        j                   d      |g	  fd}t        t        j                  ||gd            cddd       S # t         j
                  j                  $ r Y lw xY w# t         j
                  j                  $ r5  fd}t        t        j                  ||g|            cY cddd       S w xY w# 1 sw Y   yxY w)	zCompute gammaincc exactly like mpmath does but allow for more
    terms in hypercomb. See

    mpmath/functions/expintegrals.py#L187

    in the mpmath GitHub repository.

    T)r   regularizedNr   c                 \    | dz
  }t        j                        gd|gg d| gg dz  fgS )Nr
   r   )r   rr   r   negas     r   r   zgammaincc.<locals>.hM   s?    aC&&,*QFBAr7B$OPPr   )force_seriesc                 z    g d| dz
  g| gg g df}t        j                         | gd| dgg dgd| z   gf}||fS )Nr
   r   r   r   )r   r   T2r   r   r&   s      r   r   zgammaincc.<locals>.hR   s]    !QqSA32r14vvd|mQ*Q2JAsQqSE1L2vr   r   )	r   r   isintr   r!   libmpNoConvergencer   r   )r   r   r   r   r   r   r   r&   s   `     @@r   	gammainccr-   7   s    
C F!188A; Q!!FGF F wwq%C
	FQ R\\!aStDE!F F 88))  xx%% 	F R\\!aS8DEE-F F"	F#F FsM   D$ B,D$:(C,C	D$CD$AD!D$ D!!D$$D-c            
         t               } t        t               t        j                  j                  t              }t        j                  ddd      }t        j                  t        j                  t        dz        t        j                  t        j                  d            d      }t        j                  t        j                  t        dz        t        j                  t        j                  d            d      }t        |ft        |fg}|D ];  \  }}t        j                  ||      \  }}	|t        j                  |	      z  |t        j                   |	      z  }}
|
j#                         |j#                         }}
g }t%        t'        |
|            D ]V  \  }\  }}|t        k(  r*t        j(                  |      t        j(                  |      }}|j+                  || |||      f       X t        j,                  |      }t        j                  j/                  |dddd	|j0                   d
      }t        j2                  ||       > t        t               | z
  dz   d       y )N         g333333?gffffff?z..testsdatalocalz.txt<   z minutes elapsed)r   print__doc__ospathdirname__file__nplogspacelog10r   arctanr!   r-   meshgridcossinflatten	enumeratezipfloorappendarrayjoin__name__savetxt)t0pwdr%   lthetauthetaregimesfuncthetargthetagr   r   datasetia0x0filenames                    r   mainrZ   Y   s   	B 
'N
''//(
#C
Ar2A[["Q$"))C.)A2FF[["Q$"))C.)A2FF&!Iv#67G &e[[E*
F"&&. "RVVF^"31yy{AIIK1$SAY/ 	3KAxBy  "rxx|BNNBDRL12	3 ((7#77<<T7FG#'==/ 68


8W%&" 
dfrk2.
/0r   __main__)2   i )r7   r8   r   numpyr<   r   scipy.special._mptestutilsr   mpmathr   ImportErrorr!   r-   rZ   rJ    r   r   <module>rb      s^   & 
    0	
,FD1D zF }  		s   ; AA