
p7]c           @  sb  d  Z  d d l m Z d d l m Z m Z d d l Z d d l Z d d l	 Z
 d d l m Z e
 j Z d Z i2d d d	 d
 g d	6d d d d g d
6d d d d g d6d d d d g d6d d d d g d6d! d" d# d$ g d6d& d' d( d) g d6d+ d, d- d. g d6d0 d1 d2 d3 g d6d5 d6 d7 d8 g d6d: d; d< d= g d6d? d@ dA dB g d6dD dE dF dG g d6dI dJ dK dL g d6dN dO dP dQ g d6dS dT dU dV g d6dX dY dZ d[ g d6d] d^ d_ d` g d6db dc dd de g d6dg dh di dj g d6dl dm dn do g d6dq dr ds dt g d6dv dw dx dy g d6d{ d| d} d~ g d 6d d d d g d e f 6d d d d g d!6d d d d g d"6d d d d g d#6d d d d g d$6d d d d g d%6d d d d g d&6d d d d g d'6d d d d g d(6d d d d g d)6d d d d g d*6d d d d g d+6d d d d g d,6d d d d g d-6d d d d g d.6d d d d g d/6d d d d g d06d d d d g d16d d d d g d26d d d d g d36d d d d g d46d d d d g d56d d d d g d66d d d d g d76d d d d g d86d d d d g d e f 6d d d d g d96d d d d g d:6d d d d g d;6d d d d g d<6d d d d g d=6d d d dg d>6ddddg d?6dddd	g d@6d
dddg dA6ddddg dB6ddddg dC6ddddg dD6ddddg dE6ddd d!g dF6d"d#d$d%g dG6d&d'd(d)g dH6d*d+d,d-g dI6d.d/d0d1g dJ6d2d3d4d5g dK6d6d7d8d9g dL6d:d;d<d=g dM6d>d?d@dAg dN6dBdCdDdEg dO6dFdGdHdIg dP6dJdKdLdMg d e f 6dNdOdPdQg dQ6dSdTdUdVg dR6dWdXdYdZg dS6d[d\d]d^g dT6d_d`dadbg dU6dcdddedfg dV6dgdhdidjg dW6dkdldmdng dX6dodpdqdrg dY6dsdtdudvg dZ6dwdxdydzg d[6d{d|d}d~g d\6ddddg d]6ddddg d^6ddddg d_6ddddg d`6ddddg da6ddddg db6ddddg dc6ddddg dd6ddddg de6ddddg df6ddddg dg6ddddg dh6ddddg dRe f 6ddddg di6ddddg dj6ddddg dk6ddddg dl6ddddg dm6ddddg dn6ddddg do6ddddg dp6ddddg dq6ddddg dr6ddddg ds6ddddg dt6ddddg du6ddddg dv6ddddg dw6ddddg dx6ddddg dy6ddddg dz6ddddg d{6d dddg d|6ddddg d}6dd	d
dg d~6ddddg d6ddddg d6ddddg de f 6ddddg d6dddd g d6d!d"d#d$g d6d%d&d'd(g d6d)d*d+d,g d6d-d.d/d0g d6d1d2d3d4g d6d5d6d7d8g d6d9d:d;d<g d6d=d>d?d@g d6dAdBdCdDg d6dEdFdGdHg d6dIdJdKdLg d6dMdNdOdPg d6dQdRdSdTg d6dUdVdWdXg d6dYdZd[d\g d6d]d^d_d`g d6dadbdcddg d6dedfdgdhg d6didjdkdlg d6dmdndodpg d6dqdrdsdtg d6dudvdwdxg d6dydzd{d|g de f 6d}d~ddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg de f 6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6d dddg d6ddddg d6dd	d
dg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6d d!d"d#g d6d$d%d&d'g d6d(d)d*d+g d6d,d-d.d/g d6d0d1d2d3g d6d4d5d6d7g d6d8d9d:d;g d6d<d=d>d?g d6d@dAdBdCg d6dDdEdFdGg d6dHdIdJdKg d6dLdMdNdOg de f 6dPdQdRdSg d6dUdVdWdXg d6dYdZd[d\g d6d]d^d_d`g d6dadbdcddg d6dedfdgdhg d6didjdkdlg d6dmdndodpg d6dqdrdsdtg d6dudvdwdxg d6dydzd{d|g d6d}d~ddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg dTe f 6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddd dg d6ddddg d6dddd	g d6d
dddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddd d!g de f 6d"d#d$d%g d6d'd(d)d*g d6d+d,d-d.g d6d/d0d1d2g d 6d3d4d5d6g d6d7d8d9d:g d6d;d<d=d>g d6d?d@dAdBg d6dCdDdEdFg d6dGdHdIdJg d6dKdLdMdNg d6dOdPdQdRg d6dSdTdUdVg d	6dWdXdYdZg d
6d[d\d]d^g d6d_d`dadbg d6dcdddedfg d6dgdhdidjg d6dkdldmdng d6dodpdqdrg d6dsdtdudvg d6dwdxdydzg d6d{d|d}d~g d6ddddg d6ddddg d6ddddg d&e f 6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d6ddddg d 6ddddg d!6ddddg d"6ddddg d#6ddddg d$6ddddg d%6ddddg d&6ddddg d'6ddddg d(6ddddg d)6ddddg d*6ddddg d+6ddddg d,6ddddg d-6ddddg d.6ddddg de f 6a d d d dRdddddTdd&dg a e dd ddddde g a d  Z d  Z d  Z d  Z d  Z d   Z d  Z d  Z d  Z e
 j e  Z de _  d  Z d  Z e
 j e  Z de _  d  Z  d S(/  s#  
Implementation of Gleason's (1999) non-iterative upper quantile
studentized range approximation.

According to Gleason this method should be more accurate than the
AS190 FORTRAN algorithm of Lund and Lund (1983) and works from .5
<= p <= .999 (The AS190 only works from .9 <= p <= .99).

It is more efficient then the Copenhaver & Holland (1988) algorithm
(used by the _qtukey_ R function) although it requires storing the A
table in memory. (q distribution) approximations in Python.

see:
  Gleason, J. R. (1999). An accurate, non-iterative approximation
    for studentized range quantiles. Computational Statistics &
    Data Analysis, (31), 147-158.

  Gleason, J. R. (1998). A table of quantile points of the
    Studentized range distribution.
    http://www.stata.com/stb/stb46/dm64/sturng.pdf
i(   t   print_function(   t   lranget   mapN(   t	   fminbounds   0.2.3gw	g8g"qH?g$/g?g       @gfOg2Vvg,/F?g{=گg      @g9oYgW' g8.I?g;y	g      @gs4<)g襹N gޡf*X?g<W g      @gnX g9f`gՇަm?g)ÉQ߰g      @g* gm3wvgW?gfH 9,g      @g'A M gogk9Kj?gLag       @g,\Ȗg]'` g,d{9yi?gj)g      "@gj̸g4T7g {)?gzycԦg      $@g6?gVQegvm?g)5gg      &@g)gL}^gA&4?g0եg      (@gQӰ1g[g.?2?g,wg      *@gg#g2b g&$?g ckg      ,@gBgZ{v g.`?gFg      .@g^sog=i	gZ=	!?gLg      0@gg:og.Jԏ?g}Gg      1@gZ!g-G gd[?gog      2@g@C3Ug	 g%,p?g()g      3@g1Hig*TYgE)%?g.٦g      4@geA	-gLp3 gwb?gsÄ]g      8@gүM=g!&g[{zp?g'tTg      >@gtNga/t g棝?gg      D@gX0ÈgU=Yg&7?grMldg      N@geb.g7gF]Z\?g@)g      ^@g%Tg%#!ҎgV>9`?g]cIgu3AgtTgR5?g hgg      ?g^?gOW,Ag 5?gfOio3fg&SEgSA%\gG^?g[Azeg'tgrc渿gB?g/:eg7{yg%"g}?gUVeg(|H^ggݸgSu*?gFcXegVogЈg<X8\f?gm ,egccg*kg1^L?gM>wegg(rfg?gidg9<g`񻉸gBggaq?gm0$Xegg#i-g?j;?glkeg|H(Mgs|ZDgB QK?g$$eg^"FgMFghqJ?g|dgRMkgjg:j5?g#eg3`{g40Ngɋ1?g*egmg)2Wηg7ؠ?g#̓dgj;gO#V\巿gW)F%#?g)Tdgwyg|ݯNٷgXV?gYkddg-g<goC?g8YĤdg'4*gXhWd.̷g#?g[edgzg	Dجѷgsk+?gΎegB"!gr_ߋg'm?g	F7 eggh%gJqigE
?g:1Xeg6gAy-N귿g@~?gqi=egdn
%g:I>ȷgvH?gSr(eg80gY0xڸgqqϣũ?g&/ag?g1,g 	X۴g`b2?gkcu\g")g8Hgla=?gZ%IXg^0ŵgrg8Qf?geS4VVglvgPjg|[Y?g.@XIUgu^g̬gD+
k?g=n>STglgqGQg?G[ސ?g齥SggKgVa?gn`Ѫ(SgZg,	&g͵;?g RgbASg%Ug_P/g?g7dQRgPbcgLg?p?gP\Rgz(g[6g`Hŏ?g<nB:RgL!g?tdgo	YHA?g"Rg{-مg:a'gw?g+";?Rgpg8xwǥg& b̍?gS<RgdV#gRktg
ޢ?g2Rg63ig	+gI#?g_MRg#迂gLy餿gJӝc?g3RgJY$gg)KWL?gKHRg݁g<?[g3U)?gIRg3}gOSgVPi?glWTRgMqJzg:gki!??gRg=wgf#7g;ԨB?g/0!Sgֿ>rg4#̡gq:?g~woSga,mg+Nug8>uE?g5`BTg8C=kgjgw۸4?g2=ȱZ`g      ?g9gK>.g'oʕ?ga˓Yg8(.gD챎gİ?gʑ*9TgVDg
D}#gm(n?g˟Rg:g#NG4g֨?gcǴQDtPg6Wg~sg;?gvq,ۡNgo*69gCIJ2gi?glMghgT~ǥg	d?g-\Kg>g͋\ğgtR̀?g&kKgYIܙg,^gV
%͇?g	o_tJgfg"eܢgן??g %JgRڏgف-g%͆?g[ Ig%gNg\Cg)q?g'<~IgkS!gDyZgv;&?gSXIgARͅgZ9gۼ{?gX~?IgQ>gMSDg+3k?gRġa1Igg.0-ڟg"-?gFKX+IgIkb~gll ?g}^{k?g$A-+Igc}glv`xNghO?gs6/Ig7wgIN߶g	g?gۆ_Igpg[ךzgEbn?g0	*Ig	`ig.Cgý?g_GqjJg mbg+^gW%xM?gBP9iNKgPӗZg^:gm?gwTaLg.Qg-sg:?gBX8JfMg`4gc֨g|o?gtZ_g?g63[HgܳgICP?gh)5UWgבgAS	g;K?g Rg$%@DIg~EݬgC?gvOgPtg|gwkv?gHKgx߿g@gܒ,|?g{nzIg*߿gGXgօچ?gvtGgc[߿gУge8?glIXFg'H߿g]&gTʭ?gmvEg,k߿g򇉡g?gEgNj]o߿g."gחQ?geԑƍDgL+a߿gM_2៿giV(oׂ?gf=:Dg TCU߿gg럞gu?gK?Cg1<꣟K߿gcWgLeV%?gbo7Cgx |B߿g5d{g)t-?gyCgp:߿gWSLƛg嚮?g[#YCgd̨3߿gÏ7gEBN?gW>Cg+y-߿gMqfg,s]?g.Cg)i"(߿g̺,әgQCXu??g-CgHG߿g/LgER7?g[yEECg0t^߿gm:3YgPŀ?gp<Dgd_H޿gEĔgSؾ?gv_.Dg؈J޿gĭTg@?gdҴEgN޿gFscekgoH4?gRQ	iVFg}N޿gk'A<ߐgP _,?gJsPJGgX_g-i)g[?g`g333333?g}[߿gV?ʳgq6vՓ?gY'W3	VgH޿giVg&%@?g&p*Pg}Ɯ_NݿgR>~g@7@?gFEKgGܿg0!gl0ԇ?g@Ggd̂ܿg|1g(ba}?g%EgU`Gܿgz8gqWN?gyvaTCguܿgL^g?u?s?gBg羀ۿgzjg1+_yq?g:4 AgۿgE쟿g 5T?g"wx@gJۿg:ugy݀	?gɢb @g jۿgb)eg+uQ?gq V?gg[߱ۿg>gmI~?g!B>gۿg(gJ]}?gLTT>gV DۿgzoJg7S	&}?g}[>g?{ۿg)@g
j}>|?g<W>>gtzbnqۿg'W}ghsQ|?g|$i1>gd'hۿg.{gЖg⴮|?gFû0>g_`ۿg6kD$6g+{?gk9>gel CGۿg>kXgJ%{?g6t>gLE-ۿg1zggTz?g	zY?gI$kۿg6䐿g֥ibz?gYksE@gDzڿg*x{0gdh
z?ggjAg]gXڿgmV⋿gAf{i{?guAgy_mdڿgo.h,?gz*	 |?g醁_Bgg<8g`?g]ngg?g      ?gy giDʧԸg#Q?g.dT]gwvܿgsy³g8l?gà`TgO=/*ڿg/<g+?g՞#Og!pp"
ڿg_ŖARgP_?g<SXGg*KKcٿgh
gC{?gDgpؿg%_Yg!/?gCAg1YhWؿgZ'g5Y?g{>g^w+qؿg-ig ?gg	=go@ؿgR gP0S}?g;1D;g&ؿg)xYxgن]j{?g2	8gxN#
ؿgzg͈`Fz?gqA7gr9|Ѵ׿gygSsLy?g a7gBdF׿gNቘg7V3Fx?g%$C, 6gO׿gogT=gzߵÕw?g쎁A6gd7Y׿ge2$gVwSiw?g036g^VD׿g&égR2v?gtqw6g<ե[э׿gHjӔg`Y"cv?giy5g׿gu\xՓg	
1u?gu.`5guxs׿g̷ΓgPnNv?gG6gcCT׿gng,ou?g2,f6gHʖ3׿g XOtg"Ut?gajP7g:,׿gO۴gLy[WEu?gFm9g.ֿgH"	g.ȳ+t?gC?9g#Z&wֿgCW-g'b\u?g16Gƚ<gꃁ|ֿg2{g:sWv?gcr=ggXR-gzLl?g!Qmfggffffff?gx^9޿g?gŃw?gI_gmlFdٿg(PgՈ7?g@kaSgSxv׿g%9Vg/ so?g_kk}MgVr^ֿgT;Ags K?g#M Cgտg I7ag4˻?gm*T4@g7b$_Fտg;s}g=Dd?g5Ғ;gj<Կg6gk}i|?g@r7g썑OTԿg2>gN'z?g񟥚u5gJmԿgSK)՝gw?gG2g쨳ӿg}W~gTu?g?ެ=$1gMS'Lӿg
CA酪gP3Ct?g[~0e0g6ӿgLog5?kRt?gAȤ0gNh-|ӿgvgæ=r?g8-g:dZB^ӿg]OCэgxFnܙ`r?g˖vd.gdSԔFӿg\4⤔g<^r?g~;T/g$6z6ӿg).jg-7֖0,q?g;1-g@ӿg[1gAnq?gK'$/gӿg)'(.gE1np?g( #-gbߝҿgi2]÷gwhep?g	]W/gJ]iҿg[@fgb\j*p?gG8v/g!ҿgln,FZg"p?gRZ1g\ rҿg=\g7UKo?gY>1g.7Aҿgƾg@o?g M2go'ҿge Rg۩o?g:i 3gʣѿggeVq?g[ؼ6gߐzg>#gu3H?gZH[gg333333?gݿgIҸg#"?g35\g Cb}ؿgS>gґ?gSg^տgb[Kgi<?g
;arhKg?{sVԿgY۹wg=?gfPAAg0oQ^9PӿgxIgN__?gQR<gpbURҿgcLWg
<0t~?gf5|8g9ҿg񮉣̡gdy?g'N:3g9bFIѿgV7ݢgķrv?gs()0gK"npѿgK' gVqt?g͊:,g_.ѿg3ƚgeIbs?gdYBP*gDпgigIB r?g&)bv*g#пgo:.Ug\ҕp?gƤ(g(пgRXЕgf#p?gXNz]'gEuFпg\4Yeg?.|o?g	g](g*0=Hpпg4J|WgZfmm?gG%gRпg8ؼ͒gP+5m?g^x&g`tdA5пg;Զlgju]Dm?g~m(gH&пg[gsk?gL%\&gA	пg<cйg?;.1k?g*i&g`4Ͽg,6W
g%lOj?g?(g8BϿg:	2",qgRr42j?g<Xnq]*gAοgu1g(6h?gb*g˳ec`οg=l򋃿g,5i?gie:.g-D#Ϳg1zgLp'j?gC!0g%T>3qͿg݁C}{g@Rj?gF31gv&lgKbh6g7ʠex?gu#|ggGz?gXݿg{Dg@@6?g>Xw\gȐL׿g#eIg,=(D?gSg/YkԿg\xZCg@KĈ?g(
FgÁҿgtMg뻁?g÷{wBgvѿg`Eåg==}?g.Ō4gpۙ~пg/X**g\O|?g8nv|5gϿg$5_Rg:Lv?gRY-gP *Ͽgf-2g3/r?g]*k"gŨGοgP-g>a!q?g@"g5Ϳgc!fgom;=	o?gb^* geͿg	9gؑ o?gbPCa#go\\̿g{{5gOrk?gD&M gC榷i̿gbg~ag i5i?gWW8g̿g,~ʓg@!i?gd޶7 gN$˿gɜrU-gMQGh?g&g=w&˿gsݑgO90g?gO#}TvgL<TX˿g	EKglbV0g?gw g.˿g_T3Iqg5z'f?gwh6gXʿg];/agu;f?gg&!gyʿgmEgm;>e?gx!g{6ɿg>ig4,c?d?g*bE#gZqbɿgggfQXIe?gvqm &gC
5ȿg/tg*-e?g<LW(gJ`CDUȿg-ggve?g9(g[ǿgqOqygr}qe?g,*gj1gZF7gf\q8qw?gNIyggףp=
?gz8rܿgV.Dg|/3Վ?g<\g"5=ֿg@t\g<KO9:?g.Qgӿg&gǒP
(?gxHg+ ѿg$VZӦ媿gٱcG?gNQ֋@gRkпg[|[;gmsq~?gY6g4,οg&YEgјG3|?gLr6gҗͿgEg]Ov?g/g]̿gEg`8	9&s?g?M&g,˿g
b3gyMNp?g'x7!gTO˿g<gX`n?g~ g"ԍʿg!%}gRܚgl?g: gSI5%ʿgS&ǲg];uh?gr.:3g;ɿgi~}gmg?gKWgHjɿgUBgFaf?g*<)=g V8ɿgp^EBfg=ڵ(6f?gM }-g.G,ȿgkgI)e?gu3g:ȿg~/g+30d?gW_44gv50Dfȿgu02>gd$Jd?gPogDOS@ȿgCJcgMB[jc?gx&k	gh_mϛǿgYi3g`"d?g. g9nǿgc;gfb?gp'wn g*wzƿg>	D̈́gPNb?gG!g`	JſgbzgjAo2c?gϺWI%g^
2ZOſg11؆~g3!c?g'Uo&gXĿgUX!)xg~Ȅb?g8m%&gg&ggU^`bX?g[/KRgg+?gܿg.*)g~t?gfeK\gp[TֿgN=g?gdAwQgK	@PҿgwC}g#?gw̃Gg=vпgc_gFFi?gd9AgnMοg@ng-$y?gvBD,g˿g5-gbv?g K*gԑWʿg7gwgs?gP[#gusɿgbBݝg_ޥp?gl g;\Yg+#ȿgӉU9g{'Y8hm?gSP)VgY6Nǿg;`+Șg(,!Zi?g Egh0ƿgVBg+xc?g[}gzb r<ƿgWz*	g6-Wb?gO#/Dgi0ſg400$gnre?gb"g,,Kſgz]Ugk$Db?gk(=g!8FĿg=qg^)`?g%'gĿgyI=bgE]M``?g:GJB	g>SĿgf6O5gKeca?g3"guĿgA[gێb?g<<ugAvzÿg20(gmGLa?gGg|]C\2ÿgY;vg7&X^?g(4gQ>¿g<@gE4^?gǣRFgg僿gřX̴]?gg~I՞fg,R.gd~ӀggrL]?g7g ́g\\|gsC^?g{ gN!LgWNwg2Z]?guyb!i   i   i   i   i(   i<   ix   c         C  s   y t  |   Wn t SXt S(   sC   
    returns True if x is a float,
    returns False otherwise
    (   t   floatt   Falset   True(   t   x(    (    sD   lib/python2.7/site-packages/statsmodels/stats/libqsturng/qsturng_.pyt   _isfloaty  s
    c   	      C  s5  |  d k s |  d k r+ t  d |    n  d  } d! } d" } d# } d } d | } |  | k  r t j d t j |    } | d | | d | | d | | d | | d | | d | d | | d | | d | | d | d S| |  k  rt j d t j d |    } | d | | d | | d | | d | | d | | d | d | | d | | d | | d | d S|  d } | | } | d | | d | | d | | d | | d | | d | | d | | d | | d | | d | | d | d S($   s  
    Modified from the author's original perl code (original comments follow below)
    by dfield@yahoo-inc.com.  May 3, 2004.

    Lower tail quantile for standard normal distribution function.

    This function returns an approximation of the inverse cumulative
    standard normal distribution function.  I.e., given P, it returns
    an approximation to the X satisfying P = Pr{Z <= X} where Z is a
    random variable from the standard normal distribution.

    The algorithm uses a minimax approximation by rational functions
    and the result has a relative error whose absolute value is less
    than 1.15e-9.

    Author:      Peter John Acklam
    Time-stamp:  2000-07-19 18:26:14
    E-mail:      pjacklam@online.no
    WWW URL:     http://home.online.no/~pjacklam
    i    i   s5   Argument to ltqnorm %f must be in open interval (0,1)g%1Cg4pFk@g;->qg@rKa@g͋40>gyTW @g0<KgwB,2d@g^vcg駱HP@g&x~*gJg$ԿgXp4g:p,egM@g?\@gԟW?gdY+M?g|@gh	@gEԘ?ii   i   i   i   g      ?(   g%1Cg4pFk@g;->qg@rKa@g͋40>gyTW @(   g0<KgwB,2d@g^vcg駱HP@g&x~*(   gJg$ԿgXp4g:p,egM@g?\@(   gԟW?gdY+M?g|@gh	@(   t
   ValueErrort   matht   sqrtt   log(	   t   pt   at   bt   ct   dt   plowt   phight   qt   r(    (    sD   lib/python2.7/site-packages/statsmodels/stats/libqsturng/qsturng_.pyt   _phi  s6           
D5 C5

Hc         C  s   d d d t  d |  d  S(   s+   function for p-value abcissa transformationg      g      ?g      ?g       @(   R   (   R   (    (    sD   lib/python2.7/site-packages/statsmodels/stats/libqsturng/qsturng_.pyt   _ptransform  s    c         C  s  |  d t  j | d  |  d t  j | d  d |  d t  j | d  d |  d t  j | d  d } | d k r| d d d t |  d 7} | d	 k r t j |  s | n d
 } | d d d d | 7} qt j |  s | n d
 } | d d | 7} n  | S(   s|   
    calculates f-hat for the coefficients in a, probability p,
    sample mean difference r, and degrees of freedom v.
    i    g      ?i   i   i   i   gMb`g      (@g~jt@g*Gg     (@g     s@g     g@(   R
   R   R   t   npt   isinf(   R   R   R   t   vt   f(    (    sD   lib/python2.7/site-packages/statsmodels/stats/libqsturng/qsturng_.pyt   _func  s    R  c         C  s   |  d k r d S|  d k r  d S|  d k r0 d S|  d k r@ d S|  d k rP d S|  d
 k r` d S|  d k rp d S|  d k r d S|  d k r d Sd Sd S(   s-   returns the points to use for interpolating pgGz?gףp=
?g+?g333333?gffffff?g333333?g?g      ?g333333?gffffff?g?gffffff?g      ?g?g      ?g?N(   gGz?gףp=
?g+?(   g333333?gGz?gףp=
?(   gffffff?g333333?gGz?(   g?gffffff?g333333?(   g333333?g?gffffff?(   g?g333333?g?(   g      ?g?g333333?(   g?g      ?g?(   g      ?g?g      ?(   g?g      ?g?(    (   R   (    (    sD   lib/python2.7/site-packages/statsmodels/stats/libqsturng/qsturng_.pyt
   _select_ps  s&    
c         C  s  t  |   \ } } } y' t t | | f | | |  d } Wn t |  | |    n Xt t | | f | | |  d } t t | | f | | |  d } t j | t |  t |   }	 t j | t |  t |   }
 t j | t |  t |   } |  d k rt |   } t |  } t |  } t |  } d | |
 | | |
 |	 | | | | } | | | | k r| |
 | | d | | | } n" |
 |	 | | d | | | } |
 } | d | | d | | | | } t j |  t |  t |  } n|  d k rd | |
 | | |
 |	 | | | | } | | | | k r| |
 | | d | | | } n" |
 |	 | | d | | | } |
 } | d |  | d | |  | | } t j |  t |  t |  } n t	 | d  } t j
 d  | t j j j d | d |  } t j
 d  | t j j j d | d |  } | | | | } | } | |  | | } | t j
 d  t j j j d |  d |  } | S(   ss   
    interpolates p based on the values in the A table for the
    scalar value of r and the scalar value of v
    g      ?g333333?i   g      ?g       @g*G(   R   R   t   At   printR
   R   R   R   t   expt   minR   t   scipyt   statst   tt   isf(   R   R   R   t   p0t   p1t   p2t   y0t   y1t   y2t   y_log0t   y_log1t   y_log2t   p_tt   p0_tt   p1_tt   p2_tt   d2t   d1t   d0t   y_logt   yt   q0t   q1R   (    (    sD   lib/python2.7/site-packages/statsmodels/stats/libqsturng/qsturng_.pyt   _interpolate_p  sR    '#####.%"&&.%"&&!!2c         C  s   |  d k r d d t  f S|  d k r) d S|  d k r9 d S|  d k rI d S|  d
 k rY d S|  d k ri d S| d k r |  d k  r d Sn |  d k  r d St t |    } | d | | d f S(   s-   returns the points to use for interpolating vg      ^@i<   ix   g      N@i(   g      D@i   g      >@i   g      8@i   g     3@i   g?g      @i   i   i   g      @i   (   i(   i<   ix   (   i   i(   i<   (   i   i   i(   (   i   i   i   (   i   i   i   (   i   i   i   (   i   i   i   (   t   inft   intt   round(   R   R   t   vi(    (    sD   lib/python2.7/site-packages/statsmodels/stats/libqsturng/qsturng_.pyt
   _select_vsY  s&    c         C  s  t  | |   \ } } } t t |  | f |  | |  d d } t t |  | f |  | |  d d } t t |  | f |  | |  d d } | d k r d } n  d | d | d | d | f \ }	 }
 } } d | | | | | | |
 | | |
 } | |
 | | k r7| | | | d | | | } n" | | | |
 d | | |
 } | } t j | d |	 | d | |	 | |  } | S(   s`   
    interpolates v based on the values in the A table for the
    scalar value of r and th
    g      ?g       @g*Gg      ?(   R?   R   R   R
   R   (   R   R   R   t   v0t   v1t   v2t   y0_sqt   y1_sqt   y2_sqt   v_t   v0_t   v1_t   v2_R3   R4   R5   R7   (    (    sD   lib/python2.7/site-packages/statsmodels/stats/libqsturng/qsturng_.pyt   _interpolate_vu  s    ''' 	..%"/c         C  s  |  d k  s |  d k r' t  d   n  |  d k  rQ | d k  rl t  d   ql n | d k  rl t  d   n  t |   }  t | t j  r | j   } n  |  | f t k r t t |  | f |  | |  d	 } n|  t k r^| t	 g  d g f |  d k k r^t
 | |   \ } } } t |   \ } } }	 t |  | |  d }
 t |  | |  d } t |  | |  d } d	 | d	 | d	 | d	 | f \ } } } } d
 | | | | |
 | | | | | } | | | | k r| | | | d | | | } n" | |
 | | d | | | } | } t j | d
 | | d
 | | | |  } nY | t	 g  d g f |  d k k rt |  | |  } n! |  t k rt |  | |  } n  t | d  } t j d  | t j j j d	 |  d
 |  S(   s   scalar version of qsturngg?g+?s   p must be between .1 and .999g?i   s   v must be > 2 when p < .9i   s   v must be > 1 when p >= .9g      ?g       @g      ?g*G(   R	   R   t
   isinstanceR   t   ndarrayt   itemR   R   t   p_keyst   v_keysR?   R   R:   R
   R   RJ   R!   R"   R#   R$   R%   (   R   R   R   R7   R@   RA   RB   R&   R'   R(   t   r0_sqt   r1_sqt   r2_sqRF   RG   RH   RI   R3   R4   R5   (    (    sD   lib/python2.7/site-packages/statsmodels/stats/libqsturng/qsturng_.pyt   _qsturng  s>    &/..%"2#s   vector version of qsturngc         C  s>   t  t t |  | | g   r. t |  | |  St |  | |  S(   s  Approximates the quantile p for a studentized range
       distribution having v degrees of freedom and r samples
       for probability p.

    Parameters
    ----------
    p : (scalar, array_like)
        The cumulative probability value
        p >= .1 and p <=.999
        (values under .5 are not recommended)
    r : (scalar, array_like)
        The number of samples
        r >= 2 and r <= 200
        (values over 200 are permitted but not recommended)
    v : (scalar, array_like)
        The sample degrees of freedom
        if p >= .9:
            v >=1 and v >= inf
        else:
            v >=2 and v >= inf

    Returns
    -------
    q : (scalar, array_like)
        approximation of the Studentized Range

    (   t   allR   R   RS   t	   _vqsturng(   R   R   R   (    (    sD   lib/python2.7/site-packages/statsmodels/stats/libqsturng/qsturng_.pyt   qsturng  s    c           s     d k  r t  d   n    f d   } | d k r   t d | d  k  rR d S  t d | d  k rn d Sd	 t | d d d
 | | f S  t d | |  k  r d S  t d | |  k r d Sd	 t | d d d
 | | f Sd S(   s   scalar version of psturngg        s   q should be >= 0c           s   t  t |  | |     S(   N(   t   absRS   (   R   R   R   (   R   (    sD   lib/python2.7/site-packages/statsmodels/stats/libqsturng/qsturng_.pyt   <lambda>;  t    i   g?g?g+?gMbP?g      ?t   argsN(   R	   RS   R   (   R   R   R   t   opt_func(    (   R   sD   lib/python2.7/site-packages/statsmodels/stats/libqsturng/qsturng_.pyt   _psturng6  s     s   vector version of psturngc         C  s>   t  t t |  | | g   r. t |  | |  St |  | |  S(   sK  Evaluates the probability from 0 to q for a studentized
       range having v degrees of freedom and r samples.

    Parameters
    ----------
    q : (scalar, array_like)
        quantile value of Studentized Range
        q >= 0.
    r : (scalar, array_like)
        The number of samples
        r >= 2 and r <= 200
        (values over 200 are permitted but not recommended)
    v : (scalar, array_like)
        The sample degrees of freedom
        if p >= .9:
            v >=1 and v >= inf
        else:
            v >=2 and v >= inf

    Returns
    -------
    p : (scalar, array_like)
        1. - area from zero to q under the Studentized Range
        distribution. When v == 1, p is bound between .001
        and .1, when v > 1, p is bound between .001 and .9.
        Values between .5 and .9 are 1st order appoximations.

    (   RT   R   R   R\   t	   _vpsturng(   R   R   R   (    (    sD   lib/python2.7/site-packages/statsmodels/stats/libqsturng/qsturng_.pyt   psturngM  s    (   g?g       @(   g?g      @(   g?g      @(   g?g      @(   g?g      @(   g?g      @(   g?g       @(   g?g      "@(   g?g      $@(   g?g      &@(   g?g      (@(   g?g      *@(   g?g      ,@(   g?g      .@(   g?g      0@(   g?g      1@(   g?g      2@(   g?g      3@(   g?g      4@(   g?g      8@(   g?g      >@(   g?g      D@(   g?g      N@(   g?g      ^@(   g      ?g       @(   g      ?g      @(   g      ?g      @(   g      ?g      @(   g      ?g      @(   g      ?g      @(   g      ?g       @(   g      ?g      "@(   g      ?g      $@(   g      ?g      &@(   g      ?g      (@(   g      ?g      *@(   g      ?g      ,@(   g      ?g      .@(   g      ?g      0@(   g      ?g      1@(   g      ?g      2@(   g      ?g      3@(   g      ?g      4@(   g      ?g      8@(   g      ?g      >@(   g      ?g      D@(   g      ?g      N@(   g      ?g      ^@(   g?g       @(   g?g      @(   g?g      @(   g?g      @(   g?g      @(   g?g      @(   g?g       @(   g?g      "@(   g?g      $@(   g?g      &@(   g?g      (@(   g?g      *@(   g?g      ,@(   g?g      .@(   g?g      0@(   g?g      1@(   g?g      2@(   g?g      3@(   g?g      4@(   g?g      8@(   g?g      >@(   g?g      D@(   g?g      N@(   g?g      ^@(   g      ?g       @(   g      ?g      @(   g      ?g      @(   g      ?g      @(   g      ?g      @(   g      ?g      @(   g      ?g       @(   g      ?g      "@(   g      ?g      $@(   g      ?g      &@(   g      ?g      (@(   g      ?g      *@(   g      ?g      ,@(   g      ?g      .@(   g      ?g      0@(   g      ?g      1@(   g      ?g      2@(   g      ?g      3@(   g      ?g      4@(   g      ?g      8@(   g      ?g      >@(   g      ?g      D@(   g      ?g      N@(   g      ?g      ^@(   g?g       @(   g?g      @(   g?g      @(   g?g      @(   g?g      @(   g?g      @(   g?g       @(   g?g      "@(   g?g      $@(   g?g      &@(   g?g      (@(   g?g      *@(   g?g      ,@(   g?g      .@(   g?g      0@(   g?g      1@(   g?g      2@(   g?g      3@(   g?g      4@(   g?g      8@(   g?g      >@(   g?g      D@(   g?g      N@(   g?g      ^@(   g333333?g       @(   g333333?g      @(   g333333?g      @(   g333333?g      @(   g333333?g      @(   g333333?g      @(   g333333?g       @(   g333333?g      "@(   g333333?g      $@(   g333333?g      &@(   g333333?g      (@(   g333333?g      *@(   g333333?g      ,@(   g333333?g      .@(   g333333?g      0@(   g333333?g      1@(   g333333?g      2@(   g333333?g      3@(   g333333?g      4@(   g333333?g      8@(   g333333?g      >@(   g333333?g      D@(   g333333?g      N@(   g333333?g      ^@(   g?g      ?(   g?g       @(   g?g      @(   g?g      @(   g?g      @(   g?g      @(   g?g      @(   g?g       @(   g?g      "@(   g?g      $@(   g?g      &@(   g?g      (@(   g?g      *@(   g?g      ,@(   g?g      .@(   g?g      0@(   g?g      1@(   g?g      2@(   g?g      3@(   g?g      4@(   g?g      8@(   g?g      >@(   g?g      D@(   g?g      N@(   g?g      ^@(   gffffff?g      ?(   gffffff?g       @(   gffffff?g      @(   gffffff?g      @(   gffffff?g      @(   gffffff?g      @(   gffffff?g      @(   gffffff?g       @(   gffffff?g      "@(   gffffff?g      $@(   gffffff?g      &@(   gffffff?g      (@(   gffffff?g      *@(   gffffff?g      ,@(   gffffff?g      .@(   gffffff?g      0@(   gffffff?g      1@(   gffffff?g      2@(   gffffff?g      3@(   gffffff?g      4@(   gffffff?g      8@(   gffffff?g      >@(   gffffff?g      D@(   gffffff?g      N@(   gffffff?g      ^@(   g333333?g      ?(   g333333?g       @(   g333333?g      @(   g333333?g      @(   g333333?g      @(   g333333?g      @(   g333333?g      @(   g333333?g       @(   g333333?g      "@(   g333333?g      $@(   g333333?g      &@(   g333333?g      (@(   g333333?g      *@(   g333333?g      ,@(   g333333?g      .@(   g333333?g      0@(   g333333?g      1@(   g333333?g      2@(   g333333?g      3@(   g333333?g      4@(   g333333?g      8@(   g333333?g      >@(   g333333?g      D@(   g333333?g      N@(   g333333?g      ^@(   gGz?g      ?(   gGz?g       @(   gGz?g      @(   gGz?g      @(   gGz?g      @(   gGz?g      @(   gGz?g      @(   gGz?g       @(   gGz?g      "@(   gGz?g      $@(   gGz?g      &@(   gGz?g      (@(   gGz?g      *@(   gGz?g      ,@(   gGz?g      .@(   gGz?g      0@(   gGz?g      1@(   gGz?g      2@(   gGz?g      3@(   gGz?g      4@(   gGz?g      8@(   gGz?g      >@(   gGz?g      D@(   gGz?g      N@(   gGz?g      ^@(   gףp=
?g      ?(   gףp=
?g       @(   gףp=
?g      @(   gףp=
?g      @(   gףp=
?g      @(   gףp=
?g      @(   gףp=
?g      @(   gףp=
?g       @(   gףp=
?g      "@(   gףp=
?g      $@(   gףp=
?g      &@(   gףp=
?g      (@(   gףp=
?g      *@(   gףp=
?g      ,@(   gףp=
?g      .@(   gףp=
?g      0@(   gףp=
?g      1@(   gףp=
?g      2@(   gףp=
?g      3@(   gףp=
?g      4@(   gףp=
?g      8@(   gףp=
?g      >@(   gףp=
?g      D@(   gףp=
?g      N@(   gףp=
?g      ^@(   g+?g      ?(   g+?g       @(   g+?g      @(   g+?g      @(   g+?g      @(   g+?g      @(   g+?g      @(   g+?g       @(   g+?g      "@(   g+?g      $@(   g+?g      &@(   g+?g      (@(   g+?g      *@(   g+?g      ,@(   g+?g      .@(   g+?g      0@(   g+?g      1@(   g+?g      2@(   g+?g      3@(   g+?g      4@(   g+?g      8@(   g+?g      >@(   g+?g      D@(   g+?g      N@(   g+?g      ^@(!   t   __doc__t
   __future__R    t   statsmodels.compat.pythonR   R   R
   t   scipy.statsR"   t   numpyR   t   scipy.optimizeR   R;   t   __version__R   RN   RO   R   R   R   R   R   R:   R?   RJ   RS   t	   vectorizeRU   RV   R\   R]   R^   (    (    (    sD   lib/python2.7/site-packages/statsmodels/stats/libqsturng/qsturng_.pyt   <module>   s  	*%		A				T		*	Z		:		