From 1fd206a84fc9898dbffa1aae65143815cfea1024 Mon Sep 17 00:00:00 2001 From: merliseclyde Date: Sat, 30 Mar 2024 19:14:00 +0000 Subject: [PATCH] =?UTF-8?q?Deploying=20to=20gh-pages=20from=20@=20merlisec?= =?UTF-8?q?lyde/BAS@25d643ccd35baf896338577c46c20377808b0157=20?= =?UTF-8?q?=F0=9F=9A=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- articles/BAS-vignette.html | 106 +++++++++--------- .../figure-html/diagnostics-1.png | Bin 37840 -> 37804 bytes .../figure-html/diagnostics-2.png | Bin 41050 -> 41190 bytes .../figure-html/plot-confint-1.png | Bin 20698 -> 20691 bytes .../figure-html/unnamed-chunk-1-2.png | Bin 39181 -> 38930 bytes .../figure-html/unnamed-chunk-1-3.png | Bin 70542 -> 71020 bytes authors.html | 4 +- pkgdown.yml | 2 +- search.json | 2 +- 9 files changed, 57 insertions(+), 57 deletions(-) diff --git a/articles/BAS-vignette.html b/articles/BAS-vignette.html index f9321514..6e966141 100644 --- a/articles/BAS-vignette.html +++ b/articles/BAS-vignette.html @@ -331,23 +331,23 @@

Posterior Distributions of Coef Density intervals from the summaries from coef.

 confint(coef.ZS)
-
##                    2.5%       97.5%        beta
-## Intercept  6.666605e+00 6.780476294  6.72493620
-## M         -1.206267e-03 2.163933898  1.14359433
-## So        -5.830268e-02 0.306753091  0.03547522
-## Ed         5.578925e-01 3.107169976  1.85848834
-## Po1        0.000000e+00 1.443627734  0.60067372
-## Po2       -7.562799e-02 1.476699866  0.31841766
-## LF        -4.330386e-01 1.113585347  0.05933737
-## M.F       -2.099673e+00 1.885398820 -0.02702786
-## Pop       -1.255982e-01 0.006179825 -0.02248283
-## NW        -1.108672e-05 0.166589909  0.06668437
-## U1        -4.684904e-01 0.402105224 -0.02456854
-## U2        -1.131477e-02 0.648917132  0.20702927
-## GDP       -6.171786e-02 1.161168686  0.20625063
-## Ineq       6.973847e-01 2.145803613  1.39012647
-## Prob      -4.154054e-01 0.000000000 -0.21536203
-## Time      -4.992947e-01 0.075976670 -0.08433479
+
##                  2.5%       97.5%        beta
+## Intercept  6.66770273 6.781702951  6.72493620
+## M          0.00000000 2.177381010  1.14359433
+## So        -0.05485621 0.307111466  0.03547522
+## Ed         0.56732766 3.136097257  1.85848834
+## Po1        0.00000000 1.455247021  0.60067372
+## Po2       -0.25023581 1.433650732  0.31841766
+## LF        -0.48970270 1.071017370  0.05933737
+## M.F       -2.25829665 1.784670735 -0.02702786
+## Pop       -0.12285039 0.008864886 -0.02248283
+## NW         0.00000000 0.166754621  0.06668437
+## U1        -0.52224407 0.353015104 -0.02456854
+## U2         0.00000000 0.665710068  0.20702927
+## GDP       -0.04790262 1.171018509  0.20625063
+## Ineq       0.65578748 2.107592475  1.39012647
+## Prob      -0.41394961 0.000000000 -0.21536203
+## Time      -0.51467783 0.060187459 -0.08433479
 ## attr(,"Probability")
 ## [1] 0.95
 ## attr(,"class")
@@ -505,7 +505,7 @@ 

Alternative algorithms } )

##    user  system elapsed 
-##   1.375   0.001   1.376
+## 1.391 0.000 1.390
 system.time(
   for (i in 1:10) {
@@ -517,7 +517,7 @@ 

Alternative algorithms } )

##    user  system elapsed 
-##   1.195   0.004   1.199
+## 1.215 0.000 1.215

which is faster for enumeration than the default method=“BAS”.

@@ -639,7 +639,7 @@

Outliers Air.Flow -0.999190 +0.998745 1.00000 1.0000000 1.0000000 @@ -648,16 +648,16 @@

Outliers Water.Temp -0.443780 +0.477550 1.00000 -0.0000000 1.0000000 0.0000000 +0.0000000 1.0000000 Acid.Conc. -0.095890 +0.087530 0.00000 0.0000000 0.0000000 @@ -666,7 +666,7 @@

Outliers 1 -0.569035 +0.610125 1.00000 1.0000000 1.0000000 @@ -675,7 +675,7 @@

Outliers 2 -0.151975 +0.165970 0.00000 0.0000000 0.0000000 @@ -684,7 +684,7 @@

Outliers 3 -0.600350 +0.641605 1.00000 1.0000000 1.0000000 @@ -693,7 +693,7 @@

Outliers 4 -0.952810 +0.945095 1.00000 1.0000000 1.0000000 @@ -702,7 +702,7 @@

Outliers 5 -0.068995 +0.065675 0.00000 0.0000000 0.0000000 @@ -711,7 +711,7 @@

Outliers 6 -0.079570 +0.083865 0.00000 0.0000000 0.0000000 @@ -720,7 +720,7 @@

Outliers 7 -0.063875 +0.064475 0.00000 0.0000000 0.0000000 @@ -729,7 +729,7 @@

Outliers 8 -0.060505 +0.072510 0.00000 0.0000000 0.0000000 @@ -738,7 +738,7 @@

Outliers 9 -0.068120 +0.066955 0.00000 0.0000000 0.0000000 @@ -747,7 +747,7 @@

Outliers 10 -0.062665 +0.062450 0.00000 0.0000000 0.0000000 @@ -756,7 +756,7 @@

Outliers 11 -0.062515 +0.064540 0.00000 0.0000000 0.0000000 @@ -765,7 +765,7 @@

Outliers 12 -0.088540 +0.083845 0.00000 0.0000000 0.0000000 @@ -774,7 +774,7 @@

Outliers 13 -0.347550 +0.342110 0.00000 1.0000000 1.0000000 @@ -783,7 +783,7 @@

Outliers 14 -0.182855 +0.187165 0.00000 0.0000000 0.0000000 @@ -792,7 +792,7 @@

Outliers 15 -0.073295 +0.071065 0.00000 0.0000000 0.0000000 @@ -801,7 +801,7 @@

Outliers 16 -0.055340 +0.057130 0.00000 0.0000000 0.0000000 @@ -810,7 +810,7 @@

Outliers 17 -0.064400 +0.057900 0.00000 0.0000000 0.0000000 @@ -819,7 +819,7 @@

Outliers 18 -0.063760 +0.063780 0.00000 0.0000000 0.0000000 @@ -828,7 +828,7 @@

Outliers 19 -0.091775 +0.087175 0.00000 0.0000000 0.0000000 @@ -837,7 +837,7 @@

Outliers 20 -0.124905 +0.136480 0.00000 0.0000000 0.0000000 @@ -846,7 +846,7 @@

Outliers 21 -0.985850 +0.981505 1.00000 1.0000000 1.0000000 @@ -857,26 +857,26 @@

OutliersBF NA 1.00000 -0.3397571 0.5779604 +0.3397571 0.2016282 0.5555328 PostProbs NA -0.05800 -0.0234000 -0.0217000 -0.0208000 -0.0185000 +0.06980 +0.0233000 +0.0216000 +0.0210000 +0.0187000 R2 NA 0.98920 -0.9873000 0.9923000 +0.9873000 0.9803000 0.9922000 @@ -884,8 +884,8 @@

Outliersdim NA 7.00000 -7.0000000 8.0000000 +7.0000000 6.0000000 8.0000000 @@ -893,8 +893,8 @@

Outlierslogmarg NA 23.82319 -22.7436630 23.2749373 +22.7436630 22.2218573 23.2353597 diff --git a/articles/BAS-vignette_files/figure-html/diagnostics-1.png b/articles/BAS-vignette_files/figure-html/diagnostics-1.png index 7065a6050a4f49a6c8ac5277a63e89d1a3227f43..fb8fa07fd02e17e97f07c92c2f49cec866410a9d 100644 GIT binary patch literal 37804 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%0A2GEH>b=OQGfnV^nXgO#W+E-CFeFU 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 WXB|t^wWmMmHiD1B0~?Q=`{mzT%A2zQ literal 41050 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�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 z zjUQeq`_#bqh9$$GyShDI|221Dpj?hHw}RSKmWIV4kVS6dPV4fm+XG5sfIVdt&U@i} zup`*MKgMF#E!6dRk(OW{XxrRo-(PtQelJD3U}SNq9XH0T4o~c;-lS(ez?AWYbpD_8 z85sM+N*~)BJiWZ+9NCUEt4q*t=u&^K54Nx)>*t69pB%T!blF91*HIBrf&5BpdA9(h zY|_ZA#%si}0GN$rchhMH@qF!+06x4LAAckW@i6rHt7*e(WMOR=HGD{njCuPk-K$5B zfdPGIu+?G1@ET3&fCiM9aOs0JGiUo%qVU1C1gFUMGtCUzj_ZE=LA{aMV&wdEV*pke zNmaGR;S__T8iZ@IXErES@xyuj?=7|rO}iPl%dY>49_(W!SBln&cJS`8%4c zlj`9a%t`XJ7dIACKOm{fT)i#;G{v~dDyF@JCOho9L5$!O{*M*zH0!;MqzG=3KvSkX z6{iX_-|QLHK-u5c^RX*7{>b?;=z-t>wP{@fl0mt<{gD*Cz)4qZ?d(9rJnJBxE?+^w#POiSH!m;g*PA zi`Wv>1rQQ}5@|R*Nijt$&0RQUy9m~tp#>aJyl@{bR^>oaIY1t)1JP}~VY7!FKdI)q zSf`wgtyp%}=VC~DgKp-cR(O(OoDkbah%h?Yg-$SaxyU)-x_&X})wHJyM^c#w*w-z+ z_ODRqEWo(Z8onj!w7C&$BMH*~vF^2R+25`PfsUrDtwWm#>6*<2CP^M!Xd`ci5b~X) z6{0lZ`wAE0(qUbmRAGH%vuRY>`G_S$%^7*mR9aXm9jS5gDI>;5R@|xSmdUr%`|V1{ z)MPVmD+v+({gU6wN^v}0+eJa0Hatd@F23zE9A_07?dpxGZ(nZ0|JM+%r#ocFt@?znzV`8(kv@V)w=I*!}C zma3<66-b_yc*HMn&2iE`?NQBLC>>m93@9MU`fl(5scOtsj+Mm>3}`8!Eru z%;p{lB9?oA7rdPn0Xru;4i`QQzJkl-<-hX1glB8Mi58PB!_N&VLGT4N$c7ju zjC018T>L9DK0g1E`-@EmVO`A4$UNR+H@DZnkMX`o4a*$@^Zs`G2pwu$qSA+Ui9efg z$uchFzbWM{RQu?{e=K-nT8}AWErt&q>Y#38O{m)@H{{sW52lxO0 diff --git a/articles/BAS-vignette_files/figure-html/plot-confint-1.png b/articles/BAS-vignette_files/figure-html/plot-confint-1.png index 394ab516ca05ef8af59cfcc282791c59968eed8e..fbb23bce6bfb12dfe5a457349560730b0dd6e8ed 100644 GIT binary patch literal 20691 zcmeIa2~<;Aw=TK?5iLb*s%&V>0z?!9K|q=SN(myJNE7--q?0BHh9(feQo$-v%7B2< z1Vw2QAhe+k!9t~I148IRh)8Qlhyn>s2)R30=YRK&d+&JXjx*kP_q=iT7!uigt+m&h zYp!q3`OO)Aziw?N{)6NX004-aU;Xt40Eij`fQa{=-Qb;5rw*aOkKH#d%zgzw!E3{$ zIRX6G8+O$>0sv%^1^DFa|8K#U zubXB(DmYzn{8!r_-x>7(+V3@S_=x!D-v%D-IWU z5hF$Ae%t>2nmzj?Sgf?cwGpHm)!l(gMq+G?&}khpcj0*~-8H*;M>v$Y*!<(p?EdQq zC;`n}2SRaEXnQ2Z_N=f#B2FkY_6fRrudxvLOQHzNqdYl(L=g}bJUjI{l`bQGZ=Q&o z%m8+TnEiyx8|5x;l2__Y;x zawg8K-Jn2e&p&Tra>|o)*YteR|1_zz#(E4K4BMVK#T6|Oj9d1)(C1j&y{`-ONwSec znoMJ+8fK~Gb%eXUyCVc+5TdiC-#s2W+Kv#c<@j^i zg5de9?4G2PUr8k%8lk!b+~!OAISV~np_HtYV1TeaND~va&NO?Su_EfFJdxF3dj+@K zPDXgZLrjd<3r>WH7VO-)x9nRk_5fW{LGjaXy+VOe)-cE9cZ8IEF(OeTZEysCh4RAl z2-rB$c5jKG58x#Q3q)SrV47C=9!hEx%-Awlwm_x5O1vI+yj*amfQt|R5vz*OX~FO6 z&fmofWdEG=BX%ei7@+T9gNGf9mfS`7!Yd zgn;Nz)jnn)g_-muz)dOj_Hr(l-NEO;KK;VYRk|%%k?aYTE2#+CqrF|W`F2j~K=bWY z;2~ipJ85J@(dU@pplFqc%Y;c9RNN+)p835Upa}Tl zqa1C@WSyul^@{ZfQ;iXk>_D$?UYuN({!ws`N?+-?g>hEZO<>6Jp z*V)6#y=p49{nO3~%>y!gH{T^uppPAQ@TTlgVzmm|fqI+Cq1nrws5&YbtYlXKqwfnj zL~3r6i>>2U;9Bq0{vmkab$3Y=WH_LWAAVZS}0#keJs$vQ8N!&!Vdw+obd zyOqTCqu)~N%IR0(j&N>L|B9F-B6<5Ze35P*`<0c@&{T4Ak9*RZ$`=E{kZteW-KhNt zTvy5mRsVAcP=*5{AZjK)^ZF?|bGDkUq!Y(~RP}>k>4`^n6{rl#g*5PV3mtZ379_aw z#dShpSrcvd7&{l?s9{`(|L$ow55uB-{@hvNyq%5bk+)N3u@+K9Ya++0{$o8~D-ed-S6|KQ@af-QJzadPhq8 zx7GF@jE=mCo$uAe=tJekJ6r^B@v=y2tH~>NPz%kbt?a|5ND22vU>7Bm-V^bg?Q|PV zw^`|7K|B1mVe@YoVdEyS9f5XD2Fw-1O48@-H zVmc02VpvOgCD`6b(C|zYBA6)B#vk;E%s6ZCUgE>O#`o%>{N|RX5wu_XI>Z z!Vz$GYUGFmtmpKv$G@A)Pq%0uyk+pk>-4=AhDz#ULZ>OZH{AOx*L#teSe>%t@t4{o z=9%JHq)|P>oBhoeBRI^n;6Nk2OG2Ap#0U3*9!zjf}ikl%K2i2uyI;aX0GM)+op8KcxQs%T<+bT{6tx=tAU4!Fs}e12ULyP)PIU zaMBd3J{0-e{2(Sm3L(-8Yd>!^roMAb0k6ZMHwcC7le0E*^|_5Fgo(#ZJ~=-)`4s@9 zcPF*A3l)f+?hbQcmx$AhZk1i$k(0d8>F(t&@p_WfcQ;|w80f0bB}{P^&9ERS1Aw;R z>|1`w3U1)(3lKv3*1RJPN{usZrr6Izad`tvPV7|rPt9uLK;r#tK$k|YJH(gC5hvT3 zm5Blu8(M1-Tf$5^b+eolOfs`f8UTvGSA@!x<~xJn%Y~I1)+X~O?_=~?QyW5w-&zVb z=ls?Hq#N9u{hAJ;)apAz5_I2y`<6^j$4&=Pa5}qQ#m?fTw#$7(|7RO~>PvMJ`uwpp z_dP)JBw3u8-glz;pjQwgv0BOoBikIw{YbZEh7_!~(v9q+oIh@~2AR(bP|@qkUgNRf z<;f&_S~G_ifq?~Q^CQ$`aN8Y+NlO2?UqYu-^vXBMNsWfsdG`ZR83rAx-`>=#A~ZD70-g!k`TP_OI6idvBy{SNADLD! zdvojV;2t9jpy@QIksHbv}hPG;IDQn$`$sKZ2A9z~At9;KxMj`ZCh+ z0QlR{UqGNvgB_o2N@o_z5A9gDtK!d z7#>u*j@Wy8KoU%wM;y^mLIg<=fFx>x9Wtl7=s_4U2U3M$btJ!zoPsffqTLC;8Fa8K zaNyCLQM#ycOH@#p#NW>-Tu8XFdg^ifEs{G?zP_*IqZIP@mtq9&;Q<1|h>0Nu%rX+BPGN%_Yq}yEC z0<=5Njg6tl`sK2glcpTRs5B@H#$A&x)>%DFc!^-8t{`g>Yd6k_0NFGNdmYyTo-;Yk zk=6pLe9FN@;kIx$JKk)nwtoeZP>uL9nOUO|?-N4lV`8ElSXe_}fqpslJf%xThE0rU z?|M0Mu3p;9_UI)6f{u=FkRR$_TslS0%XHgUDFP}XsEg&)yRUujDeic_KroZne365+ zzzUC^--*uJhAS{0t@o!V$JI%?>KfngapHZ&I^1r^ct)OV`wX5E@S?;b*wv!re0TOr zto^>qpZ{rSXp3}bkL!-NzS*SH>5%e0**QBQn-_k~0S)B^!>OmZuz=&7cr-nP>vT;0 z{`aSbPzQch6P*2(zFEhWb8x?ojAg&Pb4>&f!U^~?r=Dlz2+5=mPzZMOQ}irA`968z z-xD8tWkz6d6-#&y59+Xnd6MdQ2pq62cUM81qcwKhon1j+!zSP(`Gr`hgBo^8(>hSF zycO^bIl3;88pJhtit2b=C>uqW;$Q{wYvL6dnP$LC5mJR%muB{r<=YbK5byIHK|{!R z=;|mD8fh5TLC4TVG{?c6jc0$OX6>$&7QX(;9_`5M5FJN5^Mcu;v34M0R3_&;LHs)B zxA1gmR-ARB45;tLo0;@g5ZMyie=&!-A+*5BdTh=niCWipi}jVt+Pb^*`UE<&**=@` z&$tq!@9zlq_M(#qnIT(nOlwyG^n%JCKZF%H?b>^hEUIs?q-{|y&J*y3=0vY0J5M#&n4i8o@G=W^Hoyd!EKA0 zV;=;IcG^4l57YBM&|44SgvaS_LlDWgqq+u#2pqo zE!N8>Kl3>z1T?Q&hXU;wrYcC*c zfSxNrmqA~46@RrZq);9_uRAxvNJ#MMRSkx$nbTi-_kzE)3B3{fzmYWmFHkFbpj#(+ z@!7dDdN(%0uT~$)TpWRpgbpq>fx%W9v-N_P?RTt7M?%@OV*&idh}xJN?ECs>#YV-! zr85ZfAPH(#flMd{t*=p;;YCMVAnfm4cPe&jZ8@?JXXu8!Y1%Ad5A(R}URE>@J*Lwv zwot5n>ugQ_z7a>#1k$<98gx>;V8~GRJ~BaPB8r>jAv|Jljss02@=#m2pc5+&$#x|_cV!T5*(T(9sHd|#!3HkW=DnIrZ^5&K5H)mJ zvKeNCbdfeocFnYt1Y*BbiWY#>MOj~Y1!mHb;6L;Skc~;f(gGI0Mih$K6F;h}$O5BM z{2&n7MKH&pIFDxWwq3c}kwV-V3v5EkB$QCLX+-w4=Q|M!5dk&x_kgx}ewbrh ziMKC+(sX)tUpi5?w6(J7^~wG%HFCL5;7SDOWHg7~$*1V_h_2+wFcyW{=<6Bud!S9Q z?G^<8pDOiBOg^P)_t2KLq?WjU(C>&7AfDBcGzkYkXP2KUV91_Gk7b_vM33ci1q$7PL+bvBdCJh@8=uYe*dX3c4oQ5myEx}Qq zK?x&C>UDJ-ow4q}gf9Nr2lg(0atrM2m381Iu=#~d#DtdQyHSh1k8`O~N7JIs*e&!d z46*!N@Pgl&$$=Vy{df=d+=I84@zy&yCj~(TXe4QcP&x@%<_v z-X9fNJ&T2X5v=5i1I(ov$rPR^++;cd__bF_5?Odke$z0=Hlh|83twt=AR2ji68ywE zc*E6#$nGNJz)gvMibDdVuy?*33BhfC%AJRdAKXKXNrnqaAC+55FaA-N{50wPoZ$dt zG7nl&mxG!n`(TYcK4oXwlV~~Nf|cL|vtW`{{cB@P+4!S5_nDzVp8gN9Kr*#mGN}$$ zpGW9&gI7LLzr@ryq(BVtb}#$nuiE*?}WuF8sW^fJm!!;XVx+H)w3KOX*c! zvlBOwFsfbo2z*ko3C_m*Hq%tq0-X9;1g`Btun(5?L>zL<<2toa537gFqC{z{{B@_< ziX-#x&+H9p8yNPA+jtm3Rxk2o7?3wo`G|(rX?bGk#9O1c`W&sh96A!_J_(6Dd3NDN zQjliQ`KtE0>ZHZ+Z=(-^^p(UUv>HE(aoMrwiui~xw(cS@Dv}0+w2Y@QyTGHK!|J&2 zL)&8vvdj;u+|NlP1L!pOzyCOt7-|JH=?a~$gzhTH0d1n#_$4NF{Q+Gcv$*z!*6hso zC6{x)(02Io%uhd82z$0G*$~|zgv~PgUwHJ9yGqu$P&fDM)ViiM6iEVHB*3V;FPWGh zX2s4DpfPxr72Vg{B`f%!SJC~+9SSQQQiu4Os%?f{!Jd^g9S)gSB|{zLXvjdIlE13} zY&p2RK`!naXfOE1R3WgRC?H|HkZ;sOy$+U86)Ft*5 zJqjC}W`7Jc1n0qFyoh;rJZpF$oNpa(6duX$r~gDwyRhpG*jfJ+*qJjJNQOB|pbMEc z_GwfKs8ETe0{@x&<*B#{ZJzy(j%M0|cDe23&pWNBj|L~Wuz9hzd%z(7qBQ8!B>u!v z>|Kh9jD*+I*<`lncxyFc>@fYe`}8Md2Qn?2di;t+jLtwLt^;rQ?d=K&ee zKaB#Ll=D7Hhr~CX1dx;CAzneSv8g**#cN8Sb7Ug$VmaLuj1J>dgOL*$0EPV_FD{?Z z8qehF+k1|vtA6y3>ZW5yLTRtPLzf~xoE7sD_(5JqkifT`4h$cE>><$hA_WWLX?d$Z zvsK@oRK8ucIdx!up>qXW?7)H{Zw>WI8fM2Ou+dn}4rOt#9YGuMOxrUKt!z$34hQ`R z%zb+%zEYbob(9NpfxJAqsvk@I!$l|x=V6Nsf^UNE>F z_IF?{uw3YxQ!|T4?#1Fljz@|CAXQPW#;AD&a|I9Q+$#M%i24+82ir6Rud8ye?aDF$OoQqKkvUU=9n$;%oE$^v_bFjw>OSeh;tKDcl>oyKLbtz z#Rt(U=j_@>!~M^NU;u#`vjRSx1l0<(C^54K(qhRsuuc$IN$BX*oe|Z>qls^HzZ-r1 zFa-NIdcNj(o^zh7yRExXA=3hDc0pz6LoLsp-9*> zlNLK^r~|Jwv83SbMrjhdu-9KJ6-6$+6Q{d}Q`>)jn@uYW-$HIgv(bAXL7bU+`WF5g(Zj^f{(c zEl-ZJmkV5(@BT*TYj0KP1#iRKU)i|2XVvS({S5%=;9)PJ$B4H}S75fAHc8~-RHqT^ zy#myv<^ma4_899Z0q#+_;dVkVUdIuw;{wN;09}!-gw0=FiBFzD<-lx0nK1MLuzG7A z%72M)ZihF%+MK0#OJ4riPR|r)MR<;fxmV!giJQapvO|l)iI8s(#oJTyvGN-;2ZnP* zcIX?W=E}|dq`j+YI{SY@Si-UAQ*O@g6}(zzg1G5K;a5OB++867uO*=mfsFDvc#Wrt z5`Ix?a$43=xW5-t!1h3wHJ3~^ZB2uwf$;zgDLO=?CV^Z?A=L-#$?|$wP+3w)wy}qm z$5%9UjPuqi;@==#+300G;Alij(#BrW^FroxaqL0Q+Tx$yz6J9!`}Wlux$thb*B$}d z9_$4}loo4`6W^+n3g&x~bW)Bv8WFwuIu4#SF!I}Nz46NB`LtU0pXi(m`&0Pj2L)|g zt;7w-62mD!aqOz_qU^`dgBnPL2`dip`b)qHpJm0mc!o{Yk&%)~lX+h!=`;agh`#p> z&OSD$UiRnTQ_EZ}g%~Ip%ZrZoJ*7Vd&zKbA{c}11e6Iz-utKvJ501p@{`Er7BsrmiZUoU7pgzNiCAlCqH2mQ z+&sXQE;y#GlC92ax!Hl0fX+X$RXN)&U67;Ch)A5oypP8RPb}$OCScp73xelFnGE>q zBAECP?h$IzjYtgblP;(v*aXe9=JDemRk$>-&!D@n9~FX}B!QNmQ~k_GygeRW&Eegb za(t9r8ts&VyBp)deny6=5v9E@_fg(g>3F*QB-R1C8jpv*dd$L4z{5M}i`ZBPopR7G zZSelJuj9knAeuXY)FESUh9Q-;-ePiN9X*FCyVlt9uq8 zrEYAb=TY^vBj_LGaPhaFaH44a@y(TY9TtR|vfC#`R_n*diX&~t7`LQd5Q(8nm1_W` zK5uRR`Vdbo>H_~2!WkVWKIzKyT2cL3OH1c=He%sO$o5t=jQzOKp`IUKmPdH9P2E%X zWOhXg@ncA&%p_SI&G#-ATbKhgg0s=q?Ll9>eU62XI_>(MIpNdJj6p=Su4MSA0__=$ z+AOkari-Zh6{vPk4WT3o%5n-<#V*v+{V_(ErRL6UioH$n0zo@yvRt{*+(eDU3RraL zfeotvFeSEDT2uvz66=__4uOq5EGse7dVpA)yvb)`{4c14(UArKNRWckpA6#?B5H|q z87x@sI~T8DIS^atN4!ezrB#GD)Vp&L zVA3#$VKg->#iuld=;w?C<})EVTd^$NU%6QXg5P^t zng)l~G?mpbpT%=!CUBCtTX8PI{L+ZT3Kt}|j^8JqaIgnqJyH3J&3eC`w>6RXnXOAa zIYhurNxaY7HfY?;n1;@NW8US*>TmF4Pf#){NWb&eg8WB5cl}hF@SKYa@gKR_%oIAi zy3PsbU&-5QfR-C_*P{5<^%hXZH)aQ$J7AqpjC)3>^ln>dkJSrO)A}PJ4ag6<9fCZI zQl^uI_}LfnvE7S8o9N-z?GbJC%oeS7JISw$3zmy4rqgC7OE)v>D6HEHA$L1KvL!(} zw<%#-X(3^>f92*+vb1WBrw4ClTpMRpagI{F$&gFn)9ley1de{hNWy3m0b3uG{A=~G zk*Cg*(NylRk$A#eLo$rN&ZXVptV|aZXMI!WgS4+CYi-dxyH8uv)N@aj*d1g*&;$>5qAm0-s9`SOrWXhjuCRr4+ z8PFavGbFnp2jf8)XAD|>8T?mPOpYI)9~H1?vkx~p{MB%2 zh^LhA$tv}j{K`!r(&b_k#O2;?ef(qCpTEs8s+sa%oGoS;v03eE!O^M^WI59@!AKUH zKlXLp^>!0P}LjBU|Y?GbaDpdWH8Er_%5801+s9q%PS zyz=L0Uyja1esR{@vEn!)W5dYXC~vaz^VepbU{>(D{bCpX04YtY=Q)=xjt&kr*seeF zhww^_D|=`-_7(3kTVnc|<{#6{xC@=|njGl>eRnU?UvbHUW}J(_ zsjphv^PzVifhnv$DQ)m|Vhc>2iFh9bG`up;0qNLYOf3$b$FtR{1|^do1V>H~Rw9mh zd33mX_5|4KLzW6g14%7Jkc^c65jQz?2j>jZlF8lW7=D!(myb8A`%~9=Z1RInXIfc& zv?*7O7RDWVW;#{S*yR1@FW24yPFa#U+rP1e?QmHrn;D~Ocz4MvZ|mgJkC4L6Nzt?z zcTitS9+KDoN*Yj}SB;)vfz)JKg|pm8H2yuaT$*x4Rb7;JgL?O^kL<9zRz~1UFLd5O z=UK%`WDdR6Skg&haHC5&nPeZu{6GKEeBp#z=h z-K{N~sY#+YF@3oBrgYCrS_9vA=@Iawm)0KR`cr_6L9O?tOy;)N`ZIb@)eq90&ScVs zUB`0V)1$QA^h>-qYxv_F2rnN@zLp8!GuLGZEnq3mz~<=rKSXz@thPjliWSd;Y3qN6 zbB|i2can{2xAnK=$u$^~Tvdfbm@S)1rbt$F%h`Ln=0W^y%gUOyQm6Poix3nWeyj<&b`aX>!n@;8<| z-L?H}xihu&^WvB0Bdt~bjO#))ixFRzET#d39eX`#gUk14ZzTaTiL;Hh@69?q z9C%-3hlEuYa+7pu3H|-kpPQ1%zoPpqT{xEt#ZI@~?iaZW=4?Zk{$Vi~>9P144+Tm{ z^2v*Sv9#f@ZqefcZsYD~Y+}9#q2hhKj!}HZHHp0tFcnKCD+Yl@cid?f1{M-2(I0`; z*M5-G;a7{CI!qT%d>lGiSu$)QWe8H|)ATe+)6~}R*G(V7OiU#DvmA7u7xGfDN=)BN zZBrl%`+v=(k`0zIff@8lOHW&5B{TNoc5pIIev*Kx$MfJZjw=se1Nva1#7SJZzkJ6d ze@F!b|L*0sB-yl;{VUsb2m1c%><*7KA&nACDqsxXwyq?!W~_QeeYw3905k+vjSlc39(2#+w!NOfVbjBh%_pkjkj+C4l4# zPOYT1o=JDC@gxWY~+BeC^NANQ|(0pS8t7p_^3XlH62f;*1nW18S5 zYPJxg6M|)dA+>Kz#G?1SFPSYrEc|Te7Lcv}eO~`o8Tr2^-Qj|SCwN^{@AIJGBR0oJ zavbMF2Ej^*r@lXm{*xC|Pvbfy3^Rb$2U$G>bN*mK)txJX`Vm3LmGuDjB>gBDfIH;b zx@#3utLj$X=I_*7T6X*EtbQEt0|`um8QUGCf9f_1sYgXE|60W8KX%`xva@z|RidZ+ z1%C=xOJ5~~8OIvCa|KZUMKE|JvH? zO9AsY9wur7U~HT{z|plR*=HE0batBOXU`O$CCTN@G(E2uu>Qb@gNYh_C(I4?ih8bGUKC2AngcV>dIMd zJ6!U=-u}OwzTZ9n=hE3TER?h+D@o9|QW`8uNhd3aDU9j;_jf4i(s^@FD9w@>K?W~T zR1u&y8|Zdkkw(gCXS#%t%$ z*G`D;EH_qE-dONF@qdt1H^lgazhbAmh%Bz}6u(>{Y7N4Ft#Hhy)Jib;bude*hkp_i zZ{c66F}72E7BPQ#C-GNMmkJ63a{k3mLARpst{s5*_ixevQb_;aJ^rr&fdBYG`40n&D4Fi=z#Ee@uy}o8B&H2F| z@kP80;B*f9dUZ;vrx`p*Du!8YgBiT^Es_Eb9c3cuQD6adoz_o}JKdRb<6MH#FP(i7HHS)h`k0@8#jD;e>T?b9DT5k?1C??Yjb37c;~p398CO}q2w@3Lc5;b z8D0_(L*?99dS7?8^W{p2b;uG}Kh@m{(%(QyhyZH7lq+l)quTY2_{9qKmfzTYmf<}= zF79OC*Q;pVn^(Ic?1Tpbb*q5>f(|hA1mBLyOb34?jt|dKfy}PV zz8%?Hc*7^fcZ8gsiMR9P%@14+k3q@EcTuUOtis2& zVDXDrX9HMjppxl%mBs7GahlW_q=E4E&}T*}RujZJud1@wmcbW7cP$v2AFvLe&JK@K z+GtiVnur?&-<6qm2owPTsQMpP5PbeW8Ir*;v{=Yygmz*dOr)bx7>71Dvg*2=1 zn=Z*;l3!FQyWewTyN=Pfd&9l;ejZKR+a@S7;U4e^O_PWxap;)Wezkcb(WhS z$g!|c`d&^Opt}YdKA6%5%iP*xxj=!dG=>UiFml3UwxrI^N|-PEYlg}Tdbio>B}KnSOVR zOhU}VZ=tdj8qX?PPCTDkh|#_+EPydEUDnZOx%XmJQPf|BOW}7=Tv9na{d){iJ2BoO z)po<#sv7=x1nb)J3k9R>a4E+drujRE?gBmLgu!x6GsANEFXh(lOXk}#mQvc)f-!+r zC-Z6;$|t==k#O&GQ1R*uu~UtDzW9w(na$~LMsM&t188z)%4qEo{nb84;OIYZMGc$u z7iyDl2>J)K(ZN?+mcO28j~J@9g(}2E%+C9VygIk@@Bxr<%H7^MVQ9iduzo|;TomKeVz)MdI~KeW$c zIo&+;xworeNUzgb%9>rbQ9d`8SQ`%%lwR-36;m2}J|kt``eFu$iqq(Pyb^dy(DJ{o z|7{7>)T?&(^({Zut$(P9*JJGl_D$_`X4yxcYE1AQ1LNkI=MRTT`Fm@19znIJ zb}E{OT7~9k0nh)QDWo$lOg-emJ)4>9Bl#nhAzY?}9} zK^0>nlh8ieA4lABW_0E06O5pXN}-lgoE3aoJ?l4tH2rp+R`0>y&TNLF{4HxvYJO$i zXg#6x;+{D{ualo2C7nG@$IjhLxH3%HdfZSy zKUuNl+ZANqYOfsoZ8axS!n2~K)#A`G+J$rXXqJ$kNsT;Dr{KZXUGc|xeV?Pf5NfX5 zH|DFF@NZh637db;D=~wHZ!Dc0OEBNUAEI0YH(!cVWAQ2Q!68skIHe6se;(YYYg^#$ zF2Zsg?-wzYpRu6|V*_5)v*xnT*_|Shuj5SOZRhI_1bwZ`E_XMNuUlSGK4EYt+Xu)V zQX#3`_ZxOMUw)Ud*RJBr5O-FAm^bt2_xK}Tl8zr^$z-VAsf8`hE;tC#S>}f0*K;Bj zHwG1qpfQXR1+~zUCB6Aywf%?UWwrNl3++x(n>2hskLH~)$i5}XN@hC%!B^QiZ`brRo)o)HzFr3q;j&|&JQIQRrn2BeD{+|lDVmYbnYZ^mcY$N zbIyAy^no5~#uWqNY8qw?#J`Rq-7kdQf%%6DV(Wbdxe4Kt$hUr*FO0Cku_j6A`!5WX zG~AAG8;Lk4i@p6~>_fcz>p`!GAE5(#`!Rwbk@%(6|ccY36=ql9f?mb zcE8^Peywq1nJ1r$mU7ON&{0Q5J>hKAtF> zJ@aHWG6VX0SD}Q>7kedJ@uVo46*aOBGu&VB2{N6uTqyKs7@<^ z{S7+5Q*MNQp5!x^zdX~Z(c2w&(EZ%t9^*w7wTX8@17!l`N+^jN$kvl6&!B=yI6oVp zX^l=an?C8&#Y+F?nIZl|wKm0{P*Kg(PtFMZ{9UNqt)FWpag3rX{F}*@FEH`)}N2CZgw9rI7 z5oa0q3n6Q}hkpF)rMr!SFG8(Y@RPf?JJ0Uk2z#^jO{;6rKxkodv2t}AEwlE1%kTu% zjL~^lxS#I-C?e@!^9e!1_j9G~$$|;JI&`jnm+6MFF9BhcsdIOmXOCj_R_NNn%}}(f z;l?O4g$7uFKT(ac<%mY z&zeHa?XDc`yYp?qGFi()zC+9Tjdf3KLB$LYx#oGX@5(c_82Pls1@OBsB=~P7F&7J} zH+ff+Xqh z&VJK8PX#2kSS#IRt;I6@;@>YQ>X7s&Nt%FPBU{YKOrbI4*NtY4_2Z3N(`sm1D*aJ& z!nl{rbl>k6d_MBF@+9HbH6TP(c?)0n%B@$}i0&#&H1k7Vek`ZB(bFQSD0jT%(NRy^rcR?&mRZqPVZK_@A%}i z5MI8#X07^{&NN&Zu4v7WIc?9HkG9h6_5NV!=$!Cv!sYyg$j8{uJ9%xrKZ)0z$MOt% zK`eNm1bz$j&eFBz`8>AHE#yqw*h*mE1k?PvVpUMAFVbw-WQtq7ww&e-S~$vLRER~C*~&O zL(Y5QJNtn_4dzNWQEp}Hqn19w0~oAEJ2M=2I1ZTM;9nSzdeS4-Sg2o95>Te#tO?!mk- zFKQxvrlfUV&NF7IF9QZijjT9M11+*5<%W!RD`NvEEapIY?h z2tZktfE<_kLa2UuTdULTj4$bV%f^L;*Q?u1SxC{Aq4_y%Mgo7ghaIuzqAY0C_=@IB zI&V4k4tPj(+e&&q4*$C6$n}uHI_3Fn?^XYrfp_s0oS%*jO%(lu(jP<%;Ho~rW?zQ+ zG&bX1XL<`7}kM{CwJDf{Bwlrc-<$xIbJNH^(#XjWvY2%|)Vwj7LgPGJ$@3qXK91K#t?+90SJ@V<;wR422pMk^}VLT{p7yLj^ZAP zun^BY{q(JwY|bLd&&NY3Af5ND^@qd{j9#Gy(MJDd7ym}pPHz*sfkr3u$PnD4$GYM4 z3xww6%=t>x@}*Y^rJ=;2ww2-onAFBnS=VOGb(mg&ZqTm~L-li6AVAw2*~g#iEDjoW zUPA>HEq+qqqdIBr2C+&N<+M2i<&? zia_>xn$2>C0$R>)35wb>f4rI9O1ZJLxY7Dz7H6@Xy*il#10A>U=!7oDnA{7moMt=I zeKe&`&*9TFn!or8HN*7^MB&uvt87zn7B|}kj8md6S3)@}C2z>t+A`d-E2mQ=eM^1T zYQn+X@aYWf#<`Uf^GOOyQJKdSHpVh^0HdoLr#P=NV7jo|OHl8(7k4KHJ|Euj^+ze4 z+SpJaS#JCpgI4gg*?VnU!S~(Cl<6l5{--uz%17=SD9<*G<}b_6VU;`HiKWM#_q`y; zTqb1jabj<_&=9TJcb47ry zQIPxq#i$x~6UEbCw z(tN{DkMD-kIi;&hNC(8LQ8Q1?x78OlOK7<>uM}`s!$)_I!<|rBiW^SFkSLJM=^Rr| z|FU25;@7q^(nM=}oJZ*ktiz=9s*Dpcl@%jWIa^MQ%3qSVy!JCBhMXe*^ zrHhG@Az#kP$*wdDXri`v_%|K_y5|b?f07JeDUyI~qwaZ2~JZ_(9pF-DE{yxe7R$nyY?&a zZwLUug}KqyBsUwX7bFckRCTt~Bq_tyd>MajY*BOFBZEAUL$lmVO>(vh_kOcQ+JAZ_ zw`(O$l80S&qa$(WePNvoKy4{6Cso2YXTqN+w4igtH2grd*6bQ96LR~iZcUpY6{#LU zK6IZ*{2eiAS2{oI(^c^%^%NsBVIfh2m@{zCkH~zs43qr2)gs(q#DQrT0wLjOwpaoG zwxzpTc?RkYU1kL-tjOy{~VHdbSMb* zc3hnka*5iFB#h8P$O$8Fa^aa-w9e~PknBGm0H#L-1Usi2;S>{b?Ku7r$d}gF#Ji&? zLBV$76V?l{q3Ddg&rma!3i^7BSS0@x;qAn5A5m#In&%vFn?HQM7s**uemQ$O%6@oF z%I+vokSxd|1eQJ-+Df(>vXfDaap(;ZxTyuK#_iveIp|7A%HcMxx`f5-Im2e3cM z!Z(1#m%FJ4L1yqMnX1+8AX2m4jqPv`?S+i_gQXvW42QZZ*@DbfGeQ3ffAHy>R=w`4 z>g~KkY^0&$M9!@-$NDL|;i2vFLRId5V051#@tmEhUnBcb=4m+V@5iH0H7?npCXA+) z4qQXoon3_PFJW=>*ml+N=q}$uu%FKu=Q&9iXiJOn0oC~eFUFTQqHRkOJF`fVw2QPr zjX1_{GZHoC?{2$WE%!Xu30itFPK2v$8e%6oUbahvg1nS*w@l7qOL*3xwi9XkEPUd* z#^Jl!Iu2cv8E-)!d{x|u(B z*jfi2@#QTcI0%Io2qzaJYGi+|D0&b)zeX7TB0tXNv{ok!1-2VL(*P}70?u-;-P+yp zNtnP7=-IaVAXZ==!3}m13ShJN)yMY=7Spyr*dp8+algj4J1A)=;#L<#ZE-ll!<6LF znmJ>4WN5_ws45Tw?*CrnoN@obAB=6}mN)hFyEn8v_5lGWvL1qJ9-^OaaIVu;$C<=d zmfxp_v*py8d;B@cz09FJ3-4S%n?B)Q*auV6mG2x0%E)^ID!WWdD{1>or=o}~ZQOa- zZ)k^b=G>s9x18yG2$GJ~`o0;{@0EonOHUZJuU|u%DaH7sus1F@Qqtoze19q61{b)C z6sKKKXpX|*Aq+me@9=xb?emeTMrz~j)#B! zBj5jF%XU}I*FP@({p+_CrN3%sp2=%{;Njx&hrPS?GtbHWhq!;$-IUIHx}W<_ErZcI zuSN)*U&hfK$ay;(>)Vgg^#+U9HON?10gv0D0DMuY;=C%J~qkOVAsoE8z&8PurW3NbT6;KVD*v_^OEnP?%4{ z|CxuXniCSF)3jaTuqe3Kr8JR0)(K#~pTse(MGHl=0;C0smuudRs*>v7hV)_l1fY?J zJiGD5-gD#IXy1`VD}i1I-yMyPkzxn82Iy&&k$_onKz@i{^Rca2OIcAuI>mTu;(p9umS_@#KZ+yE-4nckM_gg~m0Hse1)il$070(ZrAJqBE z1-4u?5im=f_>|i*7;Vi1bxGI$K{ca9;AiM}veXZn0Y)!xzJwZ}H=w&~`Ti{E-gM`X zHZ&5t?Vt0Ay8!HsbkXqtdn7r#e@Og41N^rj;=<|>4=6I~6(Jv@6!WZ2N zCdme#?`+TVqqn^B8Y^<2$eZPon%SUPcvfzw(pvFUT&7(1k_X>8NK~6LnQ1dCAL)P7 z>iyftPHJeo1<80lif~d7J_kNM>vQV*?G#PoPU}$*h~-?34{E1O3zIEy&#VaeZk&nl zqs8=LIdyhh+6XpI#0BgEG<{GnTo8Ds6+Bv52M_m z1|Z4=Xus-2oL|$^#qX&Z#e-lErlrzo%`Sm_^8CPFV*(H#7w8p)kE~_0LniCIaV0`U zze2AMO@UM^Em69=h^!o1OAEaNxySk!-_FgUE+boD{Ml zUae>q0X+wJzYN;wA%=>JMF{VysD7G@=a_Df<|@+{mSIe$89& z-w~##xG}V!1Cd!Vu7HQz>Jn5}u2V4i<`;2w4re%iJc)?Cg!6zHSn=r0PBxhrXDXCE)Kjo* z%NiB=LH*II`!h4t@ga82yO{!oGCl{D;pR@`a#CzMS=3s#NCuW;08KCy3B+fdEnwew z58eD!1+_H2Kl+##`p5t1sQ=zH2zs>0jqb~^4-XAuM+MJX3RXj`?m1Dkak4ZMZfFV2V@`FCQ}w19{E1Pk<*;Fq0QA@oQgUzfV4b79IqU6NNvzw6g%J)dUg5f=wvD49)fP$2 zmQ6mg6(3%cvm^2a(rWmJAwf@Ql`5k>UWk0v^|zO~gN=dq@^td5@xT%;FUs)<*eN}V zTHrUdSg=nPe$W6u(tG8enjYRe(c(<$r9gCf93DSwLmiXbWt}1m@j3097WkQKl!s7r z-6P)AwNerxkYI@LZJzy>QSE-W>O=(hVxSU^LRpO-=%Wo!Cdw1s=~uCWis>bKF-`}W z?{D(OCcS8t0k>p5hl^x1RLmUa(S6H%sblpOEe+HphOL(&G69Mw(B)Dk!w#&>CRXaK=+7kU!=aZi>H_U;kG$wx z(H*jdjRmT8@2QMN8p#S_|9Oc8LN9)(liayyxICq&8G0a{@?z}!me1m`+x4XrVHyF8 zH--d3n^W(&XLCw#*eKMmXm~H)KrhX6wZAbbh{$m(?!nDkxi|<5;eUY!8;SwqZ=Ur# zs2)oP!c26IUEYO=;VPYRHJED==4mNA|7dHwkOl+Ej9t7)9#@i~R@c%0+S5#(53T9A zn4XmFP7s_j)B@2mEoZYj1FqB4$O^)!2;os@>+sEc30y#vSMt7}UAeo9*=3XGTKZFU zx9qrkZywSfZqvbcFsHr-t_M5Ov8|Uu?P(1{y3(EuhlYm9iH~uu(w_7Cvp}d=o?(jD z{Mr^=kJZJ*(rm_%xWO5RHpP5F>?TU!q!O{A0Osf*=>+wF?i4F-q0L?Pk zo4%PwqiyiSGBdzM88uhIMonV;c6WbkHUkaqP@)Pnl4yQ}-#d5qn~>o(LlDfMO)mmG zU+=KYnjd^YI$DQ^w}!&O<|YGZT02pEW7bZC(2}#uI4PvHT@u_Wnh(UYi4)D_BrAcE zOc$pzf0j5-t3bqt#iV_{g@b^QGCJn&>E&OYhaNPFs05!|JR+!|?hKhWSB%X4N71zp z7HU? z?WySC=}y`LPIkD)k*-Ewu_BGEM)2642TAIhAYwM|`FN9%n%y-H`F4|!9?;VxW#LN9 z_t8swxK=9?iQvJd20A@W0b{R2?gia@ruYm;v|1@HPWBH?QrP&l#!rGAJsXPitXdC^ zS;r+^8=I8{AK6&LolNcnz!Bsl`nTW+m%#OCMHd@Zi}TMso#5f4r?*7;G`JJzuajM* zwiOv8uV~ToBWD+``x^(fd3A6BLkSMnJ-&@+r_Gu}n{BM%b{@By!uDqYrDsix*##M) zXiDAAH(EoN$f+PZI&C`s0MMkr(@0z78NuFSJ)qO^61=ugLH8k0QYEQWeg42Q5DDnI6 zt=xvc?s;586sGC7A%=9(Vb{Tb9y5P${(JewP7*D{u$X6vXU~;u>W)APwmLcrI|ZL> z`u3xvT4*r6oo9sfI%MW=FRoK!KgJubBHLJ&V6&HU$VrwqMU}t0`t7-H=wXTt$o?Tg z^i#|d@6($RBwA6Zt)SeKJ(tl{Q?#HFUw4z9PfLwnAQh;V>{QdJEfRd7UWC}%^@?b* zbFbXBMjDb#im~A@J@LcC{6FIIyDIn{46PW(VGEEO@H*L6kZP3^=eksyVS(eAH&lf9 z(^nLWQI7NxS^}8`&I-+_$!+E;`3yg6-IK5Bk*0{XYpCC$HC#RnJ-Y=xGc6EN&?ENa zXDzXfBLQGD5IhUHJ>Ii2WQ24tdxJJl-e+wAYO>NB&v0tj)I@8p2L%O`|A`?rTHpc_W)t(AZ6DmT`jg6|=b)`F7{7ag*8r)T&+0;?) zqix${;u&4BF^}n!Tv92}d?$(O%gu&G+^#zm1--Ovm=>pYXXvmu7wF8FA68#iCcd6+ zbH{mFmUt(7FAfE>ALW#Bmkdw)mpFOtnQy}^-b)o>NcwvrU;d?==N40Dt*P~2udEb0 zm;GT6QPJdYk*ucYYy@2#q|4LDLw#Iebf6?&~xn3-R*|xrQh^6>yB-HVd8smnNHz-ioTlGtb6pz7}?LzfTh;^ zvzmfs@FLC{Ss@SU3glWcRjKpDPC88^+X}+@a=cuZ+5`VOnW`X zMWAs`Tm(EwwYfX1LpPzHrCPT8A!PNhF_iy3heLSQHuM?J)W@H7KTU>Iq#E#^{mc?o z`z93{$W?~hY{q{iik0W*lO}9`OB!mFQ~D9gLAQP07jGAnt0WG!GUG+Ep!@&N;h91Z zq{-u3eRi3D&=&B4dia9?IwQ=DPN6l+SHpZNQB+W5@M1 z+~v-r8`#U;yN*+{R4ULkZ>X9OfB{mYf09e8!nbONpWs~lPM;D03R@U9SS8QV(4OIC z2A(wJq_ViLF+K9R@+GdhSsRk=IPyjKN#KN5p$Rs$ZS!$Hl)$F*CW3327Z@PLE_or1dJ$pHWj5X)Exa=cBT*w-(RT7&o&}gF}B7zK&H$PlI)O zJ!*3N{J>e}EQl%sM82%LRv~o%hLD zE5umM?j+xd(q;}VCOGdnJ=fS|5c>OHGyKyvZf{HMt>zXw5{}?z-RK+-Tz%>sXi7iSP0gp?YOII8V3 zR%*|DEj+So*?jopp!5Tx*09{h124(r`{Xk7t{IJ%_fr$K@|SHI5VD6s9p%azfBpJd zr>G^Oq&we4qisnIhlfQDVr$@9ksmr+FR#8RJFLD)QQ>>B#j3=Y~E%*pns<2hWgJA$#eI9Jg7Y}748ha+tVU* zr|Y0LK^zzdEt%~}uDJnFCpT8RgetKg(U-^yp&QKZViEgspV$adNH3M{f7UAFniOMA zveY2fnFcKcXP$VdWK!g3n_)9vTepIN?{%{+W1T^Zte4SFx(h<89w^LXsqWv?wyqcd zPjG`fv9G14nVjN&3Z#fpEQml(H@~KJ;K3;5P|b2ZO^3W<$q+7(0m*e6@-l%3U(>Bv zC~|i75aKTVQ}ohvvZDZlC+Atp7E>xy1AvS3 zD&%I*%G#Sj*Fmr-D?b8;Mi+jfaRaWg!d<29H~+;6brogSN6z+Pqn$qeMd|%MNJSD{ zgmOO9SIZ&;A3P~LVke(;Ej{T7=#+1k!S6p3fn3yq&L?NOJFu}%pHfvw6ZQ3>pqmk_ zBVdMJ(s*0Pj8gQpMBphya+V13k^<+lr**ERI-Lrvg~RqY56H%yJ7hkKg?#Zein zaZi?dK^O&wD?!S;hLW!7rR6E?&ypRfIqI|W*+~Rp7lHz3B35?3&Hw;4q&Lx_i^WI+ zZEpHkv*u6OlCdqu60YQ4@~QbOHNp-ix-Glb3p0D zdzuG%0lzXy^EeW7#*y zA72l-L0nKc46Hx;t=Vx|VC*g@8ZQbz$m$-$zZqy6$Jy9W9W&}avSC)HICf=S8zq6K zRBi8d;Q|p04OC3EmLuy6=o@?mhz|7n8CW;#PjXLDb$XS5Tx1iYI9%xdru zOO2pK`iKs1A$`Gv2W+b#jXv6SQuQRF#IO3rq^4~1*T)K=(*x$1vTCPgV%6XUR)tsx zP)W8(43~zA;q{{&D>~Jr@!IBNB}%kmH>ugHSL{xkJw^q#64%LU~L5-~9Rkz_5XwEv189^|f7P2Uf718o=hW~bkSrrS5%nl31eA`y_G z`avb%4IE(9&kr;+6@t&5SF;3TmNy-=oMWs}lvM&PYr7@#Cbn8l7LL~pE&K+!T6Kfb zD#(I8i?u{quzsf(oFAxi*weWL5N96e?kzf`9ZN*CHa8SiE7>qai|Xj-z#t3N+G%vN zCp()j@Nq^7qDonaoBTHrl8i8S=dXUIP|u|t zs7q|MA&syPUw6Cp3@>iOF=zP%F`^e%99RML0b1y~I&f-Tg1mA~igvYQo)3QvOZxn` zD@UcmEv5%4TpaP*ZR8N(`hGtc9y1wq5&Dja%$nVZRC+-u&aA!98MJb#_9VZfsE(Dc z%?ebpUSeSiM_+Ifo@O=eHs-l)P1kq(+2#l;FU#s*dkO$QY5@!#!t8THuWfYm0vC;d zb}8!ccOF47)Kd~--2C$Oc|QC(c2Y4Z;G67J*~e?F-%6XsI%M}?|1ld- zzwA4ziHeQg2W%cXcT!Eok@Ynfh4O8#cX!xsi|OGF#M9)hZ3Uwy2KaPF1;1yLjjhd& z$Vtyy6UIOKD-|u5PT9L^jV@gt&y54n&-=a68Dq7R>k*CFZe>YJXYZfhWJX1!Q2xz_ zzssF;A%Bx}$^-%MPS&Gsg*IjtnN~tKT;jU5n>bfiZQurqLQdS8!DlV9@ z6Hr;lq9m!M%Ho`d#j#Hq)>^$`qRP252ly-moJI#?V;R;i^7cWYEBZ^z$PE|W{2(c; zMMGUtPqP|qW?gIU2j*z*_Ur%N6ks>{g0UfDlnzDMm(yf=`qS2h#m{sbR_H3dy7S z(o@l)?9`UcQKIrp9qnd^%pK!!3!Quf)pwJc8)DMTokwZiCpF{F=OX5$>8>`=&(034 z)Ht}Z?kc_O*GfWeb*hYr(sroUg`uWLHM9i-dqdG|dm?jSdEWi!j*-v%9(waO@ZKY% ze7_GSi3;a@ZeYBf(Go|wj6aCK%%HqMC5c=yNeNv>N(Vbf+)uyC7<)3(n73*@iiozD zvF`<64?({VsLz_H-LP^O4CqbX7oXvid5paVPFtk;<$Gp;lFxSFTVhMz!3F1h&N3?zqmMqP0$(1k}wLYd;R7vFRbwqayNHDlk#0gW!=Ga=uwgo_L~nYr?LU?8V4Zk$s`i+vJ4BdW@lUgZfCSuZwjmD*_uOLV9jQrdap zvoidR(J%`vxomFMDG*T|L#P*#THi!mHsJ)0M_TdvPUR5$L@2u0Aw0B-6T>HZ@UF(i zVu$`6n=+JA3DH7b3vvJZ`h#Q6E|gI^hm=$%Y?sX>6tb}6%iSNJ4ZdZ2ER$~cvlnmz z>7^N4k4Elug7_9h#{8m}sh1g8D!r$xj_k>yEQ8a(2d5A9XGhd5pzH`H^o&mS3&IfL z)CQ>CZQylbBk8T_wexFLhJ`tiCyhx(({zAEiNP^X;D z!f7qj2*nM>I-Ta#_valJIZ4K?Y&RWvLQoB=V+3VKKLH!9XV<)b)}{Id&Y>|-E;_Pw z9be9_a`l=YA2l6Y!%04Z3xtJuv*ty}aLyJ}wn($V?cmB2f^u=Bz(LaJcMd(wM14 zVmlAY2{N|%&Rb}Lk>6QdG}fVk?L7Lu=XZ!p%Q){GD$`nFgc?8L73!}{7b}fBlWQP* z6d=m`*%oIgF!-{B>L$y9&c?-Bl4^44!z3l9DSR#*HGGI^8pdHZMT%tgQ0@`OnUm+q zU>FV$a#+!A&b~96rtoF4%{@RdA~)WnI!OA&CXL?~Eo=}(s85inXO{$mSnz8D;rzw! zLGSBh!t*s%TQ{SmegW36^3I79b?8{w#daKya7Zhp>W z7i-nI;+Mk7o>5j`ufOI6lY+CxNwY%T5i^H4&YQc~(m@f5cuy;1Boe+OIwGz$5%2!{E|RcLa>k@ zs{@*8eta(?!*A=3lKhfmkD|Bh^FL}SH{^u$ANH~n?*b%! z&m8+M{>^(NLSbuV{L3izk3+l3LPOuNv6- z#?}GhcY2yW6BA3>sa22VFV`V2;ncc^mT!%F!~_$@M%U~tcr^f4SFj*DV*d0;?pBS; zrBK1MqY>4tD;uoSV8}b<7~0PisH+-O+H+#>2soLAFGnr)z`8q5%-kc+y+3NyL%62y z3}NRcG2snh1Mi@|TVL+>%E|SPr#^stf=Z=N@(kIDFt&-kQ0%YMjP^SR~B4p-W zd9o1qx0@|E!KN!*3%>)03qONYHZ5Ym{>WC;@{czV_zO%^H8loU1$}P;vo(}Qh-Nd+ zx@VB`rj4@5+>V4PY;(yW5Z z?}tkzL1&x(3-|(ruFaH@U|PaXWT1D_KhurEsbEz+SSwE-?v>w^1#4-#o2U7*uV|t^ z)bYnZNvz)ogf3|Et?R99WKIs z`%KX6l^Z+(0R4f4IAyS^Dl-KU1J&vR$}?s`Ei$nhfhm7BK~WU&Iu%qIGAI)pK6~}Z zV>@s`;I-Id80_D9l1!B$9vgZNIe1`A$5!nrmoC;U9&clI#OFtyVUu5d<4ysX!zu`& z{q6PG_eWLYP?0Du0vQtw$2Hct9aLYG_z^QA20771@g?~(!?!upV1Nf})et1G@CRql ztp%FeLfnE%Xx-#d#bRb8?G#_bZ}i866|d5B!64l?8hYNL;sYX{-2jV z?uDAbtuWss$rkvu?t2I(Xu&PQA3Y1!!@U4=M4uDh@&6z|=Oh?Vm+57{3#_b_;kqOV zIqO5A3|yx9xT`L)UnzopOGn`OlB1JG!OlWl@lgPbv$$yF@5Bo&`BnDK2+NNM7qD+1 z3VIg7Y)IGpc@!bk);9F0=*S5N(pN;Dj1v3zI!ML zEH#)q2v&G*QeM##_JVM{?|SD(hM;_>96r)>B=gDibtJ1`JmzqXb=GZ zBboYtU1``BXOzgeXNP-l(nJbeu1(5Aqks8!{GGu)e87gUE>qU4#3kBpNjRxlu|>IW}sd;i1n1OF8J7X4G~YyVHN zZ{50M#>E$DMt7XW`$sEE@$F zrKANJA<%$-q8v%(9nxyp1tt& zJ?Zn>3>mC}5D&=Xpxp7C2Zacfga1Ui4h?M~&kJpvT(LHuah$uD@$eokm9`5OUZBnd zfG@uSIWa}JW-NbWXj!84AsXv|-w;L-4Pe$xXR+b^qen|}zcB$=!g$zpT z*EUW4>bGarc*T*rm=()vq#@>6Pjw2!r=WRv#VnLZ=x;M;M$<p~Fj-B7z*Uh>6?yKO|?2TnWslUSgGk_k60zBj?sZ)b$3!=tr9VvcU zkK8eWZ)=Zdk;rBm(6mk5j|?!v=M#zE0~MGlVLQ?5+ponOQvDW>p59x)L2xs!S=g>Q z!*_@;`R)pBwF$m5bL!Pmps4~?)YT5sqUe^TxT$_S z0X}Nnyvd_$NB)&KS+|(twdxCxC)6r-Cp>~x1$^bxBQ5TU*DnU8} zO3eU??`idWAD;lgwI1-uO4Fg!)ArQ`Yp%fSKdX4VuUvqw7_Yd>1EZ9p3{>pz0ULh> z5aYtcm$$)ko5dWXKlTGJrl0FaB-1tPo=<1Uv%qFsWoW$8OMWH+z8GeV1i}>)ju}hr zbGf^05)dSB3??~kHGfQ5nXdm5n)yHL%KvC({u_wr|ISeUzqo~gnQ`D0Wk9U;g35)q zNlbeD)N6fygEbDuF<~lBUo&yaJJ9Pqbiz%Mj)`|nyQV*j>2>F&z&`sbL9L}psbau* z+|;Jnv#y++xF6uUGCdT1wVQz1C5YvTBY(%R;(YW~f;Ww8)!D`gYtO{CD})GppO3lX zOiWjP?+pjlkbTr%AsgUD)L3}^ZQsmTqADbk03bd4)1%bNit>oTF?%kkp|>=yLi5d9 zxe6gi<{v}-x>`)-a+_hCkLjTk2r-qrnbE1}J@*6HdR1Z0-7P$yv6@eG#7sR7^d6u3 zXIz5f%7Ic#>o_0bwJ~B`yzF0$@Tw5|R^w3BA_REyt#>FoV zC(w^=%o$ffJ`r%HRCVQmoQ0$WWA$v6&zA&!iuv~Ta9aLe_28LvK#snk&48!|VQ(Pq zXLetIfD=_|hsZ)u_JAhG(_98|-GzlHq+byJ?J&%q zQYYREDp%U<^x1N4HajE18%Iaqw^+s&xx;XI%WLnA>qWZkzN{bVnEg~Js-|RIvt*ax zOI3c89^tutHhHR34E1sf6VF%&XB*kxP8Z{xYt!-iqCg7^^2DGF0^Bf!3&>zhwqmdI z?1$ld9TAifJ5Z$@0}@9)^fx!8W3jGG0lp!2XXL1|Z{EdPO$J*-SDFdx3Zwok&XMdy zg69tWLw8|c46jKopN}(rD8yEW{>90;^7&x4%8N%4ZYshl^vS8}Lxk`Mk5TFwb6rw} zBftJOCIYkGLDtWVo0v_G-cT46M=t-Rs>D3g{T$XG$*PxLSRy`vs0l*tqwBQP>E*bo zlzyL2M|W?uD^2Rk%M}cYZM%S8L9ao#Y?Cr6d1@x!HT0)eaU?30^~d6z7%F9IM6C6i zEj%gko6k@W1l8vTmsT?q0wlVWNw#(zv-Pf&Ivq?{{n~n$zVpi|E(xk)aqbwuD<{5> zpQGAVk{6a{KorK_$tf?)9ozYONWalug0Uf{rSvg)(O_*`46ZMfuzo_Kbuz&s%s5ep zb4Aq$xl(`Tli7=ah{xAA)H)`R5=k=fBK6=13|3$0f@8R7s5S;Pu}~HoVKeT|+%c5pflS3RAMlQ#tOhtO#(jrMmi+NCpq6hqv0h^JdE)ELlsm( zcrj7md}Fn^-TN3UNUn#Nq-&OljKE*hx9H>SH>)F^w9F6Ny?H$(tD}NgT0a!l$pshg^bnsl&RM7d%Fq}!pbk)FvkUW z^B8a>wQ)8t{OIZD6^DbB%J!r$H1IMZ`^ zloCHNn{~10`O(1-5z8x*1LoWt*Ta9~NPkJ4E7`ER_Wq!m>r2zTF^+@~1?i)|=AA*; zGFfZBujFNbqb7<{%`)`fI+}25&UjEW*K}V6`yU1RuNJL$JeFX55J6B0>zLhuF4e~~ z4W;Gm=ke?Bennb%u>LagydgG|H)^9E{%M_jEbt5~q46-D+TSaPJFDLrk$Yt_e@H8s7>BS)x@tlpI{=*T>Kr{zat(Th#m7OCw;cz>P^1RHFy4UtVT$a zqTs_!qRc`DrkzfltKaHT30jNlqm8VkHC!Uwh!mRyK!gQtT`?$lr03`Dv3yBn;k7{u*S zv*qYvZ5zz4;cOX$o}g7~&bGN6E9(xViizirDHAzqAD06RF@bUEukLWJ1T_%K$0b|h zoeXQ0%n7^AN&{hMt}PpXtBy~rVW5a%x;dSNFRfpX@18ch0DS+wJRp`?L;jlG1zMGPzXJBlumB4y`uNyt;d? zkERJ@%%JCC3Uz)q2SiU`e_zSbs!%-;cFYN^Wza-ds2kC1*T6IY zLshDQp?oW2sdl;S}8yay7#n0`tdDIGrJN>>~wSn zN-JTCSmE7mIi4`3ggN_i>Xts+uzmUjbw!epI<+Xqc^OKYAJb}U%%HL)yt&45o@-b5A@X@G%K#Z&yh?*8KVb^l@ z%{wQqG6TH^uPqs^<#c~$vG_Z7H0Qc+Ke~Zoh^gSqm%=YE*bIg>q)9Faq*j)7jv*}G zue>mCv}0RS*JHTu-e=Uqw6kZzBWiQ+W{`u0tpZ`Wo}c?39B7gvu)og!C5DK)MACQ? z`)X94y|&$zA5+83;~TiLoc_D~#ql0$@vYfwOv&(*FffYTg7n73=5-!^WH})IWy=lI z(}}+&zd0T+bXeACEj1n%Bad}37X0NM>ax^L-K z>bPt`JfpD8J|c9VuUmC+&VKDyM1+T@PnY^{6etL5=k|aHc=Kb~Ns);qAd!33OtG$YCwHh9uO{Kzk2X zdzV5q&)3sHuE)r15~!sc!<#KVIjq?;)AuPc@rKF7iz#ns<`d}fYyD^ME`}%2QE5}j zNQFCpDOnD{qt`!B?xlhv{Wl-zy#&?cS7u?DFkcZqJ3vw*PArJt(`cWeOdEEmjbH*? z`igt}>g}YCwSuwmeofLY@k);Q#p0rdGLnO2ldl%x6yO(2zknohe;P zf#=k<7D$tsVtNb>&eQfl#@nz3mCiIt5BPK0oKx57ocChqy>NGfj)v8iFXa!qUb*J) zqhKdcLHKJn$#;IKf7xIqfzJxBuW2q3x;)jDcU>GbUyS4{(+vFpWX>*AX*G2xGcny81nv`9>^lo1!b|b9nf=4FWE3Md6rS)jGR$4Tu`>IN6N@o;}H*G-Ec}89a zDDoEC*Nez8@_Kj|144glJiL#n)ZwgO+xhL4ezzffmWkL$bI@O5*Nc0Uzg^A|1tr#A zb`HM~br&VAnEzbq`G3?a%y(--cBBsv4BIuv*u^D|96@v^<>Ndnt^UGvz})h^CeSrA z^L#sIQDPr_zT(#f#HkL$fE5mDRt)Kg(dmc%>T7%`Dl>Bm)99=C6S_FKTJ4-i1bTr< z8+$d?+FI#?QiQD^)=paljV^HQE}UOmwzEO)i)x3kK0nNS_Llx~dRFned+__4eP7bP zUyOa65HIi(%P@$Uu`g50*UY2Sm<|@szC-n2?-)K$`~KL!R_fb!&d%#Kd3{Z%itf53 zM|me+@$Dodw#bZ%JB_>|6+4@|Apt|mh9V+KE}~@5XgniLNHk)T6v_4pnK_BR*hL4a zd1fNO5Z%TyZif+9_>t_Ec%{=eU-B1%>_~V1+Pt@OdPvo^VC3poV!U9ar!FO-_Ibxz!T{P;!)(jRaQLwwyeo^;(Fpt#K}`p?m%+l{S24j zz5IdUT4B6E3d1nK*T8H|T;e>x-C4v170EV~amwkbHi_1cuOwF78dC#|!sOZnEp*rW zWT?j5oDj2i&TzkZ%ww!Uxr>1rn<3Hq&eKBXG3VVy=M`Rw3L?k7ojECKE~D1yb|UDr zb3X*3Ku7CKbzjFBE+Fx5LonR+UkFD1SA4YpNBT-X1lKrm48;*K}wg;%1+#pY&HMNjWp7i=Ja z7PZSjfX}jcObp6Vo-CBOimHd$tbwOWt@&nD`wlT~OldkCNmzuN5X<&x9{1=jMk8Z- zN+OgaLGXr`W9Y1q;dE%KV^9dlb-mhp04{0~jBVc;x45?#N0Ad}7_WU36E#X1 z4hwBJn#CHf<%;FKMf{X?-5Rs|5Tn((bCgE7SgYJ78F#k&aj|l!2KQ#Fqjiy z(tbzv$pLEUFkPeo9>TOOSS6X2$$D;mPJCj{<5hSeE?B9&}>h+6q3%rN2V>K_@<1)j95` z_<{R_!wNLwuWhfwM>XHhtn_~faF3?CS1<{%ZfC2>s_x?Ns!ulU2CEHfk666_Oge2r zU3dmg5MBK+Ng#F`Iv((oh*5Ld%CmyK!mk35$ng-0e6EwX#QF0J0|-3~)2iAf9;hr} zIe;I1ENbGbYaM1RB+kn(d||*3eEE?VbS#`17r|gbghci=o4B*_S1op6nB6?C zpu)FGQ==(UIr{ud>V(9pt@ysDxHx#~KG9Lz?TZcjMxb zi+>FoVFD#R1Vk*VVOuev?j0iOH-M`Mx8~C(b{Okt4&3*q!|ho_RN!x;){@gQqPO)%cW8xar%=1*v@58u64u}%tGo5wy}6t4tD1ms0G7_1#qlz7 zlEue|e|~xON0##La!lbf^C!zZc7qxTA-d7(iy=X}yt(7(je$cW4-7ridiWmsIdk2! zU@8fTq7`dGqlsf1)7cSTqNXyStHCUsij*dCnq0Fd(tP=uDT5h4IE}*@=I0IL@!h;9@nyqW$ zc?$qKe0As4!Q>KdT%p5iUj@4Z-|FPo)iCS{G<}9*<8snuLo!oV2m4#l)31jV2r6&N z*-OXi;hGo5((Vjf6DBMMz|~|+Gmip8N1(h(a$;z?$Y+ovS3X78sCoR6DTZ`yF+CeE zmS;6ka@LH>P+iEo%hF8f$OT!mwR}l_PeFWd0af_@o%Qye65ltO0+s_PE?b*kW7=wgO_HCTheO8J;dhZ z;KlI`7oLzdP_{Xp-D0u%eUZ`<6AL=L>Wndi@K_Ox9v92@7+6<`L*7`lPA1%obI~Jy zDO1db582ojUR`89_@@F*rO}+7bH3flyW;4 z+!W6~nyr3-U5HNatcQlSqw%3(nYqv+dELqd;cyR5et%^6Wsgn6Lu}`SpK_PyD;uaF zhrLZ(F!6|2{VAaLs>~5kF^+)dI1EGZEzg8m=$>-E zmA$xtsh4YD{JBVwpT>N*xiIXM-3`B>BHvb}(B5rs!6d}oqOv}_4qZ5>6_)mn`^Wf z=!}6sq}5Bd31W7gF|BtuzCK3A07WC6>>_#YN-ue)kNtV=eq>kPg>6?1Ja_TQa5Z}l%CQI!+M3W$Jevu z&y6c!9Jx%_CDQtvZ&=ychV@5;%;}y-#QTq)!{x{x1VTk|x^M5t)e>L#`9}U=Nv5@Gl9%f3;c!;;n zb~LO8w^_g^adWBk6FMdObrO3)?+i0O?FQ%}pk7%@g)~5nuZfsjNsfLXxdC~j-gq`C zF`*5fP4kHJqkIt393eSV}1MC*wBIU-Sy*X5^%#BG$MupLNuWNRLXR8Tj zDyJxP(jndp(*a?Ta0^nziqGQ@3Xxz;Ol{7&Dn97OkANWqBlcAZ-R_D>wb6B3Q-4QU zkBw`i=5M!O%8aH?4E0>a&>?5Rd@(d+*}TC{iX^SnjkSI4e_eOHwt`Uw&Wp6c1c(j^ zn`4>@b{Q~B+mIDG%2>Fd#MtyAB4qK{!-k=&Zxhb6HXZ{VhGJpPDX<$WoIPHSd;SYxF zSb9d4P~Lv6&L<_R9CtDpRf3c}z}t_ypZX6(%5j?HAO45|?^zNuA?Q>;^li*0q`fly zB>QIkKaTlR5OfGMzTIj6L^6M3@fhGEqzY8mO!z|*B*~8DU0r{5nXUd`$v*_R)KE?= zd+N^wqPYRP>oD6x%;32EAc}``#A;J}Z3U`wD}ZhE zdNilNP^6kLS0n<=3JunipR%cf!bELeT7x&{=?*s|}FWzqQNbWTqg z%RN%woLCTT z1xcr_t^_%i(iyR14X%jRO}9Vb{L$o+t;oVB=7gr%fK^lou}YIVLdq%5IEWzx$ddnP zjK;U)j>m@ay2)PE{OGFP1T9w^TrOaT%evjW-FsF`;I869|HA zM@XnFix_gcG9*8)u8tc+mu}Qv{eV-wjmV*Lx<^PuI2#ar08_Paf3S;%cm9luJ*r}; z_I#&*r-ua1U_IFJBJsmXG>x?Wl(}i)fQsmfd9`Xtny6G`2@Cd2HZH8lUudv4L_JJ$ zlh&6an&#tJ{9OWCcC&h=!yysBOaKggUKhLX_oBe*PFt_Lyxhpd9_pE~Fh#51naRHG zpak0^!M|GJDQ3Zvw2F8HN_(7MNngki?Pa0y?G;;LVIzB1(c#}|>Af`*%6o$E)xZO+ zO1uxuk7+N~`ZN)k+j(q2*1A-?y=E|&`NKKK<}8^8B0<;}cAssXZ9p-41!YOror#W| z^=a0+Sm_qza5}tnYU98z6Fl75J?@Ks+R zKp#hQ4v{zJG(MQJte*QRA+a(p!oC)q!m1;gjobHrs{(eCp31ON_L)cYe8&@_?HBaIjd#q=3{)XI%WGCo|2P1|I z>JRC-@x69-@+-<;Um#d0nDV_UPBDFJR_*j9QmjbPD-z)GrNM3@QC$Q6tVg$YUT&V# z9SK;%^$EWTa;ZNjBKyxmd8Rwoc0YJbCZyY#DuL=exrzh`WvLi1GM% z#^dV3JTcwy?HEvx5k)(PZ%-b3m%=Le2 z)8U8ZC_1`X=g%q^%b0d9zzu*%W?zM=TcV~Yh&GfW78 zrxk2YKpxF+Q;gy4mWX_r(e6(L6x`=>wPIsJ29s)+m>FNsMm zIR}Ob`GoK2-?(MGZEmTU*H7M+CW6a5kGs!Ta~>y4&|irUk{u8n-Iu4yWG5Rezz;cB zchub^nms8xPnu=VG@a1mFi4nPT_D9?p5MQWyW~)D&nJA7Ok6ktCCgJW8-pTvJSBIg zXwRC=*(M0K7XlT468VL?{apt3@S*1>j}<2$O_{Z;PTg`t&lV4j*?D-JJOi}{B%TS` zI5Qd!MTrsG924suV1TB}w#^q$AJ2a_i4NUN{D9Y2p*ReHL^#Aq{8+vNO0lijlb|gCU_Mq=}-li8l85?l>WE+r0SeR zgz<#cL%Dw2$+hDF?Wf|+8<6awjXymK^CVi60YaCtN+usmB}oHC@4dGZ)1YlbtI~=v zvkgr&vyq@LkfV+*zdd~N&ZRfq75EhglvBybET8C#B7?~nNBA>RA->@Lj>GH$(pG`8 zvSL%P%b~ol{6O5I({j5X!Ner-h9czjmg^Na^h_~bch11Z(1E$+4%>xp5#zPqWUZhy zrY~72#`^K->DbR_3lcqvT_(}1UJ-sj2EKV@sd@J&Ff1C(a+vsuf%pQxCw! z3(KD)-%PtB>TZ~R9Jsynaw*4QKAUIWq|F67Sk(MJAm+tkE-&h^8j!!Zrn_hR%r4Pe zk^a;<%wra0Hr3r`R{MbSVDYJO3qcV3Nwyb1Qs$CQSU&J@b3ti~DGD=?%xak2(O^Lqm;4ndnwr`t&gwS*F4ZbiA(mW`Td$xvqbwiOQRGM#h zDtdN87YP+94N=5qbr;?HYn1hbg{he`O!s!>I_GUdu{s=He-kDY=5z(lP~!>@Aosl; zWb%2Y*H!#)sf2)jtQa9Hz2rg`4Bb0@hzTLdA&+NXnI0HyV2}3LH3J9oVQG+`R-4km zIEdoZ_t(a+1hD?|>q!?17)E(h`?B0auPXVcaN=CroRBg7djzC$bZn7C$pc!y*$*<_ zJg!634(s8wq`^ghR{#iTk;5s-RlP9wkA6JHscpjMaF*f}C3^B1(U{V`@^09)y?UUg_)Q9MI=WrZ%?Ny=Zl)skPs)}!@oIvTs$tG6e*sqz0)?&t!o zukkibI-$hy_k?~rA;jo~`TxH1&jh=y&wQ9XXS`S0AAB;hzJ35;JdvIqohTrN;tOxt z2#3%L5I*&H?+uJPQfzo-1j)Iill6Db{OqxbRg!Ty73LV}w7ORarhvDEDw3b2G#;TA zx-s<(zbQ?WXg$rr8^x=8{uZTU5$bb*bMBbq)yh604Jjs9yf*yQNzNH~WRLAh}0ayw=L^8-%{<8WCD>O3p(HeziWE5f? z0SXil`4e;r+c%h+XK)Wgv_(F8m?DtIO=M*SlmVxS=H@TSe+nz>uA!@{(`sNW^WIwqs|9B;8{yPGf*> zE2GS*z!ZhcOIm2%8x$5Z6OuS_4~lF&`d|QtpwYWR^S!gh=-&l+1)8I$yVu&!r}y2| z>4N~3ZAnqKa`@6=HIe=X?bU6$#n7U4y)QjVxBF?RY#}Z8q@HDZ+|Pe#M)+98wl$`B z!$ukTsrJQLn@tYO^62;mVa=3T={<9)8|tOjoinDIjBLS zQ6uu!wxxsaD{dvIE7&vI9hRE=gtSaN5cPXb6y8iL>TQ=A5l6F3aaR$=OWQES=t4F4 zS=C^4kNrJ^{z!i@Zt^eF3;ptD!m6b#v^LvWbj<4!sblqHzoPfP^h_ElZ_0l;Jz1W( z&#q;oVmruSwcaXu_45zcDhKET9@uB-6@IGZBxP9Z&X;-yVq5q zf{Vn1f~t`_=>bo4fl7ue;JTgQ-nQ`+?hA9?X~2RjOFyaMm01mm1x@6vn9n}ez3rMW z6V{cex>0pA>Q)x%oXJb2Gz6hP+c5}(Hh=CL4q@L=m1Vz+=65-~ zB{yP^aX${_*dI&!I?+KUj=6bO$li@slrf%mAiQJeEUmSUByDrPXIi*zojEefoS#fS zsdDZR z|5PrJHHGiKL{1qy|0`C)p#TcJUDzIsV8t4^uW2Lly^sAcW#SEgQlJt%N9 zK6X6GXC)y-kObvEr~*E1z5FPAd6g!&vx%e!_{hkKSNd4doO3v1NV(dywlld>rMc1K z!mF1#<#P~tU}DbuY(v0GNrNpakNn-{Q@W1t2d|~qu2=Mj``3VHrX`p5QI4QzPR8uC zjZIpFhKrxPkFS5WV{I{ZlX8T@@a(Zwj$AGnk2Al9kRUHkMhUcWjx9BQ&>Sg$z09z4;(zpeCdU< zQ65tYd+DJxuJv~IkI>|$ggUMlPK}ZwA;GHe={Re^bJKfqVLd3kjS9y&`CE_22IFrf zGntvHpKR_a5BYKNjFvg&V#V+~F0kT-F@TL@5hB8rbb_!I-Ay(%Tux$p{b~+oUYA!N zNYDyiX1#s+nko)&d!q*5BePjDRFZ3Zh-z0t`MjUip6&NaR}js0tkVo(duxCfDE~Jx zXY7efvrcZZ-fcssf~4;oRr|h0ObIE7aGg(?3WM1tPP*lKHYa!VnbctEIy|r;!-|+q zHM?i5+vf6$Q}rfA**O8F$>i~qk}2tudn$3`G%9hNJVl#dL){Bwp9B-ZO{b#qiZ6IT zn32~j#q##OXLk!a?Ib{gqE9k|6g=+IiBrUSkG7%C5UrneV&u1*K^o5=;VONMXu zaDLWdv(Pg9p3Hxxz~*(I`?PkBw&AekBw-(=gA$t3J~;B^70;^4NoJ8TPp2}hAq>f+ z`gw+bf)))7ZhL~irxDR`Ej$=w4lfjyD|B*dAC2`(YSuH)MLwxY$W`K0?zyGhqd*=T zM0+)s_GCmEUkM*1#d0^N@6}JOu$4jkG>&9Ui|(b9|Es&S zFCu?qs2AiV>*2`H{IAVW4@SbnN$1?8NaqDVbEXZx{P6kr{io&9ySj*cYhUVnGpo0f zg^AlAqxJ!Ch^I~N6R#!^?d90Fm+{xOfUPof#V_`auH(uwyKKMKmd(L>~q-332}#}JdrHSA%wt%%&etLC!LqoJ?|ml`3zV@G&PuR$Vi zt>YAEa5Humz6{JPAH@+Lf-9> z5BHuul-!?~4p_8yR=gScL~78<|rY&5K#f)r|I`9 z=A^K+XmPW6w?`5A`?un^le5q(vn`o=(sJ@WldE?IQwpS|fWL;tR|*PQ1vEX%#d}`a z$<7q8W@XPP8oue=e03sikS!UQQu{82{54gaa=V(1I(z~75OYriiD$vEHx9Q#i+&ud zXFy@a66CZ#&CzxFtkfp=?sZ3mDLb-pEO&LzrT5zV26SQ=*(q$kOeeOV^~jZTg9o*= zce_WSwuOb#V)A|Is~cyRZ3}p1jNc^K7Vya!ewg3zq;(xiDR_T3t=W?GeeL7Y#on@C zbz`n#T#;$I$mbYZx8(U(C#Rk#r;z~brWnK94q^Nk;BW3Q@1z90A&W8M6Njmx(KiBY1 z%e}o(UgT;K)r|~}m8w3s8(A8-!moag?ypC57c#R;BO7;iruUQcUX4+gu?c<%>W}Bh zx;bcj%;;ABLoO78G;|eV1!gW_1_ zY(A21&5n&4ciX{I8V`eTuS0VS@EpQvzE+lRRd{>-h!;NK;{H~5wQBO7PbQ#`+j7O; zW%k~oA2(i-WO9?|@kP^c-Ee|=0kz+nKe1pth}?_zxOw>EeG4?K=T;hR#mcbflx%gj zdgO#hAGTQ>X*#sr`GWezjLL4T6ZH=V9fLu{uRs3EBCR6mP z__@w=FeD`G{Otat0T1xEpH8eFu=Ccl->kC#D65&dvd@h?S2nV}G0Sg2@j;F@zuAb=w_%UpM zsEM3NSDfkkphrt4bi*tyvSEFJa(a%=q+Tca-SAg$mPrt6Of8m8FIIGf2-#3 zcy`=aLx4*wZ^sd1BH(bo#JYa!ra`(KGo{ysigFqxc+@B^e4lxskQKCYs+VNW90caybY22 zQ9JV1G9Pl^=gsEdb31xMGE$*Sn>Xg~uT`p%%ye2Nsz-_G@>yLKDT)8SDSY?-ZNFlj z<5#HVbKX8(Rary8HwTbL~x!KKWCwU;O?p1!9w+2!;Z>_wX?Tu-C@8B-x==R95klA=C=@E&m zDW9_tk;sQ3;QX}q1KE6+X+*0mhtS~wdHwn_d1G2!W^d1z^{bkRC9!E^fQ~n-`gZPL z75<@4a-ZTzr;sL*Xq*9CU>Dh_>?9PHDsAthe2&z3*5YIZNh`~ci|dLA`$A&|)HgRi zux7BJY#K6IfTx`b0_Cv%T9+>*u+Jt+PHjme zwl^{(aqd(G-FrrINYX235Jyx@5wJ_c12bJ3WH)OFj_x{qVuQysgltYwyoo3@%LYIe zP;cZ}C|L!kpr&otlvpO~fI{|COi_$8oh$Q4lKbSX)JOQi)C=*}$bgKIUoX3Rn!|RN zR==FGXYo5|3fARqAy+96b=2l}j3gyF?M6GSm@0~qG{~-b1AuVw7;Y>8Zih6MjYJR+ zwGsZr68er|-x(nS-+uUwXCy4;dM-yj1>$;m<#ojM&`SB-YC1~j-o!(75)J+DVtLNn z?DAiN@@z*y4SWSpo@tOZGW!1eKVk+HK*cbOnDP6vKF(kWJUt)(pgNC4j--#Caw=ig z&0dZ`dzGKdl%$MpG1C5?F?fq?i+64dcm1qkogqi2ZMFMPy6fzpbZ66U$0jC>TxiH2 zPp%8?kM#lmD6U-{5;FIDf)j19A-q8gtIkuZ=6>=U+(&OgaizW+BgvJ^Ha8gmjgBe- z8rs6uL__Vvr?;hc8$F}4TCSV%9VbtKaI*3aN(7kV%}tG=-4llq^b=e}Uolz&3}Y83 z>qm&=9)S?1en91vn7ktyy?I5DGk&M>x>K=1FW~uXn6LMwUNSYZHwrLrsePV)MCro= zTiPmG?Q6l!oaENfOgGbBHahG=3B#lc%`Q5Z>aqX@m+4T20q5gj*S^{=PyfM>Hzmg~%J{ zp52s5WsJY7$GH6?#g>boKpM^a><(JuIXY@-z!+Y{{(mpShh&B-G3pDz;a*K(>if?i_|*; zSx)L56>jRf_C25JtRDwWuX?^R4od2%ji4_a6bWhvfPo+!;! zfQJ6#S}+1I>e8S3^+Vj|^wFOyOHa^Q;ayuwT$5SQzVZjZv+jTQzRgnd#V#p5vGFOK znTmrdJP+3O>&a&h!KkjpxtOAt#)`+G&hK#t@57NDsKMS2H8g84;<(?v>Qf zvV6`=Z(3-2tbCMyYj)jG^`_8r5?1CUC4sTclZ!szY9o!;nN!uFR8j8wMbek3^a4}< z!zFmam%@D9vYqyR&B&w0yWn<)Bdh#X4tG|kvY;t5WWSTT{oH&w zD=L$2g@IKO8+XY>z7528m%Rgc<|adMr_kl~)}MEBYIrVR5u6%BUN4PbW#vc8Bb`59 ziT!cG@2EEbMdP*1!hVDT9nJuLSan9YJXu#ZsW)fTjNUT}nCw-bYzi(J1agkCEAfGQ z{*MCPXEEC#1!b4WX4vu$Y323du~niwz>FdQ9?Se0+D}%-C*vJ+Bg?S`TnOO`S{XVKsr7-{ZsG&6%hVgtExvFG+JC7G25cqmB*!z&!jqKz|9SLt!j$jjD>m@T6Z(H(Cn)8hKQ~? z#(C9gr8^u7herhg?F0|Jx>E?(jElT$B>Fuf_r&>J6kD%#^&+e4NC6pa^b#?Wx62&c zZ&CHM!2rq@454k%jZa$%F1Kj+mwsjAbGf$b zM-f^qzrv|38vl17GFk>$t8P@j;UYoefno3dioBA z6&iJugW6RZI`>mggahrh7jVN(Ey7xk!IzRXAFr~hpt`NeegVWfQ$YD-R8@iYeR)n+ zc+wEXcz6lX_HIKE`oe|jw{g1Fk7mB=Llsa6$*@ICX}mTz#n5(jG9r|r9Q?Y{$;scNyv+iB5ni01sZp4HH^N0B zOXN(uZ!uw*Fu)1GUjtQq7r+phG3R9M)U1oD@|Z1_^Zv)wNqEW#@o!}tVU;Xen2<6U0q08_Z=Pf**F&FnON1=owO9W~|(Q?2g^6fa5+P z1)}pRfl~<)>@%$(b)y2S^Rq5_9|dT;xr#xt~A3Vdm7&{#=iA zn{na9=6D)@Ha=iUJy$N)hTw6NP}vG!i}t;$)u$rrI1sh!gHU|b!!gDy6#J8;VoA|(^VqSn^rC5W^vu= zPHdzyOpO0VHt6CyDejugs5~9Mcr(}c-izIzgBgn0e=^hz1CrsEg|VMsQnUWg1@p6a zpJFItV#7mfztruQ0?N7#K7a3Q3^xRKkUDA&b=;fLf^@)4mI!)-5~}iZm{_x#+>Q_{ z7ga0u24o%^*!XD1G&Cqq;LF|t}_cc6`W~^Msas*zq%-Q z@`ZlJ1H#-DK@yZPQE8`xZ2COF207!yKE#~$@0^pG zsnZ53Qkg(5kE}@5R~p!5t2OQJScd$*guqhfy2C{&9^-{%y$=TPg|em@{^Kn0m7i^) z&f^)Ov;U!KQ5%U!GU29M``3IM{4KYKbvCb;1VksY>>pLFMOR#!9ZB$MW-N*ejy^uW z;k{r0F1P$JZt_Rx!XyXpTS?GSF*Kj8gCeBsx@=?iq=iyqbvhY$eq7FPZT`SbCRsvkyr$lL?wODECyFPU=afF*Y+LW5PNzFTevzt=n&A! zAj)1J7$!}ptgnb&>Tg=`Q zE#3Y|>dn@AmQ$IUiVE~CyV>v4PnMg>PEHg>H~l4UN?^w9e-3c_4Ao-2E_N%D`5=&C zgJplG!rcC|pz9_7))k}&WrZH=J`I;0V%IcGbTT&cvqN0n@y4vApL?L}bdeT?v43A8 z$(rc9)CxYD>)#96)Z-HLmage28azf_3OzuLIs~{*UV#~XqlwPBtqM2)7|=CCdPHF< zAK7xjE!8tLC3@<8mO(B*{xtS(tA!EhF}%c~9REkuewFN;Bv8HiJP^a+Fc_jTu*U-K znEhD6VsmKda8t7``}Z{O4B+D z-&^vyc8v`Gy>&C%%)b4D(^UOwBXjQY^Btf@u+~UA?{E;9*W+#tlKF&12AeZNr2F~R4-ee$d9NPT3- zn9P|K#`ok@J2c1mW6quV`>i>HO$v5p$LjMP%2{VGbx8u>9J%aF(ob9zLkRyTW;8g* z??pLd8~3oD7Tm5}Zd)@d>$L%VSX*RC=n7~Z4neNKwV4X--_-_cgI2s6$yv1icK0-W z6R>bye7<)>yCGtlp|y>!PSs(c@Q-6-1}Loi(aePj5C)Diy5g!j!u+7wkxu-%r%~8k z`NcQi2Xs`hXfuz2I=Xn_iMm*+#C+@Lj*Ec;GvL;iFx=k`@sd#;<;g-4g1WR2Y{pVK zYAZn4RWoYqZ`YE6OyR3{wJ1806#8i?uo=kYS7^XRtmI2r7IFJhr23j5WUU!l^9Ui| zia}`*zNtX-zZNB55^*Utt;I?c&M5A@YbevDmof)NCMV?|1v?*OR*X!1t#e<}4_FOWIBX*cD zs#-ysi=zp8L&}0%ieNL6z<+yi7n^-B`!`@07e8&_Eso~jc1C!LclkYp3u&Q(lR6Oe zRGQm>j>%M4J5QO}NbMPe!T%zvX#K7PqaXjz**8j1yYw3c2XoGHEE2$pAuzN32f#FI z)=9_*>{~$p^47)D08wkDPUkyyDZf=n*mjqBCYvYy1(uWy9 zBjLY;lF}h}T*a`qN9}f-sK)_U{R6{~JeI}pTtrt<$+gS%y~d%OefL8c8>xJ$E3=Oj zGF42zt+wtT`(x}ewr~p337}y}<%d9O^GHWS<9YZIMY^D1d%|CP_;*V#2XEjzm|1j< z-;iKqB?u;oFXJ{BFVh*tP?u#O=B7|bvVVu_iZ5Cg#Zt`tzub6Lrea{DgW;&odjBaH z{g^}ls9^th0@%guxt-3C-B@O02SZ@{qoBX0^NK_D#IapB->PQ|N}rr)@QMg>0syJ* z%Hi0Zc+8l4oxNM#j(0odg`bFjxzsA-N{=27P_sGjymIJO{IFx#9%oo<<5u_7qLGa7 zSIu=jfIEQaRq{)W^A>*07~~c8pXsci%Tj_mcnyB1jS8HEvNU|0U14Mq`|Ad4&xvhz z!d8bBW-rVQtq;%bB7$IT^E+4fk2Nr{f`5Qle1Q3jfJLbB_IUqURCHceTApHCyBRRM zB*G&^k>S)~FzD~(b}4MPgy!{3f3B`0+j$PFC>rHQdM_VGnQhMBaxi)W-ZgzvHjUoB zz_DQx6DvWApe!K^y7!=LhUrv=5H?p(Bm2?IdDSk87*6FJ-gZ9rP<6O1r~>3Yw(lo@ zZ+xxmlh8Yy$%xP5G|*@dFs7pd)L@$sZ;&Ag3p2~p09I*w4l*^tR-cAr4y@9AE%jK$ zcs<0$%u?|RW(is7QKGSC#@83J)8q1^N%2Ch`TDjr*p_ZPQnnzCX3{`VW394;_jfX6 z1tjV2=F25r

~hQ&`4F>(@t{)0@Xy1DJi<3ypYj7QXtURAIB4`y;_8e|T_>qMWz= z&<7F%34}TJXw-SfGN#rhbRVAbQpxsQ4UqMk}&sPJExP9~<)dSv7ZvOx+vCSo0L-2YUEO z_LYa7-U8l0gDEHDm)vY~JR%U${Ir|%SGSIquqrn&#Pfyd7op>99a*8D^e`KRfApWI0@;giA= zk+68VUKp;a?x18CJ@D2>v_s^yRjCe?x8wo4F;=*-+2RWZ27T2jBH#XEzrO9`I-_5A z@GHU|{J1v}rnUL<>}gOx@zvW`Ccp@%x`T20@{;X+!t-1s_^+Mqp#HNL>%g}lR^v}> ztt{i?0iLci&8U+-B7rY4u!581Ho-n+d@>y{=AO8kgsgwEhQ((G(=*a z05RL7`vUq&KBmP@X~J67Q@2*i)!l8@GvyH`h{Yn94fPlaZG$Gv0Cxv(u0z045@)#O ziL#OjiEyZ&6?Za4bhuns)N;2jF8Cn=qc?XQAixyRMmgvg^2k?{e0?4#$?{2yB0=AY z3Sd>slJw0<8?-gPF)o|ByHCFd|K;V7<8Esy4k7XrsuuSO^sG;1B&VsxN5z8$xcB}^ z))rAkLz3s@geX#a9>wyV=o75$pS-_pCNJ)#J8YRHF809=wM9+kT+X2k>bt2ZkC0@m z*>UjOv;gWQN6p;@rRPL)cd^}iH6pf2CP`LlC`zawywXv6^hpNx0~FWbHed}yql`i%y|G=5GEEla zLo_x-rryTs(4o!C%Q~w1{b+36+B*!QwB+9=P)M2*r$<6>k749X>&+TR$`wAmcoBv> zL7hAYeDQ;!J85tI>kA%Ve$oqTK*OI)JK$1L{u5*sV=l;>SIKIKl)kC~ z?oL;Cutrv4s&BkqgQ=6KJ7^{jnzCNfMR`B$ybFwiSLqaY;x|$LIAEBGaZV$qF3(}T zgyd~l5~7qp`CvRno5=Kg6CgMa*h{WAW9o*+#zV53vYH(br(T6#Z}-Lki7o`gb%by zP=CZnc1#P+{Ne7K(5cKd!tAIg*JUrSVqD$gg{m9kiu^(BAB3!uQ&62#@p4J057(b1 zSs9DFS#W6Z$W*TqaSz1%>n3}vmofWE>jOW+kso?IN&~nHuhL!PbwFDATO#y>zDYEb z0rx)A5vDs^Wc%h|^qTGuiWL{mhM*I?$1gU1hPh#fg1%*HdM!LAk~H`Us2~`I&Ri_j ztMO(L%UV>1p_3QCDvW~mXB~71^98jF_;*ym$Or6Z$@Vx?zFq;gqT~Wct%G(K`({Re z$)v#$w4v;o*GF@rBtP@xicY}nAG|wqp8eMgK$L2_Gr$IsaMyS1HI#+7NoXv?%N1eE zdt8T-2}!dz`9eW6PO@*lI@5BVz4$9aj7aI#m*Dgcn(aNRMRA$1=I#cxLCE9G36`C)h(LK%2y`2G3bnDy=Y1N>Qjs}^pRa!Gh`;+@BI9g&;}S5&;ue683Z?aD z!4wmKQ*xRT2bAA^UuXQ+8Dn&dI|GcJ+UmmA*W`ji42WN=Z8pxNE~5WNCvy>y3c67K z3H0U0hQ=Z7MErd=;z^tzlt)YxNp%NB*G+H&bq9siW1>Pg-YtICTM)kS(^ar?CKzy1 znkC}UCrCYn@F#oJbe2^R`@}}h;!2rAd!qZm@>9u_#eJxv+Cfker{SlX<>N|J=Gyus z;8vbXL%+*zyL9aA13OcMnApTL!3beWuJ@AJ8zvDv zzXwCN_4}3RNXQ%7za<1cZn;+8DTh)M_t``f-HC|~eM`3O`S7uTNe!XEZe2&>*11Ao zLXt`P+JG!?-yBVOlVV@5@%o5dsqN)c9fWQD_<3W$-wLna;Omv(cWZcWlg%cULexNj za}i0d=7>Pfa4MeqLc*W9f_ECiTy(q-+PFQ;XMd?@dRQ!naGpu-xjblaK?RT&x4*;+aM2%ew^Sfb^V^QB>3Qas?iqFr7VQr#^h{JBgqW3eG=S~p+|4Xx1J zT}64=UM`|X?RC)D5Na<168X=1ZD)%LqAuwE*I!TT4%&d})SL*B*41Y!PK4=lf!BkY z5*PRel3Vj6-zEeVS+%#!6<&ez|)!i1@VR4qngW~Nz$KvHpaNWeA`tAZM5Kh-kfEE%v^}g7pGIv$!vj&f!i>%9Opmg3;=|*>K_0dF#H2{x(ZirbeFXfWW zikXbXEwU9CSRK2so*gzmvLW9w%*VcRiJ0}dAB6dQ%gj2a%QDv8LzEQJy-TJ10S&JXUwD~xk+y(rJEz)*; zoW;gjYFnqC$1e!MjmZ4v@2p(R{x+@!uN#yVlD@VcqK9~i;7GTc7+;s-ZQ|`4g9&N7 z8*`_K7MYnzyUcd^5t+Gs*wnu{E>{q?9{<@C7ojlPgRKhlX>60R_Sp{h`8Y-tHm{o= zO`;vl ztn@GP8z}V&kTUa7{uT7)Q+f66K*jpN$IR&7dd}YjUl|SnVa51(AyA3dIIPG1NG9=I zg^<-`o82RpeQ+LPg;-mE)&h+JiiEJFz{SEnT6!j*}&7m zVrcKxL88DG-5Y6(gL+bi#hgH%GC_o>xewf`IKS0*(wQcQsJA-9IX^+CU!QF-OQ>L| z3{GtjTtZJ6lbZkyXP|q{k_Bsgj<1^EJvDHbS`viCtBrk=uR1*CDtjrC#wR1#7e}`K zvGrWl-Q)X4|FpnZM~fg?_3gaH_$dhWMX6KydN@QV#G_b*j*mx1ppOPo`rLKU6S0@n zs@SJ!TPgQcWk%+XlvERQ$cU`k@65$;sG@MPip!QDkTLAfh}9zq0+c5$LLO4Dn&tX< z$`+(_2Bv574p72IQ3cLE=owG&+Y|}d_|^UZ^NS1uLIJi3P+9g~(;Ca3Rd|VGiBMp8 zGDwKnGc%QD0O-N5B%gSkuPVtPEdqu1LavRJ1X$V<(;X6-VvjX5HcoS70~6fr=UQi| zSBPolXCz?FSo?K(8f&dLMbH-BNvXcGvV@k$d6{R&<`H`e=6~r*0*?n5*9WWR_Pa@> zEQ-L;?-%7@HaY}9d>PEyIjFVp;M6CnRi994+<6@}J|4vtwz?w`8lMviT0%n9uNTtR2LfDKymizVGye^goOU6IB2fB=)c4?Qpn@7Ql-@pld+2ONhqf8WH}UYXLDmudV&PF( z16+sh_nz_dDRu=4-eY&fs@_ZT;9;YR#eJm%+6-Vl2HV`xgrU zJWpGE2kk&CG9;C{v>l#8C;0qK6=`hlYJS?F$AAdQcExUSgghi+A(1cOs16s2Mc9#bQux*jcK5^#Z&%#Vw-@!68mE4XNHHm=>k#$Dvq$JN|9cari3EBmyuC)M8F-SHw8gDg7hY$V5ll4kx+#I zLV!SkApJZ$Vcz%q&RS=!^T%(Ub^Jq@$=*-B>vdnx6Gv$?hIpKp!!tg#heN3Hi{bYG z0b2;RDJY7eN>dZbYluL3CT|-nMrZR1bZu1?$D0@oo|}m#N~h)L1!y680*h_U`zn?r zk(mL9?quTfqw%*|S{rA(k9|Pfwf(73k3MC@kue_K^TJt2udD)|>l#?0&>;=KL=PjR z!}){-Qh3I6>~~j|y^lRu{<+6lxovE}wH$a~svBsdB2ycQv%18gbV`(bx3V057z+3^ zA;XDpAc0~AOSoY|jq(+9)b!}DpoE;-RWd(ZnG>kb(4uETF}lDRoZ_}mkEf)Ea&xi= z7fhkvj_v#4uB4^{S{|C`GFPzGqc_HrH zW@Z1XE6g{KtMb(E^Ok-7tq)}MhL3+Uy`_YwW%H;3xk{##)c&v>n_xihI`rJUiRtt> zN;RaBO&+h8Cul}eah7S6e8|QpdTBN4aDIs=A_iuAva zE=H9X!Ns@uKe`+4lWDyAJ1X?yZ+)jnlb1nw(vj*Hh9nUKhb2_GKGsPdYhR7Hq=>G? zuU~W{sv3Fkyr@atD&$RGUb>{{n}WW3_!;Qo&394h^kxns`sDq%{gP27E$rjB=FwF= zoag3NcHPf@Vq!+Z(fGimFkTKr+yiipONwe@acBz{ZZydImq-M=Jya7paJpeD*xk=y zN91Im?`rKeWOuZ(VR?wVwSC`K(j-du?4Q)W=ebpL6^+c;LO$wdF{IxYuxTj?kGH1P zm+pLQdwEY(hC6p>?JHJtbno{3+aG;3SG$RHqJi9`n`TJYw<$B}!VRx;lP zi2TZQHJSS7{BJBZ6x-6+O1vvbd=gsU{JzWHJF2d;QRSus?T#jI+ zw1>md4-6LloN#<5EdRIb6X>8a|7!QbJx}zVW?_R_L!3tSvAFO+TemK?}%Rr+IqDk_j>qW zIM#E?4=vp1hF*29W@ypNiED#!&LQG%oGt08{_T#bot{g956Cl8zO&+t*}8-r5b0CK z6NQTV;wkzTRCPq9@~XI$*qn1M+A~|SF^CR+bjsb5)CWnELZ!#xpB2lCAcw_`M8(xK zlPhP*EkAL+g4IbexGO}2jnhmvk-VbeHL(dSTHS5+Bm z^vv9LASBn8sLk3WDO-?~M-quEK1r`CFYrqp6fl!2urEIj-VWb&hA^`Er|Tfz@}reA zbz9VkJ*xZwcejOGBnItW9nF=tzYy0Y{9PTBK*UtkWcKpdaiQSr5b`D zsgP_wcIY}|{;pYx1T*4(^HaYhAtSIyxCVott02u4H(d8~nO&WNf|i3-6yh%;k^Ar1Gn&RyH?@mhSIVm{Wz3yx7Z;*V^IX5UCA%R+M+h2SE zeCd3^-9XMwUynXV_F9)bKY2T8xHCi_amwcT#CDdJchA#Tf~AcuTJruldn{6p<4dQw z=1nX}cu+T{?cWU_EYq4BF1}Db$rq@XIyw^6etu>wd~(H#*^r zuB2VI4aZRJIx=uByl2nY%!f;gRlhO8C)=Om1OOD)_Vk`-x{)Xv@P?m61IH;Ng>Z92 zQLaQUo%XI_ae^oc&4GtOVl0ABzzw8PN)VMl+og=}0zEU-NoQG6X@nPKmRa6^3!A15Q=YxJC3 zBvyjM?9DoXk_G@V&tRlUuj~b5?I5iBgi;J`yCWhZW>(+5V#7R+s_T&m%q6;g! zY8^<1^x-lwW4qhmJlym78{1mzhhDhg2Uf6_0J>NPX-e!bufF!^DYS*`?8-h~!)0;# zb54A@CANzKBIZGF6kTA8O2{)Rcc6w{ zQH`FqJEkR=_2I$&?#}F$FcItlrW1YB9(7AJGvgFbd|42(9ZxBP1YJfJTSRLb+o)Z` zXoPXxE`sM%sW4trBtRFjv7jukBO9~f&bQl%kbb^Gd)+LWW%Pw^-%R(q=@f9u{q zjrMgb;TI0|=}aSqt96Qx6w-s}g!D~1RYw-A$=|B5v_Wj92y!9rB>rt5wXWRmL zUEnECLnJrb*|DtJ4!03B(dZPGZlCaHckf7=OM^VH(*ttz`Dlbp&T6)}khhvT49h*g z(F679dV1s!MxLEJ07t|0HR2das74+yDQEn%`egMbMPT5-J8a>9@+DK~owL;&caTBz zlD=l;novYW*9D4Ec(rrh)>JA7Tv?AOPqeeB*Q?I^}cj-hX!c8Ew$vXjgG1^Y9fMjGla zplZja?&1?UX;V3pd^Fy_(L$s!xcw_|A`4K4KK<)`?6VV9$J!MOS$eVg%Oq~jfxd^ zn%{EDA8Zta>3uqL843C?lK-riz~@7~@Eq)E6F+>g%U=wD0U7_k0Ae{TcYvFA{se{5 z`IHA&?wTrFoP(q$f*2Z{=KSE$y=jf~KsBOxhok}FA5h}y*o7?C%Q~6jNi#XFb$Z&K zRuhdTX?$p==D_op?!Q2xx})&mX5CA{NG_H#&AI9jdYOLD1%RpR!hPjFrCE89pq}SN zBqIL&WU-OmnK|>(%m5(iD!vjE*lBk@F0l!FKoT_mX7B02kwIB}hR`aA zWChzmaSlsO3GA$OcxZWrw023+h7}fr8TO4>Wl;Wsg19^R4p<;FMDr3YIk#sP%TIV# zmSbDy&$}m)9DBFshMazViJHyuUksi1)AV4~jGBqL-{ACA`|ZvQg}N{VR2tOl1_g!s zs(hldN(jWZ~Q3y_@a43P2K08?pud?fJWHf{2g>NfBzR31dGfV1i5O@ zR@AnANmr8_qrOO5S5gq^tLaFUgBy)I0{?t6z2Ds{e@#Ko>O*WIejtcE`>Y1l^Qh-Q zmv~VWm=cnNmB$1%W3}b{aUdw{(RT{=n=jV&bf0KEkdRxuYAF(}NjMtlwDaprM>hRo!`fuQ~N7&e9~PD75@l0l@VSRSMTU_mQg6I~)7T z=07j}!ZG}^h|6l8Jn2kT>lx4+l!Lcw8DuAR!tSh5-ZL3x&&Sy9(Y=>?zV>M(r2Q_b z5m%Fz|9>w~{dMh?&iyw;stG<8t z;JSG)x|M7nQw?POl`G_u>vSrWxdY~&Los^G?6DD`)|PKZ&|Z*5?X=Xl{WTHXiRF`j z^kB{qf~WJ0y843*H}l?lBPQaWp$|_qqD@6ffpn~XPeOoeKEuNb8Ft2`Kfcclx7g3g zJ>MnVS5;f>_-bO#yW}4FxD;7wusO(#o8&$Ex2j`Hsi}?VWZF(JdM!;J8>8>DM>I3Q z{nk#_;{dYIoIaMh$P7TM#x;`0Z|uc9%3mArlR;ZN?g1R&$kSW%)k4s%hF>Iivfb!v+$`@<3L6}Zvh}inR)o3%C zLzi2oJsHG`a`-;DF_H3Do-Y(n);-+v@=Fg{Y-geN=ys2!>3Zs6L;Mk0p2B@=MejKF zIvH*nFx@M1E(})@R!|hy@alAC)Airl`|4OzvwJ?ZpGG9FO+7Z=wdoW1ELE9RwvrM~ zcAGEGEAqn@9{OIQzvF$!^1#z$SZW7v!S1z!cRhVO8D>bc= zJt{tIr?eut*CwZS0t^2$auI&dtZ;m(l#8(M+(@nDaxUMkcicM}#KQI3=Jk0fES++~ z%3961^w=%)hy3*NohA*1cObcw*W&Cgw2kmIU4bo{O@2pp&k5 z1?QrW!teJ=t?q(2I*O<~kY#x}Q?+rae9Bx&E+w<0$?vbk1y{5wpQ1jY$+sXX`i(V8y!1t!vM8jyu%-_My7?0y6-$D+E$JO(qwsi^^_Mp6-m# z4kY#|&eV`Y4sS&*T+-cgB~I_G51Q6raNWFnDM>0neSlT?)IlL?Dy}}KVygqv;BI%& zs3UOR?@dTyB~y5ib*4aJIEn*&U8qI|pMq04XMD;tK|aRAPY2-=t`Q;>j?$n2b)-S* zLp263X?~#PwlQl}E+~LP&O@WF4!39z#=6-WbqHZ-Sh(PCg*D0N=7;oZiA0yWZEuod zlKwJb5@bw4x_6P4?$t!BJj=Txm)KmF#Vs7rCR0)Z6OM0RZEqAgZ2d5$KnU-&Bh{_f zx!e0r;m4EIxEbltb~1$+HRslQ1oXT`9s~0_M_6%8fb_LJt&tGih9d&J0)BRcPd5@! zi1b*ZYWj&PyOKNZC!(l0?kf{r+bgruP@`xp8w@05!*I5Kv3yC-`V`Ooek*CFVaepb za_-lw&U|l@05*dQmdol7KRZiurkdn9vq^Zn=UyTm2PD>x-To_|-W* zr{R=5h*oU1IJA#+;*(T;u`X@wgd>jc+(<2I?UHRTtD`xOwUGtQT-3`_$IpMu1t~Xt zd`mO`6=&Elj~B1a#{xWYN5R(Oj`{w}1xQ5Y;DbUaOw4usD_H0aAF)-~i#B*{(NQw!;^h#5|`H~uSGlxBR-Q?-^Z zhRXa^Gb_=_jq60l#Mmjs@(G23Leig1mGvZzdZcO!0iczi66G_BUQ9xugxtz|F6x{c z$J;ZX!m^&3t`-KfqqED$HNf63rwyxj??EgRK5d7(>KU&CfJyATmDnO}*q@1?AOKxD z+P8x)S;zYtBC-}#aSUZ32~?G~8z%n|ot?R)D0qftoBl>Y{;aFr=aY5m4=Oys0I{=TiJkC+{gO))8SLX5 zJJkc`2dzCnqtk!I`o#dn3^J<&O~GjT?x&mZ+&!FM1tp91I7 zUWO6Ty8ld!%G&ptV?VNc^D%Y(~llW4Wia;|={cVmWP z9i<-Or{uu$U^pGL=yr<7I>|Y7Mk@!I!BNCuy<$w05Pls5wNXRy6rqYX1)%^ZL=viz zCv*-5wz!`rM3K~y4J|}Xr>t?Ayoj^Rp!jT_O>}td8NrXv+P73_kalw*o|4_1pdxj^ zaf`H`^O|(Hq+g7{IT_e}avzp2``U2xdc)amT7cs{QkCG!;o3Xk#qg7M0AtaeyA1rd zG6KSSDhKhCyJSJpa0*2{Z|hytQCYZK*VB5oraZ9l(VR-~JyL(#llo%PCA8bjFAwh9 z^@iGEwUK_@z*Bspdf-k$PM1zLpA%e8)NpDI$YoYlPQ3(9F7lpd>$Q-!NnMQNVA*Af zh=r%DU@=@t;n8%Hc!f`HxgU3alg-L<;-8aRo0qbCe__tARFq?AYu(&6#4^UL?F%ts z34BfFS1&`jSvzR^)~D{2$0StZT;#4vpOTOP45e7&8Vwm3b`Wm?#HgOzMQU-B1yJLv zvcj5^NM0v&2RE1@#RcgSO`nL@eUSc?%-F$-sB(6KToh5bM#0O5Iu1wANsYaP5(qMt zkeNwo>qU^@W4{6>kQE5xgZ)@R{NY?c1QJ5wl+QD96r$1a25;|XVq_jfs`PZzr!C%& z?8EoH`sAmJsOfr|BW+N?Ed-=+NtAbJwM!qdZ1_;o!)L#6@3C{l%I%#5F7tVFf9z3N zQsG*QK)JPHM__P_S<4(+inH*#ql7;ZAyHp?&2?TccV(hDr2v)U&QBxanJI%+Jpjl5 zIySkj<%(&qGwAoYfovMgl4k+qh6uUqdtN}oL@l{z#XQvC8YtXG-9b1s2n-WoL+A%? zY^W6#3HI9&ML`U}YbX~GqvdIUj3InaC?iITfi!K;ko-@FO@vkhsdfqqj#*I#kNaF% zmil+tk7Ec#pvplT8-C(Xl;>FK*~XBC=%n3$9traez2G`X)%lb}Ub~2Kyx6os{G-Pe zq>8mio6ItqyuKezwYTTpW*63K*D@O2t>|ZO5pM#_!i^vB*P@M@W)k&0-H}J-V{?qY z&|@g@`o?}b=i>Spd2JUabPMB5#RhiX4K;P!n$yd36r(-0H>R4VP$)A$$`>L+e??8^ z8+&R_^ZH}*+B5LNDQBuXBXQs6{0L`HM*FDlx1)!?FiWC~OXQJ|fS8PJp^A$Ak}coE zK{4pjFA#X2?eM(@gRY~4p?sjoyS7hp{a9Y~jVeXLdIKPal3xoiZm0QrbJc2}oEWrtx>Y1ixdUSuEI^44-T4OBN5)sz8*8ZX(-z6)AjW=j_$`Kk%Pi zt%K|l+Lz)qy&AO$ryq~WoXi4LP+xPM+m7g|0jAb>K&3_ok}3Bp+S-IcY{!kLND{h8 z44pE-Zh8Wz<0xKmu^#;cxuWR_WkP})9;ytuYUhfM&Ti4s{b$=h{pXac)0kO=WYT@K z6YiXq6ZH*4QK$#AdzT^uq#)l!q{<_2@vz+Epej zd29adp?LCmqY@rx-li35Sw?yLF-bitN*i>Ll$ z<1)PU2SK+tzRVAa;mTpY15Ub2o-Nsul_9jQ8p76tx#sBOwgMdJuRH;$>P0hqM~dr@ zK=gm62#6L)n4JXX2grNJD`frr6#cmKm{ND_Su^|Qa`+D977WU`p9NlZV$0!5;ne_y zw|uE^Fio4Ai3{`>xq(pRCP1~wMu=RIT~9MJuwh&5Yi8FDy7X7nPV!`Xji?{*8x18q*W%5uZ0Q_9g!Lld)87gFJ1el%b{j6% zu8^(j1^25tWp_&S3IqBEvktbeSl5r%!3?^?86Y~<_fX3cNNiRJhDA*A3LR3`nb9qCN7#!cnwQ57^ z>KL+NjqqYgs%rSUHR}b6*eltGuXb~=%y;<7g>477$jOMHPI5_n zMNL~_&fzi6p(4NrS$VS)6}<&~;WwN^TS5M=A%-z#RcD`QyT|h+dFV$fl2*)_TJL=+ zqH4SH3o)&G$m-=*=pf1Nm{)wQBDod<(0v6|l@loGu1kM9^J7yD#U_(vKMR=kYjX=83Zgtr1R7wx7Mb7#jA*hZ)Q5r?FXHwFnc%cUw&q-nMEo zmDsG(MjFbN+=lhsQ&IEJhUp!dZHjT4>si&;q!;aQZ`_3gT&N2~NKo8>U#N43v6agMVMt2E3sIA_#~Ch_>Ni@NBfv<9SsnL(ca$NQIf+~8r5OyFgdtX>F;mZ0ZSc=(uw6va;jFwOPdqWB8LKuH+<@DKEZOhcY}omyFLl|}`83lgkG(4DPJ(e?B@Cirw=X)BHi zUv$Vm{|jFEiyUZy_!KRlia#HA8js1F5OVi(5u8SiTKI2$%^leV3eNpW@0C-gTm5~g z$CR1H+BIFE_$pOhi^Z^vVNkHKpfht1e*=lJdAD|1KI6yCu8^Tg5k(P)(3A6}#J0gh z_D>mrC6q*IIg?r?vDn1j)X%cc;jdl^5gvrkwq*w2YMvDL2=)kHmUL2Dq$YPqD_9o< zT|fkLlUC5?ZBv0JS}^m(PEKp`f(5)Kyy(Z}NA-cNV=2#fn+dsSmwC-Dfa*d#r2-y8 zC|-G6>Rwk71t?(k?jkjd2VEJUocQO*4sYutA zsd%@nu#_c=K7A{4KkZh4U+=!CXWaJVDcRzL0p0wh2K1|s4}^Uq-b$@jK?;5Wvyw<~ zo-Gq(`uGcnwI-+TWVyE!u29kj4JO!L>ql@S>j)oWANYji2&z}Y_)mGhO!CnMyL0|2 z3Qz4x5GXG-Eqjp8s;xYwhbG%6KsGk>8*f*>^~1h;bXtTcv!(bfz{WC!1#pzda3juH z;X4L))0Jaq5Q$?+(6BCj0*ZOG;{03QW!m=i4^uQ8n@Z^cyf$K=F({nvn;d?m^1S%macN((HZ>G|=<Dxhg&v7c4WRfX?i9o_i7WN=Pyf((j3|F{C1 zkwLKvDM8sSY~jGdWgQ!evp0@Bp)3^8ayM1|5b?a`m2>EqvBy7M{hJ@yjWY6D1K7fD z_s?=T%79VVr&*Lwh(2Qb?lv%c0Hm`B>QwT3XvzF+H~QIsi&X#pES_B3+gHa<7%o{4 zWO5AIuA~Agc}P*EYH?ek9l!zuJJ+`R>sIdccduHH3|F|K=swKbkPc%#Plq_RG)iKl>N(5QTEv zM98m)Y~7&i>Rx0+Qtq)%rJU$>d-wAJA;oj!FZ>G(-PjAWRrdWZkn~%>f%Wdd&DXrU zr&NUGrXRW7I8vFjQP!9V ztcMzo(g6#kP~QGBeO?%^j2oy~UM0s-#(G-6w012;K~8#gOdaq1n~EDag`dnBj13TK zu2a<0qc0Q>Z(3-5W_XE7+N{UKy_>C!qs)GT=aP}bTknf~1Y;?uaM-zb{Au>Xw-uiM z1(=M=s2b9829Eux0OSIC46K*oX)#g_jv}nujkD(t9Q!JXuQS-1-%J7XgYafBrye~U zO3vQ;^#VyOaHG+wG(acoU1Y=`Xw7ejEw1 zYWE1+0&4=N#~+DtPx4j&9gi^_U6Ac{`w3E%5)vp$^;ORtKOiO@KmkvQ@kd-YRAPVg zdR0wc=RrcDYkHWbrzT=3yLP;uBn+6mH{c=J318Iguz9s>6Xi+2fzks)!3YC;?Uq3y z0z&nP+?7eOJ<(yxHEGv{zCHI) z!||cNef)+Bp72XdXS6nMM$eM~X20MrU;d}c?$Rj+Og{rx>eii%1#BuDZbo6;_d-7g z;ggxYa-oAC8E_^)4v)8h6mOvara(1*$kW>jdq=mwGAH!^hre28)4ILUysjk)%B z&U))-IGfV`GpZI@mC9&KjfRfnPNTkKt^6^#+8E(-LA6m2JAt$bk8;^@t|M8A%ZnJU zm3ar5Jpa@LTJored|JZ9tHmTJQm)YN-=1<;)naK6Qr2Y>-zCh!@A|5#-r_FBFyx;g z-TiLXzf=3J9}x`7Z9w#31!D=h@6)rknjRVSqb$itrMtyXcj0{96?nc_xaJRhv--4U z>yKYz*w`tVac${jg}D+)QF{DUf;j9JPgyE#s8I_(E$$#ou&LEQt{#GWQ0_sRGXEOP z1=I0Ri4MIKYJ>Vj#=lm@EP&1&qGUakRmY;+Jcc!JeKCRy=LNta&bhebO49g~ux~bB z%hR}Lmj%)(qlK9GDnSEUVFoRrI#MzVem_HL&GvhCeYXn~mESXs@C(MntT^-(8Ysa>Pvc|v3 z=%%ODFSm|W?`-;j<+{kKwNe|s@Z`ADW^hjnCUxt|<2JMHVle@3bw4gbXj|~k8oQb) z4|QiYy>^G`5&1KN!b3_qw^MCuMSgJ_EAFk3vLNEFTC|=&T9smV{YZVe0N6yOxs+~? z`kNPO%+!V#?{GO)=PV?4GQeV2n-*(Mnhw>s(H)`$7e2gQNH`Eb==wRJe|E)i=x%?{ zGHh)T68bTl=l$EH%c+m+^hj?vm~D4Bpu4Eo#$B))u|F<_DH(U}V|il6gauC6>&u1t z#EheB^5ovB=8m#D6S-{@j`nRkx$O_qRrlV@Jv`6rmsWglwJOR(*e#)>5J-J$bVI>v z374n>OTG`2&Iz>Xs(kJ_2)mJ!w=I!^z&JBh8qV?^w2mM2AZ!G1w1+iet=vCZa`tG^ zw*WNTmqh0tsuBvg)6ULu|9_8n(JpJ{lRbku=8%F_KaT&|PhA%o6};ifociBqPQa@D zYl9VVXo3DJYf+wzIP?wHCO1`IT(z>wNZHDbTV>S20?CvSXgy~mYbzTP)Li{ztN+AC z%*M_xPYg3RSdh12M~xPNg;*|Hr6L<8yBv1*xB1G$Hn(zym7z*^LYqk6VDfdt`}RMs zA+op`07F7mT6FgiqRoHj{0m_t?40QE=G(tFTl@JYJ~qNbPbf>f9E5i^emfpjv75I% z1$7g_BgKfn2yCkF3=D$}DeKf@!5`X{bBqC#DE2LiV$ z*A=Wp5Z((aE$f=NpPd1aN&@K$j*vlnnx( zlw`kaQ-$49C~`&P{kRPWL~X8oOQto(-~OBCeA&#jhB2qh)leY^m%_@72bJjM|eFeUo1rj8&DUO5f%9~ z>)X0JtNQ-@sE1L?CfZFrm+_+C)GMZmV(n%|-h|+A=Ei3J>Pl3NcxTDlwVE?QXEXkn z6?tU$_1~GiGC{(0=nsgKRZzgqEBZNItc@Fc)OO94WvMC|N$wUbf8ZE|U=6l*S0z)v z?sBMtR;`U0=||o97j0=!-RFmotYf-#cf_MISS)QU$iBsgsT&if`YO@S|6RSYDtDwO z*DG}>R)%vF1mG+`#Ow60e%xH`^^P8Y6m*uUgKX^Izj(V5ZFIJ)ZZ*CmWc)1GxjJ816NdQh>`u(oz_cxPg;tlKPR^!4C_zZ)_BGxeKR!zX9uM zdwL=*1_Eu^u!qCQ5m_#MdWjh?cMSj4$^ST-z@yGgoum_w#^9=V#-YO5O&&7Hjm{fl z`2w3OxCd2+dEXCS)m{FsNq zjuCdV94yGU8CXtnJC{ATGZ1-nAgky=dSzt-H!PF4B&A(YSz1a-<$V!*c34_}!RF z2RRxG*WTL`r@f?`8s0FM}7)C7qS;i;t`NO-=Dd)jMub ziKd$@6yQ=5D38V54F|FO%lbRw=B0DGIpwSqut<+jIH~BZ?byQQ6z{tVNt>+jN&2CG zY84tjRl2~QI$ERKl7{z>RjUYv`U)wkfmBFE)#0beYvOhr4>bNijBW9yqX3TPz6)Qz zX!QSKxBn-*I-Yw#2zXIFa<=Q7i!1F+%4>|gqlS_+y%9k10=i>7d)VSX#@_~rfo*HB zQd)NB9F!o^r}TDhW!gN<4~cwS^LVTjb&2ME*{+pURjyG!Zm?$tN&%9Ei#5y6;DrEX zlroDJMdn}z@0f4Gd#JlFa8L#uKB-s0#~5@kI>4$3pvmZcn0W7bw70qyonQP=0DQeJ zCn&mfs}DmA`;pjxo|8*2H)Lf94Ajk)c2}AJ_}OY7IAT^ZZ)Zrm2A!DEoUBfheeb(* zNvo_8zuF+0!rjxN!<;~@07$`FHbYxH6}0FtVfnwem)<}bTAm=ketQ{%!8Zxlc(u?q zgjekmg?HON;IQyFZ7#M8VYJ(u8(q-4g6Q@~=dGCqg~<2_Bsg5*a$+!L2eT#hJyW2d+|^mYT`ylOm*7RIE{}s8I&`yZ%)0+ zw7M9+GeV=#T>}w$O>8hL0kM&{ENJpoO1uiuHG5w_8+@67_pKghJVMH%-UbL^3U}otN{|F8#F(34)0V} zNxD%owJP?oKHGI{x;ZGcV$e?B)WkJ)Jy0(q z@Vdpi=i*5ppOtKIu?21IiwT!dnYe>ygz&8Yjfhz{n4X|MeS#4gE9};9JUOdjxgG9( z(^U?CDk#p3CavqZ!qfjj6-5=!M$PS|MMFX688)At(u%|yeq1*UY!~V}QXiSKw1Gv! zEdZ8x(pBxWP_s&5dI7G!c5Og%^|knm1gBnxRT3q3*DSBe-IWM}yr5FHi{aQ1Dd*r2 zA@2D3I~S~cM(6Cr8m_Dpe6pO=gu~9?N*=)|;OlsZK25vUKfgOuP^ zI8`wR?_y&|9TWkh3cvR`ZA2GQc&%!aJ`@8Fmzz(1CDQH-`J0r<@2V2P%Nn$vu!7+Y zz7$^JLxLZ(ihV%S8>%SiET!~j7&{be26S%EU+)L*2vu2Co2SZE z`d0WKN9vnQTxp-7rt0Q3WPwJdf@@unqXzdizYgU)X}4>Sf_k5_v6a)|mj!wQ6}cUT z-L$`^2Fur@is^v#8H`mU&z{dDG$v%%XBXmqC1H9jvDPP*_-bPiof;{>HaRL}u*1Ww zf6mpagXE>-w8>-9!&>oF>w`l!`JsLZ0^lx0`B2F;sJ(Qrd)lu1k!*DvP1+brEnvnUwvIq@0% zNIFKOe>~_h9C*EA;}`YmIk~ev*ffKkhTHj}viD17np;aTOcO zWN4>W>fW?TsWmYsg{;L*=?x5qX{PylzVbK!}uvCAgy1e6q|COs65?% z_UfTQS3m<1E)RQLf&Uxu;CE5XfUm2>)I$%Ib=hJ*u8}yTu zJp8QIXd3-bjaM&@?d39bUui!a_HJ9kcvYm(D`k1Xv}>NS@q2>t@<0)`?`0bZz_Biv z^}TFo!>waLW#Eo_m|+)bY^3q^^5OubcH5NH2s7Newx!1Rxwd>cm^M}yKbxTUc8Xo> z;g=h#=WY9}#U#VEwcffqVabH#;=G(e!WX>^hdZQrJ$ZH&Wqm?Hj>fq>n%nMsW} z3@)GQsJZd>4zgbR*?bFu1a&>H#RN*^wGRi53?1W!YJA_&Lq4xYG&_hLZ1(t(5clre z?C0;6|Q^@?Z0N#!6=z%B9u1LI82Ecx5<|cqNJ1oixLdn_%)e4`EA6z zn}9KIQkFnjp^fH#2J3;B5v~_e!vjV*SDSP80fW379j9D^5(^@^Pb9OsjpkZqaOu(o zsV|)}3UxVcK9|_u7wom)Dt;x5F6K`dfITKF7cDOqi`luTz5=K)BxvK5Mp8IyBGR)T zb9(r7-8TtZ(%=Gx|1neX?<@C+4@h?74db-GpxehafG>7RT%@nh+YYi_eF6~8TXR`ckZXDxh0A<#Te(Z1&#fRxU4V2aO}$`s zZYaPfr0rZGEq+ftVR_R_OU60w_Nf?x{@ZOGPmkrA(E5-g>uVaY+d%TRHKHL@^QV^N z$0D)e=6zk6pT9v5&-g4VvUM&27`XV}DpRP%Yy{ z+?YG3A6^WOHKhp@tLf7JlCJ2GL#usK2fDSVZqy`K*i}>(W!IPHSxqR0Os{U{ceVtb zZSt!KHqp`_3bi(S+HkI6TQkhlc%lqCu$+g*A~8k|CKj$!zA4VD>F0R$eX&|)Yu7{K zX>J6+ixIW0QwPoJnl!w{1t%MeUr(FrdOGYE5!V0iOqvR5pMBY$+MDUx=1ovO`{`@X z%YIDd>87D)zXcL1k}0^FZ;$Y`uKM(x;^jcAApH0B`2T4Kfo;*{(4H^$cEy@#xpy<} za99{1=V|Ta%bz0FUEGC)JjfD$0f>!$nLc*4GVYZV)s<6ARR~Y5ZBI*=ah$g{P6{zN zV%(z*tCr+!pIRQ%ns1cGXXNsc`d=LOD#fI6n-oES!}3rpW}UP?|4`K@8r-!sT+uMr z3op6pdKw`nl>3u6EDsK4ALcb6ZBAUb=*L)?AT#~swn>rIG-(&V)PqA%zzyPD3jwx{ zqkNC^*K79y9NV_s!x7gK!kpHcI$bbr-oz4VCd?o1VtrQuz^5|S&VDj4hnJ$4^i73? zPS)qP1rGKWgPQR-e6B0p&HpT9_V(w4LteyBIfOWYip|z+{>erGwYO`MMH6jFBZE&U zi>F?X-Lv~TSADb|2D6*AY*LJf%(8Ho@s4NqWopn0bSyFbkzwFO$g_)mpbqmcj-so! zolG|<$v7+uFy(9WVa}yp7_pcYHOcXD+m>K8p`^{O{SFHKk+=b+&6uw9E6W>@zU$RC zb==0E5uVgn%6JT}-uKe7dpzj{B-=zT-H5>rDByd0XH=rwSt2$jUw**7Ukj;waTqiI zI4--#7***V-TBKG1QVAtz?H*(if2 zeOAmB)SG%rjxO3Gn&l0#ihm#+3oAO#5F{g6kg4WJ1Hfh z+ZR)S1fRu=!E;D6W&q2I8>d)x7@#lzr~Z`w>navh!}5Slj5CUN_A>XTW*w z&qF3URbuR8nGh+PuUA>GhFLw9`VtKl6iuaqyy@7Cp5ifX9q>b*DpD_s>Tok^a^Q4af7vZJq+4!bM68O*2HKB|SYfS?)W_&d z*7K`^2A=!n@b%NKNHQx=j){9|=8Lf-gP=<6(Jeg1Ic3SsmFQ`KHk~PXaHwM9WOESB zySr~NcOd>xMp2yI#wsWPvDr4L{Ii#>H1#@?no8+}hPBIN@gQMW!9U}meod$7!N9ba z7+Rb9I206@R7^MOCx=a{KzJ{3yUmN0X*qDYM+LPIYD%Lxa!|<+_{HFnL3qey6X3b- zIsw^0OjH}s<9A`Es{@b(q1Bs60nQQ#FdXgr^*(n+C^!hjzNbCpxieLlhZtgC(cQ;E zGBa|&wOQ|lWaaiT3Ebav>kiNuanSU1_|!p;X^fL5|LoL8+~1SGOFEm9oRK}euU%tr zVEpUAuXaN;{*UQtu$x8EcIV02Fk&oY*5oM$tJ!zJ$RW&Kv#&D2m^zU4P3h6}^(nqb z+&ZkC`e>L|x?y@>#IL^>7x|_CTytIW=c83NHyNK!eJSq)3XH37x|kxNU*@NEvmUQH z;BjGHueco(_@U878Ha_3cG0gxR3sey|9W~o z=_nFhSuk*8&vZx#IB8boHx`%Pd`1i|k3azJ&@aEX`@3OJOume}j;9V1V(wFv4e7;b z(qkc7_k^&2f3F`7aF9a^+6FcNG+qWJ7Qu4~l%lEnQraU} zPd7k%u=EGGRCP+M;Zg20fj=m(44s*zx+Owd=|EGn(z5pZ=>8D~_1$Q1(AjPOijC%^ zVEyiEN9s)+e^ggaULSW?&YsE2FB4fYZ49f}z^YH@4>p<8JVM%4s!n@-{>g`n-eIPE zSfk{&N&6iEkr%S{t?_Z(G|ZXt<15MnDc^>sUN67@w@+h{vy#r$-M#rfp&=J)p2l(C zZ-DR`7Rxp`SV6Vcl4ij8TgOQu{= zZyzc-y&f*m!Br5S(Qn)Dy4*nwY&h#81V~TgCiW_lCPDW5MSL~Vwr%3g=6Cpz~Sq!=#XT@JuFVHx6mpj;b=!a5o1r%)UiV@6 z2G!mU$6ZJmGU!q($M(@o7M&iO(ta<|o%$=}x)#?rs$rn*wiF1mm$p=Y7wTKjA<}S^ z14WD>W&9v+qyKpSxqPL(MyzuYYWKobr%xVe1hHuDb*jqCHoA#%M^g&Ddh43lL9)16 z%CE&XWcle+^A@-PA$))_e~-YcXt%7xpYG^ItZmhvRx3R4z2v$>5XYy|A!+}9)lcRt z$#I+Ci_75{atm@AP?HEcbn*Y5v5i?erLUkqkI0k^4>9p-8!T8cJ>J}z>@-cinM;Ylaa zJqqsD^fb+Iut4hN(r6Fe^>Zg(EP_%APz|>I(U&#FlX$T`@q$k%V(QbH?NWQ%O!@^G zGUWk`C(c_Fr;6)D@L2Q36&?CJZ|iEtw0Acz|8mEA?RFxQa$#r^Bi5e|Xvhz|?_<9v zQ>wjN@3`t~Eafe38Yk&zLpJ>|xkzkmq49Z}Z(Z96rgnL~z@SyF!Ah%#P|5ou>Pg^5 z6wPA;M+bc@A``22u$i*;Gml7o;Yo5dbeuoHDD|abd(o(Ivu{XUMS*EO?ci= z)XWH4^(P8cd6CR|>TmPxajhzBZ@T5#wVN%GPaV*j&L(8!K*zQNG;5q3?{Ixs#Hmy? zGX#{f(`mW&A7@iIrq?`>qlVTKl^?*2xr$cXUMxKjAmmwP*i<|_CSH8t`l6G5(Qj;Q zyuUM--4`5`6RKGbGdPk<0*roS`-#limK2^Zi$q8x2jY^vMOf&KleV{s1=qa^YEJR@ z^*AFjIfuLM+(dejUs*^oI+z$BbvEF@Y5*PLRcPCS#(!8IZ}3B9BK)8kOi%j1#`Esz?*}D9yS|nrX4hV` z(sFVdQ&MBb@0Kpoz9RL6T literal 39181 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 L)z4)eaMLmXO62=v diff --git a/articles/BAS-vignette_files/figure-html/unnamed-chunk-1-3.png b/articles/BAS-vignette_files/figure-html/unnamed-chunk-1-3.png index fb3457100e2035415ed9cec1beb876b94c62f45d..206c7c62e3a607423cbfb73ff362dc7a2f2edd18 100644 GIT binary patch literal 71020 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 z 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 literal 70542 zcmeFZXH-*f&^;QuNC%ZBJrwD^Hzf)I2~wmtsRGiacljwqdT0UyN)I5t*B~g;l`b_R zMM@y_PVPb9_uh~9%l&fK`m=zrPLgw;XU@!?J$oj=pTN{9ZZh2jfj|^c4Tv5HMC1>k*AF~7=h;6jgA;2T>b*k1H20V~@Xqb3|KrB($KX?f%yY?UuI|vH7Z{Yua zYu@i2*uJ@HH%OW!tqLV9cTa;F%BhLvdlk+3*6WF!wc)LYc=rdrM8ki56GPGLi{afY ziGD>w2%?;J-)BfWN z0z#VGi+iGHO&m>Xy~LNc_{rha9<}KeFGfXxTDD{2`{QnSwNOC$DNG7&jlP8rwC1QH zY$7?Kz(TDZA03A}H^Dlivd8(3@Jex&Mt2xf{uyV_M@rN{0we!+B`l-*V$&Nq-MMa@ zdjhbK8ek!a{lF=3Q0r9IDnS&1zE`}h;-B##xvBe8s8bJV4kR`Lo+DwC%wv<4MuLl?rsly9A(!aYje(MiRWTy6>U5@k^^!ws_|@ zBH5^4-1MQKw*NGiV4O#(yu1m1Amy8i1~1-i(CA0!w9LL#p#FzwKCl)@_crp}-R;>= zGekotSKy^--m@k}k)6fFU-tBFk5}t$@Uh~iK{`_AD(TOk_s~)xz{s+#f0u3~NCzLQ zEEHgPP?LR^m2tn^DL^8G9Wbx}Jzc%c2uVD9;D-k1n;y?=w)9c>Hi^}Kps}yi%zcYE z)tVgj=&pe)y!VgD1&t1r*BO!LjRdWrfr2 z|04S&_)}(e{9*VAXbLYTdg_G5dO+*~gU4AN!XzpZpfp90OSCF!vS?hlpJ9@HGAFE+ z=91QCm32}s!eu!%7b_i;yypIRC@W*oEGP4r^ATlA6S=I!#HtSRv^J~9u=>6;W6+7# zU#R!dXd&4#MV09#Fmq?b>&yspYvRWiT_4KrW2F{UVtEK&XZjh-cmIhyiw=l+ERbpe zikzB!e#ZP0T3^=|80KcV-`MCj7yNk7U#F;GCR^*pKrM5*ix{?Td@oAsbauyuIt;Uz zLvH@vE+k5N0j%n>^UN|gBfWTL0Z}e9K==l?*x`ArdgKMiaQ{nR=jMas&%Y=v)n**^ z2HFa~*#Gl2NzHoFg?lLLy%Rd0vLZ<;;D0yz{)qHM2b`Ak3j7$NAjKXC|0)V%0G}Hl&<%0Sb8#dc!|)mDiGo7U!o1 z5%H+}{4W+Z5@!fSP%=oK#Tr_P)}l0|x%{H$E5Gnx?GTcPW7_m!Dr#tf5S;bhI%KSD zqkQwx8{T0`kOTLKHn*@+XHpWpERb{or&(_TY9lk|g}Z>>QMNHO@l0&z$#1^8plu7& zxoi(}_qM3t3)U$T^)g#jJ9wO(RPN4HB{H$RNUeL*`i3!HaI{7^j2-b`)>My?NLTh@ zV>*b0u8^G=A*}#1ny7ObFKhT2^zPWvL0ot8umK9W{O&-y5T`$~_|P|G`YmY>$}9C~q;gC+fzVx^My3agAP)Gp zuY}aDS$F`Rscow(!cbRfXE%&7RD zQPETFf#P92SYv0FAx$62w;_U&<*tdQt5MoBIl0aXnSnEZy&B3?SWdVD`k~-)<76@O zsH|XyEiDtcCC4O4X|@-%Q(&79rGb5&IBg|A)nuPfSU)7ZhO{XO*r#a(1CXKFD6?mog%5TC&Bu{5~3uoL?cY`sDp+?DvL$G?5g3$Ka zM?24Wl_hRR70g&Z21k!ThZI^~cc%NjqDQ|S_cDR|M*rtlI24d?-1yI{zp@K-k$ED6 z?XM2TFB%J0i-T6{5oim9^H@ov?WDX*a>DvdtG=o6)EDFta0@h-yh6z~OG^%l+RBIb z1Hk@ceKj0;A5uI%d!#~SEJ7mSM16q;aJTzam)Y+qWqp`)@k5upI+4l8i^s93lkCih_; zqJHNaFOruYK44=HbeB$sy=rIo3FDb4*j|i=7)rzi(gLW(6sb`n3@hU9tCN%x($Y@- z&%ZsQb5GQGzbVzuw+vXIvxOG;gb5lJ%KBo|_t{2heoHOrn68i_Q%=Pv?Dw6S;@i6! za{oE+`A01uF)k7I_v?PmN{>lq04ZnhUVtXL7<0iJyZ~gyS-&y@ka?e#sN(T9-90(vRnLj)&XwzxWKfVCS5r5*(jshr+lJrKwI{&ZX~QYl;^8 z{xFBK>OQ~)Cp2G4Wfzod+f6yA3Bu0RV=&v=^HzShHlu8mB}PCyyJ;6Ixuv@lgA&3k++_DUgw;gct;J(yIyF7^yIAbC~x+7nO}2Q z*{1V&g~`1LH&fEN%)q&l3fI=K;@h9vc;^j!T<$H^>)6?SS|A`hX&nj{@xfJPt|`B7 zu`=s4Lx9(D64%McAeIctGoTC#1~=neO$A~S)3$$@R4zDudg(rKzESQHb7!g^8o4&Q z+4^2%A11A)0_i@klBky-Hog6{0ruX!45EMJI2^X{PP6y$u=d` zdV^jX1FHdk)W^O{73#w`z*fXF(5YZ3|5v@z_CsZ;4|T=Z*Q$yy2Fah9McWirmDcex z-AYZS_Li^67(>^Clq#LEb2g=g)V?mBArH?yH?Az}a>m_wMve>8UqHs4+*VVO=Y9!$ z?k~?I_H9b*U*H~+KQIcY9OhiqW3iR%I5YQBczyEtGq&rt&I`3A$cbvQYaLyk*IvqeckxN{d}fqTMN6sCD%oe~QvgMfUEOKm z#wqT3O^2b7)})_S)+VF%$@zib-lo+1wIFfs!?|Vv=g0IhSrY~G0u#~#Cb?I$Y6d}w z$y)g;PN&vaXQVU#BA6O}M1=HlPa9kmk=k*W)ESgMzbI7E$(Mrv`JxD^H#}zP`~AAd z@!>zLA$p#MW&yE6>rbt-59<)n()x3$H-`5 z-Esm$6DOVLVT211DLf;ANyVP^ZYlj^fo*wxXQ#$H|=&Tl+@PNhL2wBU~1>4N7V%tqZ`PPIu1pp#5Q zlg5l2WUWJNcGMsU@8~lrtNq7V{I;K~X*Yb!pPu@*F{ z1z;577*x8##6vr~tRsb)bjSK-{mrHe*``ycv0Fkax8J2Z*XlD@7cY)ceZNpDsTbyI zJf%LQ+x)lSjc`u7Hfrd{;%_i=du+dG_}8Fsu5V3m&!8 zW87?`V>Nd2wZmRc>EnVyx?}_YOm$EFA+JA2;E9FWK6u(wvh!uI7H8j6cYsc;i7RG2 z73tF2JC6TQ58hBj`;6L~gnH6pcUXxYyHpJ;E+kt*u{l|a9p!y40q$gC z4STGsyBQhebE(daF3C;t8ugbxU(Zb8A^5r~jh5w(GH^WWkxYBbh0o&uHs7x+L)%78 zinIvVkC=_lY0|-?$5$tCNmz2%AzH`~Z2eDT!xGe%;JowIkgn}^8HfZ=g@@KXvM;cb zumdt)=jxYO<~zjWoEsX&z~|ygyLQ>La@k8D!V#F!kT(y6ByjSbkq*fG43I{>$*@G$ z?RSoj)TR{h9UVSB?DS?f@*_ z(ex9?-_!I@fvWJZS>tWLTW-btONRxtRV40fg(Uosb#Uy64&Z!3wZxUz&-pCgL`y;P zu7ThFFXDocL98SlBrnM4CaxFo&wT%1{I+KV3MMAMNdjfi;2&T1f2Z7N=?zbg;GU-} zu+rYRej0$|yxIHz90%!mK_FW^d;dUyu8rTcaBaI8RcH~b_V1nZJ~yhkEZ67n(6w!( zX~DOT{~cz^_2r~(bMF4njfDMw7SF^?*Y-af7%zT|)%^FjUhd!G=kE?f`U(FU19-#X zz5mx2JL@$PT+2D*x0Ay|BBnrD1QHSI;Q|r0;bA@^lE69Y|DCSi89xaX%vGgS#Zv`p zVm$E?|MbW7<$OIoRtO!yID(-Hra4jeAjiIp@Vs8>h9@t98cKJb5`qAy&NQGFqc7tF z$AnNZt+%b|+jBKuP~qVSm5JJDrzvC^P8dbsDTYZ@x%pl5uCJWW&63ivnsnmEs z13c4nkg#$*>e{jeurrG4N>57N$i^hRyx}cskAS_V!G(uylg!UMT=|c*(gL2}x`u^o z6aDX7e!ia`F(w~$^~`u0(TiB=w@f%TU-Id2yfr}n1oNd;i^K-7&hISJg}eTDEP+4m ztF64w1<*8kG)IxIFh@RgP~O?lHrTE8uG|Y#+eUT;kM{? z!Y`3GdQ4nJ$ffr(kpwTAZW>rK5{*_$mQn@Tr0tyx9c znuty)t9U06w^NVG=;?}pyZ)&A+E?`C2DyoE&LYkTVp8YJmwmO+2`C=aCsb?1P&B57 z25X2mpPI*gnQ&sTYd1%qz5%hRCQpF@ioG8}LD{Np%ZM)PWVuwa5I-PfH9zwN7 z?;|1zMQDCuYSUx8jsiX9tGE&gGw8Swp&RiwA+i4c2(R!LHY&=zvzAVs1N7w`-7uMK zP*|+SoGV_ioD}ZzwYquvC9-3(5H(v8hHou|UNSg0i@8yyUQT?0_?4SczP^Uyw|J`y z*c>qZKcA|17qMpC%{p_;E7~d;->;3JqDx<l1qJo=r%y?WL@dA#oS zr&M^#Ja@b{;F_;ufUk>ORyBWHD6DPwJJ@ z##We|i#0LxE64!#J8WLh9B3|IYuY*cqcn?d)nAL|I*b$jN`Vt zvIwp(3O-DrNS>XIPA;_K?x!ke7p`Sv_f6!bB~W1@X=C))cRtn35-%OU&q6578zj(;_L3#Mlx*3aN%a4O11mE- z(m@vm$0EAn3kQ|F%4VB%xn)7}EG0nT3;oRxm-&cy^LJ%MrQA7xY*tOOi+!ItMK;(Q z-s2Wk$Z+Ed%yxS~Ue~~*D{+{BDvs9L^wShl(P;iu9?3~aiwq!uRS;C@pm@ z``VU5F~xAERw_E2jsVhOj6)MSoh>d5_&h@?V=H_^B+hv5{6HMWlzxop5b^Z%yh!vse1 z#V`fhlfdi-8PEux8@Hys>Y?~SjcLwYkro*_NQ9fVBY~E5VV+?@p?)+}ZpCnx%kLhR z#O6cQ6kTqmdIVYc8jVud*yP5`a0^M*6!Y*C#TSoLj!LGE9vYBfnc0aYfNZ&O^WQDB zb$oNoGne*f$V^16nY8=(*mwQ0u~Po1nooF>`PFl@v9-GOVrD}lz7?@@-w8ClSVds~ zo>_f9RrfP-!#Y${(L_0B&oq4lrx~cAL}^Y80Int7iA-LxdkbvGfV1!1&aoS~98=%l zgn{!1YDGP?MGyK}FI}XPkamt4iN69?%vy?5PAcoqM>*AiO>9MOi%R;RXU%j;e-?5y zhL!LxSeodjqy8XGs_%2?9=+)s$^z-eG|IMHFK+dGO%iGxDaryqtx!2B@ z?*2qx1{Wy&mvUOGpEbwE zsmyBv$KLC4Ec6X3&;0>h4Eg)7rhC>!*`sQcMdt(AAqv$be_vk{<9Yj2&5m>g!}7X8 z-tl(Ia`Q|`YXAxgNwCx#NDIkQdH`bK{q0vqS{ z7O&pUt@2oHQ8UPhsD8%y~jY#Y7f8G##sE@m_u>+ZgPm zX+p?);_D{+QK3&6T^k9mlER)Vtu*(f(lOI5$`tEgcA7zhc{^`Tzu{x?mc%Z8iMj`n z9#{>qDCBK*eGI9uNR{`aEQ*LSeN3pX@ymG$)$zqoZL7TDaZGh#Y~4YwIg9I{)-9#F zDT005>+SmnVRMXt&C9+0Rq4b1BfqslJ$R)*Ld9{g(&%P^pdk>VmYYH-t8Z8D6(7I% zC=Fh)oQkvNhK6*r{tvZqcA)fxUs8Lp=z2FMu|3fi+?xOSJ@B*5Bc7~|8*R}|F9X#$ zKkhL<;<1FSKWKY66MaPcPT@A2*T)&5`yTeY9P|!WGmFY1f{Gh9m%O|3Z29$=T@SAy zHqmynT}{MUB&j8m>YDOOc?<8FRWrPsd2o)0&g~QT^AWAEth&b)#3-#G8p&Vasi5do10j0{vyu+V%F~#TMZbg^A0`K^{;|3_`TAH zk#Tapb;N;g@4M87GbP#|zFGDq^;|zu-8(U{ekLBK>lMa5u`n{l-MD#&&SA5uub0|;{!B^18L$_f6VaD#_t9i1OK2-R zB?#w!92=m(GiHh!T=rG4PLFLc^AWDoGcLaNo7mU@DjMEIXA16-iOdWaNW1+2@rV#N zEJso8=m>vW`50&fjpAgGvv>e2FI41hX2ECG-mWBSd#y3&_F$`Xj>;VW;%<|IQzL`1 zQhmI*>H9etN8tKZBEv*zoIIuyZx|WSVToTvKI)^KK57b2STP72&EGCfs$S-;LGMD+0*Bc zv~dP(-$L6$M(J!oA8JZdZW}Y7a8Dp85~vBrw7F>owBQBXTHz{m1QqvFJovm{`LX+S zrY;K`B)2+OOt{V@Y-5sq4obDfSD(^0t?#5nWUle|U;Io0BRBt6DVBS(NhR+!w8rB) z|92MP;QPE#Mi>W{4(*V)g<3^Lpt7#{>8g=%bw?Y@KgO4JBFEF6JunxR7rN850IJ%B?u?^zh9E*9jO7|gF*^sLzKXK}bf3`OG;tqA7m z%$o0Q$4;1i-euOLugT)P{>W=~g{zSxJl2F$X_#wE?Zh_stwJGliE9;G&F$>7vf z(rfS-eArL10+I z(+s+I0es#G-KTQpzjyCW{wOo-d)J64AMiq=y*XAa^&Fr3DTa^9a!myxNJt8aIEE=*J z2WcOe@iltMvB3FhFvVD?-!S8<+3XJlu^3WOOlG7}jnBBSk0eo1JOS=ex)yo4Tpt9h zEPTO2#;hW2`?lqtI+(y`4U@eEBBTHsDtazL)?vZIl)zr;ss(KDiLB@=Lc7oFV_3^R8@evG95)PLDc{&KYxhw0XUE zY?qIm>{SawQzu-0f(@Rw&aPGi3mTNG>kR48_aFa~k$^Lc+fr-$+6sr@eoHRg*$|=8tjVwb5Q`>nniRefCPp zpZi{0)`_zDgM%fcBff{t=n(`>%z-;`$_m`~-!YUes_O#U7mG~me&o20OX@=%S#83O z%sPv-xzP4-25zL$&qx^(`-QG_Fw$s<6VU*Q!s~SU?#qoOMfXC6Iz)V=>ngOUgd1Z^ zbb@8DcWkiD+0nG*-qAn4;W7txjynXrIiIaFq%(^s`A?YGEBk)?jr)v|2p!Ux$B| zb-tXw(G1h>CVT!Skqrp2RBCU0?2H8HG1u@63_SctS?y3yAF6k{l{|O#-(=?|8~4T# zE2s_8^u8%J2N`fdmFMv587fU`L`n7FMaM^nEBA5@g7fc!1|SQWdr2cnkZ#eoEpRV#w1^R;oPB! zo7S%y{RvQH5g`#W_#)50A34}S7WX4uq6c1bLoeNvmyfk>8(p+DGsH=zfvlM)Ljl*MYSUX8moh#Q;cu zlOM+o=X*k9)={41IvcR{=MY4}=>FpuV#MKW_-lG9&F7MyrD*%1-&d#MQ6I5xySJ!qpU!}kXGU*CmmI2U}O^)?Bf z6~?~@AaN~{%^|<}(lTJ29U*5X$PP*J3W3r~4lS{s`*LJ)C>EL}{eIZ?41$MJ9 zAuQ2lMv6Jz@>_7;I7y)>pU3VC1@03Hr$yhlclNZKAskSq#x0`JfE~?w92;7tw<`97<5zPgf2W z9?-GMv;wT#h@aKa9A6U_Ixc5_wN;MjmY=+4Q~kfcezlxk-K!)F%~59$v13{Cao0Ss z3r+mf7c8-IRRI(M$g*g*5)SKj>8W~OXN#%&<_b5tjA&em0|hs7nTLR$ZV|47r%q=d zI4X_bp?%njt4&$VG_cy~&peNTyBSz4EEeFxS@EqAloa z-^QW6q%y%ch38@C=B6*d6KRIAop(x&+SWC?R`4k=R|HUca_hH`jK`tMTJB^QxSibF z#f51A!bGQi-2WTMDnFmW&x`+{o2Cqu=rR0Q>ufPVMmJfW3Y4Vp9aZrdX{cs}>bV;~ z9yeW#Y%=h~7v;*Ie~KF6!{LeBu?=c-hw8ZVIv-F{AByLyAK6a?m^;sxt*%zZlN#&j z+e*yf6`Vm?dmplz#aUr;WV2=fSPK%vy5z-<&i71wQgEz0r>`RQxSMpsss&erGWpGs zuD1@m&IAlc{IT z5F<#YhNYraoZUmsY2^{n6SA0C1$H|JeGI!m1&eSbprgZy6<;~QzwiPT) z0{biT6lVxz?f`r(Ny*XehI>Ky?enhstAwkOKvH+(SKL^#3n4l0e7fSNW4ps)X9GPS>6}Z++fv`ED?FkML8~@@??s@EZ&R7O!NX2#`rTGdqeqX7D(xB0LKA&`FBv^<{)jn-=1I>h zqkceyTJA5&EUD&24SasUB@A<=TA5iW5=eH^iB6k(-KtU!l`vrOgOR7xF%>{yXlDdr zrOz#$>{}YIgN170>%}(G{pQ5fi84A4^64UQ_L&@Z5%mTc5Os&OzJT*Dv*>_SPF=79 z#mHUHfR*QhBrwjvpzKs{b40;Xq1It=3Lv8IptnuXm>zbn+d+OjL>P5@+f{@@EW&^%l@_0hy4@htgfuvu z?^FWMxKYjX@YTz8ILDjg7qHxS6`0+&R~suosC?KfEUU@iEnwISX#4ZqJ}=*$#AOQ&FT^@H1rsHebrm8!>EtD%)K`E&-ekH8bNAVza)UVFITxQg`)SiECwIO++X_O5UDFDp<3^# zWkO<1FkQF03*khXRKD!C$#Zi*LwN?F=PuMXNwvI;qev~C3KX1h;@GnN8xZ~s&C83Y z`uj{P95wQ{=YfhBVeo**f8uR&w66Ak(@V@y&+vY-T)7tFY~n#4{VG{Bc;`|`a9`Ty z18sPxA76!~sF1B?eoLE##Ol!Sy)?^|-U&&dfsm9Y<35^#Gt+A*U-X6Q#XrWD-k##s zXZ7W!Z420fXl;nphKGb_N60~%fne$C-rlq^pZAccqD(4prJjbD+?UBJ`O(3TWvC9x zA(AHP$Tq#2X`;-Iy5-n@G*=I_ejvvH(+z1v{ z3Vz2Yl(_w|nV~5{1Eixp)S0)>;X8D3chb{|a`VsA0CR1Lq!Ld)B!2?y8;MMrq_5fK z1+Mng6L6G+PmWd)2cqE3W9%Il0W^aRs-`|XD_kNR_wf)xL{<_HF+K0*g|<6rqh(NT zeZR}X$-+sZ?@Rd-9T89xA8~fD^{P>HOGMB`+iioYEX67C5~!sd9SK~X%=_NZJp6d(mSbUfw;Q=wvrR`cMVu0G`N$cPS7AvsWEmj|1IzmZq3PB{n61$ zeNQA9>3CP`Zj+<-K=e%AC*w5J3N{P%o~una5>DiA9y+CaQPDZgB9&uqbm+W-`QNcy zeY%E=AFp;E3CVXuC~gSWCN^hj9sDx-~(w>1eDwx6oxrC zqPXNXfL$C$-ZSW&wVYoPuSFig%7wI^NN>`l699cUy-UlmcMLDL1*HI~9pD z0wRvyQtL2kou&Ya}Oubn5*|CZw>(xVYRj z-~QRZt7{#jSvFr90{ZNtJgSrKJT{7sg~vhK{K1A5kH0sX-6i|@&G_Xp&FkMTLL9VR zR@}k@O3~AOiYZ<@8e067EXlK)uJeYMNer=GQFB~?Bo)}>NSDr^^9X21;)!AB?xNk$ zHcR~pZx;#NiH^XCHTycSPguE9YVjIPbb%*#f&f?l`vQH()YIBp0O3=bJA6K|MBktG z>+^Rb^8B)+9v=0UTvKmH0-)du#oJbMALgldAGW_@NW@s@(W6@Vj;T5dyi5g}L;O<) zp3YQGR6WI+sWi89HP0uVY==ozIhW42Ln>1%sb^Q?fwuDV!@HBakn1q6=ZZ;q&6`k| zMC^paxtRQoAN5zqp8;5*iYMxTT++el;JYD~>g0SuPGZlX8zemb3hra$mxdc&Eb0e} zXY5!?&b}a7o&fH{bfP{?CNf}zU_s;kNv2vb?*j2f+Vp)E&3Y@vdX9e_hnpeO)HCq6w86fP)JA>n3@2v4k~BwU z4{uG(-2ZgtK?PEQ3HfPM3EhHd zn<)k)=tIiV#T6YoCDB>}8|c8t?4#U^kgh~7GB@aV zXY$Q`X+5CMrz7IQ|1E|BZE+@*4#?s8Mxb@AJjQ{RAol6Zf@U+_6HwNZc`>W|E+jGo z$+NvNREXI0A2-s)0NP8I|d8Xy>tO#mR!x%2-ZQ`zYCai>zJ*g1N0 z*rjWAUC~g;mngxNVM2FGo|g*Yp6HqJOA7VoEp{wFrx?D6;)*g~vVrjWPT9Tj&bQBK ztG&&{BKCOwj|S!I&+z7cbh4TK(c9R7{Pp%)Bg=?`4<>Tu z-FQ7r-Z&kmdkJ)GV}H}8{XFG|UL_UVh1-xNUoKAiDzd6ORm{5iGOpogk;9ry>T_K? zZOr<|y{7tJVxD~)mzXFn=Di-X#-PL{6aRgbk-A)t$8N$4e@UI+3-Ef?d zm{%C_)wrVLhwWbU_KE5g15sYa>XrS!#VzU3h=ROjT@}B8zZk%q4g*?Bn%VO@vAVmG zVhtmka8JQ2%i6~o18cz6(`kGbx=~$ym%hW6!i2u;9b4SUDc9sVOIUDNJN*f#2gviY zv#@R%))(D~dJ0)`##~RX%*O@{L}#B&AbQn$K6tx`ik~W^2|PG^$lCWa=5ST*_Dc(G*@a&>Y!-%@@nIuQ z7W)wiD|N!qjRH-C*L~*&B~+hwS`cTmh0;!V;NU@KZzrgOcnfM?D#Pp_UefF<$(82=%t19%wV5id(5;%XNOCk5Z~^zbQQ{iBjxshUSC(m{s9)qe ziqgr!72$~S-fQh&{uwZhGt8H6Cej=t*lQf9+X5MV-4h>R=pN@sqkvuHMJ#wDPVHgg zmAT#WzSr6Ue*$48ln<(>TT@}m^hunGvc+{HbOn5T6Rl@Wlf=#j{<``zdP5l|zizQg zdk0~9J!vvdI>pl%MAuhfn5>uD)m`B_U25*jP1~jg?>RZJGlgtbRcetNr*Hof%h;P? z2PChQZu$Pfg;qUBd#dT4Q$s)S#yK ze_pq8f1-NVApOJkHhK$2IFau_3!g(mb|!v8UirD^sqce+c-z*Gi`#EUWc0cS?2~S_ zX-aDJTV-@+6;}7>Z=YLVyA7^1Kv8vzc@pU8zTQanMtl|X!*WBjtL~lzd*KvNMcOku zc%j7QH!mW#yol`evI<-#xf-RPoxX^#KFCyb{+8NoXvIou8N{fW{R@{SIjS#L&Xo`` z6Zq8im7idLn-w4O;dNsx+lyb<%9j#LkDjnQcALRJ;nE%cC5CQ)NHqNrbL4Q(J8o$W zP#?voHUzwP?2wB;BaMLIs!_FvSu3jmx%9NBq2NwHB0F>=kvP`n9)5;m6Z^Cmyz4!^Y7|rRWO1T@w z146|Q={)UW*i}#VY1m${BKD>*;1-kLp0U_>h&u*Eu1Q0S9PX^p!V5Z9DLcT(F<%1Z z`~{ywvG4QXBTo&K84ibDo#c)?f>BxLXKSbN`3k#Q8-#9T{Z$` zSnR6{BD5Zw1Za5~g%2R?DLDhr(=1v$JImH+AG!xBM)}O8cFO~EFXv3Dh0aeiwEPQ` zYi&Oz<@T!jUOvC`WBr+Qya@Z>vkr>DbDCq|tf{;-hyISdBO`>q_{tPpH|CNCRg?oN z0A5Wxln-;Q?6)OpA3T={Xlw8dO4LFa6x;*AGxDp8mv8wbr+myDr6SQq%%8hhb`Pc> z0T6&L1cSiPhqL4-w>;se7+}b5CxR=YzLmj9=EZ{p^y}$+i?JH$jw}Wuf6gDazodGk zO^K#oP4{J!UpQ9(I?5KOlCE*1+~hkaedTKcMAy9pT+F|kR1r~YuPk=@gmRO?#VIOu zf2ZfEX)b#_^PA|MZ4PS|bUVrw9Si7tM_FMR}sk;94jA@PR3M#usd+lNgXZU&553yQ&Jb zlsAD8uC!Z_ly)r^^vfSc&FNV)wMq~!vzpj2UnB~zh52o*@_}9Q+xe%GEV397wu*ir2|sL{yg=& z?gmx>qK$+q*lTRDR$ZcI>>J3F2>sb$mKQ!OyAh(oy-@qV)38r7+R`?L)dYwxkHNm0 zh9EOvU@#yNhNZ+ypo#osk4dRuAMP;noq59-#?tNUw>&UMaA5&xbp64|y#Kr25bK)t z7w_7{rOi4P_+b6olTLwG`0@cP@x>SH&NMyGelZOk(~bxzEF_n zx@IfHaiJsIzM$W#8FZwGf(7yXfaIcn^H=N%bdL7Qr@l`%uGHanIN(zR7sTiXXeLf% z5DhlidS_fb>NZ``c!<5SYDxjjlwdlWL3W8G-*|hr4-?v~K5jNjx`XV)C@u+}5uuctL*2JYXy?jL219(nD~M@!!Z*DdYnq@@Ydz+0jUIEl_kN?TFa;P~vt(bm7+5WoZ6Im4(AfajZm@KQq zGi!56q_t+|R1aVlRK|rsOWknR?6)(T+{SEdt{NM-NH!l!fGxtvu9 z9*c+@BeS-;IH0!rKTSez8s9!)L!)DTT?iBidhvJ(ay8OS6ij;a;?-wZ>PZVMzOi!q zKSdA!Vix`1SpaRueO|{w{ihi&*qL)fM8V!SuC>J838i*^7xbJuJfywZKw*V~HXFPu zF76cI*PFN5(Z6XGH_g+DzwjXT=M$G`hMoYwJPC>>E2L)+fW>h`Tz#0Ys8mRMaUseH zB?8xa!-Frv{`L!w#M2>wB##wCt*cO4F751n`qUeq7dA++nm9jz*0l*LAolXBW$5rsTj3L%sgZ4Q&u4LiP{ z_i}+1RR+Ib#ik>Kdm;8rbM(ZUWtZUKS}Un{632okXiVJ+q}{)V%5dr$IfZE#6KvHm zJGo1uYk-gG`qeFqQ$6sLjc=IOVCDK*sS8viPJo1b%FYM`qCM+3M_q(-t z@LD?!xjqgXz0A2TSx8DQ?{!;k&Z8=PW|T>q%8M?QvZ-|CO4>$%=6qtP12Epml(m97 zL;?JAxE(%Fw9$-^&A*^u()&1|aM!AF;ylCzno`KX9@K}zU((4 zZ>lxLlv7m`#JJg>?5^(Ws73v6!`Lq`(D3U4jMWLntDByR^(@#2Oa0$o1NkC1B7u&e z@@f1-Rw1w^k_70{7gU=mHD^CEr#;9fb|s0Xu@dn4uqyf7j5uakHIwhDjWykj&|yAF4Pqv#%gW4WyaGUZzAwyibs3Zlc> zayAEnv8-rZ^!-U5AQy=62678?Zrsd007 zgW391C5Ru7e^blQqTT{j=({DKs>P>BQ^AL6fkr;}%mLz?;|vs7Phr%8&-~?LJ}&RZ zj{iQ`?XK;)vd$RDgm(Y6Aad)mA~29$LUhQ@nGvL_J)4RW3D*GuEV^Y3Zu!z)8#`$k zF9W)Z_kz@1HP*is56fdCIk!%}C(ssGy@yf0~gcm`P+#9d(!Si|mKW?bI55v<#`9%t78-4}kDrV~T z<<(u>bnA`>wA2}g+mYyARvctkgCXwMyjp%Qrhbbcu$_OZ(&UzydWGDFlIWXWx~i&4 z?2LUHl-(dYYX(3IA34}bczU_H@x-U4)pw_K;W9u;M+NwI9#3mqR}Fk7O6#ZIFh?~1 zxUdbUsQ$2H{`qOpXg#%pm;!&`cxIfdgj0M>OhlgE<=pU?^c@-+EAtfXn{ueu%19q_ zjycfI;Pk;fN(^<+xUw&#%BAeK@lM|&K^VR=QLu#RDmNtXKm0aMPD}>zVD~oV4yEGV zb``P{wSF&N>#h+6($=h(t}>;h#*^#w)7gg~joYg@ru$6fn#_imC{7^@uM@*MCsJ$o zA1EJ1M{86!X*|Di`gOU8U_|_bm#<6o67E#Rx9a`Ak0_HL2Vb&XOgRR>il^cg*%UGo6I5!MtU}9`MgG{m zVCTSvw(_xkU?yCDL$m$*Lv-}50a=pG8}$W@O^ob9%gl|t`=4pC@c&MU@me2IRV}!w zJu%^5=U}oog%pG=er+Ml#t)7-po{K81)zjc6yll9=EYlj?Pc%`X)NXN`)>AopPO>Ws@L+R6R0ABSHO zGaZxA_fP_yqaAW6rymE65h|li@ms&Z=8X{k{iD z*{|7h3oImLTa$kl4radGPEirbBD(lAMzQ6^VRb_}%Z~s8f%Guai$x`BQ8#@ndcSGS z^6>EM^h*_NV7bw9R(N|vABs~j>-hg->${_x+P1v|0RqyybO|C#Rk~EABLX5E2-2H? zRFPhTAianPC5skhTSDwT==;l{qhhi6|r%@@I;h3{;z{ipsVWOkns|oCM}KRk><)(=|V-_poqw4Vs_H z`$9?n${d9}vsrv6ziV9=q+f|YFd^-z`({X3LcC4_LK7hG+(pDm6daLa^M-((T#ieK z`S|HkCf4#v8ni;Hsw)lskV@T(z?uwnx|RW0E$hn1KvqK@JJ@arFMPsYe3N>$=eP;O zh2%BR`F;=a;J^@Py-J9qD^z=(OMY8lS;ozIl9GnZU@?>^$-DBfn`I8%X^D^XWj$M8 zQ=nxt=zh0ILd73X)=~qscWuac(;z2MDM*cKw$Q=guXpS$@)rF+M9GmMssrkkE(x=m zVTFvHTZj)UYB`oYP1SCvEl#m2Dx(L)mdvX<$KDvHCkh))&#NOX%@j9?_nSzFv5BY} zu*F#r5fPp`?GiDn+qvNsN&dn;3rbY}LnOXqTQOl?41>yuJV!2f4iq;^yIU?S=U|G8 zJ)YRNQ;I2TYoKe~nNwbIWZFX?ZTq7emabPFsiP#bA%n|XOq!3x42n~&6W;%^-fH!Wp4EpUncFZm5wQN`5aCw`zVP1kB zsDzImw2-O(Mwyr=kDUE21S@43r8!O}l~J!K-AG(pTUmUaoZm*CiHk|it$Z=GQJFhR zc|cD?>?^y0!t(r-4b^QmFCi9&^biH>?!CY+U@sg@+Ea}?&}vl7o6e(q}c+8DqM!<0B~PF^YWY$C^& zwaDQ{!sklXAJoKH8}8OR#dfZ-%PVHfq(vDRD<8M#H=(O<&iS3I20gGPa<_BNvO{pM zx$Z*tIf~nBxZ(YJ_OBE!1>`Ip=8W7WtWHrI)A5!asnBj8Ar)5pmOWcHc{*_;8?hMG{?4;;&o$20}raW%d+g5PHsKT;l0An zyGQF?*Kt=wis)$_dsA;@@A2Mm8ys3mnWXhMs)lQHQqX||#Bml=N|8Uf+UzPS{^#sA zhB;Kq5{=A$II$umJj+I8Vr3_&g?Kf#hAk&pNfKuj7=TE=+1WE#W~C-b*aBsH%5qX8 zoiu-Me2-wNiH`DupcY$|7aeZ@o?>#xCcD8N=~Z`Iazn&a;+L4+X3TDcy~8^z6w}HJ z6h+O9c>rJiDQOVRb-UxMHF2wB*JcHknTMBOL)=ZYZyYcFixXIXU=Ha_HlkJpb zdwP*ySfwFKO+^_9Z*p~;-3d8(Qu1O%W{--_$9zB z^Pap>{L*HgK2j=kzsPg6;#CpP$-ZVsF?lFq?ULuJW;qLJX^%h$UAVT~u<@K^BPFqM zhpo2Z6S!+TL94P^WUEwiD#ueDCE=Wm2P(6XWbh%JR zi2BC%cx&i&%nF9YPwEbqUsB!&>Brof=cDsZOXX^aGD+5_dj&iV_bP`de~xLzFKM7<@}>Bb0^EvlZIhZF`i~unp-dK&m6_ zP~RAVDM)h7Cag=Iz?ArutY*ZJ^Sckx9~0_Y%0mlW2vS!y(GM{abHkv#NeNen@FO9M zBdk3#(VVmOc+XY5*JnfXhnbu?>8222ag$ngX845mr0_74W?%TbPx=f+lStYnVok4` zCbwD}WmJ@A;5&-5lTb~9%|1+)b}`TF_RTr}nlY8$mC(){_4J~g1@kYrYM2g*Bps$c zht8m#incM;1IPx5qKXtx*e8hF`8ttKOdc#b*nK@m^ycI%9m#ttS98?NC_};rJHFPv z-D4^==|Sm8-K$nwyOXm%EM9AS46 z{WV6-Vy=%XpS+IJfE9jFU|UYcgd#{b$gyN?E1@>%8I!8W=ey;U9EHlfiv3?y!lI%M zr$5F9wl|nOqnmW|6i)UGrr*Be=>r`=Q%nwoT1cR~f)Pj`O389%k!6^93}-(N18#5S z4}roIRi)J24w+CPxb3=SW*8Ad9ishs&ZoRMI>BTkm4$1WpJm$M@aawm0A!C^*Mh)? zwlUi{K{ZFKjakW~DxquqF~PW4%!O4QK{jN)t)q5L*^6@03H|VPNPOxUOR539pWc)9 zFG0RnoVbZwl0gB}rf~RCL3eYIRB9Eu5EM^xNyUL;a#ej*C<;vE?; z9NzMA>YZnWwH=JLaSk4x#lik-WwrD=w75I@gVVwpFBI8+{Y1u ztGQC_Z~q0DC|BPWa~)D|j$#8e%e>iw_B*M{3N-Fv(n9Hx+Nk$FWCA|7nFUVD8JVV7 z;|6)o8LZNZX};uuPd*#^Q@svTxU8)><6Z}UrOoBex+%1pn={0Wc2&-9eqL8+$>^$f zHEmK%VS{8BVy7P+6(!O;H-QxXWg#YCIqwyS+Ee%%R=Xvd@PRcZ#SBaICK3Fk#KQew z%g4HWF3LGNP?c~{Rgsw|ScNUc)Uv^++bvhsbZ+>|kpxl-Xl|P0*ewlLcX}5F?r-Gj z9ret$9WVARo{b))b8uIf38Mv_sNy3pxx{x z2c3kUj?GPD=|ur{b5YuNDIEe>Zsg@X$I!!INov`=*A^uh03|F+;{?Q7jlwe`taOKw$tX{Qg?seU&V z-x6G-^)Ho|(_(J+Ew9k)m0O3qmz4lwqv2yDt7XoZDg4IGl}Woi)pC znk`n0SY8*l{gME1zgrvhes0(YQzB!@{mCaGrtfmX@1Gco0-T9oO5ZDz#< zwS^GEY~I#DT@o)K88*WVyoDq#`8v(@Gf*L6AM@|yMrKkPGD-kg8iX08KPB00sATzb z&Tq+Fc)41m;^g7(DGzS`+Pot5ijpVXF!7)ZR3E9r%cn;{ncv~20NK~S0np-3KSl@+ zhZo0tq7q)h__LVh-C*NL%6k=;*y1V;$yR7km|L0>BoN~$5|}L%TN2_ySL<35OjdFuB3u={#dv}r9zz8&Cu%>y z*Lt;i&MHXmK$CJGrN)PfCn+G;jCQ_T{!+}?JQ*wp862ys(#*`RH>i{hWsuHSPZXTXy-1bjX9O5RYY3IKh$%(&wu8funk1?0PF=;&lp^G@=yw z1xp&)DZ9B5xh^T_OVoj({W-9YB^ye{k~LcvYW;LX2o-H_dGUHnof}~!Fb(MBN{)|n zMt&}3id)HFJnk?%GmJkD4~B|5A$<}GA{buA-sjR}-u{P&)4^5{YXBIRUH0X~R(H>3 zyJJ(~j~L{29iCQgpT<61pd*VaAYbf8N?CY1Pkl%3 z#b5_Nm|*26dX~>#&@mOn5f5{`;g-0ESPK0G+YVg~JL|_IWfO5mx@?$XVW9V2JpLtng}+_3CsGsbuv`E8-{uiq>1`B$x<7t(F^O z+5lAK&Q^)h@X3hqVjdIr4B`Ug|0p~jyCj)wZm$}Kb&KzjZ!!~Oi0EJG`g<-O^juWt9WAABv|l$aYqzO|O(hJKy1}gOPK%)g zD-Zp-K9_k=t4g$N*>Fq*r5Ul*(!EkgH!QRufYr60|$_AIi!=Ku@ppJ%pjlir4`!(&}}@J-Cv^M3)% z%Rn9&1JE-&_RD#(fW{Ql%9r&)6ZoomsO3-i0D8k8W(fbDbPGe=7ueZ{shdz?sl6S= zr6JrH1o39Z!M{=)P89FsR<`@%8E`2tyWaa}*K%TW9%m`w+?~V64r`50oE{4YtDpT` zR0n||9~&tWMF=~DJ&rhJW+&3riSirQMcT33Hz}Va(EHiLJ!ox5I(%~Emj`zW9{&$M z-K82G@wpZ(l*ORle(h=gyDHgVTVI%4g|RGbamC?wo986H0z+b_S8*o>9ikuv-2VA( z|21OYXDHS~rpyh6+q8!=R;RyiU`(_L%*k5j4K@;;LI)hildZ0&R+_0j4y(jUF zW9spd+c%?2@T>Zilb(Rwj|~<{u-Ewq4+?@B#S315;e*2|p6{gG4`05=w7K-zt|si+sIt* zsl)3r4_0=gqcpZE56!qXKwlYLY<(~)>9jj?UrPH%Z5nC?JX%Bw8emiA&1_|J$Lz)6 zIOS19w8lq6XsyEY8o%>^%$q444v7It<}|e|PAH{i_^Xn`tsNl@6-EkuR@X;bq93Yj zRrWoExh_q75ka~itDP2>^bF0(y0u~UHmf z3udUgwSr^<~vVuVPh|+{>n~y~%F#>~Q1uBsPkmJ#DYlvl1uAs1HdD6F%&#g$!L4r6ofW z)@J%pyQ_)U(O=q(3I7=QO@>sOsFF;!>NsFmgRUe=g4VZ+r>N7Smi&;%fMgD&EX76H z1c=3>P`b0c6VtV9zo6ek@VH6jHbT7t$O?bu>|{|Qsnrv!06eaI?NzvVr$!~W^Sbia z9nN^|jbsx6mF6-D^wNekpE-1d=J4U_-jmNl{HcdOPkWKnNrBHBNDc`kM_nvd<(IU% zeVPO>*=fdt-!I(Z`a%vfg9<-buzFjYjK-~dSZe;Lb(~{U$yL9O8S@jf8GtPelF~kP zRogWs+;3T4&Lj3~gQnR?_%?Qkg}?hEEhc%UkGuIwS0R!x01}c%ha0@|0G^q{3DEC! zr#nE?w_VXLKTeYK&+9me5GRAP==i+pHF#W!EA4p+X;*vhiJo)eg6B_2~%{^chMp z9O@u ztSWJ?5 z`7c5e8;f&p=Vj$2NrHn9nN zF%dy5G;G7mngCNsOyRHOl9o?w_4jsi_Gd-O|Kux}qrdosfCSzglnDG(QF%E|wcqij z1TF1Wi)wV^OEF&&;(D3@dD0cKO2$1YTO(_Em{ek&(Z_?DuiDlTIs;6~|4{r?9RL|s}uNNr1!jb@GXe)xTGE{}b%(M`XL^-^B*F^`WA z^@Mt7Zb`=n#Y?ENq-#E$< z|H7^@nA0TJJ+Ge?SF@i@ezYE?XIrrqm3%+0i0)?yLp#OwVg6v&5xPJ0pUN`5()fe7 z8>ZFp7-@f!+&Ow8K0ATfmu)bY(s(Tj6Q)^way#m{YhJU*j~ZMrplcNh#;PKLB7lmuD>k8n&X-3@NI?V{*ueqH{f zKEdQ4j5#I&`(C-*yYtX9a+C+&eCyxh zOPbHqTUREQXkaV9q64dsfaId0;@`>+FzGTlJIVFl=9oP4@VUHQWMmH(XBkhx{#hv zq8iPblaJD}P1+^jv_8R;s4(9$F%Q? z6IEpwF7tW(s&wNY8C8`SXFgm&->$5N@N5Ikp_^dXpA`%-MiMhkRUx9AVP|U28}6SL z>-q*yrY?gT10KaA8vmu@UU6SH)>OZ0(v@44WJ3b(O<1`wq!?-??m-I_%k`sNE4>9{ z0{FpRvpL6;Gz}C90kwXW*7jxho2fbt!u#j8s|lS(HXA`?T4g01FV%nKQkawdRK-s1 zlw`bXpk^B^BYHRZMUAmpK)mPFpTw8wB-8h@FJ0%*+9$zV5At-=xpD-n#f85uD)sF5 z)u#xrl#?A{3n?Z&I{@6U(fzgsL_h&NMiT-Utsr#3QBHd6@^WwT{E_2h*W%{-g;;Ev zL1}Sx>a$zz*`8UVzT~r4_+f9B45%m35v_`kPFg1wCzaVgT?P>C0Y%etXbS4lOt*~i zqxnBN;$QC=ek9Knuco>0%?Whd25<{z;O(M#X!Fln^pH|#A0Q?BLN3|PNdS-d9@qUiXYM%(Um_y*<+wcSAis4HF6OWf3FO-B zb~xTJ@R6XQy#Z|XKFk0njw!WPqmnSNENRL+0$_0Tz$Ifr~?;EZ-| zOaWwL#b&@Kx67zT`TW`tmFlu;ZpQtXER#Bc+Vl?6{p9|~s~&6bq9Oygg}a@^AAG2s zTRsJ@p6wN3|H1HgL?}Dw;|0th;^u)qLZnd-K{-7Ux&bLgze>AcGZ6+W;>%gMA+Gpf zZwRB;_ZXRMEU5NKin}swKNUbI#+T&mR5HG?fZk=ozX+4G`8^g^-Gct&!Y?m zAOV@5odFNqYH8WQX7!JKjM$$Dz<{Wh?1^K#IW9y3H1@LiM`Zqj=eH_ zKlSB7?8jf{HvnNNd3*}EFhqhpbLR)Dny4 z_EOfsv^QPS>2 z`vsPkaeW5yrWtclNSNd&afG_sl|Z*N+(vwVHuS3V%8x$i>n5%D!P zY1L;Nut{K$4%DXb5s(%L}=~tM5a)Ie@jlm&u&u`iy52wpzI_ zf@=>yIz}E4q^XoNP;{-jk8P*!o`@2y1WR((aOV@0j%I}wkiTyglE7d zy2sW#a~o%f6aK1oyP48^^5e80nbzyK)T?oOtQTUN0)@gGRal9UPE0V?ujd4{b`35x zn%rTQtUDMu6lu56y7ARC%+9rCquhDD0R2h;X#Nfn(2HCT!5S)Q4(ZF%?1x0|ZmT=l z1C@^r98z=cr;2y%YVOnF-5TQv(0;B30Dob$;%^`GKiwx9bRX`t^J9tlMBWwF+J>0c z6YCO+2Q`%L^h+TEx)9jh;2p;d&~$7`-CcGMRl|A#il4c*7S6RlaQ_B)84RyV82VVZ zQ$wMrj-pnvgk=7GpXL`~PkvACH_i(955Iez`EDv2Sfz>o*be_qVt=Hv!R>9RdJ0aGq7VUFs^IrQk z8))$vvFx8p%0v21PD{^(wT`e@^0}8wN;i#NsI$E}{}I)m!0ITY|G!Uuy*k#a`Zn@o zy7pW^xhPfRJM3=4q>0dUDq*deGihC)s_`;_82xP1%+I^c8HRe8MTw1H@lyW!yk-N0 zx>i4MDKCA?1@(3x$c4aF!Mi!`pw!avjoi_oeqjaK`!ZN~SKJ*g$)s^q$5C7Hs96ZK zO?Qd*M+HN4`-yL&G)iJ&1nG4jKC^`oTG=l#sG2W?0BjdvYI-1oFPL=BjCz`tvjcn9 zkcHbIw6TWaMjtGA6?(z@B|M*tz~PxR+m@I6jbrgt>DN&<(CJ0T8)aIh5$bvqTp5#0 zZ=zEI**LT>$SaB2axCc!SLb4}m#^4yA8^tnU0WiuP*IWjlN8r^AnT}Fsnp}`{gnIq zQpEfO1nhDa9*#nrH+XB+OQIywhG4u2>4MD3Su!HvA|8V9JV`Yk{UaHp!TgIf3=Ut9 zZy|Y&fYm|@+beEY`9cbKhKhNMS>a~tjX?kqxmR8ucnPK)LKw-BF?dhq@rQ94Xjdqlt7HRARCC&9JwbMNOs`uVrD^&G1us?P>ym{ zmFhPI6q9S{KK4#?g8Jxq(kg}mW*#_QdJ-lD(LEu6^wH;%HV)r&t|UB!p{U(&xf5A& zu{ps)9R6w#i_)yVjp6i@g1htg0b{zJ0-OcicvHCJ6U&oiFldnda(J;0jUYkAK5B#a zx0n+9Dl%o%!$1~iLQmzYtv$p9nh4n-G|cNd5q0+v->|}HV*bi>wM;OyGgX+yRpfT| zYwM-w&`|<*85?VEY^)W+XuRgOosD*Sp*CYoLC8tO1Oz3`71D`$3>&KXttQ4AM<%#6 z-^V`2OBenH+u}=xy}eMbftE*}Wtt{|w@rvHL$g}Xvl5-Gs&rL5!`a7)D>FMblw=cs zxzRoTo3xy3gZ{p488Mgiy;SZA%!BM-yBO~yROU-OGWf3+FAetHCwvrx8|=Fl#CE$l z>&CMcsN{E=HvvH>{tik^DPA_|>Q&Q@F;IBF zW17$iF8Hf!P9wrdE2<$qgRRgP>d*oGc@7G8$}ZS>nB5W8kDg2=-2^OaC6fU4D79&X zSy){ZaWFOEBmp}$JJRlOGF?kcwR*hNVEs+L>&ILWg9)F$0#w)@$y752A=#gfu`zRc z%NzN8cIri+6|}f_L0AfS%d!9VmSuhaug0$Z6SxKnBBvq1Ua$dOspJ-B2I~`aS&PZh zmZ$K(GFi>!rK3PT@eZ69<}VWU+5+^Gh3KeUkcFyuULo1wJ)7Uv3wic{C8EwrX_9i0 zfZO7FETB(upfkNpZhuuw{+K|q`P;)O>Qh?8tDA1^V=$axA;Tg))>l{eTGzp)O*Ndy z>c+b1k10ub&zkbwdLP;C3e^~px1oy>LO0AEeV6oYe(g}j7#{Q^$&jsJSj_m&TLs5+ zW&Ek0`T@jx0FeO6g16vL_?%CI{LhYsdSg!RsW)=z#~Xmca9N72`diVU1U7?Mvu&ui z00wBavYWVv82`dTk8(i}?r%J(X%@2El)>>UF9+kEI~-RS3@6djlJz~qh+*^V)yq)h zvL6@NNKb4PZur)*B3=X?NFd&uTwOoHAK*&G|7c#*t?EGY(jBf1rYpE{LcjXXL7oX0 z%y1}}irDsbKBq&K?{s%{_hH=ij}hX1PeI0D8$qpSQjy^K zLpRdtHftP?Yp~I6cO*%A;_^b$ByAwmZ<(H%#kQe0U1Yk8D@NXTF9XDWRX=>n@8& zx!S>?7LamGu-I{E3nm+N<)|Ayr`+@VrDp|Ub&d=-K z+(Y_63qjB%0x@E_n!7@ecwhTg(19#F_F3|;gOWmXR$l>)5q zUiJuUGTyS#iEl3}woVuQa+uNtdKDGDgp-h!07UE@qo#3fRxF($PJMFSaDSQ=r|^Rl ztCVXZ|2#ABj1o(BC}3#f&B@gD?!FyOc@669-0q@#*OfE%i;3YR39sOxEcN9um+ZU0 zVLo29D`rK%zw6L>Gn@nl4A0PYCI`-dGPyCe`&Unwwe)iXGjLG78><|pK@eFUvJarZjM2>9fC0S5laqx4hI-+`QcK|IQmA~lV(om##AdqU&HPzH$E$3HlxT!&T?)>>gnI={)XkTZmj3+1!$S%-yFdU{ktuwtJjj{(orna$pr zvMm7!aP=|xf%jP1@b<(%3;U1C?xMTzk}Te;O1l5?_;SsaeSeo#G~nBX>2^v7600=| zQj;m{+^R?G;>1whSv@|(CHyZHuJa$1w+U#`mow6=+@d4Kw3cTVJVWQ-q z7x>2S9|Fva8hm01AbPtANdQ3=8E}L3pVsu=hJ4GJc6Yc^)*!cCB7#H_MCN9-A7OGvL+~*a*bX7Zpp`D^_KV zKiAM)gWFRJHS*;mx<GEiOdMxi0F^H?9Gt?^F|M4^wI8&d< z8*PV^ftv8Q=R;P-9QwZz_%pq*14ev6!2IKf%(i>gA@8yt#}n2^1})^SJ*7>x<(p6? zFkialqkkLg{OYM$vdzl!(5fWfUY5XKjL2h}UmqQ#YVtwcvcha3BemeJ!4oTalb!P( zOdr;vWbEPXrBP%Dl9arzOq^@W#v%vO$l5QGXM}fufEcoW>EF!cWn%BYNYTH;orUG< zPO^!Nct}C|ZOwu^twiG+HwZxRVY1OG)rmQ;C?@U$ll{>eJkX+BG~in8R51;VE5;|R z%YQR717)71bDKh%sbFuHq`#D33&FIq4*Y}RP#>@A(A%RK_o`9`P`HBy0Hz1KWH}BQ zH=ha8Uvy#)9gZHk3pN)P7EV@gg-|uW z3Q(@%AC51jIOi#&*>29A?f4a9E{ZU<*b`l=&_CNNEJ=mGEW~B@51Vki8|-y34GZL{t66o=Fkt6kc9Er40NJrrlP|AU{;|Uz9X0H zHusAkl#YT-t-oFYG*0SU7anHskZjalI=t*o=MEVv*w)6dh}W~cf5u1aSQR_@i)o6P z&0+Di!*QS>Zcs-mg}ZNiYcIz0QI+ein2_)Rg`|gLJMnsUToz0<(ZZ@M`-v{hl0$`H$0YlQ&ei5<~q3bLY)6Rcz)@N>pQ- zB*{K>QuEAVn2&Z}DF~6bt@0J7n*LXHNnNv zS;|yMg~V!t&-hy{hQHP4Cr|sd{jDb+HGK#Y0O3ws{C(zS?FYGdXHgL9qyT;Pvz+^* z(jkz>5;`6^-1Vo_;x^%LmyYt;L8 zQ%eFX9}{!Zca(w9f`Wi6lHX3t5%RTvu;so4D>^qB4?+H?2jdJkmWQ5RKBVwY+x5Uv zVxu38%LtYRileAE+1(Qw9?yRqXIy>?@Vd_NO7GQq4 zXar4b3-O0bSw7if=(vfnP-@kUZi4k6Pws9+#asF-?T*~T**d>0df6S9Rng}9%QS9q zOy?WtAtlpcFv&{9`gC|jeuR{-o49x21&Mc)6Omy<%hKrobOwc1KJ_4>mAGX)BAqR7RYmdZFi9GAAR7(Ls@;u*#S>C?Gp!ek$0sC*C@q}<)ZT(}$?)-n$xGyTo zGARxkc!cu-ARLRm35UesyCAZydgkY~mQ#MsO{1r^e&)c$bls)T!|1kKlIQb#;?g+& zu!ACmPv{vMymHEwpt!Z#Da`Bvdn{v{@CmIuHIs@AZ6_Vk33nx{G<)TUp6n-iW(d#I zcAhTT9~)>*`_n1a9_#p{Y>ONQH_!Izj;#kHc*?UpXxnvFT^WX zccgkEC^v71pVgRimd?JwBY&>#H+*o8QevjX8w64iw$EL%ELtTZ1f5@mU)Pbj!%}MW zIvvIbjjEGLj8}x)z|r~a3)gFVC@ai5m{I7NpM8cQsWLJWy>W8caO%cV&v6~LyO>V$ zlJnwpSnrMGPg$ZtuTpw>zsV`}hI#yDY^uk%KE1_D8^#wv zeH2d6F8Sntva28TE}c1p%J1~Ko7L2ofRM0JeL`K2Uu-V@>&6vi!ClD+o6wqDm@qKT zrgdYdx8;fFWGHbIXD;3K^sqtWw;aIde>a<-$qfwS8+9R*lu22e#fwLgzwOORnx1S9 z9rJsOdcgk-o0`W`%2ZIW-F&KUd1Gh=*T49b&)X=-qL8_12f^gIXei<9#dL&@v@h0x%H7R?UUOrJ>WC%b`n zVmmnyrL|GwOXB=KiTf^ARTI{oL6!5R$&2x_-bFFPvg>MiSW=3*D9Hph)#Ff=lUb4P ztDx(|Ldq+6oxPeb|6)=Ao#8V#gOzbMn609mr@T#m>Ge|b{L_B}5bgiy{r6dFm%y9= z{#avs88jBy4V2`xz^^V;NA$B%0;j}g(GhoanRs5jvgR~OsLwZzn{ zqr-S{QGaJQN!&tBHRo{s_v7DuJ8V2(PVa4PQwW&6%ccy>u|oq+m7>A)H*?TkM-ZfyyM76>}+L|ES7=kexv=>s@nIU{z}qs&hr2&U2lJ- z^WPJlp2io!3ELnnNA>Ca1UzXs?{R%2h76JFw)S*n5PMJcFJS^-zV4Qcj-4r8?8p?i z9&(rf1URT-v@0H}$OqGTYINJj+6-_H$I##S=HZiVxMGqR?R~{R+X%m!*#Yy+ioL53z*2gO1QIy&r(YIt zpK~NaIDh!-o5!YvWW>hXeD~_!?xor9<^}eZQ|uYK8Iv12payAxoRin2ULTfXN@8k; zsjy7^@MyB>l&F3q5>hVb1ciR2FyH!edNFwK%L@hmPaONpDmj;|FQ>$fZ*xq4Uk(2Y z91ur)Ie^g&&e?YUMl9kl+5q2(5T0Y%vsAZ#3`qGuw~pGr%Z@iV%~ljvfo!j_^>OhC zcKf>&b%5oJTnZ{HSh1Dl;TXL%J6rhL(c;cun2a6AyziPUwN#b&<{Dz}K^7mZ_B<3b z=gO$hnJ@i-UV7_N_Vsd}w0U+xp;OZ1Q~Hy>Q;2&|awiy|4LyS>{{G<2*hpm{n!*gi zR?OZY?><3^j{Q)DxVBS{Fe>Z&9@qPAhFJvekq*FY%TnbYZ) zvoxjej3Y6R6Ec!*AAOCr5Ahs&crndVQOq@=!BRV6_iR-qhlqWk`P3$#;^l4&Re1qv zLau*^sm}3vbyi2YprVqn;xqb@1UK$P5{kMLwqJ1}0Go%uv&+9bgtveGr>aJR=V`%f z(xh62H>`fTOkp}|S`xJcQ0T;Z4(&9g*fR$w+ErK}7hA<2TAXCz{mHHC+{Gq0!Yb}W zScQ?KP%DVoG`?43`4NU@I9{;X5ouli)Xc$kaw^Z^SjKf}(@-B-aT55pBiP@$BQQDN zvncCQ+_G=y_8!w$k;O+<(!#ota?>t;7Q?C@Hg(5ft$ghX4_LVWD+>V5EGnfcu#sl| z!#Vy#%E>^%3;=PnVGHrtl}wiNjLa9v-Nz2NFoe+Lw&ZPU$}89YJosn(7(!vzKDs0} zswE{YRQG+Lx;7WaV+61VQxcn&g_HNk9nni{>}6tZ`agrMYfEDzqQ2uyFgh67P$y&q z;R5ucaeu5RR0?uI{U*w8KKuS*S?Nq$q1r^Imbk)FOoP;=0xQmsg(E+!PbO;&vT}Bm z>Z`8)otP7RPyki%$x+2(b`~I9jf7_L&&^^{p;;lCSSb>ftM+4r0}g9C<2qz3tc(Gk zrRw>CQ=@`&-VQG%el}fMRry%nd}nRuvE{(K(Z#V_ze6s9aXN+fTVesrrPhrvQb|b zwg+4>zftx>8Oi#ZZxhv(udqYX%&FE;t#dL33%R>y2=D;^d8*c-p1y5Gt7z`Uo#2%z%opgg9-f$0_ui=Lhi$!5Bsy8QvRjRovf=7xSQ1> zSG1q%&Ov2#rDp%`HG9vzY#yrELW&7%#X>o9mJ~c8#d}7PEB!A@G;Ve2`ZgrCN~mc4 zhWXl8J3nX?KdzrUuqO~hQOr;DQ7U~Y*TgRlgue0K5pcVLVJkGWWa%JhAz?sRYlB{u zpiO$&{bX}81^eC+22Dn>iHZZjZla z%v8qpue}Cd=C|fX8UI_D8kSV{Z#N7lov*oz-OHm-A_Cvh2O0v?Aq*xT56^&BMQP|2 z75h!xzf)Sy5UPe|{_^=4l?lwmzsHssj6}{{*IDoqnr%>|H(!TfK;SZbaA_g-; z*-+^*x|Xo3Mg+FBNgto;QJe4(#{SknLiXrK)Zza-93u-t;MI+Mp*0S`p&CowfN^TS zRafzUT>x3-?W^t}NYoBxL(94(LVEkg%_^j1pCm?Ue6Au@(*98YJ4~Y_BMm>nK+?nr zXylWCy0RQ*|ASMh%_i)M1c10=2umMo%k0I{Ev&Rg32glUt44d{=HE*BVb8dwW$z*= z+E)v}$?Lo0@&Q2**HuH?pR(&S;McU{iUg$?=S4NNg#uW2WFOOOQ_@RZuM`At7w!v; zwElT5q>04CeBkI>j7Hy=*sLgxfOY3h^GAlJIlW4pSO2)Nq*<)wGWN%-fgvGI96SRQ zCJ-#1Co+TZYf`2%ujGy%&IVDksH>74L@v$2wy<~|H|;P9hH+F?-q~#?JpIl|n*>6p zVF$;kJL>|NPHgmO9)^f@c#K1-GPFxJ)W;rS4prYRPD2jk&4U{Q>MAPLKVJi+ewPP1 zle5%7Acl-YPSDR^z&7o0H!W>&6u2}F*PJL%0uYTa;E)IZyyX_z#sNXe51kJ0mghB^ z>v12Xo)j%~ILf{ihKUhQ3Q%p8qz4Zqr~P z{Y^opsIcOsroa!z?dU)eid--k(=WgpKREF9rQ7KSvwR7Gg3{czz3Z%LMUP_RjocsY z`qSJ@MQJreYtS>`7-=1KYrp@XTWx-Fu($vYw`aStCkU+tqmm87 z1!gG**YIg5NG18G0zSff2{7J2AiXC6_vd7lKd{n-hY$)wvl@$U>_aBW*;%@o6^(}c zN~5mhAG?reZ#|G^$!EXOs?(A8z(T;8V>1Y6Tj&Wzc)R8I-_sXYCdl{X2GLKgG=>+k z&isHSJuYk`Or5(j%gW!_b#;zyWNs((V&zUv%=Fvz;a);F2xo!cg`VKz$zvR~f&GE- z8e&By*U6I~BgCN02&V`YCjW8oE24a)*eJ#$;~$^ASkzmQ#>J!`m{NM)0DI)` z2n41aTsr-=J5IWUe3o_IOlt1J5d7?3cMYu65sSqk2@y|Q&R379s` zs=2T#icK8?PQHK&Q&7)0i{|%;oNtzCg-)qwyFpe-0x6`wgKpjPp1dj?>1o)0qN=wD z2f3a=mU}_tR(yrcBjSZ!BQ(zMVyGeN5{S0?a5mfox1>CKB_nyT;@g`SKMm3f7nQ>b zqe<7n3#XAzUx<9TU?<_@cN>ic*!11BGADR}2>^*uW}aix@dp5jwOQ8Rz} z5{OF?`#6Vr6)yVTRFE zm-82?uCdx7-C!=*k9wcu1RXd3_`=*ZK|678@(FE)aPxVpZg&m$MAu(uZHFO0Sj3IS z))a6VeY;bklpJN?AWPf6RT%g%%iD^%B&95U6Iu&j^OwQTGg3YW(+Bm<0iJ8Lb({_l zP!b3_W8?N2LperyYQi4qxg6%S04W01${Aj<9)R~ZnQ~mW03e^ou6}gAx*@tuImw@P zNwNak(3;?KW{_5AtiAVh#gac1*Go_uBz{w!zxT@8L!pbF6|R3wL^Z&IN#p5xhSU>3 zXczJ@BtE>6=_#37RLi`{BRF%!=nNShLvN>!S>OGW{LyZm@07xwcFW;*$~r;W-I>7~ z*^~)E-Y$`2*IVAxQPQPi2NsYObAuRmJQW?|8!5#Tt-ogu&FB6% zu1@nh376Xx#@6edWHJ*hK-4YepZ8)&oZP+#QGKwz36g__%vb-La5vaNZaWuAcej@yY%8>-g|s@6li zPPE?W&*w~X3OS@knd!JNEHQDzG-5u!ZFE=7_4)w2_30VO!UU3v^`4i=)RDpP^NpN( z=FP73Vc8lt!#}4KhjQNREOBRs4WzXU@(ppsKO(J0diiXIK_Eyc=v@cLCwV7@F`oSq zPfOd~a~i=zlk-(s^GE!C`XJ8nIE3G)e}jn!Z`RLxsbJ0G8*`&yaq41 z-xHn0dgWYN)hV1`H$+Ug=V2w&$;QKpn^aYnftjvAV#=)TX0l@p9t`Kpa5>R#lM~cN zh?N9CNH_ibjHd6YabzElHzBMgmStKGqpaKy!AFelEh-s}ib>%i_DiuAmF--%3c~Je zXi=Nl&t}(eM8I9oLHFeh5n5WWdbzN)o8P3bys{t}rNR7kFYFr=`6wrOU}57zDf<5r z_2uzUukZWAShIx~yRsM2VhclMWDBKYWM3k?vS#11BxFyvEN#{qW#4A9B_Rr9pGdZ0 z1~GQOXU;j_&+nhpdDW}lkN5L_?)$p0`?{}3_11z-@wceM*TC3?Hh1B@AP5+LsorV* za2lG#^DsqtYW*OtT+Mlgpb~Q)t*3<3Phrn~dZVr1$JAflRH_dWuQ%U^ciT-Ya^bI( zOAtkDSTBgaasfL?FXQk0 zH(1KH04E(}I{t=vy8p+~S>pk%ZTDl$$2j>@8;Nz`E6q8f_B6v`{N&0~lde3`;HPIY z?B9R89&`js9WPA*y{Oxd#a-U}O;WiD4>k-jh7UDa9M6V}t=`Y43{89~u1WaR+etL} zqU0fNIWlzjj8mA>xUA}pWDY;sW;z@L?rh-CuhJgCxkJI{^(lZquIRtZyQ;g3E4wMo z-qT(UfRgdmGfubk7Pit>#{~7pcketpLOhdWyQi7XEX}Xa55-FB0=R@z9~O!b?Jo2yFV@m)oDg5O7EBcbs@V1` zLaCaTaP-XBz%MMW7ur%q5D2>09teur7K>U0%c)0pOuc!0@Z$tj)U7jNN=xN8EH9hC zfjBn)0^1yfOwWq*T$9WXYN$>z@ zHI#F`^&;O%rC~x z0lFhd@Wt(EoT1_^gcwaJ1$MR$W6omoaJtL(n7VL%G6PocvN1l)d>Rh;8LJWM-tlJZqw>1t$$i|u;x(mrR)-TA1hL7^#`~Gcgun% zAVW~jxC$X2<KW?=U(yqvJyXpkMKeQr zV#{=ISejNxF%vrE@MnZ$x`Xc1z8?ZlX?=SQ!RSC}c`K6}@wFw;W;)WCB-u)r(x>qV zwzP@2_=>vOcFk+HolJM&JKMAgriyjo!%48w+Ro~Gb2sc4p4D8}AU3E6%2KI9dX0f6 z)Xk#D(`sx1_1*@Y>?vqWkaI9SxLU@?CfK7Qt;iU}@`s-IE9bf~VEkjR{jO8BdN^%h z5H`f2cf)LzLSpt_81qSg03ScZ;}kEEf<^dl;<;KxUrwO{^k+81LH1T^S`1C3XA}50?sphxG6An zBa>R!DSh|r^-3DWZ^dYl*$fbn<$3tGHZCo*{iHa#s20lJY5@WV#vUI06N2ZS$WRm9 z2t$`5Wh+V(8!B*cVNBL%4a|C1or>10J!L8N4m@pa^52OPz;joRKe{pgBwFoc`oB5+ z`{e*h>Vyx$Gqgy@wK2><_zYwQ(i;6>tE;Z>?3GWZhy%bL;Ja*&uNWC0Llv2JbV3c% z1OU%;X7|!IIas)F_)~85Fzh^)=aNm+GyG+Trtb~lYiKb(dCn~OG&gPGGKC&o`X7uj zYhDRxO8(SXG$pGZUcOxsXqMau!Xz}9eLuera$Is$&k-hTyB_IXv=nrxWQtI`6FwT@ zM`z|bVocC*mMo8MS1KYyY9alr__p&RL(UbR(59N8nz-ZZ4uhV^M2bnEB2JipGz{?zc7QC1$4^gxj+6p zGu-S;C4EH;@0=?<#(Qz6jpxwUME|IGnBI0f1sh5_MI#@r8Dw z+zBurx4e~hI4tx05IsN!86^R~i&YqtFFt(4B@I82i$VdCpxwYVmn{&o4F1b#eLo z;haETDSb|I1EkBQBaQ7fRjbs}Z^t_e(>?LoXZl}U)=c7{Wq(ofTIUvf`|K;EX$P07 z)=e9$i~O-BdAVX#0hmb}!ZZ|4dJ`Y2=rh4zEt!6I}MWx3xsv z-&!_(SNiJRz~pje;BxN5&g91ynP6b>`RQwCr+9%Y$-^ovrP72*d^hbmal$kr{g$v| zbs2rri`4W!nj^7ew=3IgQ{@ThF_rDepu)7+D(Xhw85u&Z#zxI z0ol$=1Ijbp5tw63UnY&>jSi^^B|O@?&_Rn_%D=*FB%jE*mg9V9y?3?!b@+^T$~b`hfIVb!%&@R&pE$wSN!Io`tEq52thrvf{?9LepL%#OQazkkOMvIqo6OmL0Jknz*n3t3n>qt&r;8;1__G{(dX6@t6;XDUV{sL`AmeiIIiFqO4(EsLq zk_oFH#mMhB=VqI_oqj#tH}O2q2>a5o)TxJzF4$UODfhmhI4)+fP~o0n2q^8xZq^zV zi&q=_sAG;#Pep_*?FA33$iabU_&SCj#iyl;AGqf&9?&UikG5*&!W)%H8Yt2VC7xf| z*Ft&6g^GG$K@G;4(;Z>dnLp5{@!R4oV+O%giZSB`<1}!Np|n+M(+R7WCBc%4X*?TE zd5)f#UY18^|Goc|01xkVJ2gn|zDn8=aWQ(YN-e!re+jv^i$ChH5aCKGlERw5*va@* z79NE%J8wDJIE6-jNVrdrU<$wUjH! zsKF5ub{;$ai<+S7fm&`^0fQRH2`y`z2!+>TcVEpEi{0ge>2epeMg9BYzG+4J`>owx z&<5+ay6NbGH-o29u5H4kvQ>=DxQ{`=}wLrhfYPg_fAM9*J8l zAMYEoIcR{Xz@G1;l^?lrtm#BPxD#m_{7I0+GZ?B8zBQZO{r!+Ex08pA56Ubo2zkA{ zyK=AUUV-wSRg`I4c2B70cJ2BV#(9yRS?}|j|5iKZ2HV@~Pd4s~2mI(9NO9fzUg4XN zMQfH0cC(RgKevExo5n-5!P1I)n%<3H%{ob9mvcRjqnY-0WZjkZZM_YlnA&zeg3F%; zlyugx0(N?|D`3Ka(Q18I$4zHUklDbZvMcbTkhYU`uJZ^JZowM+omeGFnfmw~GjYhP z|0jkR3x8iKX}OsgdO2+>IrWyag_zmfh5!Gl?Ok_}Rw|H8H;GiT^fe|EF;M2?ru$5j zPZJlPwXJP-Qic256nM*CPzZ2$ax0oDu*rMbdO{#3!)KAIl6j;-o@k>b=C4Om`To@n zom^X=|5K5>UU~a~n?UcSMW_jD55*_36B3HJTczAw@mbH*jWJk#d#}71 z+MgZBE78Qfb?Ig?Uo)^Dp$y^4sJ|*1o*0@e?gxMUt-03UD_NI)XdHzHX^%-Y513cC zR)ScpPzZly0$CWh>$bI6TfuX`bP4{1PDvP2Xo+|MkBTBaK<;lmC#qW z(8Qza57^3dyn*Qoalymw`i7Uo*N6Cr_#VFA))(H*TG`m|8>c=-tf2W?k~^%dpKe8R zr>woEse+!Xxz&7Vm+blBBViTY9n{1oKKKYnc-z8STjTDf(T}Y~lr;M#!G)-DZ#nHM z-Gh&w+*o^ayuW>impSE^$;k{Zm*Evz>a!oHeAZq%agxDxnVM4tLwC4Q(th7S)lM65Qfa>^PG@v5 z*=K#$G-!ouR9H-f=jHeQ*QLQUJG35w2L}QxovNe%{Om&H7_P%uF=xZSqKdm=_F*BcaapJyjw71MX>v9|u|dP4q6>9$pN9B4B)q~tErLn) z;O}mcWC8sCZ*RK`LOaZ)8iAt zLSLe?rc?A0W`*!WtWO-}Rn;!dNPYD{T7KPe_ahtz!s%z>vyE>~w#E6pZ7p5cx*>H} zQs(2xweo*FT2Dm4fSz5S zM8FI~vmla3O@pdlc>mhI7AaVInas=^#dRl4)r(#63>Jz}jUvP7h^rG0!Fg-$zS9Nl zLBXb~P`5|TyvxGhW>D0^kK8EpF zao=}T=4lqsY|fAv%O$JiOfL?+UPlDB?0wSi7Mhv5uPh?c@X~m$W+I%8TCUS7has0K zx9@w}>ET-j3!4r~d~}nc<86rQuB5U5(*ne7?tac@a=rB=OP**{3GARti8D%PC?1+2BaWE3Nisge;Iw((PKwk;uVT4%Tf z!{cK8XM!R;p#%0cJ=a>4o5l_iVZuW~WeKcTOQM5itMHKn zoL?GHu7q_(Wb(9}ooI&N=Rd|~3~G^<-_(<(8koFv)NP-|#mQH}^!E(AC3>@k)J&_2 z*R}zF7veq`5vOB*{>*a2{<*;pvpHbKY#$DdV2K>nwyAjnq*Vjwcs*OwFP6^JRM#0< z11RA10$?dy@IR8S6N^ofhkv|zqiP&H3j*gyRLq0{xRJ5hA$~WFOY**+V-IU7YwH#6 zmA=KE!qF(OFRKPn6{6&k9wkl8Gs7Qc(-I0$1Rp$I;|k)!if;7){K5dh8uGFn&AQ%a zcCG^0p+}PNPQhEI1pVAKi`uS`w~h2aDQ(Xa`iBZHj1k0W*jKSpn|9=Dq=tPF5qVPx zLNT8Ukif6rf=_I7W316>xud8-0VpQGM#;u)c%!v|!SNn^zt+gb;QOeI;7rMnBk@bQ z2}4);KHyqD&&gQ=lKb@`WfZ@o(Qoaf~Cz0WaXju@SG3 zxk9^5>p>T)_cy2RLM%w69roZ|#DU5z-r)35=~yMm0Ojz`;G;vU-!}ZOO62m!wH@l! z-R|mgs~ZVa5EFgY_j(t)g*1}Hy#X!U@#i#-udHu>9{0F+LIBM42J|m*B7mt*ztQ_V zy!)qxWm=E+_5PPd(1*n>0&be|aXzwvx(Pdu>Y3rab|%{w^z>)SmP+LeS?w4nJumv$ z{d|NWhbNn!ucAzErpA}i5RX0`6$=}3e}t6vE_z#D16{9m6~*i?toN#vHq0-EvzVtl z6hC8qotSw_@G9&(ZD`6b3$cKOD{-1CKfLb^1fiLx3h354IWRxMqrw>#M#5?<27zl5 z*+LLM6W^59*BxE}%_?%Jiu1`|Ma3&9VmUHC#>M>cO&i3K+FiKZ7*_ZQznw0%hb7#w zfw2;uox%nC7w*TY^tiXhHd;cP#S)BU_htOl7%p%HxPDeKqEe+xF7Tur zauEZwsJu^2&0AF6e|FD^!Psn%+eWzs7wITu={Kvg7XArQ59a|YhSP5A@EA(q!6(tU75!DcsR6xG;V zGj6Ny#qAYBsImSnTpg$5Y>^ZK%Qx{ko%ih?+jJV*wvHZBkk}Hc>Lp4tCIw#xpdt=; zX@-6csz^UgC&1CHu7V_Az$z>56pq~uM7Vkq48UBN*iVNg!ee*(R)0chw z$$q#&gs@FJEG=+rGJ1IB(3KQycywmroU7dXns%k7#DNzrA>iU~-%yLc_=8jHr+42$6!qYfpVoyfpC157H;? z6zs;zh#2!NW6eeE(bB10G7+O+2;W*TQ&<)K@O3o#2InE^9!lu*EIp-Eo8S;Xufb%Y zyPB%d8&P1RxqS{NCX;p|PRZz)ZNGc~n#>_iSJ@p{n+pj(sZSFNqX$j$8(ajXPA4;? z)Y0F>5_tgE-EN>K zl6$7rOR+hjn@=3>{)1;TYTSbjN&O;0Kw3w9?fsil_l9+;&)u|9@uKZBHkWVh-(>ve@QW&c{GB39H*@Q8vWf;}YsDx_x`JJ? zORdRn(9RPErJJDU-z)7Y6^9sC1gvU5a>3TTKe6JY?$H_Ws$w{R0`pvYm>1#E<#v&M z`{bFsThpnyxx}0#9Yje>ZFitmv}BVt&9wF^lW{Usn<~pT-WH|%C0Iy8&@=YhvgG7B z=EFl$3%#ca9Mn5EWL=PZxp-eJB_^9R=v>`XYrH;m82|7ndi|u z;}5<1Uj?m)tx6sg?eJ=^4HL)ziI8E z<)`}6u$w~5WS3QkGP`6Y+O^M)DbvC`{&+RKn;YHI5>CvADDKj}Lwj{eRyNSHsNp3zf{)U%heGEvVY20?2@h9 zQ=5_{Wz4Z0(`E6p2fLF^W<#qWuQXoB?O(9n7OA+8SiPj*7ci`KT3jJqmi5gTt#Wyn ztEuf9o)MdF<(vx#JPYk$%3@Zr8>~XedrLIr9${S$U6#Ievt!vUy0Sb_!%DcHd_O~E zXv|Ro?bhrQF`)b2H)oKLBxPg+K$?u z!|g$;^hsTGw}!|$1qD_d-%Bbt-So+j{Kd%QhxoA4S& z*0wQKDiA4E{d9^ypTEwDu-=z6dy4&$c>dMBQHha#8^SuBF4Gg6+rx0=>>4$G6j$Qi z1`T~~P;G_{O&j@%G-~WM7jP@iX0&d)eR)$n&L`mmYwfR1V&KT$Vry0aLs-)vsHfPu z`7IR`MAg*ls(hepj!ibn?wEZy8jKzp&luwFt?b?9xh#w$&{KGLux6(4P$aZ)$HBE%m zPH7#)qS*u%RNFkMXjmE(!PvWPqe;%>3^_iJA=+-w#ix$V&`fLkT)Gpo0u6-_ZlpKw z-2(AjPxrlphFH*q6o@nYSpbevJfU1Cc5?A8S%lTi3ChCgzlYQDD zj2(5mY5PbGtZ$jrC6^HQ6>5(}e0L`=KJYu#GTv2x0>Z#s>fGmv#(J9qBsug#E7^;i zJw>tXo~TmU2@~`6nB`qc{>xVkxe;3? zEhhu&R|mPIb1h27dMZB)HS=G2-l?sgMMheLr8LUNBUK9Yk$`8`>dqQut-WocdJpdT zJ6E>#TR<#2{kHP*C)keo)^WbXC7;ywd+u?%pamTl=oJ_D$>Zb>&xrX2!tUlt61z>1 z4Ggb=-cV@4_4K)7U0Zuqe%{g~{MZdf`@~1N{{v^m(sjx#a$&o{>+bi5H%T8WD*{7a zEGnr@3$+&bcge{JK_{cMO1|DU^V;&CGmo^85ZACIIyr^MIWNI6=owd3 zCnwQ|kV~HA5>~xkDW%c0dfCHrc;%PggzF1-pAlIdP7s$gqEd$l#BW)w-f*HLFHjR9p~)=0 z=CGB)OMGQoK_|RKQD;eMHhD&~byH>evGBVl5Wo&fuhCesSXCVfJ{)D>JlnS1mS?g^ zl*}W>bElZ7&D!vjDW7Gh{>A4Nfu6D?=FIZv)~|gpKC*mQf2LkIR*)^GP17}E7q{L| zP1vuaS6$l`F1p03^oRQc*i*p*hsBJZrx>SjB^z-*#rD+ePImNE>kl;UTx~XH-ome1 zaE5!Mpg))M8C=m(V|h#ovSIu-1tH=ino4d7fH-d=LJX-}pXL3HCLa5HwL#iqrME9O z*L~GzCJtVTGx*#P^DE3$y?0#y+X7$bXt7m{Gk}P`x9N(@t7{WmgBty3_AY`LxCu~1 zK@;H2J-b^!I@xt=ZlcA=#CVC(wU{8N5FZw%&qh|29G`EGN-1 zxf&bt=Lz=kQu#ZNijq|wFn@S0YD&jJ|75VRc;QgJ4#|Yvx~V%- zJLqpjUNavBNH>)7jWndXxzBAr?fK3hm$V)lm-zb?t3ZYN2 zCS}`s=dszJs`4bqVF$9F;nfADif2Ktux0?VtBJ2CDBAmnppy}Y1yg#5@lVvR`*W z{I)F$+!qf@92H4g<%dUCeNxp#K z;9O}r85A5|j6`(g6-Q{Ie%VVxdsk$_*iBsbMKPn{oD+PO=s#UTa?pIbw=@F<-Fo+* z)A)5tn5wcV=PlZq2#?Hln)YR$e80xE7L+P3U9h6mgp-qh;@Wr-DHp^Zug0AF;t@Yv z14BtksjENvq#*fjnS$QyoYpKNHtBdesjmlhc_fqx-Ig*#RrlIn5LDxZJ6z+AMk?)F z!9s>-*}*xHY5RQC_9|Q6K_&CGS=5YzBiZ4hT;>T9%qF>XJ`h#SoqRH6^yx}suQZOj z`TDAm^ng8#8b&Qgoy0e%Yd zt}qPe4RzW*Xps>S8GBD(1+A!;=6n{X zEDx^_E9}|&Jg?-(qdz878rZ7gH~%PsuXinJD|n1X70YPkS6cUrvtWfOD`G(MD_Ip6 zGq5@r$zevRY#p877VE#uw%%$UV{+!J0H|!}MkNREqk|vuj%b$UCq`Izs#)D{l)?E-FdeU$Y2@y;|LghX{zD{liQTL2v%XW&C#yzlN~aH}p%zVwMk z^C2~fs$5J{IbpNCehDoq;_-Ceblbx&PspaKbSvZ&<82OSYAa#$IwJ7Gm=_Pj}GS!U98 z9cKqq4{YwfM^--w=_7tygoHqSGsKwOTdBn8DLkxyt+RW;o^umWY=3Yo zchDhEWK6vMxd$T-Y?0ZKro2|kBa-WdxlS}>>4*eWhoAC?FH&x^HDstTYi5~^q~;2A zbAzE4qAq#*O-pbq={C3hZ9%IP7fwMp`|2q7^m`S==NUNKwHoAOe-^*zAEAEJuy;)Q zfOHXb5XDpR72Ml8Qx41ZNsdJw@4F_jBKWGWC{9*V3(z(*)yMw&SU*75DkyUtKpMY7 z+mZ7QiXPyt9XL(WBG5R=;g#`7@T-~^EZP4x2&C!JdfZ2bQjGU<5@?8vAVmFVSO^FG$%gYFx^40o4O|J|TC5lqO0Y}5 zS9A@5NR`5_Tvd(vdN;fY_3Mj0%1VTvz77@K9)y;jY!yZ%?BKhRmoCXHZJhQxp_uX| zC!!r)P2+0cdjQc7+;fv16nk9PEi}q!CDf|Ow(^U4P&c_M_{i-6-h024&U636joL3> zb1QPjqj%{iq{>hWVYI5T0#V`z3zvPUYs3-V;VT^Ce*Y|_B++6RZ(vN7Nw37dbW@{S zwqFLLcY>h#n2j(7*h>F!e%*pc4L{sc z_i&28yp~4M9e0N=bS}ilT#i{OPXk#sKI`xI3roM`pR0}e_e?7uQpg3EIA8D@w(Q?{ z*nnuC0@QSwH;9KYj*xyTx5zQ`4~KbwPk1Sk+z1N3JKz|L0Ux}fh;$H@HQJBbTBkZx zCTLg6F@cYFmO+A*P)G|nA#B87doS!~DON~=ey?mT!{Ii^xiz=yy1sGB#sf+yp>Xj5 zXdzN!@D=QS5QxD~DS3>1`R_+rsCszDFICo^3nUL4Pp|;hvP{!mkQQ`{09U;#3rzU( zR!R8QY@xFQ)X9(_$i8j+cJL|T8&+j&9;seqCrq}BCjOqRxpsL~Vv2I=cJfPlzXGNV zl<&(n{0WrsFbnrGg>Xh#+r>{TpqO0Ym_3Xv?tSGv_OXp<9onxeh9&r4#uV08bF`!sGQ3Xx(&c zMUE~oI?fd*NkFP>-@N_Y^Qr7SL@^F-+6~%EDT*%Jv3~wPS2RmWOFr4QCBW3KZIz#n=zgoFH6g(td^)LDO^vn0`t*VO^{u9$ zS4ht+d}!uMxL%3MQVU&9T;<5)UyIS9F`>k57VAlVCbW?H@Qv>{S||&eXr-dao+46T zFSY8e{c;z3C{py>ot6jcmQigLK)9^&fEO5p^}HV|19~^Bi>r;Gd3qpTuTc~4yWNrc zSszs`+ghp~&lGeN%^CZY&TgQL(-feo1xJgS1>I_~DJIt1LMED}yG7R=>azsg+B?an zW>dnGp5cc#$ajtp+}Q`w$phWd;7546`GhAW&cXj;rqu2QlRI_!DHyiM?kv22sz+V) zsP?75O};ceGd08Qun_R2d~$j4{~L={Bi3SB?&-sv2-w@KAGn7Jx(L|h(OA-J%1xUO zc}n6+o(R-4>_~aRz2yDEt$TT7&IB_kG86fq&>&w!1>EdKC;#%CD=ufeUl63EuL6S= zD4dg;Dy3xbLSL}x1*W>oak8uiENjA04~(9?Tcp8VvVchxxrMpHwb|gGc9M@IX#9bD z(QOrc**?cCSVAnG8A#DxU>jM3B#Nc5J( zM!J`$NtJM}8i#>by&W&`rOCjAmCL~AJb8ifg+QMsCkyM3?*3J<1lHF~&%0aO zwZvwN=shd!A=VvodR3i&M0g@BabY|;NdHTUu=Xy*Jn!d@C*ufE@Qb9Ta5RIF>KrOU!=6l_&J3FU)+Wg)tnhQ!01WR&IUsa93Jay=Kh)Zy(Oj50!Z1 zkM!c*A9l&wR8_X!Vf<9|bal5h{075Ri^PaK!Jk3@Z^;mJdvrtf#@F z_%F%zD1JQ`%6yqE07^Px5@;JHL)FZzs@}|qWIhncc@OiM2CxVSHe*qo#D7vR@WbNU z56fXXkiKwcJCw~NYgG<=DGD>;orGr4=u-Erm~gSt@>@s2A*eDCjTW~PY`A~DX>!skXr*v_5A_mS)R1~ zV_>S;xOX1s+3BoBKh*QHT@SI`z=H$MOgPnmR*~&c+IlwS6Fc0Qq!t03+RO#-ER*Xt z%znm~^Z)+(^TT+0v+r?H$@VmMl?69r!ggfzRWi~1jt|5VvmlnIQL-OfVti%;F7th@>6k)EufX zK=&L5hMFGZjF78?H`*lvZq~Al5>QKnum)m>LGFi&T_Sm%ovq?aKf3_%T(n*GW+Tl5 zE(b@;-%#`Db9D>GDT3Hx_2a2HB@P-#Duuz3RW)){$#(Rr(&%Z|&B*->>`F3~H8!Sg z<+$`PFx;OytlRNX8&y4XJ$qTfo|4Sigh3CPjgG8QcvNC%Lx1Q*pFERjSxy?>*h~01 z48rh(VT1kn`gw1b-fGfrlXl5H+0>8f$yWo^>WNg`wt0|zs#dmUTK<%eY$Qg!Eq(%9 zZJV<*sR(v|=s{9@j7N>}j}U|1Xku2Jup=3KbeF>I>%`t-0r!n@o)v~; z#1SoLT+L!wMuq5amaZT9;9c-_m>|+VMAcI?e1=Nf{+O+xd-+>eka8luI%{t1p@t!~ zA@=w<)*xy>OtE2FBLZ%}vcFivSLMzzIjbAVg4&R-`R1l+A(AKS9LDaC|H6v=KP|vd z{re8}f&jEi5?&5zCwB=YL$^B(JII*8O~dx2;sUISwm|3iXfpI4h8I}+5;TNoY#u%) z-@|L5_U>__k7Iqq6C?Mh@mqOlt4MGAm3-<0(+SZvStr2OKgAqj!Y&8zEbHNeF#Hj3 za8xVZ-p|oew(v%FgG!hzar1dk!ky_A?Dm}1P|%doBfi@WJJU>tY8kAZN-5UYkTtU)8I+Y&`55(;YX+6%yQt}ie$jKu%OTYn zIRj~Ame;mJ&J^5a@Q~*TAHYl!zX1{OuO5q_DHgUikDT4`jmcasZ51p4Nb5u|vN_2& z<~^BwNxDAl`JaI>04jng_D{>$iBREZaB$)3xjwRs08MNBusCywvb}}fbj;SPRwn&( z^0Rz+cDKbtcK2sxGDjSfN}F0uunSPt9r6?9>4)?axGz}6ucbd$p6Wlk!9{5zADz8q zQ86U$ik{nM#Qer9ss~hzY_w)+G%)OFlne5m-KwKi6vi&?z)SVPD!fX;3c9<53JM;X z&(QQgb0;V8){VYr$GtFv!DzmY%x&TEM~xCAA82}sR07l%M3wg(4Lr)6JEnx!N552h zlc_^_)Q)HeQEI~Q0#e}9Up;BpT!TkPq9qN?wCxy(^9kHyo8C6p^bt{rbffQDr&(WSo^T#<#|;O-YChI>2CmEcqt3%V z`w2{d)4x$B&}D4mWXnk{^jzF36k{$D`EvVD+(KQ?W(%Q z|7@-@fC2aB*Fw!h?1qvmi$QTCMx{3{`rwwe^AK5W)#3p&(Vd%@5=ZH+=#f0-bxt|6 z=gOer*3g9bBX0WeCUka2w^-G39;#V8bK()DDiJpu`Vf+O_=3{eNi?HaX#HQY(8NDB z;nW18>VPiJsrgOMmLbDPQ{NLX{4~oX4jkZbbD9htzIxA$$w#L8-AJ3j3Dv`JN&&6h zIryv9O-w894UD9Dy3t+kk%V7Djh;hsZFZU)Bc04Uj9(pH}4J|cOpfZ_kQpr9nwOo?Wpqe?R8VWs4%X2QftQ!_XANsVbx zDA18}t~>{A3qX`v^bB2g<|8$HBbAcN{`Ri`|ESYD=ZU#Q%}eew}9 z?@kYBG>CaglM0Y_XJjUBRls)mNRMO+$seNUgGUm?y_2bGv4QY`PL6pcJUQN=rj30I zBbaz-@VskWiqJEu{};}`9sJBleIckqJ;kJ6O87MsPGt4h<|89x;=~S7rKCW^{b}OH z#%*L!{a9Os*OL%A%0~oC>a5&z5_}wJJRPBGQp>?on9N?YX&vEjtGk_o>B8NLxUfyt z=)H*Hj~{v+3jBjZct&6f>)x~mBN;vU#c z&@btpRKwLY88uArV{i-I--#Vc0{(YYCl62!yEfC;79MIAJ?7$9KwItPg?gw)f?KWS zK-*r>^%Ux|;_dO|aQ=wyaHq(94ce-L2!kE`54X_=hNMVwi2)jqZkIQ#cABdm*dqUg~6?_p64w}hhzIbYgp=?MmiPf!p?D zw5yC2cSD~h-r5uQy6I(3^Q}w5Yx31%(7`D3dVs;&ZJ^)t;oZV>rN}qYlIxVv{d@!j zgN^CC!Sr57bhjw_Rio>jOzWq4Cp(Q8BtM<0tiF|Mcz+A=50@yMCsJW<=>u_>m-w~C zj!DAQVzx1?KMmKelYR1c;Uhvb?GmT0*lSmVh{6N0Hg-9fI#zTtmU_9xd2Z+*%YwVz{ZkrMrPd` zs55mmyXwenY~;nrU#QKR@do^Y2s-#3Y90n2S1(4%sh^`_-}y* zZpj!br!(wMZSrKaYGSEpSSf7c!<`7ACwXFWq8=Oxdxcb{{P8U2tAfWHC|1K!XZ=JD zL=@S3jL@%|AN8`QxF}J*bDWGBV6=k$j557H@BO4s)jl~W!rB&AktRR`VD{nCv|~3`i_QO>+ENVs+|9+@ z?CssIbFjxZ4`LOAiBGdL24?z1DgwdW2v3aA#9i~ME?1)_rgx%*h%LKm;g>O%^+%Fk zP(RR%iC+e}3sC|EX)Jf23nK2IWbR4VIWfi6N%2EQUrYWW~4R&&#VxY?)8YQT=WQLUhf-nnn)Xw~v2&S`BZqQ`kb% z=kQdS8cN8M`5(2IAo*`_9h-0jlQrJHDiw8oy0jhU(eB}9I43K{1Dc#H8&f<4e+R>f z-H$3UQU^zXnxd~26Aw`BJ;WW4q7BM_FnwbjnP?HbmeG;_$&Z?c7?P#<_v4TATDqC? zde_C982;^DCiVY+xry-OV;=CV5WvgV#UmL@Nt+&-s7VGq6QWzK)u5>nbU5}LSNwV0!;1TK;hvBMnt@|}o{8;6uyc(s!MBp? zc->1lzuArL0FraHSg!s&Mq)@geo<9i?c&Cjp1OLm2`T9rqsMPT9Dx|M$9X1IWH%Q- zmGum1R$)A{E4cU=WG=7)w2~DQXu}ka!=jcgNNa=4~ zM{RzeS%>y@h4XhHC{WT+OPGwEA_Bkou(Y{;R8luRSxpc-wxF9xDC?=#UOuk{dJ8~;@K@G5} z>ra7W>V;}Bkx}weHR!jym-~fS z1tKyW-b3VUVQA0Jz{4YXWZ3C|0aM$SSRDZ$!*B?qU@HidAaNH@oM_j5PV>=ub9lCwhZ zdtL)k;(jSOJU~pV^NKTS|HR;nX-3@l&Oiy977L=Qrp1E`7qmw#UBcIh zV>flNn-8#uCYWsO957YOwUhaphIN<3x65auEMdx`0S6QR%w~v)(1Ied{}SfA(4)k^ z!OK8RI6(Q>7rspEyHVJ{0gj&uvWb-0t)~R{Vxi_Gr2=hJiZE?EC-0M7XF=ObFn`yS z{pZ;6=$1~&t}6R}vvh>gPcuK}!S`>>2cMdQcE?+xX4V}wgb|`TAxyi2?b|+jyjt$k zCn0O!SpBX?)KLtI-;YHlsjWl=l0d?8L&6ZdjUa3Km!oZ%R<+hBHLEhGvR01QP z1G^#Ss!4C2hq4`T?5oxb?l9D7N3ZcUhlznZd0+=^0hH__mGSUoisLu>e%jE)VH~aM z?u4*1@MjR~U$C+pkZ7Kc-8$M;Rs6OE!Jmw&)1pOA)-FDS8IcqNFWzp`71`y9l6|k^ z8eBlL?u}?Ole24k@PjimFX}MU^Vwl&2=@-M2`Yo6-GAPK)O}W9&-raSdU(1ZT98vH zPEfd?F6o_WU?`;)@!`sNxG1w;n4Qeo7j2<0M{SspaT8b$_h8CFZOO8{Cy!$Pbu_^sI8YFE%- zgZ|TB+aFo9HQ$N_C5SEc$Ki>1ilX~`y!wLVDGmQ+&OYUp&q7D_F z0dFA)3^cy}g%TNhpMWmR-X9Ji_96!|G^qKztqNXfT4;S3W-UB%d+PJfoC~;Js*$-A zLATz7i2anDFeI)%`qCHextsg{+Iz3CCb#HsFd&Mkz)_A35G(=A5m1UC-GV@<$Ds74 z^xmXbu>b-hZz2c?QR%$~q=O(B5P|}s2|)>+5D0`Gm>tjmyPEkf=9#&ei+L}^=OOI8 zd+oK?`t7yWZ*5r8W3BM$2PFgBX`0)Vz+B+XRBveJv6_8v3ru1maR}%Ew0ZVEp7W7V z-kt@h?E)PhicMb}kJj+5OGxj3cci|09*3YD&G9g86KFD^Tj+hZJ`?y`w%t*6>f?6$ zkAHN^iJ`#Tme8H*4Xz}lK29LpfI2#z%~VAV@6##MJa3-gn_(u05YL!tf|pax2b#|f zW%42org?NP{8pNsmMt5vAF{@x-*+v53)jRvJQt_EIW3S$^v}N~bU$9s8GO2Pyg3$B z&7?Urnf;Om#{PK1AwX5U=m-S{=(IV}8aaj(Z5gNEsoxh^$y_>S<#S-6utk^cj`GHR z{y+5rHM+S3`ok{9Des-l-QiBFF($q~ z*!*o`B{IBPwzLP)oYyib5}pOBe3%GIJS{v%BgOx0#1W5c%SU9orksuR-hXcvZ@yJF z^;zI{H%5F`deGLaDMH70@(Na@23ki&6f=U0TT*>kBQE{e1Ca0^&+f~(G7 z|JwPcF@aV^7qFO({PFavs+zwqERq=`9}gtFIQD4Y@|Wwwfz?e{q0;<$+a;i^U^ON!3 z6mF0_UibRk{x<^XDKXAoFSseZY&IZy_2UQ;$gBwPla!PIKS@6Mk6rfH%RVBrvo5*F zRwB5=HODSv?v)z&#RtGPfPCm!4bR;_WJK@02P!q}wL$#WW3n-{!D5?%37}LOb#4$YW`j zMWw?z<3JNn(N`^0o)$4+5YO%EEU%wF7d{iLn?fiC*$L&ajZYKa-1d$-f<%2EM5$1z z1g^>6fP6;(-Vz{*6kkZW?@9c2H}n=fF6AxptSS5;Z^I&fxAbZRjV#2Y8;aPzXj z?bO%7$MIj>Ek!;Z7&`t5#`oabN#`V;Qu5Np!o4M3quc+v)&dYBvNwLl2ovK<7d&jn z0jQ+%AsejNX5GJ<{tj}lcsJSI_uyDj(}pN+;mnKb>qc>no6e)mN;JC z*tn}`p~8_*f(s0u z^fLm_bozg1;Li?j)UZ7P#ly|Ao}iMKr(S%WlVbTJ7kD1G-O;%Y&1;I$X~Fr#V(^Wa zSKwM&jg-|Wr=F1GsdsBnYl(}so%r<7%g=8D@sT_=xAojO%0J+_PpL&D{astHg^IGC z@b$b|Sf;fSVC5)NO(F3jb~hE7ns=K1{eagI6*Jf3v|{l*&cWo#IUX^#&;$GiW)94i zyZ8ka{i3Hr`x!<$he7d(7lp2-F*c zazE<(`3tK>KiipseY47VLcYqvJa5VKYTPk*!q!%#Srq+=3Mfz5I9R>uJZMc1U>yW^2aVBEVimO6g@**kv?qYv{jDeiz5owJUd{&*7j%bFDI1l(}8v=(CiTP6^NeS+J$AIqw7&@o=WJ8@>> z;o|13|3s}XJ0K-oM8z;&Kw&`h{;6}S9Q=S&p}#DPF92!!c_F|n4uDin?@=SR5jrr?!8tK`7zkSVR6ccGoB|0T9N^GqTG!<2 zC=G+H*m>8B2ueN1q@m1{#!aarH=;kj6Ml5sedh@Y82l-txft1u?+2JK^cN7Ns!7Gu zr>-vGZ7wz@|FYua{eW@P1{908RF2<5X9q23;V->Ljw#3nKKVtF<|^QBJlTr=bo7Z_ z^JS~RRBMo*KAwjJCMkg!o4;aG5&a|&5YiDsLnB=?@P3~Ej67SiY-rYL`E+k2P>?*gcXz=looXkdZp6U$BIll_D2)+ni`SW7>V|Dh|zxU3yOl z5dNKy*7Y9cF+s#$mWRz5i3c98&7EARcmiC{rGeABr>~avekI+ae}QAw)4y>nRkKwc zTxy->zrp4lIowjje&g>?te<3!eEY1%4839ufLnsA{dweQi#UGP) zm(lQ=SxNZL{3zD|1vqAU{I7B z82YHQ{8D&^Q+>Lvu=kvsvgP|Uund57{$}EhX#T?0rbF+Z3}DB&wA>m&(nN`MQ)7TO zTBXn&Va^rI^Op4|NBsdKGu*dF6Bj4^n(56fWj@Sc`w>8AjnZ(Q9~eFwbURDvx6{DN zNyldd4*Ap9MSWJ_X@rLRA$u<3ZDHs`;XY5UEEMWra2j-^9L`t$J(XnfWu78z+|&DA z(O9IE2Q02*GAQ#^RUOHzRoBB=%!hTX%e~Bs4c5J>xwT~`(tnp#e<$a@L$Ks$KvD=P zCLLRDnF!_dV8+(0UM%@F7;%o*l?gP4JXl~JlbHd$t{is0y{b!qa(T`lT&UN5ObjKw z!9wl)#EBJ&;8o=*!l4NbfBSir#(6Tc^v-9Mzcm_|RW?R)BDacG?V zXM|8h$AK%}aVE_3oaT(t;>|MDWEE@y**hojS()%30jH;b+%UCfOY!9+PEZ4F&t&W! z4OIsOPCKT*nFeiQf*Us>oNMh|ojvC=H#GWCj)*_MH%B%An* zemm5teP1frV7Zon?geMrN>JGFKXJ2K+{W#6w~P4|0Y;r(r(yP4^-aniCznsTd_GFj zyQ$jQbC+8a8}x8qA-^Hmjf4YxsT1t(d6~j$+f&Ni6(!f!>Tufu4O4aa%c6P1kvgZ= znHO%v>?s-P4V=p-uGI9nZ2J8b+5~{pmlHKorRm>Jx~z4poZVL9S6<)xTm%+G!!Ty! zkrwE0vXT4g?@fLW4&RA$Vf!JjvDITB5EtxuYB(s`RmP=YZ&tlw_J@sY>K^li_W{&x zFh&KIR1da zHotjrh%J^p?Jf$S?v~gP%XAZr#H!1l4GW7B^S&^=K#kUrNxcCocPkPWHtw3>LV+TQ9t}nj zX3RbAC(m+q{MS&6baU{8>oJuZW(VILu0NxQ4c8%`zxXBK`ueBjUp*^$!&6MPuJ!rq zZ2@@Hz7kvS2~)3>;Qy-@0L_2ywI?GF;PI=Zpb5JNW6IV~WUVe~PO}o&yB4E$woSV? zjlj5O!z*c~47aS+HzIq*Cl6Kyj{s z#r8RHuV1RdslizM095?jn>7SveSxQmE0_Oga(i-lhbrRCaRe)J?b(MNLmyL}4q*;H z!JwjT)@lD;UkRdCXb`wOS0rGNrI@9PRp7v0HHAr)j)MOiQSHC;MSz5|A0D-i-|!WD z872Me!bkLEJS#h^rM&}Tym!^8d%Q2)I%05oGVJ25%#(3zDGPS&fHy z=h_La&7R_wamhk;YScu)(CXj}U`wpuV5xHmI<|b?;{>r!PMQm_$oM_jO0OApY-}@O z@kR5Zak%peUQ~@ZY~b!PtV>DDL=xLX2LGa<36GSpf#H;J*#nWVRQ9eV?)p=vdldof zsTG@TN-47rH+0zExCoY4>ogqAPFwU$agOn@jMYoL{%FX6aa_Q@GH|t~UDW7zRfLdG zfrvi1K}6Kpgl-W$tT!XzDdF23NPB?|I#@+jdh#Zm!!qpMNR}v2gG|p98y)%E4Q%ea z?`sk)j{o8?k-DzZr3!lZ;QuZx)cnL<0&WHr@*X@W12~G7oxS8v#a+Q$-vO3z1o)*& z3WQSam=!9Q%{FhM(T&0sRR}B=h#EawWNl`#nSpyl65%X|=I?NBlXxl+dW)%K~bfRDS}p!;?UcyPnRnFR(Y-7SfBJa{kgi zK^0n#D0r_5M>knr-*ju9r)3$#_@51s>1hNGxMK;Pt4d-7m>ee=VwYTT(ytveZaigT z^r^oPH_Yi{ z6LxEM%F^o?$Hb2IiG?Y=-zL#x;rU`g*F6O1cD_G1dQ`z0d~M%@i9?Sv`3iv7E$)6` zNiQHwZE?li^_9>PY{JsBufR5DqA~S^`HypnEQ0Jk&B6wwe`}R~W3>wndkWmRpW z+?QR1sqRIfQ52)+{Yu+xxja?yTu`u|^RG&>b|F`)7MkB(FH`iN=9m^8)s&gvtX4V1 zJomPAKpyq>@)P?`>g6x21m$4*;hc}U#M(Pg2J_uWyWFDiR`2ceZNBB}6N*+{6S&h) zBFn757d>eR&ua-`n5d4KP&)YO&?cL~w)Fw45SPZM zTSI}SU~Q#NFBOd zJ^z5-YmNn#@^9n%57U*R-}Bbv*Utk4jsXaqV{*)Tbu-}L{ zGfuMF-}n`LxT$^Qq3pzJ^VRSI5Ol(?_>?j{14?)C2iur%cTbQ;Lfg>J#mHfdVOQ%^{9vDOyZOUOx&DMZ|-YuY_4qyESWhA z^1GlX3==nlZYG6jGbJkgNSN54^fahBB>Z8oQqFOQZg`Bd4aGZ1)?6QY_6S!W@diEj zMLcEk@Z!5Wv3CO{KQ$c#Z6j;KSQlUE)K)1Q{3eeztAvY%D?F*bUj(9H7cUBd>SX|y zT4!SyHsnAjra$dM+KHB#;@F@YB0^VESN2EiR<8}`(=3{slzAeN$5m~PykucHiMesN z<>p7VgZ3XiU*6-9{yzJ_+O3~Yi1*?O@^_r@UlLAH$$#H#iN4I@dH&;}gCf00CBMd= z_uyjh>EDRQUBT7q>WrD2>o-wX7jt|EEP@8A{Wx=a2A#v4Q+Vn-vUeL9+7NeE@M#KK zQl9=Bep+}-S5xjq1LT4w$HMnfl>NdB9SSb?2Gx;S+V9q{AhOPgBUeK_?V8HEU5|p#ej2fbg(#N$p`(2kVB2q}PjGS< zxDm8y3drK2&^eL^tMi<`!dj6uGCER`SW;LGxq%3VW7%+wNa5m^D7^ zJ&VzixUR2F>Ev>!27OfC%BDGTuh=$hBz2l?%mREviuw(e+^(wO#4NOjWt@Ki=zA#GR0$v}@pG+1)2=R*R zdRb|1y@){-7jC}!_2MWDhIY0N+@EnlHHb`ovQU}787|~=v(uh2gP>p4(A;OqJTr5;{Ro|^=1g9 zw}0*5_PW!_W<>9h5#9>zWHT)bHS;4Y?l4!4! z?Jk=5_(;(Z2UxQtyyYm523X+gH^_B8+7QO1Kp|GXvyn+3# ztHYaQR?oBGK(jFc<3=_R_;?L|@PGR5Ig=}8n?tWstyCoMkdyktSXtOe7Z^x8dSQh`} z7o@MAmr1Rj(dG(#2QF7#8#cFmM&}ibRp_Fy>t1U+zdtu-FPk4#u z*{piQ&fNYPk(!TLW0B~3AzM^chI4$F=V6IgF-1sa1F^as3}G07=R}HYl?OcjzyiA_ z2n_JG;FzKh3f=pm)a&8Or&8I@*>jta_xcoDOrUpZHJ8YPnXyO0bRqT3*zpE2ybxmQ zOjQA;?m9l_#i=>}ni>-r?Cs6IT|rgY8AHB;(JkT~*GlZPs&@5vykE9lzK1Zrp>J<@ zOnUZx`_~pA8DSw7<)SQJUrnj#1|j?hM23HzBWB+y0hRx2TPTJL21{&~j`v^*_w)(y zQ9#?6V|RW+c9N^}Pt>KAYX@$Q0qZ**f;!=u22I*?%jZgzn^T3AbiAWqSnG$9#uI_A zmuMqWAvnS0<$D;+3URjOD6DmZp5GPU@LmMBuia&=yM^n(`YDtFe*?F!aH){G!Xk5ZC?sHb6Fxa)f z{|L_>zSW9>_m98{I$pOrpXn{=tL2ZUqvF?b2>ci)vPuu}&|?p%R(_l@h>#6St6S@4 zm^v+(>Z^IHoVWd4ni*?mo=UTD+;oE?2bT1JvokLkRqETl(=uJT-#xnd6z>A<7{pVm z`dL_E&F_)Rtj)_IO8C>L6V<14;9i1;VwBzUwuw6w^g9eW{X*M~f3D~Yx0~c9!y~g| zp>(y4;-V4_+72Q^H(swiOmpjHX1%(&HjM}`A^c>cYG=#h>l&++(PRwVU7NNnEn*Co zb_1mx>8?kc9#LLBw*`Dz>0-Uel**eDL7(%mOY7kn{0}>HupAyMEGL53)1RkVB#=qy zcdyAQ`D0tgW;E{;i)mhkF~$~hYq^m#{oj;`MTkrH71CljT?JC7<<2O-p7z}H-o8R# zk;R4dnAG;dU=EYOT}3u9-Ie4ee-xvypP03w5Ab$7!)TSVo9FFngEXwv-b3+M}oE_k;K>=Z! z2u!9ND=!Qd&J{ax@U3$RJSQu*%|(`V^%Xn}dOnz$Caqwzw6gC!5`WuO)D#L96>1sw zU)=nluA~^2{w3bS;v1Xq7DUEh?wYhXj7fvvE796t1tMfO4ccc6N2$eYG6ESYF}2b403jr{Cx+Jp8%^@J zT=Ei0mOk>CZbMN@-cb)1Lxf2irPZKgub=qUm+#57q@Aa*i-TX)Om-+9xSFl)vN?n) zzpP+eO9CEL8=>-u#Y)jE)eE`hWvGV&Zp>-I895HLV=)yq{qbRnmUKT)y%YldoRa3M zb+oWBQ43m3nkKtci~59Lsw%E+_(!OQQHqH^rh+A_=l<7$1)$ z0zVyy`p6RQwv<#e#kQpF^*CvrTQ|?%jAWm(A18M{<_h5&Md=7A0f(ep=8$?V30jrBhphZio zzX}Wdy21)X!4HO?wev~2B&wjJIOvua|3fjD=>W9KDJxY9mT5g>MC}c@vx0DqSob93 zk!D`J?-CmN=~~%v1;2DB>NqT1_>w>Sdmqd(So399&17jYMD$l51V^3jlCGC`N``@~ zP|aifN4|#Cg3$paaZsR1#G9vD3W1!kS;};(uKJ0USwPokn2=J)(MWMUFR#uh>Ls+| zl_~BXLwJDifH-nbzIzpHtDEd<%dEX!9K*i-bB0jx1-v18*Rb>Jx2xI43b?X&a=RXp z^Lvg03*P8mEJprInwm_QY}SjF=K~BuZWZze(`2#~qN5JMh}+%Mgsx{CJ_WN%mWntn z{F?15tYI;cye{f;qRf)_R(+Y(XU7 z($~eeZQ0NRqBykwlYa(YxmTCXGbl=1tzv~`S0 z8(+R_waC_(6Cqk`?S9vvB6+3z-z$H_*EdHyWL~uUrTt{LwY&= zzm+cFSCGod&~nIaNJ(F9$s$2AV8{o#geJ!g?Cs0{^k4x#Q$|x7*8H0vl5`4?5o#Ij z=0Y|a;TR_UX$N6e^_Rb2gLOTWJOK-Lq&Pb}G&%-3Lll-%#P2;w?LsRm;UC<2bsSheL?-y;v7S5n zPRlZyGW|)Z=z1l5&n2eUt=0edkZHnTZ_P+rv_*IwJiujIw|t$1tcn$v29ER$+@A#| zOd_D)Db1e;WBroC17iw|7L)an4rdTvsJs(Z&eKGcFt2& zv}Zhn%ZgWHS<*$N(9N&p6l}y)Y90m~YVRD^ft~rd^WZ4j)fp0ulaE5mfL|CTu4|RI z=01g;(H9X4P=hw$TZH2stT&PK>B+!$Bwu=UF#LBO(jtw#26q<(B80=cRTZvl}np}}_j4d4Qy-y$qowZVw7GKy8NHILpT5bznXU^jPVqO@q1;O+G zOgR5H2Fd-S&Tl8D6HQ@i&d!i2+J&DfNA9L%7T6h61rfP_ipyEfh_H*udGz0cEvpy^ z%gN(kWpDv4{{P5hb+JJj-yR@36DO=4p66Ktj}#8L2Q?wRJf}kmOAXDTgTevEke*PD z5WW_KHUfg6kkh9noA2|jZIqJ+VX$KZUFdH;)?4!qpV{6XA!t&m!y%`7sXUO&?02dq zJlWW66Q*yEXiQ=>+6|jX0L20N*NaBK!%9X}r-H+iUIO_bEHMhKT>|S#@Ipry-IL(hys;)Y{;H5M+Qt@Yfa*)C7+;X-HO(`uZ`Gde zS-4GY0M*bc4&@mB0QAhNX506aFJc+nzg`E&`<@$Vz!8^f&sZJk?YiBR#M4w_+`iik z-e;DS4|mTS3%dmc$ybILLe2$rCA6Xw$0RE(5y9L<;d|#^+l`GCpo5#VMvIW+=5=A; zPzMjfL@obpK1NWmE5mZfVgLEawl_QfQCK*0Hct$N4QSEabU#3lVvqi5P}ekR)yiU(zT0Rw z4?;=J4nLF0ZJ6(t8#?9kQ>3W@gj7+}4Lm1qy#z^%z0h&Exr#_6%F=5H<~aI;1F;9g zg_}x%?kYG#!OGoT_~Lk#9@b+&Zi^pm%&j6k-T66_IHFufkWveuvXKzt-Tt+4T_2x% z2G%~p4u$5%jR3Dfa} zVffWEzVBiBZXcqbnWJ5bDLdV8ZXGFPX%OURzvQ>+&LwOUo>$dNwf!US{3M$t?ymOo ztk%g2q_Q-m!IIso4aK=8Zf`73%Z$d){+N;K+fu0Wk-O9lyvfsji}gPfoL@UoIaUtf z?6Pq=$|PzQ;O?h z!CiZNXhrX439irD(7=GCROXC}A}OC`ZD3n|AV~q}6S)vh)urvigI?XRIMog`Rr{QZ z3pleA^D)m*ts#)2F#cf3(teZ4y55VVo94PEmN~TpNMBuAGhDAkDby8`6_QiJPYcBX z$RU3X>>R62i$VLkG&FxT=1J-0Ad#&>cv2QTj0I*j%ftvTW+n$HtI%S<`i^}+QBN@V z#$%6vJ1@_*mtVB~n;L@VPbcrgYqE%;`|u=#>aoJS?VzvWlUZRF2VhoAs{=bmAoUaD zDH#mY{82(yf0XTwDge-R5G~6UaFVXqBTde6QUT5wP3{^H13n}UScT?gvqW;e6Qf&c zMEN}a!oarW)rlHANKsNKFW3{JgOfBkB5^~DGVzT>cmNVdJ%@DD^0I@HgpBLLhj@Lp zX!H3cd}tSqvm85n82nWGR`vWeJPb>Y#&xXg((26Djj@uBqhHQdl_0$zRqOQ&s9eP3 zk;U3_>Ljgz{htLofSggycVeA4 z;3Y_}%jy+m80(VK-rsc~Hgd2M6f+8pv5Sn|_a zF4jcY_PPgG=fsY<*qfcG-?4N1mInGfh_nRhcFqo4%*+rm_xi8SWl&t8)>{6K^OmVZ z>n#Uth;rVYuqKK4Pk?`XuHW9F_dhuuchFfD#_#;l?!nddGdyu2yh+3j^h6r|=e@{O zG(Xm6&}lS3zo|k}_QM*6E5zK)**gfb7a6V@sWOMut1IV3T6PR^zSTkjccC4_vTpdW zGTs^;Eai>1ro?JR$O5xZ+3)9aokmZ%iW)M}7#Cv3-gRKV)+AN!w}%!qm<=~K%-sDj z5&kVi@7?IsnL}G6l?sVqgDPcJsxlZx@zhQ(hPk1$w-`0&RHOvaw@>Ag$4}9eBEidwqJ!*biX2b&P%G0e* ztRfl2Gz{d!XYAch6zE6zHJPM#^)*5AjmKA$E8SppeNiBUl3WvA zsLL_#*FRFJb);$}gSbZ+aS_a6qoz9VV1It-4(6%nUZ4d_IVP^W)$w{1zp0y#Q~K1s zeyd5QsDrjFz-Y)PuIDDY7C4XU&Rwc<3v4*V6cOz|5nTi#Le^j!S2ovi9hUzF1y_$u zGT{EQ{UeY0o(vZgh&Bcd>q{xh+w#@KM*WEDgkyDC@q4^(#p_#MsjfgMMNR2~OTBi= z9OI*XL9F%OP87kP85GaCbVdF(XDO0(!2KeI)`*J=fQdtxOzQ2mK+Z#3XL;9vzB?3{ zcgq43I^Hx$T%aqEOvcjDWc$@w_ehM^Fq%Aq`JUF$&*L3QB>HJfP29%K z%@`2}h}G^DjB4noc~MxciOLnByzRG`jr~WQG^u{4zkvF`7Xw%`{QD;aelVY|QtY;& zwJJ$%dS@S|Fh~r$5r2kvy{L$K-*o>THpG0uI%px&P$4t3suBb2RahJqkK37m>7M@;QY=;pxY&36+_Lv^fY4KQ>NNtsvsiQ_uZH=WBqwZZkI#z5SHPr!C&K~mNk zReaRL6wKgs72I9ptXPNP|jHWBF%#=(WSLJ zF{pi(#?NZE54YTruS!`6#nGMR*L*;WSEctI>w#EHB=SYK{ag;$a_(ZP>8=Kd4W-pnQ$ z5Q>z-e|Kzj*E71Q0>s1eKVHfq?WfoN2wcU;%90*Enoi1~bV@t#3*(bas<0Mg#Tv8) zrR|YRQ?yMBWwV9VfRIWoo1O+Oe}tjZZ9_z*y%?M>hLZ}2)YRv3q5@?5!!WDMOpmL! z0DVi#oy!zeytT=Vqi z9kc38W)%yHrfziXsJ`dH3z1pOZzN+^}1yO6uaY~iHv%YWIKw?>e2It zuec$>_KNX{0jJ6bS=ChO0I zeXOj#75ai{tKPDn&W3y1>x=VQ<_->Q2N)#z1_{?>5UU1h379r7g`J$(h{b`97w|CS zx-grhO#>l0dx4efiBCt?aAhMhQ3+`Jprh7+pY`0y(Kkqe{toXorkf;GY|m0jPLyiu z_w{I8Roc7|Hw~9eE#trM48T|wWBM$i9TQC*nVV6P$|dxkC$PY7s)L{*OgjnW8H_>; z;;X{mq3qu4BcrZBiqf`Z8<7Ql@tJ)TcEwfq?8?r_n(XhDdCaqQ+mLmY!&gw9EYgX( zZW=TQvl_DX*KZT2$?Xxdv=fFZ1n)agE846gYKHHRD&UKFeZaJj{ft8jn2TN2@p`QJ zdA=BvkdM_n>*Mb&7-F7+vR}K41hJ?n%<*DNotk5Nmk`Kt-;5gy!zn1zS}U_8U6xqW|K8KAScohyGf|fKZPebfjq&ze$vrR!&N-|4zm*52~ zFdjlDGdTZ*!fF9da0Z6v3fc^NVnIQjzpHZidN-l141@xh!_`9n{hpw+>QlELWu2_H z4|%zj#NPW8K#P^&7_Sk&&{B61@3WF3mKB-3RpZ|oWzCG3g}(w<(WE?Mqb4{u+QoyQ zSl^;LVrDay8OX8vVD^#?R;t(y2PeTDwAmY*5XfBw#7TDO!yWT*ZavyOd_Ph0;Q-}< zC8=OL^!E0CcTEs92$xf^U7J@zx)uDE7sJP(7l-XFW6FeuIO-+vB2Mvw31l)xYg;yx ze=-&Qe*&jy{(k#o?)h%ALR(-@%nUvn!x0)c@+jVc*d6VHjR)27+U2Cn2mZXfu8I0` zu`cpskFT-C5A`N{`fNs-83ZjaPV0oMUr!~EhqMuON{-hT%{V`Rq-xtLl<`lUcbdx8 zcT47vlV0Jfa_9~_7?V*F^?TJXS6oPF4Iw0ZV9zll@XVo+M^&l5IHr0x|~DOetf_#IJxSA$`FWB&}fG`krN~m5D3NFe&QH!_p*gD z(2M`Z%;h->YuTfNE5Y4nWE?_B#2^#?fLp`sRuQGf{CALH(b&`N8|eV{sMM>EW;nT8 zlGI6Ew;0?43a|c~@{pSIXRkY&pDWYeAeBv>clKBmH@@KZd>w`xtEwoAca;sBrc);v zp%4W`lx|n)98$@=Gm1-2{c8!Mz3W@lJtE%my;QG=5gAm;2ricK2=y79BOP-xAd{pp|-8K;bgGM>ZFE3ZCWN=P}BQ!V+>R;W&5bsf{LY}>t$^p zuUziedRA|xD)C3u>fjsGwuf?*^M)?O1n&htTJanG4?Kx7GiuShtn+O|131+wf~t&t#Nzmvf;;vOo0! zV&+pH=&*39FP7eY>E)kTw0ypZXvv&6mXt?X?H8xmp@feGX+c*F7$h{L>MEKFRv25-=**CNL-bkV?{{($h!Bo|I&+X z8)u5}(Nv^Y2#!&8%+3oplO6QPud(aV{_E0zBZ-gvsZozWSwZQPva>j>*~{AzODQfc zq7HxP9!Jo9n$W0}iD(4f3gqEGyNX_M-l^0gTA(FUK+hSOtX;K`KxiXNd%H>*9|jLF z!NP=8h&~s1@SJlGiZbtB{CW%Q(#U^1fZZs&tn{`v_cZSZ+~Mx$WqJ(?U*n1<7qZ zO_Ft|5_9}BNPt^erjpT!j3(+EXi*6lsE7@Zjr z{U`!CWRY%W>MmPL^UEKtLj%W(s&YnkB3!zE9&g@A4tu+Atp&M*Gh0^h9q3(Y)L#1- z2wJlHx(t9;xTDt*crrY|z;&nY)QS7-)!d~e_iDpj8J+hIvcO9JBuTmm-hnP8A-w0n zHW9AkHryzQXXMjMvi;IVPWN1?U0>4lR$U0`<4==!t;+6~*41qIy_M*=iPD6WkmDv} zjYYK$m!{~Cik~_yFo?N_U}yN4aI=emK(5c0y50pffLjVH*dP3IqrJHmDa;BljUu!< zJU~5(0!&aqyfTEco9G=`-AMW70x{HGLrMac>g4d2_ZQ-|Xg{Py%z_M4O89i>_#Kn| zw|_RrCBqWLs1Z>pz&B-z7vv7$-Mqzdwp6Z=bYo}lP)!;xA=5k=6~FOJhA?XK)URoN zMFBOB6?iAgvGWB-_HWskBeQQND1O6lAw{>D z0i18nnMDYoU}I`tUv5U7F#gi% z(lDhbVfN6~tMVV`*4PIqevp~m=No^v1ETyQo{r#HmO5R!|0LP;;#1di@22JC?f!FA zF#YLIqQMcB`c6B(DVN=A6vU>$9Rh|je{yjLswBJb)l=VggzjV~|7`H!_?>d7E;Ha& zIzU4IjqRhYdBV#YIu}%#hD0t|VC-nL+^l165e#JKR*ke8_0KR`HXzV9r~GnbNSddX zKJ~*XY4jgjYQCGswHTs>QdhBK{8p_emQ7 diff --git a/authors.html b/authors.html index bff3ef30..20045b7b 100644 --- a/authors.html +++ b/authors.html @@ -89,11 +89,11 @@

Authors

Citation

Source: inst/CITATION

-

Clyde, Merlise (2023) BAS: Bayesian Variable Selection and Model Averaging using Bayesian Adaptive Sampling, R package version 1.7.1.9000

+

Clyde, Merlise (2024) BAS: Bayesian Variable Selection and Model Averaging using Bayesian Adaptive Sampling, R package version 1.7.1.9000

@Manual{,
   title = {{BAS}: Bayesian Variable Selection and Model Averaging using Bayesian Adaptive Sampling},
   author = {Merlise Clyde},
-  year = {2023},
+  year = {2024},
   note = {R package version 1.7.1.9000},
 }

diff --git a/pkgdown.yml b/pkgdown.yml index 2b0af8c7..1fa81cfc 100644 --- a/pkgdown.yml +++ b/pkgdown.yml @@ -3,7 +3,7 @@ pkgdown: 2.0.7 pkgdown_sha: ~ articles: BAS-vignette: BAS-vignette.html -last_built: 2024-03-30T19:04Z +last_built: 2024-03-30T19:12Z urls: reference: http://merliseclyde.github.io/BAS/reference article: http://merliseclyde.github.io/BAS/articles diff --git a/search.json b/search.json index b33ceded..879d810e 100644 --- a/search.json +++ b/search.json @@ -1 +1 @@ -[{"path":[]},{"path":"http://merliseclyde.github.io/BAS/CODE_OF_CONDUCT.html","id":"our-pledge","dir":"","previous_headings":"","what":"Our Pledge","title":"Contributor Covenant Code of Conduct","text":"interest fostering open welcoming environment, contributors maintainers pledge making participation project community harassment-free experience everyone, regardless age, body size, disability, ethnicity, gender identity expression, level experience, nationality, personal appearance, race, religion, sexual identity orientation.","code":""},{"path":"http://merliseclyde.github.io/BAS/CODE_OF_CONDUCT.html","id":"our-standards","dir":"","previous_headings":"","what":"Our Standards","title":"Contributor Covenant Code of Conduct","text":"Examples behavior contributes creating positive environment include: Using welcoming inclusive language respectful differing viewpoints experiences Gracefully accepting constructive criticism Focusing best community Showing empathy towards community members Examples unacceptable behavior participants include: use sexualized language imagery unwelcome sexual attention advances Trolling, insulting/derogatory comments, personal political attacks Public private harassment Publishing others’ private information, physical electronic address, without explicit permission conduct reasonably considered inappropriate professional setting","code":""},{"path":"http://merliseclyde.github.io/BAS/CODE_OF_CONDUCT.html","id":"our-responsibilities","dir":"","previous_headings":"","what":"Our Responsibilities","title":"Contributor Covenant Code of Conduct","text":"Project maintainers responsible clarifying standards acceptable behavior expected take appropriate fair corrective action response instances unacceptable behavior. Project maintainers right responsibility remove, edit, reject comments, commits, code, wiki edits, issues, contributions aligned Code Conduct, ban temporarily permanently contributor behaviors deem inappropriate, threatening, offensive, harmful.","code":""},{"path":"http://merliseclyde.github.io/BAS/CODE_OF_CONDUCT.html","id":"scope","dir":"","previous_headings":"","what":"Scope","title":"Contributor Covenant Code of Conduct","text":"Code Conduct applies within project spaces public spaces individual representing project community. Examples representing project community include using official project e-mail address, posting via official social media account, acting appointed representative online offline event. Representation project may defined clarified project maintainers.","code":""},{"path":"http://merliseclyde.github.io/BAS/CODE_OF_CONDUCT.html","id":"enforcement","dir":"","previous_headings":"","what":"Enforcement","title":"Contributor Covenant Code of Conduct","text":"Instances abusive, harassing, otherwise unacceptable behavior may reported contacting project team clyde@duke.edu. project team review investigate complaints, respond way deems appropriate circumstances. project team obligated maintain confidentiality regard reporter incident. details specific enforcement policies may posted separately. Project maintainers follow enforce Code Conduct good faith may face temporary permanent repercussions determined members project’s leadership.","code":""},{"path":"http://merliseclyde.github.io/BAS/CODE_OF_CONDUCT.html","id":"attribution","dir":"","previous_headings":"","what":"Attribution","title":"Contributor Covenant Code of Conduct","text":"Code Conduct adapted Contributor Covenant, version 1.4, available http://contributor-covenant.org/version/1/4","code":""},{"path":"http://merliseclyde.github.io/BAS/CONTRIBUTING.html","id":null,"dir":"","previous_headings":"","what":"Contributing to BAS development","title":"Contributing to BAS development","text":"goal guide help contribute BAS. guide divided three main pieces: Filing bug report feature request issue Github. Suggesting change via pull request. Coding Style Guide Contributions BAS","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/CONTRIBUTING.html","id":"feature-requests","dir":"","previous_headings":"Issues","what":"Feature Requests","title":"Contributing to BAS development","text":"wish easily extract additional information BAS objects ? like see new functionality available BAS? , feel free fill feature request! Please describe much detail like added. can anything just idea code advanced user!","code":""},{"path":"http://merliseclyde.github.io/BAS/CONTRIBUTING.html","id":"bug-reports","dir":"","previous_headings":"Issues","what":"Bug Reports","title":"Contributing to BAS development","text":"filing bug report issue, important thing include minimal reproducible example can quickly verify problem, figure fix . three things need include make example reproducible: required packages, data, code. Packages loaded top script, ’s easy see ones example needs. easiest way include data use dput() generate R code recreate . example, recreate mtcars dataset R, ’d perform following steps: Run dput(mtcars) R Copy output reproducible script, type mtcars <- paste. even better can create data.frame() just handful rows columns still illustrates problem. Spend little bit time ensuring code easy others read: make sure ’ve used spaces variable names concise, informative (OK using “.”, camel case “_” variable names improve readibility. details see Style Guide use comments indicate problem lies best remove everything related problem. shorter code , easier understand. can check actually made reproducible example starting fresh R session pasting script . (Unless ’ve specifically asked , please don’t include output sessionInfo().)","code":""},{"path":"http://merliseclyde.github.io/BAS/CONTRIBUTING.html","id":"other-issues","dir":"","previous_headings":"Issues","what":"Other issues","title":"Contributing to BAS development","text":"sure something bug undocumented feature, see possible errors help files documentation use clarification (issue) please file regular issue","code":""},{"path":"http://merliseclyde.github.io/BAS/CONTRIBUTING.html","id":"pull-requests","dir":"","previous_headings":"","what":"Pull requests","title":"Contributing to BAS development","text":"contribute change BAS, follow steps: Create branch git make changes, ideally using commit -s sign-commits Developer Certificate Origin. Make sure branch passes R CMD check. Push branch github issue pull request (PR). Discuss pull request. Iterate either accept PR decide ’s good fit BAS. steps described detail . might feel overwhelming first time get set , gets easier practice. get stuck point, please reach help. ’re familiar git github, please start reading http://r-pkgs..co.nz/git.html Pull requests evaluated following checklist: Motivation. pull request clearly concisely motivates need change. Please describe problem show pull request solves concisely possible. Also include motivation NEWS new release BAS comes ’s easy users see ’s changed. Add item top file use markdown formatting. news item end (@yourGithubUsername, #the_issue_number). related changes. submit pull request, please check make sure haven’t accidentally included unrelated changes. make harder see exactly ’s changed, evaluate unexpected side effects. PR corresponds git branch, expect submit multiple changes make sure create multiple branches. multiple changes depend , start first one don’t submit others first one processed. Document ’re adding new parameters new function, ’ll also need document roxygen. Please add short example appropriate function optionally package vignettes. Make sure re-run devtools::document() code submitting. (sure include name authors function!) Testing fixing bug adding new feature, add testthat unit test. seems like lot work don’t worry pull request isn’t perfect. ’s learning process hand help . pull request process, unless ’ve submitted past ’s unlikely pull request accepted . Please don’t submit pull requests change existing behaviour. Instead, think can add new feature minimally invasive way.","code":""},{"path":"http://merliseclyde.github.io/BAS/CONTRIBUTING.html","id":"style-guide-for-contributing-to-bas","dir":"","previous_headings":"","what":"Style Guide for Contributing to BAS","title":"Contributing to BAS development","text":"consistent style improves readibility code. wed particular style generally draw Google Style Guide well Hadley Wickham’s Style Guide noted . Using package styler enforce styling based TidyVerse helpful, required. Function Variable names: Use informative names using “.”, camel case, “_” improve readibility, .e. variable.name, VariableName variable_name, rather foo xxx. tend avoid _ historical reasons going back S. Assignment: Use either <- = assignment consistent within contribution. many style guides prefer <- suggest using styler enforce use <-, OK = shorter type! Just consistent within contributed code. Spaces: Include spaces around operators =, +, -, <-, == etc improve readibility. Put space comman, . : :: never spaces around . Additional spaces newlines fine improve readibilty code (e.g. aligmnent arguments). Comments: Comment code whenever can. Explain clear code. Use # start comment followed space capitalize first letter; short inline comments (comments line code) need two spaces # Curly Braces: opening curly brace never go line, closing curly brace go line. exception short conditional statement shuch else code may fit one line. Indentation: Use 2 spaces rather tabs per level indentation. Indent code inside curly braces. Semi-colons: use semi-colons put one statement line. Line Length: Use 80 characters per line code. RStudio setting display vertical line 80 characters visually assist . Turn going Tools -> Global Options… -> Code -> Display -> Show margin File names R code informative end .R. Use - improve readibility. include spaces file names! Contributing adopted ggplot2’s CONTRIBUTING.md","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/SECURITY.html","id":"supported-versions","dir":"","previous_headings":"","what":"Supported Versions","title":"Security Policy","text":"Supported security updates.","code":""},{"path":"http://merliseclyde.github.io/BAS/SECURITY.html","id":"reporting-a-vulnerability","dir":"","previous_headings":"","what":"Reporting a Vulnerability","title":"Security Policy","text":"Please submit vulnerability reports Github Issues maintainers address soon possibl","code":""},{"path":"http://merliseclyde.github.io/BAS/SECURITY.html","id":"expectations","dir":"","previous_headings":"","what":"Expectations","title":"Security Policy","text":"package utilizes C code efficiency allocates/frees memory. package checked memory leaks prior releases CRAN using ASAN/UBSBAN. package distributed via CRAN https://CRAN.R-project.org/package=bark reports additional checks. development version may installed GitHub https://github.com/merliseclyde/bark checked via github actions (users may check current version passing badge installing) Bugs reported via Issue tracker handled soon possible. (See link )","code":""},{"path":"http://merliseclyde.github.io/BAS/SECURITY.html","id":"assurance","dir":"","previous_headings":"","what":"Assurance","title":"Security Policy","text":"highly unlikely malicious code added package. submissions CRAN require verification via maintainer’s email, protected via two factor authentication. pull requests contributions github verified lead maintainer. Based Code Conduct Contributing Guidelines modifications include unit tests cover additional code blocks.","code":""},{"path":"http://merliseclyde.github.io/BAS/articles/BAS-vignette.html","id":"installing-bas","dir":"Articles","previous_headings":"","what":"Installing BAS","title":"Using the Bayesian Adaptive Sampling (BAS) Package for Bayesian Model Averaging and Variable Selection","text":"stable version can installed easily R console like package: hand, welcome everyone use recent version package quick-fixes, new features probably new bugs. get latest development version GitHub, use devtools package CRAN enter R: package depend BLAS LAPACK, installing GitHub require FORTRAN C compilers system.","code":"install.packages(\"BAS\") devtools::install_github(\"merliseclyde/BAS\")"},{"path":"http://merliseclyde.github.io/BAS/articles/BAS-vignette.html","id":"demo","dir":"Articles","previous_headings":"","what":"Demo","title":"Using the Bayesian Adaptive Sampling (BAS) Package for Bayesian Model Averaging and Variable Selection","text":"use UScrime data illustrate commands functionality. Following analyses, go ahead log transform variables except column 2, indicator variable state southern state. get started, use BAS Zellner-Siow Cauchy prior coefficients. BAS uses model formula similar lm specify full model potential predictors. using shorthand . indicate remaining variables data frame provided data argument. Different prior distributions regression coefficients may specified using prior argument, include “BIC” “AIC “g-prior” “hyper-g” “hyper-g-laplace” “hyper-g-n” “JZS” “ZS-null” “ZS-full” “EB-local” “EB-global” default Zellner-Siow prior, ZS-null, Bayes factors compared null model. newest prior option, “JZS”, also corresponds Zellner-Siow prior coefficients, uses numerical integration rather Laplace approximation obtain marginal likelihood models. default, BAS try enumerate models \\(p < 19\\) using default method=\"BAS\". prior distribution models uniform() distribution assigns equal probabilities models. last optional argument initprobs = eplogp provides way initialize sampling algorithm order variables tree structure represents model space BAS. eplogp option uses Bayes factor calibration p-values \\(-e p \\log(p)\\) provide approximation marginal inclusion probability coefficient predictor zero, using p-values full model. options initprobs include “marg-eplogp”” “uniform” numeric vector length p option “marg-eplogp” uses p-values \\(p\\) simple linear regressions (useful large p highly correlated variables). Since enumerating possible models options important method=\"deterministic\" may faster factors interactions model.","code":"data(UScrime, package = \"MASS\") UScrime[, -2] <- log(UScrime[, -2]) library(BAS) crime.ZS <- bas.lm(y ~ ., data = UScrime, prior = \"ZS-null\", modelprior = uniform(), initprobs = \"eplogp\", force.heredity = FALSE, pivot = TRUE )"},{"path":"http://merliseclyde.github.io/BAS/articles/BAS-vignette.html","id":"plots","dir":"Articles","previous_headings":"","what":"Plots","title":"Using the Bayesian Adaptive Sampling (BAS) Package for Bayesian Model Averaging and Variable Selection","text":"graphical summaries output may obtained plot function produces panel four plots. first plot residuals fitted values Bayesian Model Averaging. Ideally, model assumptions hold, see outliers non-constant variance. second plot shows cumulative probability models order sampled. plot indicates cumulative probability leveling additional model adds small increment cumulative probability, earlier, larger jumps corresponding discovering new high probability model. third plot shows dimension model (number regression coefficients including intercept) versus log marginal likelihood model. last plot shows marginal posterior inclusion probabilities (pip) covariates, marginal pips greater 0.5 shown red. variables pip > 0.5 correspond known median probability model. Variables high inclusion probabilities generally important explaining data prediction, marginal inclusion probabilities may small predictors highly correlated, similar p-values may large presence multicollinearity. Individual plots may obtained using option. BAS print summary methods defined objects class bas. Typing objects name returns summary marginal inclusion probabilities, summary function provides list top 5 models (terms posterior probability) zero-one indicators variable inclusion. columns summary Bayes factor model highest probability model (hence Bayes factor 1), posterior probabilities models, ordinary \\(R^2\\) models, dimension models (number coefficients including intercept) log marginal likelihood selected prior distribution.","code":"plot(crime.ZS, ask = F) plot(crime.ZS, which = 4, ask = FALSE, caption = \"\", sub.caption = \"\") crime.ZS ## ## Call: ## bas.lm(formula = y ~ ., data = UScrime, prior = \"ZS-null\", modelprior = uniform(), ## initprobs = \"eplogp\", force.heredity = FALSE, pivot = TRUE) ## ## ## Marginal Posterior Inclusion Probabilities: ## Intercept M So Ed Po1 Po2 LF ## 1.0000 0.8536 0.2737 0.9747 0.6652 0.4490 0.2022 ## M.F Pop NW U1 U2 GDP Ineq ## 0.2050 0.3696 0.6944 0.2526 0.6149 0.3601 0.9965 ## Prob Time ## 0.8992 0.3718 options(width = 80) summary(crime.ZS) ## P(B != 0 | Y) model 1 model 2 model 3 model 4 model 5 ## Intercept 1.0000000 1.00000 1.0000000 1.0000000 1.000000 1.0000000 ## M 0.8535720 1.00000 1.0000000 1.0000000 1.000000 1.0000000 ## So 0.2737083 0.00000 0.0000000 0.0000000 0.000000 0.0000000 ## Ed 0.9746605 1.00000 1.0000000 1.0000000 1.000000 1.0000000 ## Po1 0.6651553 1.00000 1.0000000 0.0000000 1.000000 1.0000000 ## Po2 0.4490097 0.00000 0.0000000 1.0000000 0.000000 0.0000000 ## LF 0.2022374 0.00000 0.0000000 0.0000000 0.000000 0.0000000 ## M.F 0.2049659 0.00000 0.0000000 0.0000000 0.000000 0.0000000 ## Pop 0.3696150 0.00000 0.0000000 0.0000000 1.000000 0.0000000 ## NW 0.6944069 1.00000 1.0000000 1.0000000 1.000000 0.0000000 ## U1 0.2525834 0.00000 0.0000000 0.0000000 0.000000 0.0000000 ## U2 0.6149388 1.00000 1.0000000 1.0000000 1.000000 1.0000000 ## GDP 0.3601179 0.00000 0.0000000 0.0000000 0.000000 0.0000000 ## Ineq 0.9965359 1.00000 1.0000000 1.0000000 1.000000 1.0000000 ## Prob 0.8991841 1.00000 1.0000000 1.0000000 1.000000 1.0000000 ## Time 0.3717976 1.00000 0.0000000 0.0000000 0.000000 0.0000000 ## BF NA 1.00000 0.9416178 0.6369712 0.594453 0.5301269 ## PostProbs NA 0.01820 0.0172000 0.0116000 0.010800 0.0097000 ## R2 NA 0.84200 0.8265000 0.8229000 0.837500 0.8046000 ## dim NA 9.00000 8.0000000 8.0000000 9.000000 7.0000000 ## logmarg NA 23.65111 23.5909572 23.2000822 23.130999 23.0164741"},{"path":"http://merliseclyde.github.io/BAS/articles/BAS-vignette.html","id":"visualization-of-the-model-space","dir":"Articles","previous_headings":"","what":"Visualization of the Model Space","title":"Using the Bayesian Adaptive Sampling (BAS) Package for Bayesian Model Averaging and Variable Selection","text":"see beyond first five models, can represent collection models via image plot. default shows top 20 models. image rows correspond variables intercept, labels variables y-axis. x-axis corresponds possible models. sorted posterior probability best left worst right rank top x-axis. column represents one 16 models. variables excluded model shown black column, variables included colored, color related log posterior probability. color column proportional log posterior probabilities (lower x-axis) model. log posterior probabilities actually scaled 0 corresponds lowest probability model top 20, values axis correspond log Bayes factors comparing model lowest probability model top 20 models. Models color similar log Bayes factors allows us view models clustered together Bayes Factors differences “worth bare mention”. plot indicates police expenditure two years enter model together, indication high correlation two variables.","code":"image(crime.ZS, rotate = F)"},{"path":"http://merliseclyde.github.io/BAS/articles/BAS-vignette.html","id":"posterior-distributions-of-coefficients","dir":"Articles","previous_headings":"","what":"Posterior Distributions of Coefficients","title":"Using the Bayesian Adaptive Sampling (BAS) Package for Bayesian Model Averaging and Variable Selection","text":"examine marginal distributions two coefficients police expenditures, can extract coefficients estimates standard deviations BMA. optional argument, n.models coef use top n.models BMA may computationally efficient large problems. Plots posterior distributions averaging models obtained using plot method bas coefficient object. vertical bar represents posterior probability coefficient 0 bell shaped curve represents density plausible values models coefficient non-zero. scaled height density non-zero values probability coefficient non-zero. Omitting subset argument provides marginal distributions. obtain credible intervals coefficients, BAS includes confint method create Highest Posterior Density intervals summaries coef. third column posterior mean. uses Monte Carlo sampling draw mixture model coefficient models sampled based posterior probabilities. can also plot via using parm argument select coefficients plot (intercept parm=1). estimation selection, BAS supports additional arguments via estimator. default estimator=\"BMA\" uses models n.models. options include estimation highest probability model median probability model variables excluded distributions point masses zero selection.","code":"coef.ZS <- coef(crime.ZS) plot(coef.ZS, subset = c(5:6), ask = F) confint(coef.ZS) ## 2.5% 97.5% beta ## Intercept 6.666605e+00 6.780476294 6.72493620 ## M -1.206267e-03 2.163933898 1.14359433 ## So -5.830268e-02 0.306753091 0.03547522 ## Ed 5.578925e-01 3.107169976 1.85848834 ## Po1 0.000000e+00 1.443627734 0.60067372 ## Po2 -7.562799e-02 1.476699866 0.31841766 ## LF -4.330386e-01 1.113585347 0.05933737 ## M.F -2.099673e+00 1.885398820 -0.02702786 ## Pop -1.255982e-01 0.006179825 -0.02248283 ## NW -1.108672e-05 0.166589909 0.06668437 ## U1 -4.684904e-01 0.402105224 -0.02456854 ## U2 -1.131477e-02 0.648917132 0.20702927 ## GDP -6.171786e-02 1.161168686 0.20625063 ## Ineq 6.973847e-01 2.145803613 1.39012647 ## Prob -4.154054e-01 0.000000000 -0.21536203 ## Time -4.992947e-01 0.075976670 -0.08433479 ## attr(,\"Probability\") ## [1] 0.95 ## attr(,\"class\") ## [1] \"confint.bas\" plot(confint(coef.ZS, parm = 2:16)) ## NULL plot(confint(coef(crime.ZS, estimator = \"HPM\"))) ## NULL plot(confint(coef(crime.ZS, estimator = \"MPM\")))"},{"path":"http://merliseclyde.github.io/BAS/articles/BAS-vignette.html","id":"prediction","dir":"Articles","previous_headings":"","what":"Prediction","title":"Using the Bayesian Adaptive Sampling (BAS) Package for Bayesian Model Averaging and Variable Selection","text":"BAS methods defined return fitted values, fitted, using observed design matrix predictions either observed data potentially new values, predict, lm. Plotting two sets fitted values, see perfect agreement. always case posterior mean regression mean function point \\(x\\) expected posterior predictive value \\(Y\\) \\(x\\). true estimators BMA, expected values model selection.","code":"muhat.BMA <- fitted(crime.ZS, estimator = \"BMA\") BMA <- predict(crime.ZS, estimator = \"BMA\") # predict has additional slots for fitted values under BMA, predictions under each model names(BMA) ## [1] \"fit\" \"Ybma\" \"Ypred\" \"postprobs\" \"se.fit\" ## [6] \"se.pred\" \"se.bma.fit\" \"se.bma.pred\" \"df\" \"best\" ## [11] \"bestmodel\" \"best.vars\" \"estimator\" par(mar = c(9, 9, 3, 3)) plot(muhat.BMA, BMA$fit, pch = 16, xlab = expression(hat(mu[i])), ylab = expression(hat(Y[i])) ) abline(0, 1)"},{"path":"http://merliseclyde.github.io/BAS/articles/BAS-vignette.html","id":"inference-with-model-selection","dir":"Articles","previous_headings":"Prediction","what":"Inference with model selection","title":"Using the Bayesian Adaptive Sampling (BAS) Package for Bayesian Model Averaging and Variable Selection","text":"addition using BMA, can use posterior means model selection. corresponds decision rule combines estimation selection. BAS currently implements following options highest probability model: little interpretable version names: median probability model: model predictors inclusion probability greater equal 0.5. coincides HPM predictors mutually orthogonal, case best predictive model squared error loss. Note can also extract best model attribute fitted values well. best predictive model: general, HPM MPM best predictive models, Bayesian decision theory perspective model closest BMA predictions squared error loss. Let’s see compare: Using se.fit = TRUE option predict can also calculate standard deviations prediction mean use input confint function prediction object. prediction new points, can supply new dataframe predict function lm.","code":"HPM <- predict(crime.ZS, estimator = \"HPM\") # show the indices of variables in the best model where 0 is the intercept HPM$bestmodel ## [1] 0 1 3 4 9 11 13 14 15 variable.names(HPM) ## [1] \"Intercept\" \"M\" \"Ed\" \"Po1\" \"NW\" \"U2\" ## [7] \"Ineq\" \"Prob\" \"Time\" MPM <- predict(crime.ZS, estimator = \"MPM\") variable.names(MPM) ## [1] \"Intercept\" \"M\" \"Ed\" \"Po1\" \"NW\" \"U2\" ## [7] \"Ineq\" \"Prob\" BPM <- predict(crime.ZS, estimator = \"BPM\") variable.names(BPM) ## [1] \"Intercept\" \"M\" \"So\" \"Ed\" \"Po1\" \"Po2\" ## [7] \"M.F\" \"NW\" \"U2\" \"Ineq\" \"Prob\" GGally::ggpairs(data.frame( HPM = as.vector(HPM$fit), # this used predict so we need to extract fitted values MPM = as.vector(MPM$fit), # this used fitted BPM = as.vector(BPM$fit), # this used fitted BMA = as.vector(BMA$fit) )) # this used predict BPM <- predict(crime.ZS, estimator = \"BPM\", se.fit = TRUE) crime.conf.fit <- confint(BPM, parm = \"mean\") crime.conf.pred <- confint(BPM, parm = \"pred\") plot(crime.conf.fit) ## NULL plot(crime.conf.pred) ## NULL new.pred <- predict(crime.ZS, newdata = UScrime, estimator = \"MPM\")"},{"path":"http://merliseclyde.github.io/BAS/articles/BAS-vignette.html","id":"alternative-algorithms","dir":"Articles","previous_headings":"","what":"Alternative algorithms","title":"Using the Bayesian Adaptive Sampling (BAS) Package for Bayesian Model Averaging and Variable Selection","text":"BAS several options sampling model space without enumeration. (current) default method=\"BAS\" samples models without replacement using estimates marginal inclusion probabilities using algorithm described Clyde et al (2011). initial sampling probabilities provided initprobs updated based sampled models, every update iterations. can efficient cases large fraction model space sampled, however, cases high correlation large number predictors, can lead biased estimates Clyde Ghosh (2012), case MCMC preferred. method=\"MCMC\" described better large \\(p\\). deterministic sampling scheme also available enumeration; faster enumeration default method=“BAS”.","code":"system.time( for (i in 1:10) { crime.ZS <- bas.lm(y ~ ., data = UScrime, prior = \"ZS-null\", method = \"BAS\", modelprior = uniform(), initprobs = \"eplogp\" ) } ) ## user system elapsed ## 1.375 0.001 1.376 system.time( for (i in 1:10) { crime.ZS <- bas.lm(y ~ ., data = UScrime, prior = \"ZS-null\", method = \"deterministic\", modelprior = uniform(), initprobs = \"eplogp\" ) } ) ## user system elapsed ## 1.195 0.004 1.199"},{"path":"http://merliseclyde.github.io/BAS/articles/BAS-vignette.html","id":"beyond-enumeration","dir":"Articles","previous_headings":"","what":"Beyond Enumeration","title":"Using the Bayesian Adaptive Sampling (BAS) Package for Bayesian Model Averaging and Variable Selection","text":"Many problems large enumerate possible models. cases may use method=\"BAS\" sample without replacement method=\"MCMC\" option sample models using Markov Chain Monte Carlo sampling sample models based posterior probabilities. spaces number models greatly exceeds number models sample, MCMC option recommended provides estimates low bias compared sampling without replacement BAS (Clyde Ghosh 2011). run MCMC sampler number unique sampled models exceeds n.models \\(2^p\\) (\\(p < 19\\)) default MCMC.iterations exceeded, MCMC.iterations = n.models*2 default.","code":"crime.ZS <- bas.lm(y ~ ., data = UScrime, prior = \"ZS-null\", modelprior = uniform(), method = \"MCMC\" )"},{"path":"http://merliseclyde.github.io/BAS/articles/BAS-vignette.html","id":"estimates-of-marginal-posterior-inclusion-probabilities-pip","dir":"Articles","previous_headings":"Beyond Enumeration","what":"Estimates of Marginal Posterior Inclusion Probabilities (pip)","title":"Using the Bayesian Adaptive Sampling (BAS) Package for Bayesian Model Averaging and Variable Selection","text":"MCMC sampling two estimates marginal inclusion probabilities: object$probne0 obtained using re-normalized posterior odds sampled models estimate probabilities estimates based Monte Carlo frequencies object$probs.MCMC. close agreement MCMC sampler run enough iterations. BAS includes diagnostic function compare two sets estimates posterior inclusion probabilities posterior model probabilities left hand plot pips, point represents one posterior inclusion probability 15 variables estimated two methods. two estimators pretty close agreement. plot model probabilities suggests use MCMC.iterations want accurate estimates posterior model probabilities.","code":"diagnostics(crime.ZS, type = \"pip\", pch = 16) diagnostics(crime.ZS, type = \"model\", pch = 16) crime.ZS <- bas.lm(y ~ ., data = UScrime, prior = \"ZS-null\", modelprior = uniform(), method = \"MCMC\", MCMC.iterations = 10^6 ) diagnostics(crime.ZS, type=\"model\", pch=16)"},{"path":"http://merliseclyde.github.io/BAS/articles/BAS-vignette.html","id":"outliers","dir":"Articles","previous_headings":"","what":"Outliers","title":"Using the Bayesian Adaptive Sampling (BAS) Package for Bayesian Model Averaging and Variable Selection","text":"BAS can also used exploring mean shift variance inflation outliers adding indicator variables case outlier (mean given regression) . similar MC3.REG function BMA, although using g-prior mixture g-priors coefficients outlier means. Using Stackloss data, can add identify matrix original dataframe, column indicator ith variable outlier. call introduces using truncated prior distributions model space; case distribution number variables included Poisson distribution, mean 4 (truncation), truncation point 10, models 10 (one half cases rounded ) probability zero. avoids exploration models full rank. Looking summaries","code":"data(\"stackloss\") stackloss <- cbind(stackloss, diag(nrow(stackloss))) stack.bas <- bas.lm(stack.loss ~ ., data = stackloss, method = \"MCMC\", initprobs = \"marg-eplogp\", prior = \"ZS-null\", modelprior = tr.poisson(4, 10), MCMC.iterations = 200000 ) knitr::kable(as.data.frame(summary(stack.bas)))"},{"path":"http://merliseclyde.github.io/BAS/articles/BAS-vignette.html","id":"factors-and-hierarchical-heredity","dir":"Articles","previous_headings":"","what":"Factors and Hierarchical Heredity","title":"Using the Bayesian Adaptive Sampling (BAS) Package for Bayesian Model Averaging and Variable Selection","text":"BAS now includes constraints factors terms represent factor either included excluded together. illustrate, use data set ToothGrowth convert dose factor: fit model main effects two way interaction without constraints: image model space, see levels factor enter drop model independently interactions may included without main effects. may lead parsimonious models, however, hypotheses tested coefficients represent factor depend choice reference group. force levels factor enter leave together can use force.heredity = TRUE. force.heredity option also forces interactions included main effects also included, models several factors higher order interactions, heredity constraint implies lower order interactions must included adding higher order interactions. force.heredity set FALSE sampling methods MCMC+BAS deterministic. 20 predictors factors, recommend using MCMC enforce constraints. Alternatively, function, force.heredity.bas, post-process output drop models violate hierarchical heredity constraint: can used sampling methods.","code":"data(ToothGrowth) ToothGrowth$dose <- factor(ToothGrowth$dose) levels(ToothGrowth$dose) <- c(\"Low\", \"Medium\", \"High\") TG.bas <- bas.lm(len ~ supp*dose, data = ToothGrowth, modelprior = uniform(), method = \"BAS\" ) image(TG.bas) TG.bas <- bas.lm(len ~ supp * dose, data = ToothGrowth, modelprior = uniform(), method = \"BAS\", force.heredity = TRUE ) image(TG.bas) TG.bas <- bas.lm(len ~ supp * dose, data = ToothGrowth, modelprior = uniform(), method = \"BAS\", force.heredity = FALSE ) TG.herid.bas <- force.heredity.bas(TG.bas)"},{"path":"http://merliseclyde.github.io/BAS/articles/BAS-vignette.html","id":"weighted-regression","dir":"Articles","previous_headings":"","what":"Weighted Regression","title":"Using the Bayesian Adaptive Sampling (BAS) Package for Bayesian Model Averaging and Variable Selection","text":"BAS can perform weighted regression supplying optional weight vector length response assumption variance response proportional 1/weights. g-prior incorporates weights prior covariance, \\[ \\sigma^2 g (X_\\gamma^T W X_\\gamma)^{-1} \\] \\(X_\\gamma\\) design matrix model \\(\\gamma\\) \\(W\\) \\(n \\times n\\) diagonal matrix weights diagonal. illustrate, use climate data, available url includes measurements changes temperature (deltaT) various latitudes well measure accuracy measured values sdev 8 different types proxy obtaining measurements. use explore weighted regression option group terms factors poly. illustration purposes, eliminate proxy == 6 one level interactions estimable, convert proxy factor. can fit weighted regression weights = 1/sdev^2 following code Examining image top models, see levels factor enter drop model together, well vectors design matrix represent term poly. Rerunning without constraint, allows one see factors levels different reference group.","code":"data(climate, package=\"BAS\") str(climate) ## 'data.frame': 63 obs. of 5 variables: ## $ deltaT : num -2.6 -2.6 -2.9 -2.4 -2.8 -1.2 -2.4 -2.6 -2.4 -2.5 ... ## $ sdev : num 0.7 0.8 0.9 0.7 0.7 0.3 1.3 1.3 1.3 0.5 ... ## $ proxy : int 1 1 1 1 1 1 1 1 1 1 ... ## $ T.M : int 1 1 1 1 1 1 1 1 1 1 ... ## $ latitude: num 2.5 2.2 0.5 0.3 0.2 -1.1 5.2 11.4 14.6 6.3 ... summary(climate) ## deltaT sdev proxy T.M ## Min. :-7.000 Min. :0.1500 Min. :1.000 Min. :0.0000 ## 1st Qu.:-3.900 1st Qu.:0.5000 1st Qu.:2.000 1st Qu.:1.0000 ## Median :-2.900 Median :0.7000 Median :3.000 Median :1.0000 ## Mean :-3.111 Mean :0.8579 Mean :3.333 Mean :0.8254 ## 3rd Qu.:-2.000 3rd Qu.:1.3000 3rd Qu.:5.000 3rd Qu.:1.0000 ## Max. : 0.200 Max. :2.5000 Max. :8.000 Max. :1.0000 ## latitude ## Min. :-22.500 ## 1st Qu.: -3.450 ## Median : 0.200 ## Mean : 2.187 ## 3rd Qu.: 9.700 ## Max. : 29.000 library(dplyr) climate <- filter(climate, proxy != 6) %>% mutate(proxy = factor(proxy)) climate.bas <- bas.lm(deltaT ~ proxy * poly(latitude, 2), data = climate, weights = 1 / sdev^2, prior = \"hyper-g-n\", alpha = 3.0, n.models = 2^20, force.heredity=TRUE, modelprior = uniform() ) image(climate.bas, rotate = F) # May take a while to enumerate all 2^20 models climate.bas <- bas.lm(deltaT ~ proxy * poly(latitude, 2), data = climate, weights = 1 / sdev^2, prior = \"hyper-g-n\", alpha = 3.0, n.models = 2^20, modelprior = uniform(), force.heredity = FALSE ) image(climate.bas)"},{"path":"http://merliseclyde.github.io/BAS/articles/BAS-vignette.html","id":"summary","dir":"Articles","previous_headings":"","what":"Summary","title":"Using the Bayesian Adaptive Sampling (BAS) Package for Bayesian Model Averaging and Variable Selection","text":"BAS includes prior distributions coefficients models, well bas.glm fitting Generalized Linear Models. syntax bas.glm bas.lm yet , particularly priors coefficients represented, please see documentation features details updated another vignette added! issues feature requests please submit via package’s github page merliseclyde/BAS","code":""},{"path":"http://merliseclyde.github.io/BAS/authors.html","id":null,"dir":"","previous_headings":"","what":"Authors","title":"Authors and Citation","text":"Merlise Clyde. Author, maintainer, copyright holder. ORCID=0000-0002-3595-1872 Michael Littman. Contributor. Joyee Ghosh. Contributor. Yingbo Li. Contributor. Betsy Bersson. Contributor. Don van de Bergh. Contributor. Quanli Wang. Contributor.","code":""},{"path":"http://merliseclyde.github.io/BAS/authors.html","id":"citation","dir":"","previous_headings":"","what":"Citation","title":"Authors and Citation","text":"Clyde, Merlise (2023) BAS: Bayesian Variable Selection Model Averaging using Bayesian Adaptive Sampling, R package version 1.7.1.9000","code":"@Manual{, title = {{BAS}: Bayesian Variable Selection and Model Averaging using Bayesian Adaptive Sampling}, author = {Merlise Clyde}, year = {2023}, note = {R package version 1.7.1.9000}, }"},{"path":"http://merliseclyde.github.io/BAS/index.html","id":"bas-bayesian-variable-selection-and-model-averaging-using-bayesian-adaptive-sampling","dir":"","previous_headings":"","what":"Bayesian Variable Selection and Model Averaging using Bayesian Adaptive Sampling","title":"Bayesian Variable Selection and Model Averaging using Bayesian Adaptive Sampling","text":"BAS R package designed provide easy use package fast code implementing Bayesian Model Averaging Model Selection R using state art prior distributions linear generalized linear models. prior distributions BAS based Zellner’s g-prior mixtures g-priors linear generalized linear models. shown consistent asymptotically model selection inference number computational advantages. BAS implements three main algorithms sampling space potential models: deterministic algorithm efficient enumeration, adaptive sampling without replacement algorithm modest problems, MCMC algorithm utilizes swapping escape local modes standard Metropolis-Hastings proposals.","code":""},{"path":"http://merliseclyde.github.io/BAS/index.html","id":"installation","dir":"","previous_headings":"","what":"Installation","title":"Bayesian Variable Selection and Model Averaging using Bayesian Adaptive Sampling","text":"stable version can installed easily R console like package: hand, welcome everyone use recent version package quick-fixes, new features probably new bugs. ’s currently hosted GitHub. get latest development version GitHub, use devtools package CRAN enter R: can check current build status installing. Installing package source require compilation C FORTRAN code library makes use BLAS LAPACK efficient model fitting. See CRAN manuals installing packages source different operating systems.","code":"install.packages('BAS') devtools::install_github('merliseclyde/BAS')"},{"path":"http://merliseclyde.github.io/BAS/index.html","id":"usage","dir":"","previous_headings":"","what":"Usage","title":"Bayesian Variable Selection and Model Averaging using Bayesian Adaptive Sampling","text":"begin load package: two main function BAS bas.lm bas.glm implementing Bayesian Model Averaging Variable Selection using Zellner’s g-prior mixtures g priors. functions syntax similar lm glm functions respectively. illustrate using BAS simple example famous Hald data set using Zellner-Siow Cauchy prior via BAS summary, plot coef, predict fitted functions like lm/glm functions. Images model space highlighting variable important may obtained via Run demo(\"BAS.hald\") demo(\"BAS.USCrime\") see package vignette examples options using MCMC model spaces enumerated.","code":"library(BAS) data(Hald) hald.ZS = bas.lm(Y ~ ., data=Hald, prior=\"ZS-null\", modelprior=uniform(), method=\"BAS\") image(hald.ZS)"},{"path":"http://merliseclyde.github.io/BAS/index.html","id":"generalized-linear-models","dir":"","previous_headings":"Usage","what":"Generalized Linear Models","title":"Bayesian Variable Selection and Model Averaging using Bayesian Adaptive Sampling","text":"BAS now includes support binomial binary regression, Poisson regression, Gamma regression using Laplace approximations obtain Bayes Factors used calculating posterior probabilities models sampling models. example using Pima diabetes data set hyper-g/n prior: Note, syntax specifying priors coefficients bas.glm uses function arguments specify hyper-parameters, rather text string specify prior name separate argument hyper-parameters. bas.lm moving format sometime future.","code":"library(MASS) data(Pima.tr) Pima.hgn = bas.glm(type ~ ., data=Pima.tr, method=\"BAS\", family=binomial(), betaprior=hyper.g.n(), modelprior=uniform())"},{"path":"http://merliseclyde.github.io/BAS/index.html","id":"feature-requests-and-issues","dir":"","previous_headings":"","what":"Feature Requests and Issues","title":"Bayesian Variable Selection and Model Averaging using Bayesian Adaptive Sampling","text":"Feel free report issues request features added via github issues page. current documentation vignettes see BAS website","code":""},{"path":"http://merliseclyde.github.io/BAS/index.html","id":"support","dir":"","previous_headings":"Feature Requests and Issues","what":"Support","title":"Bayesian Variable Selection and Model Averaging using Bayesian Adaptive Sampling","text":"material based upon work supported National Science Foundation Grant DMS-1106891. opinions, findings, conclusions recommendations expressed material author(s) necessarily reflect views National Science Foundation.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/BAS.html","id":null,"dir":"Reference","previous_headings":"","what":"BAS: Bayesian Model Averaging using Bayesian Adaptive Sampling — BAS","title":"BAS: Bayesian Model Averaging using Bayesian Adaptive Sampling — BAS","text":"Implementation Bayesian Model Averaging linear models using stochastic deterministic sampling without replacement posterior distributions. Prior distributions coefficients form Zellner's g-prior mixtures g-priors. Options include Zellner-Siow Cauchy Priors, Liang et al hyper-g priors, Local Global Empirical Bayes estimates g, default model selection criteria AIC BIC. Sampling probabilities may updated based sampled models.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/BAS.html","id":"references","dir":"Reference","previous_headings":"","what":"References","title":"BAS: Bayesian Model Averaging using Bayesian Adaptive Sampling — BAS","text":"Clyde, M. Ghosh, J. Littman, M. (2010) Bayesian Adaptive Sampling Variable Selection Model Averaging. Journal Computational Graphics Statistics. 20:80-101 doi:10.1198/jcgs.2010.09049 Clyde, M. George, E. . (2004) Model uncertainty. Statist. Sci., 19, 81-94. doi:10.1214/088342304000000035 Clyde, M. (1999) Bayesian Model Averaging Model Search Strategies (discussion). Bayesian Statistics 6. J.M. Bernardo, .P. Dawid, J.O. Berger, .F.M. Smith eds. Oxford University Press, pages 157-185. Li, Y. Clyde, M. (2018) Mixtures g-priors Generalized Linear Models. Journal American Statistical Association, 113:524, 1828-1845 doi:10.1080/01621459.2018.1469992 Liang, F., Paulo, R., Molina, G., Clyde, M. Berger, J.O. (2008) Mixtures g-priors Bayesian Variable Selection. Journal American Statistical Association. 103:410-423. doi:10.1198/016214507000001337","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/BAS.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"BAS: Bayesian Model Averaging using Bayesian Adaptive Sampling — BAS","text":"Merlise Clyde, Maintainer: Merlise Clyde ","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/BAS.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"BAS: Bayesian Model Averaging using Bayesian Adaptive Sampling — BAS","text":"","code":"data(\"Hald\") hald.gprior = bas.lm(Y ~ ., data=Hald, alpha=13, prior=\"g-prior\") # more complete demos demo(BAS.hald) #> #> #> \tdemo(BAS.hald) #> \t---- ~~~~~~~~ #> #> > data(Hald) #> #> > hald.gprior = bas.lm(Y~ ., data=Hald, prior=\"g-prior\", alpha=13, #> + modelprior=beta.binomial(1,1), #> + initprobs=\"eplogp\") #> #> > hald.gprior #> #> Call: #> bas.lm(formula = Y ~ ., data = Hald, prior = \"g-prior\", alpha = 13, #> modelprior = beta.binomial(1, 1), initprobs = \"eplogp\") #> #> #> Marginal Posterior Inclusion Probabilities: #> Intercept X1 X2 X3 X4 #> 1.0000 0.9019 0.6896 0.4653 0.6329 #> #> > plot(hald.gprior) #> #> > summary(hald.gprior) #> P(B != 0 | Y) model 1 model 2 model 3 model 4 model 5 #> Intercept 1.0000000 1.00000 1.0000000 1.00000000 1.0000000 1.0000000 #> X1 0.9019245 1.00000 1.0000000 1.00000000 1.0000000 1.0000000 #> X2 0.6895830 1.00000 0.0000000 1.00000000 1.0000000 1.0000000 #> X3 0.4652762 0.00000 0.0000000 1.00000000 0.0000000 1.0000000 #> X4 0.6329266 0.00000 1.0000000 1.00000000 1.0000000 0.0000000 #> BF NA 1.00000 0.6923944 0.08991408 0.3355714 0.3344926 #> PostProbs NA 0.24320 0.1684000 0.13120000 0.1224000 0.1220000 #> R2 NA 0.97870 0.9725000 0.98240000 0.9823000 0.9823000 #> dim NA 3.00000 3.0000000 5.00000000 4.0000000 4.0000000 #> logmarg NA 11.72735 11.3597547 9.31845348 10.6354335 10.6322138 #> #> > image(hald.gprior, subset=-1, vlas=0) #> #> > hald.coef = coefficients(hald.gprior) #> #> > hald.coef #> #> Marginal Posterior Summaries of Coefficients: #> #> Using BMA #> #> Based on the top 16 models #> post mean post SD post p(B != 0) #> Intercept 95.4231 0.7107 1.0000 #> X1 1.2150 0.5190 0.9019 #> X2 0.2756 0.4832 0.6896 #> X3 -0.1271 0.4976 0.4653 #> X4 -0.3269 0.4717 0.6329 #> #> > plot(hald.coef) #> #> > predict(hald.gprior, top=5, se.fit=TRUE) #> $fit #> [1] 79.74246 74.50010 105.29268 89.88693 95.57177 104.56409 103.40145 #> [8] 77.13668 91.99731 114.21325 82.78446 111.00723 110.40160 #> #> $Ybma #> [,1] #> [1,] 79.74246 #> [2,] 74.50010 #> [3,] 105.29268 #> [4,] 89.88693 #> [5,] 95.57177 #> [6,] 104.56409 #> [7,] 103.40145 #> [8,] 77.13668 #> [9,] 91.99731 #> [10,] 114.21325 #> [11,] 82.78446 #> [12,] 111.00723 #> [13,] 110.40160 #> #> $Ypred #> [,1] [,2] [,3] [,4] [,5] [,6] [,7] [,8] #> [1,] 81.17036 74.83464 105.0725 89.69881 97.15898 104.4575 103.3893 76.06454 #> [2,] 77.70296 74.24113 105.8554 90.46267 93.09565 104.7152 103.1399 78.80193 #> [3,] 79.70437 74.40553 105.2175 89.76253 95.63309 104.5709 103.5254 77.08557 #> [4,] 79.65151 74.47846 105.4218 89.83174 95.62799 104.5962 103.5068 77.00839 #> [5,] 79.84321 74.31409 104.9063 89.65651 95.70301 104.5285 103.5476 77.15919 #> [,9] [,10] [,11] [,12] [,13] #> [1,] 91.57174 113.1722 81.59906 111.2219 111.0884 #> [2,] 92.68123 115.8058 84.50293 110.4162 109.0791 #> [3,] 91.98604 114.1759 82.78145 111.1196 110.5321 #> [4,] 92.07571 114.1088 82.68233 111.0429 110.4674 #> [5,] 91.83513 114.2353 82.88128 111.2384 110.6515 #> #> $postprobs #> [1] 0.3089304 0.2139017 0.1666632 0.1555023 0.1550024 #> #> $se.fit #> [,1] [,2] [,3] [,4] [,5] [,6] [,7] [,8] #> [1,] 2.220164 2.265862 1.546911 2.181188 1.310135 1.523300 2.655096 2.176560 #> [2,] 2.716798 2.389723 1.633637 2.179215 1.321062 1.581232 2.721957 2.078129 #> [3,] 3.203405 2.501485 3.279273 2.357164 2.589756 1.549136 2.623290 2.765255 #> [4,] 3.117350 2.283957 1.602160 2.149087 2.589321 1.508471 2.610923 2.545817 #> [5,] 2.932580 2.353352 1.538009 2.141694 2.507848 1.498758 2.616407 2.680289 #> [,9] [,10] [,11] [,12] [,13] #> [1,] 1.883610 3.264656 1.908238 1.970691 2.054234 #> [2,] 2.013244 3.298134 1.933819 1.964374 1.924460 #> [3,] 2.353516 3.609909 2.821295 2.227363 2.390135 #> [4,] 1.990817 3.485929 2.456636 1.951456 2.212238 #> [5,] 1.889302 3.569065 2.665166 1.934336 2.117189 #> #> $se.pred #> [,1] [,2] [,3] [,4] [,5] [,6] [,7] [,8] #> [1,] 5.057182 5.077410 4.799885 5.040193 4.728892 4.792328 5.262651 5.038191 #> [2,] 5.415848 5.259391 4.961773 5.167146 4.867815 4.944766 5.418438 5.125333 #> [3,] 5.489152 5.111401 5.533771 5.042342 5.155175 4.718984 5.172102 5.245534 #> [4,] 5.440156 5.009380 4.737547 4.949344 5.155775 4.706689 5.166658 5.134065 #> [5,] 5.337427 5.042456 4.717369 4.947217 5.116386 4.704719 5.170463 5.203081 #> [,9] [,10] [,11] [,12] [,13] #> [1,] 4.918734 5.594992 4.928218 4.952735 4.986566 #> [2,] 5.099370 5.729582 5.068538 5.080274 5.064974 #> [3,] 5.040638 5.735890 5.275291 4.982985 5.057839 #> [4,] 4.882702 5.659428 5.090431 4.866787 4.977090 #> [5,] 4.843301 5.711946 5.195307 4.861045 4.936658 #> #> $se.bma.fit #> [1] 2.688224 2.095245 1.769625 1.970919 2.197285 1.363804 2.356457 2.302631 #> [9] 1.822084 3.141443 2.237663 1.801849 1.991374 #> #> $se.bma.pred #> [1] 4.838655 4.536087 4.395180 4.480017 4.584113 4.248058 4.662502 4.635531 #> [9] 4.416563 5.104380 4.603604 4.408253 4.489054 #> #> $df #> [1] 12 12 12 12 12 #> #> $best #> [1] 3 6 4 13 15 #> #> $bestmodel #> $bestmodel[[1]] #> [1] 0 1 2 #> #> $bestmodel[[2]] #> [1] 0 1 4 #> #> $bestmodel[[3]] #> [1] 0 1 2 3 4 #> #> $bestmodel[[4]] #> [1] 0 1 2 4 #> #> $bestmodel[[5]] #> [1] 0 1 2 3 #> #> #> $best.vars #> [1] \"Intercept\" \"X1\" \"X2\" \"X3\" \"X4\" #> #> $estimator #> [1] \"BMA\" #> #> attr(,\"class\") #> [1] \"pred.bas\" #> #> > confint(predict(hald.gprior, Hald, estimator=\"BMA\", se.fit=TRUE, top=5), parm=\"mean\") #> 2.5% 97.5% mean #> [1,] 73.17015 86.09252 79.74246 #> [2,] 69.48178 79.49934 74.50010 #> [3,] 101.18320 110.09817 105.29268 #> [4,] 85.06175 94.69350 89.88693 #> [5,] 90.49213 100.40376 95.57177 #> [6,] 101.23478 107.96299 104.56409 #> [7,] 97.63448 109.07312 103.40145 #> [8,] 71.49627 82.42323 77.13668 #> [9,] 87.73351 96.35950 91.99731 #> [10,] 106.67366 121.85448 114.21325 #> [11,] 77.58914 88.14563 82.78446 #> [12,] 106.56487 115.34932 111.00723 #> [13,] 105.51356 114.94017 110.40160 #> attr(,\"Probability\") #> [1] 0.95 #> attr(,\"class\") #> [1] \"confint.bas\" #> #> > predict(hald.gprior, estimator=\"MPM\", se.fit=TRUE) #> $fit #> [1] 79.65151 74.47846 105.42183 89.83174 95.62799 104.59616 103.50684 #> [8] 77.00839 92.07571 114.10876 82.68233 111.04286 110.46741 #> attr(,\"model\") #> [1] 0 1 2 4 #> attr(,\"best\") #> [1] 1 #> attr(,\"estimator\") #> [1] \"MPM\" #> #> $Ybma #> [1] 79.65151 74.47846 105.42183 89.83174 95.62799 104.59616 103.50684 #> [8] 77.00839 92.07571 114.10876 82.68233 111.04286 110.46741 #> attr(,\"model\") #> [1] 0 1 2 4 #> attr(,\"best\") #> [1] 1 #> attr(,\"estimator\") #> [1] \"MPM\" #> #> $Ypred #> NULL #> #> $postprobs #> NULL #> #> $se.fit #> [1] 3.117350 2.283957 1.602160 2.149087 2.589321 1.508471 2.610923 2.545817 #> [9] 1.990817 3.485929 2.456636 1.951456 2.212238 #> #> $se.pred #> [1] 5.440156 5.009380 4.737547 4.949344 5.155775 4.706689 5.166658 5.134065 #> [9] 4.882702 5.659428 5.090431 4.866787 4.977090 #> #> $se.bma.fit #> NULL #> #> $se.bma.pred #> NULL #> #> $df #> [1] 12 #> #> $best #> NULL #> #> $bestmodel #> [1] 0 1 2 4 #> #> $best.vars #> [1] \"Intercept\" \"X1\" \"X2\" \"X4\" #> #> $estimator #> [1] \"MPM\" #> #> attr(,\"class\") #> [1] \"pred.bas\" #> #> > confint(predict(hald.gprior, Hald, estimator=\"MPM\", se.fit=TRUE), parm=\"mean\") #> 2.5% 97.5% mean #> [1,] 72.85939 86.44363 79.65151 #> [2,] 69.50215 79.45478 74.47846 #> [3,] 101.93102 108.91264 105.42183 #> [4,] 85.14928 94.51420 89.83174 #> [5,] 89.98634 101.26964 95.62799 #> [6,] 101.30948 107.88283 104.59616 #> [7,] 97.81813 109.19556 103.50684 #> [8,] 71.46153 82.55525 77.00839 #> [9,] 87.73810 96.41333 92.07571 #> [10,] 106.51357 121.70394 114.10876 #> [11,] 77.32978 88.03488 82.68233 #> [12,] 106.79101 115.29472 111.04286 #> [13,] 105.64736 115.28746 110.46741 #> attr(,\"Probability\") #> [1] 0.95 #> attr(,\"class\") #> [1] \"confint.bas\" #> #> > fitted(hald.gprior, estimator=\"HPM\") #> [1] 81.17036 74.83464 105.07248 89.69881 97.15898 104.45753 103.38927 #> [8] 76.06454 91.57174 113.17222 81.59906 111.22195 111.08841 #> #> > hald.gprior = bas.lm(Y~ ., data=Hald, n.models=2^4, #> + prior=\"g-prior\", alpha=13, modelprior=uniform(), #> + initprobs=\"eplogp\") #> #> > hald.EB = update(hald.gprior, newprior=\"EB-global\") #> #> > hald.bic = update(hald.gprior,newprior=\"BIC\") #> #> > hald.zs = update(hald.bic, newprior=\"ZS-null\") if (FALSE) { demo(BAS.USCrime) }"},{"path":"http://merliseclyde.github.io/BAS/reference/Bayes.outlier.html","id":null,"dir":"Reference","previous_headings":"","what":"Bayesian Outlier Detection — Bayes.outlier","title":"Bayesian Outlier Detection — Bayes.outlier","text":"Calculate posterior probability absolute value error exceeds k standard deviations P(|epsilon_j| > k sigma | data) model Y = X B + epsilon, epsilon ~ N(0, sigma^2 ) based paper Chaloner & Brant Biometrika (1988). Either k prior probability outliers must provided. uses reference prior p(B, sigma) = 1; priors model averaging come.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/Bayes.outlier.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Bayesian Outlier Detection — Bayes.outlier","text":"","code":"Bayes.outlier(lmobj, k, prior.prob)"},{"path":"http://merliseclyde.github.io/BAS/reference/Bayes.outlier.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Bayesian Outlier Detection — Bayes.outlier","text":"lmobj object class `lm` k number standard deviations used calculating probability individual case outlier, P(|error| > k sigma | data) prior.prob prior probability outliers sample size n","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/Bayes.outlier.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Bayesian Outlier Detection — Bayes.outlier","text":"Returns list three items: e residuals hat leverage values prob.outlier posterior probabilities point outlier prior.prob prior probability point outlier","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/Bayes.outlier.html","id":"references","dir":"Reference","previous_headings":"","what":"References","title":"Bayesian Outlier Detection — Bayes.outlier","text":"Chaloner & Brant (1988) Bayesian Approach Outlier Detection Residual Analysis Biometrika (1988) 75, 651-659","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/Bayes.outlier.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Bayesian Outlier Detection — Bayes.outlier","text":"","code":"data(\"stackloss\") stack.lm <- lm(stack.loss ~ ., data = stackloss) stack.outliers <- Bayes.outlier(stack.lm, k = 3) plot(stack.outliers$prob.outlier, type = \"h\", ylab = \"Posterior Probability\") # adjust for sample size for calculating prior prob that a # a case is an outlier stack.outliers <- Bayes.outlier(stack.lm, prior.prob = 0.95) # cases where posterior probability exceeds prior probability which(stack.outliers$prob.outlier > stack.outliers$prior.prob) #> [1] 4 21"},{"path":"http://merliseclyde.github.io/BAS/reference/Bernoulli.heredity.html","id":null,"dir":"Reference","previous_headings":"","what":"Independent Bernoulli prior on models that with constraints for\nmodel hierarchy induced by interactions — Bernoulli.heredity","title":"Independent Bernoulli prior on models that with constraints for\nmodel hierarchy induced by interactions — Bernoulli.heredity","text":"Independent Bernoulli prior models constraints model hierarchy induced interactions","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/Bernoulli.heredity.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Independent Bernoulli prior on models that with constraints for\nmodel hierarchy induced by interactions — Bernoulli.heredity","text":"","code":"Bernoulli.heredity(pi = 0.5, parents)"},{"path":"http://merliseclyde.github.io/BAS/reference/Bernoulli.heredity.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Independent Bernoulli prior on models that with constraints for\nmodel hierarchy induced by interactions — Bernoulli.heredity","text":"pi Bernoulli probability term included parents matrix terms parents indicators terms parents term","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/Bernoulli.heredity.html","id":"note","dir":"Reference","previous_headings":"","what":"Note","title":"Independent Bernoulli prior on models that with constraints for\nmodel hierarchy induced by interactions — Bernoulli.heredity","text":"implemented yet use bas.lm bas.glm","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/Bernoulli.html","id":null,"dir":"Reference","previous_headings":"","what":"Independent Bernoulli Prior Distribution for Models — Bernoulli","title":"Independent Bernoulli Prior Distribution for Models — Bernoulli","text":"Creates object representing prior distribution models BAS.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/Bernoulli.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Independent Bernoulli Prior Distribution for Models — Bernoulli","text":"","code":"Bernoulli(probs = 0.5)"},{"path":"http://merliseclyde.github.io/BAS/reference/Bernoulli.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Independent Bernoulli Prior Distribution for Models — Bernoulli","text":"probs scalar vector prior inclusion probabilities. scalar, values replicated variables ans 1 added intercept. BAS checks see length equal dimension parameter vector full model adds 1 include intercept.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/Bernoulli.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Independent Bernoulli Prior Distribution for Models — Bernoulli","text":"returns object class \"prior\", family hyperparameters.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/Bernoulli.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Independent Bernoulli Prior Distribution for Models — Bernoulli","text":"independent Bernoulli prior distribution commonly used prior BMA, Uniform distribution special case probs=.5. indicator variables independent Bernoulli distributions common probability probs, distribution model size binomial(p, probs) distribution.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/Bernoulli.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Independent Bernoulli Prior Distribution for Models — Bernoulli","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/Bernoulli.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Independent Bernoulli Prior Distribution for Models — Bernoulli","text":"","code":"Bernoulli(.9) #> $family #> [1] \"Bernoulli\" #> #> $hyper.parameters #> [1] 0.9 #> #> attr(,\"class\") #> [1] \"prior\""},{"path":"http://merliseclyde.github.io/BAS/reference/CCH.html","id":null,"dir":"Reference","previous_headings":"","what":"Generalized g-Prior Distribution for Coefficients in BMA Models — CCH","title":"Generalized g-Prior Distribution for Coefficients in BMA Models — CCH","text":"Creates object representing CCH mixture g-priors coefficients BAS .","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/CCH.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Generalized g-Prior Distribution for Coefficients in BMA Models — CCH","text":"","code":"CCH(alpha, beta, s = 0)"},{"path":"http://merliseclyde.github.io/BAS/reference/CCH.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Generalized g-Prior Distribution for Coefficients in BMA Models — CCH","text":"alpha scalar > 0, recommended alpha=.5 (betaprime) 1 CCH. hyper.g(alpha) equivalent CCH(alpha -2, 2, 0). Liang et al recommended values range 2 < alpha_h <= 4 beta scalar > 0. value updated data; beta function n consistency null model. hyper-g corresponds b = 2 s scalar, recommended s=0","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/CCH.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Generalized g-Prior Distribution for Coefficients in BMA Models — CCH","text":"returns object class \"prior\", family hyperparameters.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/CCH.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Generalized g-Prior Distribution for Coefficients in BMA Models — CCH","text":"Creates structure used bas.glm.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/CCH.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Generalized g-Prior Distribution for Coefficients in BMA Models — CCH","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/CCH.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Generalized g-Prior Distribution for Coefficients in BMA Models — CCH","text":"","code":"CCH(alpha = .5, beta = 100, s = 0) #> $family #> [1] \"CCH\" #> #> $class #> [1] \"TCCH\" #> #> $hyper.parameters #> $hyper.parameters$alpha #> [1] 0.5 #> #> $hyper.parameters$beta #> [1] 100 #> #> $hyper.parameters$s #> [1] 0 #> #> #> attr(,\"class\") #> [1] \"prior\""},{"path":"http://merliseclyde.github.io/BAS/reference/EB.global.html","id":null,"dir":"Reference","previous_headings":"","what":"Find the global Empirical Bayes estimates for BMA — EB.global","title":"Find the global Empirical Bayes estimates for BMA — EB.global","text":"Finds global Empirical Bayes estimates g Zellner's g-prior model probabilities","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/EB.global.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Find the global Empirical Bayes estimates for BMA — EB.global","text":"","code":"EB.global(object, tol = 0.1, g.0 = NULL, max.iterations = 100)"},{"path":"http://merliseclyde.github.io/BAS/reference/EB.global.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Find the global Empirical Bayes estimates for BMA — EB.global","text":"object 'bas' object created bas tol tolerance estimating g g.0 initial value g max.iterations Maximum number iterations EM algorithm","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/EB.global.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Find the global Empirical Bayes estimates for BMA — EB.global","text":"object class 'bas' using Zellner's g prior estimate g based models","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/EB.global.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Find the global Empirical Bayes estimates for BMA — EB.global","text":"Uses EM algorithm Liang et al estimate type II MLE g Zellner's g prior","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/EB.global.html","id":"references","dir":"Reference","previous_headings":"","what":"References","title":"Find the global Empirical Bayes estimates for BMA — EB.global","text":"Liang, F., Paulo, R., Molina, G., Clyde, M. Berger, J.O. (2008) Mixtures g-priors Bayesian Variable Selection. Journal American Statistical Association. 103:410-423. doi:10.1198/016214507000001337","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/EB.global.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Find the global Empirical Bayes estimates for BMA — EB.global","text":"Merlise Clyde clyde@stat.duke.edu","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/EB.global.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Find the global Empirical Bayes estimates for BMA — EB.global","text":"","code":"library(MASS) data(UScrime) UScrime[,-2] = log(UScrime[,-2]) # EB local uses a different g within each model crime.EBL = bas.lm(y ~ ., data=UScrime, n.models=2^15, prior=\"EB-local\", initprobs= \"eplogp\") # use a common (global) estimate of g crime.EBG = EB.global(crime.EBL)"},{"path":"http://merliseclyde.github.io/BAS/reference/EB.local.html","id":null,"dir":"Reference","previous_headings":"","what":"Empirical Bayes Prior Distribution for Coefficients in BMA Model — EB.local","title":"Empirical Bayes Prior Distribution for Coefficients in BMA Model — EB.local","text":"Creates object representing EB prior BAS GLM.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/EB.local.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Empirical Bayes Prior Distribution for Coefficients in BMA Model — EB.local","text":"","code":"EB.local()"},{"path":"http://merliseclyde.github.io/BAS/reference/EB.local.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Empirical Bayes Prior Distribution for Coefficients in BMA Model — EB.local","text":"returns object class \"prior\", family hyerparameters.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/EB.local.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Empirical Bayes Prior Distribution for Coefficients in BMA Model — EB.local","text":"Creates structure used bas.glm.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/EB.local.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Empirical Bayes Prior Distribution for Coefficients in BMA Model — EB.local","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/EB.local.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Empirical Bayes Prior Distribution for Coefficients in BMA Model — EB.local","text":"","code":"EB.local() #> $family #> [1] \"EB-local\" #> #> $class #> [1] \"EB\" #> #> $hyper.parameters #> $hyper.parameters$local #> [1] TRUE #> #> #> attr(,\"class\") #> [1] \"prior\""},{"path":"http://merliseclyde.github.io/BAS/reference/Hald.html","id":null,"dir":"Reference","previous_headings":"","what":"Hald Data — Hald","title":"Hald Data — Hald","text":"Hald data used many books papers illustrate variable selection. data relate engineering application concerned effect composition cement heat evolved hardening. response variable Y heat evolved cement mix. four explanatory variables ingredients mix, X1: tricalcium aluminate, X2: tricalcium silicate, X3: tetracalcium alumino ferrite, X4: dicalcium silicate. important feature data variables X1 X3 highly correlated, well variables X2 X4. Thus expect subset (X1,X2,X3,X4) includes one variable highly correlated pair subset also includes member.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/Hald.html","id":"format","dir":"Reference","previous_headings":"","what":"Format","title":"Hald Data — Hald","text":"hald dataframe 13 observations 5 variables (columns), Y: Heat evolved per gram cement (calories) X1: Amount tricalcium aluminate X2: Amount tricalcium silicate X3: Amount tetracalcium alumino ferrite X4: Amount dicalcium silicate","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/Hald.html","id":"source","dir":"Reference","previous_headings":"","what":"Source","title":"Hald Data — Hald","text":"Wood, H., Steinour, H.H., Starke, H.R. (1932). \"Effect Composition Portland cement Heat Evolved Hardening\", Industrial Engineering Chemistry, 24, 1207-1214.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/IC.prior.html","id":null,"dir":"Reference","previous_headings":"","what":"Information Criterion Families of Prior Distribution for Coefficients in BMA\nModels — IC.prior","title":"Information Criterion Families of Prior Distribution for Coefficients in BMA\nModels — IC.prior","text":"Creates object representing prior distribution coefficients BAS.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/IC.prior.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Information Criterion Families of Prior Distribution for Coefficients in BMA\nModels — IC.prior","text":"","code":"IC.prior(penalty)"},{"path":"http://merliseclyde.github.io/BAS/reference/IC.prior.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Information Criterion Families of Prior Distribution for Coefficients in BMA\nModels — IC.prior","text":"penalty scalar used penalized loglikelihood form penalty*dimension","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/IC.prior.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Information Criterion Families of Prior Distribution for Coefficients in BMA\nModels — IC.prior","text":"returns object class \"prior\", family hyerparameters.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/IC.prior.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Information Criterion Families of Prior Distribution for Coefficients in BMA\nModels — IC.prior","text":"log marginal likelihood approximated -2*(deviance + penalty*dimension). Allows alternatives AIC (penalty = 2) BIC (penalty = log(n)). BIC, argument may missing, case sample size determined call `bas.glm` used determine penalty.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/IC.prior.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Information Criterion Families of Prior Distribution for Coefficients in BMA\nModels — IC.prior","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/IC.prior.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Information Criterion Families of Prior Distribution for Coefficients in BMA\nModels — IC.prior","text":"","code":"IC.prior(2) #> $family #> [1] \"IC\" #> #> $class #> [1] \"IC\" #> #> $hyper #> [1] 2 #> #> $hyper.parameters #> $hyper.parameters$penalty #> [1] 2 #> #> #> attr(,\"class\") #> [1] \"prior\" aic.prior() #> $family #> [1] \"AIC\" #> #> $class #> [1] \"IC\" #> #> $hyper.parameters #> $hyper.parameters$penalty #> [1] 2 #> #> #> $hyper #> [1] 2 #> #> attr(,\"class\") #> [1] \"prior\" bic.prior(100) #> $family #> [1] \"BIC\" #> #> $class #> [1] \"IC\" #> #> $hyper.parameters #> $hyper.parameters$penalty #> [1] 4.60517 #> #> $hyper.parameters$n #> [1] 100 #> #> #> $hyper #> [1] 4.60517 #> #> attr(,\"class\") #> [1] \"prior\""},{"path":"http://merliseclyde.github.io/BAS/reference/Jeffreys.html","id":null,"dir":"Reference","previous_headings":"","what":"Jeffreys Prior Distribution for $g$ for Mixtures of g-Priors for\nCoefficients in BMA Models — Jeffreys","title":"Jeffreys Prior Distribution for $g$ for Mixtures of g-Priors for\nCoefficients in BMA Models — Jeffreys","text":"Creates object representing Jeffrey's Prior g mixture g-priors coefficients BAS. equivalent limiting version CCH(, 2, 0) = 0 hyper-g(= 2) improper prior. $g$ appear Null Model, Bayes Factors model probabilities well-defined arbitrary normalizing constants, reason null model excluded constants used across models.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/Jeffreys.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Jeffreys Prior Distribution for $g$ for Mixtures of g-Priors for\nCoefficients in BMA Models — Jeffreys","text":"","code":"Jeffreys()"},{"path":"http://merliseclyde.github.io/BAS/reference/Jeffreys.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Jeffreys Prior Distribution for $g$ for Mixtures of g-Priors for\nCoefficients in BMA Models — Jeffreys","text":"returns object class \"prior\", family hyerparameters.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/Jeffreys.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Jeffreys Prior Distribution for $g$ for Mixtures of g-Priors for\nCoefficients in BMA Models — Jeffreys","text":"Creates structure used bas.glm.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/Jeffreys.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Jeffreys Prior Distribution for $g$ for Mixtures of g-Priors for\nCoefficients in BMA Models — Jeffreys","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/Jeffreys.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Jeffreys Prior Distribution for $g$ for Mixtures of g-Priors for\nCoefficients in BMA Models — Jeffreys","text":"","code":"Jeffreys() #> $family #> [1] \"Jeffreys\" #> #> $class #> [1] \"TCCH\" #> #> $hyper.parameters #> $hyper.parameters$alpha #> [1] 0 #> #> $hyper.parameters$beta #> [1] 2 #> #> $hyper.parameters$s #> [1] 0 #> #> #> attr(,\"class\") #> [1] \"prior\""},{"path":"http://merliseclyde.github.io/BAS/reference/TG.html","id":null,"dir":"Reference","previous_headings":"","what":"Generalized g-Prior Distribution for Coefficients in BMA Models — TG","title":"Generalized g-Prior Distribution for Coefficients in BMA Models — TG","text":"Creates object representing Truncated Gamma (tCCH) mixture g-priors coefficients BAS, u = 1/(1+g) Gamma distribution supported (0, 1].","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/TG.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Generalized g-Prior Distribution for Coefficients in BMA Models — TG","text":"","code":"TG(alpha = 2)"},{"path":"http://merliseclyde.github.io/BAS/reference/TG.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Generalized g-Prior Distribution for Coefficients in BMA Models — TG","text":"alpha scalar > 0, recommended alpha=.5 (betaprime) 1. alpha=2 corresponds uniform prior shrinkage factor.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/TG.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Generalized g-Prior Distribution for Coefficients in BMA Models — TG","text":"returns object class \"prior\", family hyerparameters.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/TG.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Generalized g-Prior Distribution for Coefficients in BMA Models — TG","text":"Creates structure used bas.glm.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/TG.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Generalized g-Prior Distribution for Coefficients in BMA Models — TG","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/TG.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Generalized g-Prior Distribution for Coefficients in BMA Models — TG","text":"","code":"TG(alpha = 2) #> $family #> [1] \"TG\" #> #> $class #> [1] \"TCCH\" #> #> $hyper.parameters #> $hyper.parameters$alpha #> [1] 2 #> #> $hyper.parameters$beta #> [1] 2 #> #> $hyper.parameters$s #> [1] 0 #> #> #> attr(,\"class\") #> [1] \"prior\" CCH(alpha = 2, beta = 100, s = 0) #> $family #> [1] \"CCH\" #> #> $class #> [1] \"TCCH\" #> #> $hyper.parameters #> $hyper.parameters$alpha #> [1] 2 #> #> $hyper.parameters$beta #> [1] 100 #> #> $hyper.parameters$s #> [1] 0 #> #> #> attr(,\"class\") #> [1] \"prior\""},{"path":"http://merliseclyde.github.io/BAS/reference/bas.glm.html","id":null,"dir":"Reference","previous_headings":"","what":"Bayesian Adaptive Sampling Without Replacement for Variable Selection in\nGeneralized Linear Models — bas.glm","title":"Bayesian Adaptive Sampling Without Replacement for Variable Selection in\nGeneralized Linear Models — bas.glm","text":"Sample without replacement posterior distribution GLMs","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/bas.glm.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Bayesian Adaptive Sampling Without Replacement for Variable Selection in\nGeneralized Linear Models — bas.glm","text":"","code":"bas.glm( formula, family = binomial(link = \"logit\"), data, weights, subset, contrasts = NULL, offset, na.action = \"na.omit\", n.models = NULL, betaprior = CCH(alpha = 0.5, beta = as.numeric(nrow(data)), s = 0), modelprior = beta.binomial(1, 1), initprobs = \"Uniform\", include.always = ~1, method = \"MCMC\", update = NULL, bestmodel = NULL, prob.rw = 0.5, MCMC.iterations = NULL, thin = 1, control = glm.control(), laplace = FALSE, renormalize = FALSE, force.heredity = FALSE, bigmem = FALSE )"},{"path":"http://merliseclyde.github.io/BAS/reference/bas.glm.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Bayesian Adaptive Sampling Without Replacement for Variable Selection in\nGeneralized Linear Models — bas.glm","text":"formula generalized linear model formula full model predictors, Y ~ X. code assumes intercept included model. family description error distribution link function exponential family; currently `binomial()` logistic link `poisson()` `Gamma()`log link available. data data frame weights optional vector weights used fitting process. May missing case weights 1. subset subset data used fitting contrasts optional list. See contrasts.arg `model.matrix.default()`. offset priori known component included linear predictor; default 0. na.action function indicates happen data contain NAs. default \"na.omit\". n.models number unique models keep. NULL, BAS attempt enumerate unless p > 35 method=\"MCMC\". methods using MCMC algorithms sample replacement, sampling stop number iterations exceeds min 'n.models' 'MCMC.iterations' exit 'n.models' updated reflect unique number models sampled. betaprior Prior coefficients model coefficients (except intercept). Options include g.prior, CCH, robust, intrinsic, beta.prime, EB.local, AIC, BIC. modelprior Family prior distribution models. Choices include uniform, Bernoulli, beta.binomial, truncated Beta-Binomial, tr.beta.binomial, truncated power family tr.power.prior. initprobs vector length p initial inclusion probabilities used sampling without replacement (intercept included probability one need added ) character string giving method used construct sampling probabilities \"Uniform\" predictor variable equally likely sampled (equivalent random sampling without replacement). \"eplogp\", use eplogprob function approximate Bayes factor using p-values find initial marginal inclusion probabilities sample without replacement using inclusion probabilities, may updated using estimates marginal inclusion probabilities. \"eplogp\" assumes MLEs full model exist; problems case 'p' large, initial sampling probabilities may obtained using eplogprob.marg fits model predictor separately. run Markov Chain provide initial estimates marginal inclusion probabilities, use method=\"MCMC+BAS\" . initprobs used sampling method=\"MCMC\", determines order variables lookup table affects memory allocation large problems enumeration feasible. variables always included set corresponding initprobs 1, override `modelprior` use `include.always` force variables always included model. include.always formula terms always included model probability one. default `~ 1` meaning intercept always included. also override values `initprobs` setting 1. method character variable indicating sampling method use: method=\"BAS\" uses Bayesian Adaptive Sampling (without replacement) using sampling probabilities given initprobs updates using marginal inclusion probabilities direct search/sample; method=\"MCMC\" combines random walk Metropolis Hastings (MC3 Raftery et al 1997) random swap variable included variable currently excluded (see Clyde, Ghosh, Littman (2010) details); method=\"MCMC+BAS\" runs initial MCMC calculate marginal inclusion probabilities samples without replacement BAS; method = \"deterministic\" runs deterministic sampling using initial probabilities (updating); recommended fast enumeration model independence good approximation joint posterior distribution model indicators. BAS, sampling probabilities can updated models sampled. (see 'update' ). recommend \"MCMC+BAS\" \"MCMC\" high dimensional problems. update number iterations potential updates sampling probabilities \"BAS\" method. NULL update, otherwise algorithm update using marginal inclusion probabilities change sampling takes place. large model spaces, updating recommended. model space enumerated, leave default. bestmodel optional binary vector representing model initialize sampling. NULL sampling starts null model prob.rw MCMC methods, probability using random-walk proposal; otherwise use random \"flip\" move propose new model. MCMC.iterations Number models sample using MCMC options; greater 'n.models'. default 10*n.models. thin oFr \"MCMC\", thin MCMC chain every \"thin\" iterations; default thinning. large p, thinning can used significantly reduce memory requirements models associated summaries saved every thin iterations. thin = p, model associated output recorded every p iterations,similar Gibbs sampler SSVS. control list parameters control convergence fitting process. See documentation glm.control() laplace logical variable whether use Laplace approximate integration respect g obtain marginal likelihood. FALSE Cephes library used may inaccurate large n large values Wald Chisquared statistic. renormalize logical variable whether posterior probabilities based renormalizing marginal likelihoods times prior probabilities use Monte Carlo frequencies. Applies MCMC sampling. force.heredity Logical variable force levels factor included together include higher order interactions lower order terms included. Currently supported `method='MCMC'` `method='BAS'` (experimental) non-Solaris platforms. Default FALSE. bigmem Logical variable indicate access large amounts memory (physical virtual) enumeration large model spaces, e.g. > 2^25.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/bas.glm.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Bayesian Adaptive Sampling Without Replacement for Variable Selection in\nGeneralized Linear Models — bas.glm","text":"bas.glm returns object class basglm object class basglm list containing least following components: postprobs posterior probabilities models selected priorprobs prior probabilities models selected logmarg values log marginal likelihood models n.vars total number independent variables full model, including intercept size number independent variables models, includes intercept list lists one list per model variables included model probne0 posterior probability variable non-zero mle list lists one list per model giving GLM estimate (nonzero) coefficient model. mle.se list lists one list per model giving GLM standard error coefficient model deviance GLM deviance model modelprior prior distribution models created BMA object Q Q statistic model used marginal likelihood approximation Y response X matrix predictors family family object original call betaprior family object prior coefficients, including hyperparameters modelprior family object prior models include.always indices variables forced model","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/bas.glm.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Bayesian Adaptive Sampling Without Replacement for Variable Selection in\nGeneralized Linear Models — bas.glm","text":"BAS provides several search algorithms find high probability models use Bayesian Model Averaging Bayesian model selection. p less 20-25, BAS can enumerate models depending memory availability, larger p, BAS samples without replacement using random deterministic sampling. Bayesian Adaptive Sampling algorithm Clyde, Ghosh, Littman (2010) samples models without replacement using initial sampling probabilities, optionally update sampling probabilities every \"update\" models using estimated marginal inclusion probabilities. BAS uses different methods obtain initprobs, may impact results high-dimensional problems. deterministic sampler provides list top models order approximation independence using provided initprobs. may effective running algorithms identify high probability models works well correlations variables small modest. priors coefficients mixtures g-priors provide approximations power prior.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/bas.glm.html","id":"references","dir":"Reference","previous_headings":"","what":"References","title":"Bayesian Adaptive Sampling Without Replacement for Variable Selection in\nGeneralized Linear Models — bas.glm","text":"Li, Y. Clyde, M. (2018) Mixtures g-priors Generalized Linear Models. Journal American Statistical Association. 113:1828-1845 doi:10.1080/01621459.2018.1469992 Clyde, M. Ghosh, J. Littman, M. (2010) Bayesian Adaptive Sampling Variable Selection Model Averaging. Journal Computational Graphics Statistics. 20:80-101 doi:10.1198/jcgs.2010.09049 Raftery, .E, Madigan, D. Hoeting, J.. (1997) Bayesian Model Averaging Linear Regression Models. Journal American Statistical Association.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/bas.glm.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Bayesian Adaptive Sampling Without Replacement for Variable Selection in\nGeneralized Linear Models — bas.glm","text":"Merlise Clyde (clyde@duke.edu), Quanli Wang Yingbo Li","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/bas.glm.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Bayesian Adaptive Sampling Without Replacement for Variable Selection in\nGeneralized Linear Models — bas.glm","text":"","code":"library(MASS) data(Pima.tr) # enumeration with default method=\"BAS\" pima.cch = bas.glm(type ~ ., data=Pima.tr, n.models= 2^7, method=\"BAS\", betaprior=CCH(a=1, b=532/2, s=0), family=binomial(), modelprior=beta.binomial(1,1)) summary(pima.cch) #> P(B != 0 | Y) model 1 model 2 model 3 model 4 #> Intercept 1.0000000 1.0000 1.0000000 1.0000000 1.0000000 #> npreg 0.5684414 0.0000 1.0000000 1.0000000 0.0000000 #> glu 0.9999949 1.0000 1.0000000 1.0000000 1.0000000 #> bp 0.2198720 0.0000 0.0000000 0.0000000 0.0000000 #> skin 0.2653924 0.0000 0.0000000 0.0000000 0.0000000 #> bmi 0.7425039 1.0000 1.0000000 1.0000000 0.0000000 #> ped 0.8860972 1.0000 1.0000000 1.0000000 1.0000000 #> age 0.7459954 1.0000 1.0000000 0.0000000 1.0000000 #> BF NA 1.0000 0.4406494 0.6209086 0.4628319 #> PostProbs NA 0.1596 0.1172000 0.0991000 0.0739000 #> R2 NA 0.2938 0.3040000 0.2901000 0.2703000 #> dim NA 5.0000 6.0000000 5.0000000 4.0000000 #> logmarg NA -101.7878 -102.6072611 -102.2643268 -102.5581467 #> model 5 #> Intercept 1.000000e+00 #> npreg 1.000000e+00 #> glu 1.000000e+00 #> bp 1.000000e+00 #> skin 1.000000e+00 #> bmi 1.000000e+00 #> ped 1.000000e+00 #> age 1.000000e+00 #> BF 8.659168e-03 #> PostProbs 4.840000e-02 #> R2 3.043000e-01 #> dim 8.000000e+00 #> logmarg -1.065369e+02 image(pima.cch) # Note MCMC.iterations are set to 2500 for illustration purposes due to time # limitations for running examples on CRAN servers. # Please check convergence diagnostics and run longer in practice pima.robust = bas.glm(type ~ ., data=Pima.tr, n.models= 2^7, method=\"MCMC\", MCMC.iterations=2500, betaprior=robust(), family=binomial(), modelprior=beta.binomial(1,1)) pima.BIC = bas.glm(type ~ ., data=Pima.tr, n.models= 2^7, method=\"BAS+MCMC\", MCMC.iterations=2500, betaprior=bic.prior(), family=binomial(), modelprior=uniform()) #> Warning: no non-missing arguments to min; returning Inf # Poisson example if(requireNamespace(\"glmbb\", quietly=TRUE)) { data(crabs, package='glmbb') #short run for illustration crabs.bas = bas.glm(satell ~ color*spine*width + weight, data=crabs, family=poisson(), betaprior=EB.local(), modelprior=uniform(), method='MCMC', n.models=2^10, MCMC.iterations=2500, prob.rw=.95) # Gamma example if(requireNamespace(\"faraway\", quietly=TRUE)) { data(wafer, package='faraway') wafer_bas = bas.glm(resist~ ., data=wafer, include.always = ~ ., betaprior = bic.prior() , family = Gamma(link = \"log\")) } }"},{"path":"http://merliseclyde.github.io/BAS/reference/bas.lm.html","id":null,"dir":"Reference","previous_headings":"","what":"Bayesian Adaptive Sampling for Bayesian Model Averaging and Variable Selection in\nLinear Models — bas.lm","title":"Bayesian Adaptive Sampling for Bayesian Model Averaging and Variable Selection in\nLinear Models — bas.lm","text":"Sample without replacement posterior distribution models","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/bas.lm.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Bayesian Adaptive Sampling for Bayesian Model Averaging and Variable Selection in\nLinear Models — bas.lm","text":"","code":"bas.lm( formula, data, subset, weights, contrasts = NULL, na.action = \"na.omit\", n.models = NULL, prior = \"ZS-null\", alpha = NULL, modelprior = beta.binomial(1, 1), initprobs = \"Uniform\", include.always = ~1, method = \"BAS\", update = NULL, bestmodel = NULL, prob.local = 0, prob.rw = 0.5, MCMC.iterations = NULL, lambda = NULL, delta = 0.025, thin = 1, renormalize = FALSE, force.heredity = FALSE, pivot = TRUE, tol = 1e-07, bigmem = FALSE )"},{"path":"http://merliseclyde.github.io/BAS/reference/bas.lm.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Bayesian Adaptive Sampling for Bayesian Model Averaging and Variable Selection in\nLinear Models — bas.lm","text":"formula linear model formula full model predictors, Y ~ X. code assumes intercept included model X's centered. data data frame. Factors converted numerical vectors based using `model.matrix`. subset optional vector specifying subset observations used fitting process. weights optional vector weights used fitting process. NULL numeric vector. non-NULL, Bayes estimates obtained assuming \\(Y_i \\sim N(x^T_i\\beta, \\sigma^2/w_i)\\). contrasts optional list. See contrasts.arg `model.matrix.default()`. na.action function indicates happen data contain NAs. default \"na.omit\". n.models number models sample either without replacement (method=\"BAS\" \"MCMC+BAS\") replacement (method=\"MCMC\"). NULL, BAS method=\"BAS\" try enumerate 2^p models. enumeration possible (memory time) value supplied controls number sampled models using 'n.models'. method=\"MCMC\", sampling stop min(n.models, MCMC.iterations) occurs MCMC.iterations significantly larger n.models order explore model space. exit method= \"MCMC\" number unique models sampled counts stored output \"freq\". prior prior distribution regression coefficients. Choices include \"AIC\" \"BIC\" \"g-prior\", Zellner's g prior `g` specified using argument `alpha` \"JZS\" Jeffreys-Zellner-Siow prior uses Jeffreys prior sigma Zellner-Siow Cauchy prior coefficients. optional parameter `alpha` can used control squared scale prior, default alpha=1. Setting `alpha` equal rscale^2 BayesFactor package Morey. uses QUADMATH numerical integration g. \"ZS-null\", Laplace approximation 'JZS' prior integration g. alpha = 1 . recommend using 'JZS' accuracy compatibility BayesFactor package, although slower. \"ZS-full\" (deprecated) \"hyper-g\", mixture g-priors prior g/(1+g) Beta(1, alpha/2) Liang et al (2008). uses Cephes library evaluation marginal likelihoods may numerically unstable large n R2 close 1. Default choice alpha 3. \"hyper-g-laplace\", using Laplace approximation integrate prior g. \"hyper-g-n\", mixture g-priors u = g/n u ~ Beta(1, alpha/2) provide consistency null model true. \"EB-local\", use MLE g marginal likelihood within model \"EB-global\" uses EM algorithm find common global estimate g, averaged models. possible enumerate models, EM algorithm uses models sampled EB-local. alpha optional hyperparameter g-prior hyper g-prior. Zellner's g-prior, alpha = g, Liang et al hyper-g hyper-g-n method, recommended choice alpha (2 < alpha < 4), alpha = 3 default. Zellner-Siow prior alpha = 1 default, can used modify rate parameter gamma prior g, $$1/g \\sim G(1/2, n*\\alpha/2)$$ $$\\beta \\sim C(0, \\sigma^2 \\alpha (X'X/n)^{-1})$$. modelprior function family prior distribution models. Choices include uniform Bernoulli beta.binomial, tr.beta.binomial, (truncation) tr.poisson (truncated Poisson), tr.power.prior (truncated power family), default beta.binomial(1,1). Truncated versions useful p > n. initprobs Vector length p character string specifying method used create vector. used order variables sampling methods potentially efficient storage sampling provides initial inclusion probabilities used sampling without replacement method=\"BAS\". Options character string giving method : \"Uniform\" \"uniform\" predictor variable equally likely sampled (equivalent random sampling without replacement); \"eplogp\" uses eplogprob function approximate Bayes factor p-values full model find initial marginal inclusion probabilities; \"marg-eplogp\" useseplogprob.marg function approximate Bayes factor p-values full model simple linear regression. run Markov Chain provide initial estimates marginal inclusion probabilities \"BAS\", use method=\"MCMC+BAS\" . initprobs used sampling method=\"MCMC\", determines order variables lookup table affects memory allocation large problems enumeration feasible. variables always included set corresponding initprobs 1, override `modelprior` use `include.always` force variables always included model. include.always formula terms always included model probability one. default `~ 1` meaning intercept always included. also override values `initprobs` setting 1. method character variable indicating sampling method use: \"deterministic\" uses \"top k\" algorithm described Ghosh Clyde (2011) sample models order approximate probability conditional independence using \"initprobs\". efficient algorithm enumeration. \"BAS\" uses Bayesian Adaptive Sampling (without replacement) using sampling probabilities given initprobs model conditional independence. can updated based estimates marginal inclusion probabilities. \"MCMC\" samples replacement via MCMC algorithm combines birth/death random walk Hoeting et al (1997) MC3 random swap move interchange variable model one currently excluded described Clyde, Ghosh Littman (2010). \"MCMC+BAS\" runs initial MCMC calculate marginal inclusion probabilities samples without replacement BAS. BAS, sampling probabilities can updated models sampled. (see update ). update number iterations potential updates sampling probabilities method \"BAS\" \"MCMC+BAS\". NULL update, otherwise algorithm update using marginal inclusion probabilities change sampling takes place. large model spaces, updating recommended. model space enumerated, leave default. bestmodel optional binary vector representing model initialize sampling. NULL sampling starts null model prob.local future option allow sampling models \"near\" median probability model. used time. prob.rw MCMC methods, probability using random-walk Metropolis proposal; otherwise use random \"flip\" move propose swap variable excluded variable model. MCMC.iterations Number iterations MCMC sampler; default n.models*10 set user. lambda Parameter AMCMC algorithm (deprecated). delta truncation parameter prevent sampling probabilities degenerate 0 1 prior enumeration sampling without replacement. thin \"MCMC\" \"MCMC+BAS\", thin MCMC chain every \"thin\" iterations; default thinning. large p, thinning can used significantly reduce memory requirements models associated summaries saved every thin iterations. thin = p, model associated output recorded every p iterations, similar Gibbs sampler SSVS. renormalize MCMC sampling, posterior probabilities based renormalizing marginal likelihoods times prior probabilities (TRUE) frequencies MCMC. latter unbiased long runs, former may less variability. May compared via diagnostic plot function diagnostics. See details Clyde Ghosh (2012). force.heredity Logical variable force levels factor included together include higher order interactions lower order terms included. Currently supported `method='MCMC'` experimentally `method='BAS'` non-Solaris platforms. Default FALSE. pivot Logical variable allow pivoting columns obtaining OLS estimates model models full rank can fit. Defaults TRUE. Currently coefficients estimable set zero. Use caution interpreting BMA estimates parameters. tol 1e-7 bigmem Logical variable indicate access large amounts memory (physical virtual) enumeration large model spaces, e.g. > 2^25. default; used determining rank X^TX cholesky decomposition pivoting.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/bas.lm.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Bayesian Adaptive Sampling for Bayesian Model Averaging and Variable Selection in\nLinear Models — bas.lm","text":"bas returns object class bas object class BAS list containing least following components: postprob posterior probabilities models selected priorprobs prior probabilities models selected namesx names variables R2 R2 values models logmarg values log marginal likelihood models. equivalent log Bayes Factor comparing model base model intercept . n.vars total number independent variables full model, including intercept size number independent variables models, includes intercept rank rank design matrix; `pivot = FALSE`, size checking rank conducted. list lists one list per model variables included model probne0 posterior probability variable non-zero computed using renormalized marginal likelihoods sampled models. may biased number sampled models much smaller total number models. Unbiased estimates may obtained using method \"MCMC\". mle list lists one list per model giving MLE (OLS) estimate (nonzero) coefficient model. NOTE: intercept mean Y column X centered subtracting mean. mle.se list lists one list per model giving MLE (OLS) standard error coefficient model prior name prior created BMA object alpha value hyperparameter coefficient prior used create BMA object. modelprior prior distribution models created BMA object Y response X matrix predictors mean.x vector means column X (used predict.bas) include.always indices variables forced model function summary.bas, used print summary results. function plot.bas used plot posterior distributions coefficients image.bas provides image distribution models. Posterior summaries coefficients can extracted using coefficients.bas. Fitted values predictions can obtained using S3 functions fitted.bas predict.bas. BAS objects may updated use different prior (without rerunning sampler) using function update.bas. MCMC sampling diagnostics can used assess whether MCMC run long enough posterior probabilities stable. details see associated demos vignette.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/bas.lm.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Bayesian Adaptive Sampling for Bayesian Model Averaging and Variable Selection in\nLinear Models — bas.lm","text":"BAS provides several algorithms sample posterior distributions models use Bayesian Model Averaging Bayesian variable selection. p less 20-25, BAS can enumerate models depending memory availability. BAS saves models, MLEs, standard errors, log marginal likelihoods, prior posterior probabilities memory requirements grow linearly M*p M number models p number predictors. example, enumeration p=21 2,097,152 takes just 2 Gigabytes 64 bit machine store summaries needed model averaging. (future version likely include option store summaries users plan using model averaging model selection Best Predictive models.) larger p, BAS samples without replacement using random deterministic sampling. Bayesian Adaptive Sampling algorithm Clyde, Ghosh, Littman (2010) samples models without replacement using initial sampling probabilities, optionally update sampling probabilities every \"update\" models using estimated marginal inclusion probabilities. BAS uses different methods obtain initprobs, may impact results high-dimensional problems. deterministic sampler provides list top models order approximation independence using provided initprobs. may effective running algorithms identify high probability models works well correlations variables small modest. recommend \"MCMC\" problems enumeration feasible (memory time constrained) even modest p number models sampled close number possible models /significant correlations among predictors bias estimates inclusion probabilities \"BAS\" \"MCMC+BAS\" may large relative reduced variability using normalized model probabilities shown Clyde Ghosh, 2012. Diagnostic plots MCMC can used assess convergence. large problems recommend thinning MCMC reduce memory requirements. priors coefficients include Zellner's g-prior, Hyper-g prior (Liang et al 2008, Zellner-Siow Cauchy prior, Empirical Bayes (local global) g-priors. AIC BIC also included, range priors model space available.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/bas.lm.html","id":"references","dir":"Reference","previous_headings":"","what":"References","title":"Bayesian Adaptive Sampling for Bayesian Model Averaging and Variable Selection in\nLinear Models — bas.lm","text":"Clyde, M. Ghosh, J. Littman, M. (2010) Bayesian Adaptive Sampling Variable Selection Model Averaging. Journal Computational Graphics Statistics. 20:80-101 doi:10.1198/jcgs.2010.09049 Clyde, M. Ghosh. J. (2012) Finite population estimators stochastic search variable selection. Biometrika, 99 (4), 981-988. doi:10.1093/biomet/ass040 Clyde, M. George, E. . (2004) Model Uncertainty. Statist. Sci., 19, 81-94. doi:10.1214/088342304000000035 Clyde, M. (1999) Bayesian Model Averaging Model Search Strategies (discussion). Bayesian Statistics 6. J.M. Bernardo, .P. Dawid, J.O. Berger, .F.M. Smith eds. Oxford University Press, pages 157-185. Hoeting, J. ., Madigan, D., Raftery, . E. Volinsky, C. T. (1999) Bayesian model averaging: tutorial (discussion). Statist. Sci., 14, 382-401. doi:10.1214/ss/1009212519 Liang, F., Paulo, R., Molina, G., Clyde, M. Berger, J.O. (2008) Mixtures g-priors Bayesian Variable Selection. Journal American Statistical Association. 103:410-423. doi:10.1198/016214507000001337 Zellner, . (1986) assessing prior distributions Bayesian regression analysis g-prior distributions. Bayesian Inference Decision Techniques: Essays Honor Bruno de Finetti, pp. 233-243. North-Holland/Elsevier. Zellner, . Siow, . (1980) Posterior odds ratios selected regression hypotheses. Bayesian Statistics: Proceedings First International Meeting held Valencia (Spain), pp. 585-603. Rouder, J. N., Speckman, P. L., Sun, D., Morey, R. D., Iverson, G. (2009). Bayesian t-tests accepting rejecting null hypothesis. Psychonomic Bulletin & Review, 16, 225-237 Rouder, J. N., Morey, R. D., Speckman, P. L., Province, J. M., (2012) Default Bayes Factors ANOVA Designs. Journal Mathematical Psychology. 56. p. 356-374.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/bas.lm.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Bayesian Adaptive Sampling for Bayesian Model Averaging and Variable Selection in\nLinear Models — bas.lm","text":"Merlise Clyde (clyde@duke.edu) Michael Littman","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/bas.lm.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Bayesian Adaptive Sampling for Bayesian Model Averaging and Variable Selection in\nLinear Models — bas.lm","text":"","code":"library(MASS) data(UScrime) # pivot=FALSE is faster, but should only be used in full rank case # default is pivot = TRUE crime.bic <- bas.lm(log(y) ~ log(M) + So + log(Ed) + log(Po1) + log(Po2) + log(LF) + log(M.F) + log(Pop) + log(NW) + log(U1) + log(U2) + log(GDP) + log(Ineq) + log(Prob) + log(Time), data = UScrime, n.models = 2^15, prior = \"BIC\", modelprior = beta.binomial(1, 1), initprobs = \"eplogp\", pivot = FALSE ) # use MCMC rather than enumeration crime.mcmc <- bas.lm(log(y) ~ log(M) + So + log(Ed) + log(Po1) + log(Po2) + log(LF) + log(M.F) + log(Pop) + log(NW) + log(U1) + log(U2) + log(GDP) + log(Ineq) + log(Prob) + log(Time), data = UScrime, method = \"MCMC\", MCMC.iterations = 20000, prior = \"BIC\", modelprior = beta.binomial(1, 1), initprobs = \"eplogp\", pivot = FALSE ) summary(crime.bic) #> P(B != 0 | Y) model 1 model 2 model 3 model 4 #> Intercept 1.0000000 1.00000 1.000000e+00 1.0000000 1.0000000 #> log(M) 0.9335117 1.00000 1.000000e+00 1.0000000 1.0000000 #> So 0.3276563 0.00000 1.000000e+00 0.0000000 0.0000000 #> log(Ed) 0.9910219 1.00000 1.000000e+00 1.0000000 1.0000000 #> log(Po1) 0.7246635 1.00000 1.000000e+00 1.0000000 1.0000000 #> log(Po2) 0.4602481 0.00000 1.000000e+00 0.0000000 0.0000000 #> log(LF) 0.2935326 0.00000 1.000000e+00 0.0000000 0.0000000 #> log(M.F) 0.3298168 0.00000 1.000000e+00 0.0000000 0.0000000 #> log(Pop) 0.4962869 0.00000 1.000000e+00 0.0000000 0.0000000 #> log(NW) 0.8346412 1.00000 1.000000e+00 1.0000000 1.0000000 #> log(U1) 0.3481266 0.00000 1.000000e+00 0.0000000 0.0000000 #> log(U2) 0.7752102 1.00000 1.000000e+00 1.0000000 1.0000000 #> log(GDP) 0.5253694 0.00000 1.000000e+00 0.0000000 1.0000000 #> log(Ineq) 0.9992058 1.00000 1.000000e+00 1.0000000 1.0000000 #> log(Prob) 0.9541470 1.00000 1.000000e+00 1.0000000 1.0000000 #> log(Time) 0.5432686 1.00000 1.000000e+00 0.0000000 1.0000000 #> BF NA 1.00000 1.267935e-04 0.7609295 0.5431578 #> PostProbs NA 0.01910 1.560000e-02 0.0145000 0.0133000 #> R2 NA 0.84200 8.695000e-01 0.8265000 0.8506000 #> dim NA 9.00000 1.600000e+01 8.0000000 10.0000000 #> logmarg NA -22.15855 -3.113150e+01 -22.4317627 -22.7689035 #> model 5 #> Intercept 1.0000000 #> log(M) 1.0000000 #> So 0.0000000 #> log(Ed) 1.0000000 #> log(Po1) 1.0000000 #> log(Po2) 0.0000000 #> log(LF) 0.0000000 #> log(M.F) 0.0000000 #> log(Pop) 1.0000000 #> log(NW) 1.0000000 #> log(U1) 0.0000000 #> log(U2) 1.0000000 #> log(GDP) 0.0000000 #> log(Ineq) 1.0000000 #> log(Prob) 1.0000000 #> log(Time) 0.0000000 #> BF 0.5203179 #> PostProbs 0.0099000 #> R2 0.8375000 #> dim 9.0000000 #> logmarg -22.8118635 plot(crime.bic) image(crime.bic, subset = -1) # example with two-way interactions and hierarchical constraints data(ToothGrowth) ToothGrowth$dose <- factor(ToothGrowth$dose) levels(ToothGrowth$dose) <- c(\"Low\", \"Medium\", \"High\") TG.bas <- bas.lm(len ~ supp * dose, data = ToothGrowth, modelprior = uniform(), method = \"BAS\", force.heredity = TRUE ) summary(TG.bas) #> P(B != 0 | Y) model 1 model 2 model 3 model 4 #> Intercept 1.0000000 1.00000 1.0000000 1.00000000 1.000000e+00 #> suppVC 0.9910702 1.00000 1.0000000 0.00000000 0.000000e+00 #> doseMedium 1.0000000 1.00000 1.0000000 1.00000000 0.000000e+00 #> doseHigh 1.0000000 1.00000 1.0000000 1.00000000 0.000000e+00 #> suppVC:doseMedium 0.4500943 0.00000 1.0000000 0.00000000 0.000000e+00 #> suppVC:doseHigh 0.4500943 0.00000 1.0000000 0.00000000 0.000000e+00 #> BF NA 1.00000 0.8320043 0.01650685 2.812754e-15 #> PostProbs NA 0.54100 0.4501000 0.00890000 0.000000e+00 #> R2 NA 0.76230 0.7937000 0.70290000 0.000000e+00 #> dim NA 4.00000 6.0000000 3.00000000 1.000000e+00 #> logmarg NA 33.50461 33.3206946 29.40063248 0.000000e+00 #> model 5 #> Intercept 1.000000e+00 #> suppVC 1.000000e+00 #> doseMedium 0.000000e+00 #> doseHigh 0.000000e+00 #> suppVC:doseMedium 0.000000e+00 #> suppVC:doseHigh 0.000000e+00 #> BF 7.895214e-16 #> PostProbs 0.000000e+00 #> R2 5.950000e-02 #> dim 2.000000e+00 #> logmarg -1.270492e+00 image(TG.bas) # don't run the following due to time limits on CRAN if (FALSE) { # exmple with non-full rank case loc <- system.file(\"testdata\", package = \"BAS\") d <- read.csv(paste(loc, \"JASP-testdata.csv\", sep = \"/\")) fullModelFormula <- as.formula(\"contNormal ~ contGamma * contExpon + contGamma * contcor1 + contExpon * contcor1\") # should trigger a warning (default is to use pivoting, so use pivot=FALSE # only for full rank case) out = bas.lm(fullModelFormula, data = d, alpha = 0.125316, prior = \"JZS\", weights = facFifty, force.heredity = FALSE, pivot = FALSE) # use pivot = TRUE to fit non-full rank case (default) # This is slower but safer out = bas.lm(fullModelFormula, data = d, alpha = 0.125316, prior = \"JZS\", weights = facFifty, force.heredity = FALSE, pivot = TRUE) } # more complete demo's demo(BAS.hald) #> #> #> \tdemo(BAS.hald) #> \t---- ~~~~~~~~ #> #> > data(Hald) #> #> > hald.gprior = bas.lm(Y~ ., data=Hald, prior=\"g-prior\", alpha=13, #> + modelprior=beta.binomial(1,1), #> + initprobs=\"eplogp\") #> #> > hald.gprior #> #> Call: #> bas.lm(formula = Y ~ ., data = Hald, prior = \"g-prior\", alpha = 13, #> modelprior = beta.binomial(1, 1), initprobs = \"eplogp\") #> #> #> Marginal Posterior Inclusion Probabilities: #> Intercept X1 X2 X3 X4 #> 1.0000 0.9019 0.6896 0.4653 0.6329 #> #> > plot(hald.gprior) #> #> > summary(hald.gprior) #> P(B != 0 | Y) model 1 model 2 model 3 model 4 model 5 #> Intercept 1.0000000 1.00000 1.0000000 1.00000000 1.0000000 1.0000000 #> X1 0.9019245 1.00000 1.0000000 1.00000000 1.0000000 1.0000000 #> X2 0.6895830 1.00000 0.0000000 1.00000000 1.0000000 1.0000000 #> X3 0.4652762 0.00000 0.0000000 1.00000000 0.0000000 1.0000000 #> X4 0.6329266 0.00000 1.0000000 1.00000000 1.0000000 0.0000000 #> BF NA 1.00000 0.6923944 0.08991408 0.3355714 0.3344926 #> PostProbs NA 0.24320 0.1684000 0.13120000 0.1224000 0.1220000 #> R2 NA 0.97870 0.9725000 0.98240000 0.9823000 0.9823000 #> dim NA 3.00000 3.0000000 5.00000000 4.0000000 4.0000000 #> logmarg NA 11.72735 11.3597547 9.31845348 10.6354335 10.6322138 #> #> > image(hald.gprior, subset=-1, vlas=0) #> #> > hald.coef = coefficients(hald.gprior) #> #> > hald.coef #> #> Marginal Posterior Summaries of Coefficients: #> #> Using BMA #> #> Based on the top 16 models #> post mean post SD post p(B != 0) #> Intercept 95.4231 0.7107 1.0000 #> X1 1.2150 0.5190 0.9019 #> X2 0.2756 0.4832 0.6896 #> X3 -0.1271 0.4976 0.4653 #> X4 -0.3269 0.4717 0.6329 #> #> > plot(hald.coef) #> #> > predict(hald.gprior, top=5, se.fit=TRUE) #> $fit #> [1] 79.74246 74.50010 105.29268 89.88693 95.57177 104.56409 103.40145 #> [8] 77.13668 91.99731 114.21325 82.78446 111.00723 110.40160 #> #> $Ybma #> [,1] #> [1,] 79.74246 #> [2,] 74.50010 #> [3,] 105.29268 #> [4,] 89.88693 #> [5,] 95.57177 #> [6,] 104.56409 #> [7,] 103.40145 #> [8,] 77.13668 #> [9,] 91.99731 #> [10,] 114.21325 #> [11,] 82.78446 #> [12,] 111.00723 #> [13,] 110.40160 #> #> $Ypred #> [,1] [,2] [,3] [,4] [,5] [,6] [,7] [,8] #> [1,] 81.17036 74.83464 105.0725 89.69881 97.15898 104.4575 103.3893 76.06454 #> [2,] 77.70296 74.24113 105.8554 90.46267 93.09565 104.7152 103.1399 78.80193 #> [3,] 79.70437 74.40553 105.2175 89.76253 95.63309 104.5709 103.5254 77.08557 #> [4,] 79.65151 74.47846 105.4218 89.83174 95.62799 104.5962 103.5068 77.00839 #> [5,] 79.84321 74.31409 104.9063 89.65651 95.70301 104.5285 103.5476 77.15919 #> [,9] [,10] [,11] [,12] [,13] #> [1,] 91.57174 113.1722 81.59906 111.2219 111.0884 #> [2,] 92.68123 115.8058 84.50293 110.4162 109.0791 #> [3,] 91.98604 114.1759 82.78145 111.1196 110.5321 #> [4,] 92.07571 114.1088 82.68233 111.0429 110.4674 #> [5,] 91.83513 114.2353 82.88128 111.2384 110.6515 #> #> $postprobs #> [1] 0.3089304 0.2139017 0.1666632 0.1555023 0.1550024 #> #> $se.fit #> [,1] [,2] [,3] [,4] [,5] [,6] [,7] [,8] #> [1,] 2.220164 2.265862 1.546911 2.181188 1.310135 1.523300 2.655096 2.176560 #> [2,] 2.716798 2.389723 1.633637 2.179215 1.321062 1.581232 2.721957 2.078129 #> [3,] 3.203405 2.501485 3.279273 2.357164 2.589756 1.549136 2.623290 2.765255 #> [4,] 3.117350 2.283957 1.602160 2.149087 2.589321 1.508471 2.610923 2.545817 #> [5,] 2.932580 2.353352 1.538009 2.141694 2.507848 1.498758 2.616407 2.680289 #> [,9] [,10] [,11] [,12] [,13] #> [1,] 1.883610 3.264656 1.908238 1.970691 2.054234 #> [2,] 2.013244 3.298134 1.933819 1.964374 1.924460 #> [3,] 2.353516 3.609909 2.821295 2.227363 2.390135 #> [4,] 1.990817 3.485929 2.456636 1.951456 2.212238 #> [5,] 1.889302 3.569065 2.665166 1.934336 2.117189 #> #> $se.pred #> [,1] [,2] [,3] [,4] [,5] [,6] [,7] [,8] #> [1,] 5.057182 5.077410 4.799885 5.040193 4.728892 4.792328 5.262651 5.038191 #> [2,] 5.415848 5.259391 4.961773 5.167146 4.867815 4.944766 5.418438 5.125333 #> [3,] 5.489152 5.111401 5.533771 5.042342 5.155175 4.718984 5.172102 5.245534 #> [4,] 5.440156 5.009380 4.737547 4.949344 5.155775 4.706689 5.166658 5.134065 #> [5,] 5.337427 5.042456 4.717369 4.947217 5.116386 4.704719 5.170463 5.203081 #> [,9] [,10] [,11] [,12] [,13] #> [1,] 4.918734 5.594992 4.928218 4.952735 4.986566 #> [2,] 5.099370 5.729582 5.068538 5.080274 5.064974 #> [3,] 5.040638 5.735890 5.275291 4.982985 5.057839 #> [4,] 4.882702 5.659428 5.090431 4.866787 4.977090 #> [5,] 4.843301 5.711946 5.195307 4.861045 4.936658 #> #> $se.bma.fit #> [1] 2.688224 2.095245 1.769625 1.970919 2.197285 1.363804 2.356457 2.302631 #> [9] 1.822084 3.141443 2.237663 1.801849 1.991374 #> #> $se.bma.pred #> [1] 4.838655 4.536087 4.395180 4.480017 4.584113 4.248058 4.662502 4.635531 #> [9] 4.416563 5.104380 4.603604 4.408253 4.489054 #> #> $df #> [1] 12 12 12 12 12 #> #> $best #> [1] 5 13 3 6 4 #> #> $bestmodel #> $bestmodel[[1]] #> [1] 0 1 2 #> #> $bestmodel[[2]] #> [1] 0 1 4 #> #> $bestmodel[[3]] #> [1] 0 1 2 3 4 #> #> $bestmodel[[4]] #> [1] 0 1 2 4 #> #> $bestmodel[[5]] #> [1] 0 1 2 3 #> #> #> $best.vars #> [1] \"Intercept\" \"X1\" \"X2\" \"X3\" \"X4\" #> #> $estimator #> [1] \"BMA\" #> #> attr(,\"class\") #> [1] \"pred.bas\" #> #> > confint(predict(hald.gprior, Hald, estimator=\"BMA\", se.fit=TRUE, top=5), parm=\"mean\") #> 2.5% 97.5% mean #> [1,] 72.82752 85.85915 79.74246 #> [2,] 69.12925 79.49711 74.50010 #> [3,] 101.00483 109.62215 105.29268 #> [4,] 85.03125 94.49408 89.88693 #> [5,] 90.33108 100.35580 95.57177 #> [6,] 101.28114 107.89645 104.56409 #> [7,] 97.65077 109.24776 103.40145 #> [8,] 71.65790 82.82641 77.13668 #> [9,] 87.50634 96.49823 91.99731 #> [10,] 106.69784 121.76761 114.21325 #> [11,] 77.27222 87.98703 82.78446 #> [12,] 106.67049 115.50991 111.00723 #> [13,] 105.72994 115.21142 110.40160 #> attr(,\"Probability\") #> [1] 0.95 #> attr(,\"class\") #> [1] \"confint.bas\" #> #> > predict(hald.gprior, estimator=\"MPM\", se.fit=TRUE) #> $fit #> [1] 79.65151 74.47846 105.42183 89.83174 95.62799 104.59616 103.50684 #> [8] 77.00839 92.07571 114.10876 82.68233 111.04286 110.46741 #> attr(,\"model\") #> [1] 0 1 2 4 #> attr(,\"best\") #> [1] 1 #> attr(,\"estimator\") #> [1] \"MPM\" #> #> $Ybma #> [1] 79.65151 74.47846 105.42183 89.83174 95.62799 104.59616 103.50684 #> [8] 77.00839 92.07571 114.10876 82.68233 111.04286 110.46741 #> attr(,\"model\") #> [1] 0 1 2 4 #> attr(,\"best\") #> [1] 1 #> attr(,\"estimator\") #> [1] \"MPM\" #> #> $Ypred #> NULL #> #> $postprobs #> NULL #> #> $se.fit #> [1] 3.117350 2.283957 1.602160 2.149087 2.589321 1.508471 2.610923 2.545817 #> [9] 1.990817 3.485929 2.456636 1.951456 2.212238 #> #> $se.pred #> [1] 5.440156 5.009380 4.737547 4.949344 5.155775 4.706689 5.166658 5.134065 #> [9] 4.882702 5.659428 5.090431 4.866787 4.977090 #> #> $se.bma.fit #> NULL #> #> $se.bma.pred #> NULL #> #> $df #> [1] 12 #> #> $best #> NULL #> #> $bestmodel #> [1] 0 1 2 4 #> #> $best.vars #> [1] \"Intercept\" \"X1\" \"X2\" \"X4\" #> #> $estimator #> [1] \"MPM\" #> #> attr(,\"class\") #> [1] \"pred.bas\" #> #> > confint(predict(hald.gprior, Hald, estimator=\"MPM\", se.fit=TRUE), parm=\"mean\") #> 2.5% 97.5% mean #> [1,] 72.85939 86.44363 79.65151 #> [2,] 69.50215 79.45478 74.47846 #> [3,] 101.93102 108.91264 105.42183 #> [4,] 85.14928 94.51420 89.83174 #> [5,] 89.98634 101.26964 95.62799 #> [6,] 101.30948 107.88283 104.59616 #> [7,] 97.81813 109.19556 103.50684 #> [8,] 71.46153 82.55525 77.00839 #> [9,] 87.73810 96.41333 92.07571 #> [10,] 106.51357 121.70394 114.10876 #> [11,] 77.32978 88.03488 82.68233 #> [12,] 106.79101 115.29472 111.04286 #> [13,] 105.64736 115.28746 110.46741 #> attr(,\"Probability\") #> [1] 0.95 #> attr(,\"class\") #> [1] \"confint.bas\" #> #> > fitted(hald.gprior, estimator=\"HPM\") #> [1] 81.17036 74.83464 105.07248 89.69881 97.15898 104.45753 103.38927 #> [8] 76.06454 91.57174 113.17222 81.59906 111.22195 111.08841 #> #> > hald.gprior = bas.lm(Y~ ., data=Hald, n.models=2^4, #> + prior=\"g-prior\", alpha=13, modelprior=uniform(), #> + initprobs=\"eplogp\") #> #> > hald.EB = update(hald.gprior, newprior=\"EB-global\") #> #> > hald.bic = update(hald.gprior,newprior=\"BIC\") #> #> > hald.zs = update(hald.bic, newprior=\"ZS-null\") if (FALSE) { demo(BAS.USCrime) }"},{"path":"http://merliseclyde.github.io/BAS/reference/bayesglm.fit.html","id":null,"dir":"Reference","previous_headings":"","what":"Fitting Generalized Linear Models and Bayesian marginal likelihood\nevaluation — bayesglm.fit","title":"Fitting Generalized Linear Models and Bayesian marginal likelihood\nevaluation — bayesglm.fit","text":"version glm.fit rewritten C; also returns marginal likelihoods Bayesian model comparison","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/bayesglm.fit.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Fitting Generalized Linear Models and Bayesian marginal likelihood\nevaluation — bayesglm.fit","text":"","code":"bayesglm.fit( x, y, weights = rep(1, nobs), start = NULL, etastart = NULL, mustart = NULL, offset = rep(0, nobs), family = binomial(), coefprior = bic.prior(nobs), control = glm.control(), intercept = TRUE )"},{"path":"http://merliseclyde.github.io/BAS/reference/bayesglm.fit.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Fitting Generalized Linear Models and Bayesian marginal likelihood\nevaluation — bayesglm.fit","text":"x design matrix y response weights optional vector weights used fitting process. NULL numeric vector. start starting value coefficients linear predictor etastart starting values linear predictor mustart starting values vectors means offset priori known component included linear predictor family description error distribution link function exponential family; currently binomial(), poisson(), Gamma() canonical links implemented. coefprior function specifying prior distribution coefficients optional hyperparameters leading marginal likelihood calculations; options include bic.prior(), aic.prior(), ic.prior() control list parameters control convergence fitting process. See documentation glm.control() intercept intercept included null model?","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/bayesglm.fit.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Fitting Generalized Linear Models and Bayesian marginal likelihood\nevaluation — bayesglm.fit","text":"coefficients MLEs se Standard errors coefficients based sqrt diagonal inverse information matrix mu fitted mean rank numeric rank fitted linear model deviance minus twice log likelihood evaluated MLEs g value g g-priors shrinkage shrinkage factor coefficients linear predictor RegSS quadratic form beta'(beta)beta used shrinkage logmarglik log marginal integrated log likelihood (constant)","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/bayesglm.fit.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Fitting Generalized Linear Models and Bayesian marginal likelihood\nevaluation — bayesglm.fit","text":"C version glm-fit. different prior choices returns, marginal likelihood model using Laplace approximation.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/bayesglm.fit.html","id":"references","dir":"Reference","previous_headings":"","what":"References","title":"Fitting Generalized Linear Models and Bayesian marginal likelihood\nevaluation — bayesglm.fit","text":"glm","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/bayesglm.fit.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Fitting Generalized Linear Models and Bayesian marginal likelihood\nevaluation — bayesglm.fit","text":"Merlise Clyde translated glm.fit R base C using .Call interface","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/bayesglm.fit.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Fitting Generalized Linear Models and Bayesian marginal likelihood\nevaluation — bayesglm.fit","text":"","code":"data(Pima.tr, package=\"MASS\") Y <- as.numeric(Pima.tr$type) - 1 X <- cbind(1, as.matrix(Pima.tr[,1:7])) out <- bayesglm.fit(X, Y, family=binomial(),coefprior=bic.prior(n=length(Y))) out$coef #> [1] -9.773061533 0.103183427 0.032116823 -0.004767542 -0.001916632 #> [6] 0.083623912 1.820410367 0.041183529 out$se #> [1] 1.770386016 0.064694153 0.006787299 0.018540741 0.022499541 0.042826888 #> [7] 0.665513776 0.022090978 # using built in function glm(type ~ ., family=binomial(), data=Pima.tr) #> #> Call: glm(formula = type ~ ., family = binomial(), data = Pima.tr) #> #> Coefficients: #> (Intercept) npreg glu bp skin bmi #> -9.773062 0.103183 0.032117 -0.004768 -0.001917 0.083624 #> ped age #> 1.820410 0.041184 #> #> Degrees of Freedom: 199 Total (i.e. Null); 192 Residual #> Null Deviance:\t 256.4 #> Residual Deviance: 178.4 \tAIC: 194.4"},{"path":"http://merliseclyde.github.io/BAS/reference/beta.binomial.html","id":null,"dir":"Reference","previous_headings":"","what":"Beta-Binomial Prior Distribution for Models — beta.binomial","title":"Beta-Binomial Prior Distribution for Models — beta.binomial","text":"Creates object representing prior distribution models BAS.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/beta.binomial.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Beta-Binomial Prior Distribution for Models — beta.binomial","text":"","code":"beta.binomial(alpha = 1, beta = 1)"},{"path":"http://merliseclyde.github.io/BAS/reference/beta.binomial.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Beta-Binomial Prior Distribution for Models — beta.binomial","text":"alpha parameter beta prior distribution beta parameter beta prior distribution","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/beta.binomial.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Beta-Binomial Prior Distribution for Models — beta.binomial","text":"returns object class \"prior\", family hyperparameters.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/beta.binomial.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Beta-Binomial Prior Distribution for Models — beta.binomial","text":"beta-binomial distribution model size obtained assigning variable inclusion indicator independent Bernoulli distributions probability w, giving w beta(alpha,beta) distribution. Marginalizing w leads distribution model size beta-binomial distribution. default hyperparameters lead uniform distribution model size.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/beta.binomial.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Beta-Binomial Prior Distribution for Models — beta.binomial","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/beta.binomial.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Beta-Binomial Prior Distribution for Models — beta.binomial","text":"","code":"beta.binomial(1, 10) #' @family priors modelpriors #> $family #> [1] \"Beta-Binomial\" #> #> $hyper.parameters #> [1] 1 10 #> #> attr(,\"class\") #> [1] \"prior\""},{"path":"http://merliseclyde.github.io/BAS/reference/beta.prime.html","id":null,"dir":"Reference","previous_headings":"","what":"Beta-Prime Prior Distribution for Coefficients in BMA Model — beta.prime","title":"Beta-Prime Prior Distribution for Coefficients in BMA Model — beta.prime","text":"Creates object representing Beta-Prime prior mixture g-priors coefficients BAS.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/beta.prime.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Beta-Prime Prior Distribution for Coefficients in BMA Model — beta.prime","text":"","code":"beta.prime(n = NULL)"},{"path":"http://merliseclyde.github.io/BAS/reference/beta.prime.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Beta-Prime Prior Distribution for Coefficients in BMA Model — beta.prime","text":"n sample size; NULL, value derived data call `bas.glm` used.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/beta.prime.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Beta-Prime Prior Distribution for Coefficients in BMA Model — beta.prime","text":"returns object class \"prior\", family hyerparameters.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/beta.prime.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Beta-Prime Prior Distribution for Coefficients in BMA Model — beta.prime","text":"Creates structure used bas.glm.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/beta.prime.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Beta-Prime Prior Distribution for Coefficients in BMA Model — beta.prime","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/beta.prime.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Beta-Prime Prior Distribution for Coefficients in BMA Model — beta.prime","text":"","code":"beta.prime(n = 100) #> $family #> [1] \"betaprime\" #> #> $class #> [1] \"TCCH\" #> #> $hyper.parameters #> $hyper.parameters$n #> [1] 100 #> #> $hyper.parameters$alpha #> [1] 0.5 #> #> #> attr(,\"class\") #> [1] \"prior\""},{"path":"http://merliseclyde.github.io/BAS/reference/bodyfat.html","id":null,"dir":"Reference","previous_headings":"","what":"Bodyfat Data — bodyfat","title":"Bodyfat Data — bodyfat","text":"Lists estimates percentage body fat determined underwater weighing various body circumference measurements 252 men. Accurate measurement body fat inconvenient/costly desirable easy methods estimating body fat inconvenient/costly.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/bodyfat.html","id":"format","dir":"Reference","previous_headings":"","what":"Format","title":"Bodyfat Data — bodyfat","text":"data frame 252 observations following 15 variables. Density numeric vector density determined underwater weighing Bodyfat percent body fat Siri's (1956) equation Age age individual years Weight weight individual pounds Height height individual inches Neck neck circumference centimeters (cm) Chest chest circumference (cm) Abdomen abdomen circumference (cm) Hip hip circumference (cm) \"Thigh\" thigh circumference (cm) \"Knee\" knee circumference (cm) Ankle ankle circumference (cm) Biceps bicep (extended) circumference (cm) Forearm forearm circumference (cm) Wrist wrist circumference (cm)","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/bodyfat.html","id":"source","dir":"Reference","previous_headings":"","what":"Source","title":"Bodyfat Data — bodyfat","text":"data used produce predictive equations lean body weight given abstract \"Generalized body composition prediction equation men using simple measurement techniques\", K.W. Penrose, .G. Nelson, .G. Fisher, FACSM, Human Performance Research Center, Brigham Young University, Provo, Utah 84602 listed _Medicine Science Sports Exercise_, vol. 17, . 2, April 1985, p. 189. (predictive equations obtained first 143 252 cases listed ). data generously supplied Dr. . Garth Fisher gave permission freely distribute data use non-commercial purposes.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/bodyfat.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Bodyfat Data — bodyfat","text":"variety popular health books suggest readers assess health, least part, estimating percentage body fat. Bailey (1994), instance, reader can estimate body fat tables using age various skin-fold measurements obtained using caliper. texts give predictive equations body fat using body circumference measurements (e.g. abdominal circumference) /skin-fold measurements. See, instance, Behnke Wilmore (1974), pp. 66-67; Wilmore (1976), p. 247; Katch McArdle (1977), pp. 120-132).# Percentage body fat individual can estimated body density determined. Folks (e.g. Siri (1956)) assume body consists two components - lean body tissue fat tissue. Letting D = Body Density (gm/cm^3) = proportion lean body tissue B = proportion fat tissue (+B=1) = density lean body tissue (gm/cm^3) b = density fat tissue (gm/cm^3) D = 1/[(/) + (B/b)] solving B find B = (1/D)*[ab/(-b)] - [b/(-b)]. Using estimates =1.10 gm/cm^3 b=0.90 gm/cm^3 (see Katch McArdle (1977), p. 111 Wilmore (1976), p. 123) come \"Siri's equation\": Percentage Body Fat (.e. 100*B) = 495/D - 450.# Volume, hence body density, can accurately measured variety ways. technique underwater weighing \"computes body volume difference body weight measured air weight measured water submersion. words, body volume equal loss weight water appropriate temperature correction water's density\" (Katch McArdle (1977), p. 113). Using technique, Body Density = WA/[(WA-WW)/c.f. - LV] WA = Weight air (kg) WW = Weight water (kg) c.f. = Water correction factor (=1 39.2 deg F one-gram water occupies exactly one cm^3 temperature, =.997 76-78 deg F) LV = Residual Lung Volume (liters) (Katch McArdle (1977), p. 115). methods determining body volume given Behnke Wilmore (1974), p. 22 ff. Measurement standards apparently listed Behnke Wilmore (1974), pp. 45-48 , instance, abdomen circumference measured \"laterally, level iliac crests, anteriorly, umbilicus\".)","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/bodyfat.html","id":"references","dir":"Reference","previous_headings":"","what":"References","title":"Bodyfat Data — bodyfat","text":"Bailey, Covert (1994). Smart Exercise: Burning Fat, Getting Fit, Houghton-Mifflin Co., Boston, pp. 179-186. Behnke, .R. Wilmore, J.H. (1974). Evaluation Regulation Body Build Composition, Prentice-Hall, Englewood Cliffs, N.J. Siri, W.E. (1956), \"Gross composition body\", Advances Biological Medical Physics, vol. IV, edited J.H. Lawrence C.. Tobias, Academic Press, Inc., New York. Katch, Frank McArdle, William (1977). Nutrition, Weight Control, Exercise, Houghton Mifflin Co., Boston. Wilmore, Jack (1976). Athletic Training Physical Fitness: Physiological Principles Conditioning Process, Allyn Bacon, Inc., Boston.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/bodyfat.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Bodyfat Data — bodyfat","text":"","code":"data(bodyfat) bodyfat.bas = bas.lm(Bodyfat ~ Abdomen, data=bodyfat, prior=\"ZS-null\") summary(bodyfat.bas) #> P(B != 0 | Y) model 1 model 2 #> Intercept 1 1.0000 1.000000e+00 #> Abdomen 1 1.0000 0.000000e+00 #> BF NA 1.0000 1.039211e-57 #> PostProbs NA 1.0000 0.000000e+00 #> R2 NA 0.6617 0.000000e+00 #> dim NA 2.0000 1.000000e+00 #> logmarg NA 131.2089 0.000000e+00 plot(Bodyfat ~ Abdomen, data=bodyfat, xlab=\"abdomen circumference (cm)\") betas = coef(bodyfat.bas)$postmean # current version has that intercept is ybar betas[1] = betas[1] - betas[2]*bodyfat.bas$mean.x abline(betas) abline(coef(lm(Bodyfat ~ Abdomen, data=bodyfat)), col=2, lty=2)"},{"path":"http://merliseclyde.github.io/BAS/reference/climate.html","id":null,"dir":"Reference","previous_headings":"","what":"Climate Data — climate","title":"Climate Data — climate","text":"Climate Data","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/climate.html","id":"format","dir":"Reference","previous_headings":"","what":"Format","title":"Climate Data — climate","text":"Scientists interested Earth's temperature change since last glacial maximum, 20,000 years ago. first study estimate temperature change published 1980, estimated change -1.5 degrees C, +/- 1.2 degrees C tropical sea surface temperatures. negative value means Earth colder now. Since 1980 many studies. climate dataset 63 measurements 5 variables: sdev standard deviation calculated deltaT; proxy number 1-8 reflecting type measurement system used derive deltaT. proxies can used land, others water. proxies coded 1 \"Mg/Ca\" 2 \"alkenone\" 3 \"Faunal\" 4 \"Sr/Ca\" 5 \"del 180\" 6 \"Ice Core\" 7 \"Pollen\" 8 \"Noble Gas\" T/M , indicator whether terrestrial marine study (T/M), coded 0 Terrestrial, 1 Marine; latitude latitude data collected.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/climate.html","id":"source","dir":"Reference","previous_headings":"","what":"Source","title":"Climate Data — climate","text":"Data provided originally Michael Lavine","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/coef.html","id":null,"dir":"Reference","previous_headings":"","what":"Coefficients of a Bayesian Model Average object — coef.bas","title":"Coefficients of a Bayesian Model Average object — coef.bas","text":"Extract conditional posterior means standard deviations, marginal posterior means standard deviations, posterior probabilities, marginal inclusions probabilities Bayesian Model Averaging object class 'bas'","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/coef.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Coefficients of a Bayesian Model Average object — coef.bas","text":"","code":"# S3 method for bas coef(object, n.models, estimator = \"BMA\", ...) # S3 method for coef.bas print(x, digits = max(3, getOption(\"digits\") - 3), ...)"},{"path":"http://merliseclyde.github.io/BAS/reference/coef.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Coefficients of a Bayesian Model Average object — coef.bas","text":"object object class 'bas' created BAS n.models Number top models report printed summary, coef default use models. extract summaries Highest Probability Model, use n.models=1 estimator=\"HPM\". estimator return summaries selected model, rather using BMA. Options 'HPM' (highest posterior probability model) ,'MPM' (median probability model), 'BMA' ... optional arguments x object class 'coef.bas' print digits number significant digits print","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/coef.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Coefficients of a Bayesian Model Average object — coef.bas","text":"coefficients returns object class coef.bas following: conditionalmeans matrix conditional posterior means model conditionalsd standard deviations model postmean marginal posterior means regression coefficient using BMA postsd marginal posterior standard deviations using BMA postne0 vector posterior inclusion probabilities, marginal probability coefficient non-zero","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/coef.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Coefficients of a Bayesian Model Average object — coef.bas","text":"Calculates posterior means (approximate) standard deviations regression coefficients Bayesian Model averaging using g-priors mixtures g-priors. Print returns overall summaries. fully Bayesian methods place prior g, posterior standard deviations take account full uncertainty regarding g. updated future releases.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/coef.html","id":"note","dir":"Reference","previous_headings":"","what":"Note","title":"Coefficients of a Bayesian Model Average object — coef.bas","text":"highly correlated variables, marginal summaries may representative joint distribution. Use plot.coef.bas view distributions. value reported intercept centered parameterization. Gaussian error model centered sample mean Y.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/coef.html","id":"references","dir":"Reference","previous_headings":"","what":"References","title":"Coefficients of a Bayesian Model Average object — coef.bas","text":"Liang, F., Paulo, R., Molina, G., Clyde, M. Berger, J.O. (2005) Mixtures g-priors Bayesian Variable Selection. Journal American Statistical Association. 103:410-423. doi:10.1198/016214507000001337","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/coef.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Coefficients of a Bayesian Model Average object — coef.bas","text":"Merlise Clyde clyde@duke.edu","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/coef.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Coefficients of a Bayesian Model Average object — coef.bas","text":"","code":"data(\"Hald\") hald.gprior = bas.lm(Y~ ., data=Hald, n.models=2^4, alpha=13, prior=\"ZS-null\", initprobs=\"Uniform\", update=10) coef.hald.gprior = coefficients(hald.gprior) coef.hald.gprior #> #> Marginal Posterior Summaries of Coefficients: #> #> Using BMA #> #> Based on the top 16 models #> post mean post SD post p(B != 0) #> Intercept 95.42308 0.67885 1.00000 #> X1 1.40116 0.35351 0.97454 #> X2 0.42326 0.38407 0.76017 #> X3 -0.03997 0.33398 0.30660 #> X4 -0.22077 0.36931 0.44354 plot(coef.hald.gprior) confint(coef.hald.gprior) #> 2.5% 97.5% beta #> Intercept 93.9672078 96.8511631 95.42307692 #> X1 0.6460259 2.1282986 1.40116123 #> X2 -0.1039008 0.8768755 0.42325794 #> X3 -0.7828122 0.6575582 -0.03997087 #> X4 -0.7793374 0.2058685 -0.22076600 #> attr(,\"Probability\") #> [1] 0.95 #> attr(,\"class\") #> [1] \"confint.bas\" #Estimation under Median Probability Model coef.hald.gprior = coefficients(hald.gprior, estimator=\"MPM\") coef.hald.gprior #> #> Marginal Posterior Summaries of Coefficients: #> #> Using MPM #> #> Based on the top 1 models #> post mean post SD post p(B != 0) #> Intercept 95.42308 0.66740 1.00000 #> X1 1.45542 0.12077 1.00000 #> X2 0.65644 0.04565 1.00000 #> X3 0.00000 0.00000 0.00000 #> X4 0.00000 0.00000 0.00000 plot(coef.hald.gprior) plot(confint(coef.hald.gprior)) #> NULL coef.hald.gprior = coefficients(hald.gprior, estimator=\"HPM\") coef.hald.gprior #> #> Marginal Posterior Summaries of Coefficients: #> #> Using HPM #> #> Based on the top 1 models #> post mean post SD post p(B != 0) #> Intercept 95.42308 0.66740 1.00000 #> X1 1.45542 0.12077 0.97454 #> X2 0.65644 0.04565 0.76017 #> X3 0.00000 0.00000 0.30660 #> X4 0.00000 0.00000 0.44354 plot(coef.hald.gprior) confint(coef.hald.gprior) #> 2.5% 97.5% beta #> Intercept 93.9689432 96.877211 95.4230769 #> X1 1.1922938 1.718554 1.4554239 #> X2 0.5569707 0.755910 0.6564404 #> X3 0.0000000 0.000000 0.0000000 #> X4 0.0000000 0.000000 0.0000000 #> attr(,\"Probability\") #> [1] 0.95 #> attr(,\"class\") #> [1] \"confint.bas\" # To add estimation under Best Predictive Model"},{"path":"http://merliseclyde.github.io/BAS/reference/confint.coef.html","id":null,"dir":"Reference","previous_headings":"","what":"Compute Credible Intervals for BAS regression coefficients from BAS objects — confint.coef.bas","title":"Compute Credible Intervals for BAS regression coefficients from BAS objects — confint.coef.bas","text":"Uses Monte Carlo simulations using posterior means standard deviations coefficients generate draws posterior distributions returns highest posterior density (HPD) credible intervals. number models equals one, use t distribution find intervals. currently condition estimate $g$. description ~~","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/confint.coef.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Compute Credible Intervals for BAS regression coefficients from BAS objects — confint.coef.bas","text":"","code":"# S3 method for coef.bas confint(object, parm, level = 0.95, nsim = 10000, ...)"},{"path":"http://merliseclyde.github.io/BAS/reference/confint.coef.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Compute Credible Intervals for BAS regression coefficients from BAS objects — confint.coef.bas","text":"object coef.bas object parm specification parameters given credible intervals, either vector numbers vector names. missing, parameters considered. level probability coverage required nsim number Monte Carlo draws posterior distribution. Used number models greater 1. ... arguments passed; none currently","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/confint.coef.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Compute Credible Intervals for BAS regression coefficients from BAS objects — confint.coef.bas","text":"matrix (vector) columns giving lower upper HPD credible limits parameter. labeled 1-level)/2 1 - (1-level)/2 percent (default 2.5 97.5).","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/confint.coef.html","id":"note","dir":"Reference","previous_headings":"","what":"Note","title":"Compute Credible Intervals for BAS regression coefficients from BAS objects — confint.coef.bas","text":"mixture g-priors approximate. uses Monte Carlo sampling results may subject Monte Carlo variation larger values nsim may needed reduce variability.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/confint.coef.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Compute Credible Intervals for BAS regression coefficients from BAS objects — confint.coef.bas","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/confint.coef.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Compute Credible Intervals for BAS regression coefficients from BAS objects — confint.coef.bas","text":"","code":"data(\"Hald\") hald_gprior <- bas.lm(Y~ ., data=Hald, alpha=13, prior=\"g-prior\") coef_hald <- coef(hald_gprior) confint(coef_hald) #> 2.5% 97.5% beta #> Intercept 93.899749 96.9469774 95.4230769 #> X1 0.000000 1.8451082 1.2150202 #> X2 -1.114669 0.8562203 0.2756235 #> X3 -1.508182 0.5533747 -0.1270575 #> X4 -1.716110 0.2007243 -0.3268710 #> attr(,\"Probability\") #> [1] 0.95 #> attr(,\"class\") #> [1] \"confint.bas\" confint(coef_hald, approx=FALSE, nsim=5000) #> 2.5% 97.5% beta #> Intercept 93.940456 96.9940631 95.4230769 #> X1 0.000000 1.8753303 1.2150202 #> X2 -1.201605 0.8338886 0.2756235 #> X3 -1.538660 0.5621008 -0.1270575 #> X4 -1.762790 0.2190579 -0.3268710 #> attr(,\"Probability\") #> [1] 0.95 #> attr(,\"class\") #> [1] \"confint.bas\" # extract just the coefficient of X4 confint(coef_hald, parm=\"X4\") #> 2.5% 97.5% beta #> X4 -1.69165 0.2614025 -0.326871 #> attr(,\"Probability\") #> [1] 0.95 #> attr(,\"class\") #> [1] \"confint.bas\""},{"path":"http://merliseclyde.github.io/BAS/reference/confint.pred.html","id":null,"dir":"Reference","previous_headings":"","what":"Compute Credible (Bayesian Confidence) Intervals for a BAS predict object — confint.pred.bas","title":"Compute Credible (Bayesian Confidence) Intervals for a BAS predict object — confint.pred.bas","text":"Compute credible intervals -sample sample prediction regression function","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/confint.pred.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Compute Credible (Bayesian Confidence) Intervals for a BAS predict object — confint.pred.bas","text":"","code":"# S3 method for pred.bas confint(object, parm, level = 0.95, nsim = 10000, ...)"},{"path":"http://merliseclyde.github.io/BAS/reference/confint.pred.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Compute Credible (Bayesian Confidence) Intervals for a BAS predict object — confint.pred.bas","text":"object object created predict.bas parm character variable, \"mean\" \"pred\". missing parm='pred'. level nominal level (point-wise) credible interval nsim number Monte Carlo simulations sampling methods BMA ... optional arguments pass next function call; none time.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/confint.pred.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Compute Credible (Bayesian Confidence) Intervals for a BAS predict object — confint.pred.bas","text":"matrix lower upper level * 100 percent credible intervals either mean regression function predicted values.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/confint.pred.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Compute Credible (Bayesian Confidence) Intervals for a BAS predict object — confint.pred.bas","text":"constructs approximate 95 percent Highest Posterior Density intervals 'pred.bas' objects. estimator based model selection, intervals use Student t distribution using estimate g. estimator based BMA, nsim draws mixture Student t distributions obtained HPD interval obtained Monte Carlo draws.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/confint.pred.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Compute Credible (Bayesian Confidence) Intervals for a BAS predict object — confint.pred.bas","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/confint.pred.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Compute Credible (Bayesian Confidence) Intervals for a BAS predict object — confint.pred.bas","text":"","code":"data(\"Hald\") hald.gprior = bas.lm(Y~ ., data=Hald, alpha=13, prior=\"g-prior\") hald.pred = predict(hald.gprior, estimator=\"BPM\", predict=FALSE, se.fit=TRUE) confint(hald.pred, parm=\"mean\") #> 2.5% 97.5% mean #> [1,] 72.85939 86.44363 79.65151 #> [2,] 69.50215 79.45478 74.47846 #> [3,] 101.93102 108.91264 105.42183 #> [4,] 85.14928 94.51420 89.83174 #> [5,] 89.98634 101.26964 95.62799 #> [6,] 101.30948 107.88283 104.59616 #> [7,] 97.81813 109.19556 103.50684 #> [8,] 71.46153 82.55525 77.00839 #> [9,] 87.73810 96.41333 92.07571 #> [10,] 106.51357 121.70394 114.10876 #> [11,] 77.32978 88.03488 82.68233 #> [12,] 106.79101 115.29472 111.04286 #> [13,] 105.64736 115.28746 110.46741 #> attr(,\"Probability\") #> [1] 0.95 #> attr(,\"class\") #> [1] \"confint.bas\" confint(hald.pred) #default #> 2.5% 97.5% pred #> [1,] 67.79843 91.50459 79.65151 #> [2,] 63.56396 85.39296 74.47846 #> [3,] 95.09960 115.74406 105.42183 #> [4,] 79.04805 100.61543 89.83174 #> [5,] 84.39452 106.86146 95.62799 #> [6,] 94.34116 114.85115 104.59616 #> [7,] 92.24966 114.76402 103.50684 #> [8,] 65.82223 88.19456 77.00839 #> [9,] 81.43722 102.71421 92.07571 #> [10,] 101.77792 126.43959 114.10876 #> [11,] 71.59123 93.77342 82.68233 #> [12,] 100.43905 121.64668 111.04286 #> [13,] 99.62326 121.31156 110.46741 #> attr(,\"Probability\") #> [1] 0.95 #> attr(,\"class\") #> [1] \"confint.bas\" hald.pred = predict(hald.gprior, estimator=\"BMA\", predict=FALSE, se.fit=TRUE) confint(hald.pred) #> 2.5% 97.5% pred #> [1,] 68.07475 92.23188 79.68307 #> [2,] 63.57577 86.16319 74.69127 #> [3,] 94.31185 116.18094 105.63258 #> [4,] 78.93185 100.77629 89.91648 #> [5,] 84.19744 106.87413 95.67480 #> [6,] 93.94117 115.05853 104.57616 #> [7,] 91.77939 114.98347 103.47945 #> [8,] 65.47413 87.93638 76.96808 #> [9,] 81.55209 103.28904 92.22184 #> [10,] 101.37360 126.42092 113.84918 #> [11,] 70.95581 93.69435 82.59035 #> [12,] 99.95388 121.84674 110.87673 #> [13,] 99.55477 121.54222 110.34001 #> attr(,\"Probability\") #> [1] 0.95 #> attr(,\"class\") #> [1] \"confint.bas\""},{"path":"http://merliseclyde.github.io/BAS/reference/cv.summary.bas.html","id":null,"dir":"Reference","previous_headings":"","what":"Summaries for Out of Sample Prediction — cv.summary.bas","title":"Summaries for Out of Sample Prediction — cv.summary.bas","text":"Compute average prediction error sample predictions","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/cv.summary.bas.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Summaries for Out of Sample Prediction — cv.summary.bas","text":"","code":"cv.summary.bas(pred, ytrue, score = \"squared-error\")"},{"path":"http://merliseclyde.github.io/BAS/reference/cv.summary.bas.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Summaries for Out of Sample Prediction — cv.summary.bas","text":"pred fitted predicted value output predict.bas ytrue vector left response values score function used summarize error rate. Either \"squared-error\", \"miss-class\"","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/cv.summary.bas.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Summaries for Out of Sample Prediction — cv.summary.bas","text":"squared error, average prediction error Bayesian estimator error = sqrt(sum(ytrue - yhat)^2/npred) binary data misclassification rate appropriate.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/cv.summary.bas.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Summaries for Out of Sample Prediction — cv.summary.bas","text":"Merlise Clyde clyde@duke.edu","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/cv.summary.bas.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Summaries for Out of Sample Prediction — cv.summary.bas","text":"","code":"if (FALSE) { library(foreign) cognitive <- read.dta(\"https://www.stat.columbia.edu/~gelman/arm/examples/child.iq/kidiq.dta\") cognitive$mom_work <- as.numeric(cognitive$mom_work > 1) cognitive$mom_hs <- as.numeric(cognitive$mom_hs > 0) colnames(cognitive) <- c(\"kid_score\", \"hs\", \"iq\", \"work\", \"age\") set.seed(42) n <- nrow(cognitive) test <- sample(1:n, size = round(.20 * n), replace = FALSE) testdata <- cognitive[test, ] traindata <- cognitive[-test, ] cog_train <- bas.lm(kid_score ~ ., prior = \"BIC\", modelprior = uniform(), data = traindata) yhat <- predict(cog_train, newdata = testdata, estimator = \"BMA\", se = F) cv.summary.bas(yhat$fit, testdata$kid_score) }"},{"path":"http://merliseclyde.github.io/BAS/reference/diagnostics.html","id":null,"dir":"Reference","previous_headings":"","what":"BAS MCMC diagnostic plot — diagnostics","title":"BAS MCMC diagnostic plot — diagnostics","text":"Function help assess convergence MCMC sampling bas objects.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/diagnostics.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"BAS MCMC diagnostic plot — diagnostics","text":"","code":"diagnostics(obj, type = c(\"pip\", \"model\"), ...)"},{"path":"http://merliseclyde.github.io/BAS/reference/diagnostics.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"BAS MCMC diagnostic plot — diagnostics","text":"obj object created bas.lm bas.glm type type diagnostic plot. \"pip\" marginal inclusion probabilities used, \"model\", plot posterior model probabilities ... additional graphics parameters passed plot","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/diagnostics.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"BAS MCMC diagnostic plot — diagnostics","text":"plot marginal inclusion probabilities (pip) estimated MCMC renormalized marginal likelihoods times prior probabilities model probabilities.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/diagnostics.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"BAS MCMC diagnostic plot — diagnostics","text":"BAS calculates posterior model probabilities two ways method=\"MCMC\". first using relative Monte Carlo frequencies sampled models. second renormalize marginal likelihood times prior probabilities sampled models. Markov chain converged, two quantities fall 1-1 line. , running longer may required. chain converged, Monte Carlo frequencies may less bias, although may exhibit variability repeated runs.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/diagnostics.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"BAS MCMC diagnostic plot — diagnostics","text":"Merlise Clyde (clyde@duke.edu)","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/diagnostics.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"BAS MCMC diagnostic plot — diagnostics","text":"","code":"library(MASS) data(UScrime) UScrime[, -2] <- log(UScrime[, -2]) crime.ZS <- bas.lm(y ~ ., data = UScrime, prior = \"ZS-null\", modelprior = uniform(), method = \"MCMC\", MCMC.iter = 1000 ) # short run for the example diagnostics(crime.ZS)"},{"path":"http://merliseclyde.github.io/BAS/reference/eplogprob.html","id":null,"dir":"Reference","previous_headings":"","what":"eplogprob - Compute approximate marginal inclusion probabilities from\npvalues — eplogprob","title":"eplogprob - Compute approximate marginal inclusion probabilities from\npvalues — eplogprob","text":"eplogprob calculates approximate marginal posterior inclusion probabilities p-values computed linear model using lower bound approximation Bayes factors. Used obtain initial inclusion probabilities sampling using Bayesian Adaptive Sampling bas.lm","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/eplogprob.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"eplogprob - Compute approximate marginal inclusion probabilities from\npvalues — eplogprob","text":"","code":"eplogprob(lm.obj, thresh = 0.5, max = 0.99, int = TRUE)"},{"path":"http://merliseclyde.github.io/BAS/reference/eplogprob.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"eplogprob - Compute approximate marginal inclusion probabilities from\npvalues — eplogprob","text":"lm.obj linear model object thresh value inclusion probability p-value > 1/exp(1), lower bound approximation valid. max maximum value inclusion probability; used bas.lm function keep initial inclusion probabilities away 1. int Intercept included linear model, set marginal inclusion probability corresponding intercept 1","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/eplogprob.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"eplogprob - Compute approximate marginal inclusion probabilities from\npvalues — eplogprob","text":"eplogprob returns vector marginal posterior inclusion probabilities variables linear model. int = TRUE, inclusion probability intercept set 1. model full rank, variables linearly dependent base QR factorization NA p-values. bas.lm, probabilities used sampling, inclusion probability set 0.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/eplogprob.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"eplogprob - Compute approximate marginal inclusion probabilities from\npvalues — eplogprob","text":"Sellke, Bayarri Berger (2001) provide simple calibration p-values BF(p) = -e p log(p) provide lower bound Bayes factor comparing H0: beta = 0 versus H1: beta equal 0, p-value p less 1/e. Using equal prior odds hypotheses H0 H1, approximate marginal posterior inclusion probability p(beta != 0 | data ) = 1/(1 + BF(p)) p > 1/e, set marginal inclusion probability 0.5 value given thresh.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/eplogprob.html","id":"references","dir":"Reference","previous_headings":"","what":"References","title":"eplogprob - Compute approximate marginal inclusion probabilities from\npvalues — eplogprob","text":"Sellke, Thomas, Bayarri, M. J., Berger, James O. (2001), ``Calibration p-values testing precise null hypotheses'', American Statistician, 55, 62-71.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/eplogprob.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"eplogprob - Compute approximate marginal inclusion probabilities from\npvalues — eplogprob","text":"Merlise Clyde clyde@stat.duke.edu","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/eplogprob.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"eplogprob - Compute approximate marginal inclusion probabilities from\npvalues — eplogprob","text":"","code":"library(MASS) data(UScrime) UScrime[,-2] = log(UScrime[,-2]) eplogprob(lm(y ~ ., data=UScrime)) #> (Intercept) M So Ed Po1 Po2 #> 1.0000000 0.9480823 0.5000000 0.9883193 0.5045770 0.5000000 #> LF M.F Pop NW U1 U2 #> 0.5000000 0.5304659 0.5807429 0.8046414 0.5000000 0.6858642 #> GDP Ineq Prob Time #> 0.6069289 0.9900000 0.9412475 0.5782754"},{"path":"http://merliseclyde.github.io/BAS/reference/eplogprob.marg.html","id":null,"dir":"Reference","previous_headings":"","what":"eplogprob.marg - Compute approximate marginal inclusion probabilities from\npvalues — eplogprob.marg","title":"eplogprob.marg - Compute approximate marginal inclusion probabilities from\npvalues — eplogprob.marg","text":"eplogprob.marg calculates approximate marginal posterior inclusion probabilities p-values computed series simple linear regression models using lower bound approximation Bayes factors. Used order variables appropriate obtain initial inclusion probabilities sampling using Bayesian Adaptive Sampling bas.lm","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/eplogprob.marg.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"eplogprob.marg - Compute approximate marginal inclusion probabilities from\npvalues — eplogprob.marg","text":"","code":"eplogprob.marg(Y, X, thresh = 0.5, max = 0.99, int = TRUE)"},{"path":"http://merliseclyde.github.io/BAS/reference/eplogprob.marg.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"eplogprob.marg - Compute approximate marginal inclusion probabilities from\npvalues — eplogprob.marg","text":"Y response variable X design matrix column ones intercept thresh value inclusion probability p-value > 1/exp(1), lower bound approximation valid. max maximum value inclusion probability; used bas.lm function keep initial inclusion probabilities away 1. int Intercept included linear model, set marginal inclusion probability corresponding intercept 1","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/eplogprob.marg.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"eplogprob.marg - Compute approximate marginal inclusion probabilities from\npvalues — eplogprob.marg","text":"eplogprob.prob returns vector marginal posterior inclusion probabilities variables linear model. int = TRUE, inclusion probability intercept set 1.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/eplogprob.marg.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"eplogprob.marg - Compute approximate marginal inclusion probabilities from\npvalues — eplogprob.marg","text":"Sellke, Bayarri Berger (2001) provide simple calibration p-values BF(p) = -e p log(p) provide lower bound Bayes factor comparing H0: beta = 0 versus H1: beta equal 0, p-value p less 1/e. Using equal prior odds hypotheses H0 H1, approximate marginal posterior inclusion probability p(beta != 0 | data ) = 1/(1 + BF(p)) p > 1/e, set marginal inclusion probability 0.5 value given thresh. eplogprob.marg marginal p-values obtained using statistics p simple linear regressions P(F > (n-2) R2/(1 - R2)) F ~ F(1, n-2) R2 square correlation coefficient y X_j.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/eplogprob.marg.html","id":"references","dir":"Reference","previous_headings":"","what":"References","title":"eplogprob.marg - Compute approximate marginal inclusion probabilities from\npvalues — eplogprob.marg","text":"Sellke, Thomas, Bayarri, M. J., Berger, James O. (2001), ``Calibration p-values testing precise null hypotheses'', American Statistician, 55, 62-71.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/eplogprob.marg.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"eplogprob.marg - Compute approximate marginal inclusion probabilities from\npvalues — eplogprob.marg","text":"Merlise Clyde clyde@stat.duke.edu","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/eplogprob.marg.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"eplogprob.marg - Compute approximate marginal inclusion probabilities from\npvalues — eplogprob.marg","text":"","code":"library(MASS) data(UScrime) UScrime[,-2] = log(UScrime[,-2]) eplogprob(lm(y ~ ., data=UScrime)) #> (Intercept) M So Ed Po1 Po2 #> 1.0000000 0.9480823 0.5000000 0.9883193 0.5045770 0.5000000 #> LF M.F Pop NW U1 U2 #> 0.5000000 0.5304659 0.5807429 0.8046414 0.5000000 0.6858642 #> GDP Ineq Prob Time #> 0.6069289 0.9900000 0.9412475 0.5782754"},{"path":"http://merliseclyde.github.io/BAS/reference/fitted.html","id":null,"dir":"Reference","previous_headings":"","what":"Fitted values for a BAS BMA objects — fitted.bas","title":"Fitted values for a BAS BMA objects — fitted.bas","text":"Calculate fitted values BAS BMA object","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/fitted.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Fitted values for a BAS BMA objects — fitted.bas","text":"","code":"# S3 method for bas fitted( object, type = \"link\", estimator = \"BMA\", top = NULL, na.action = na.pass, ... )"},{"path":"http://merliseclyde.github.io/BAS/reference/fitted.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Fitted values for a BAS BMA objects — fitted.bas","text":"object object class 'bas' created bas type type equals \"response\" \"link\" case GLMs (default 'link') estimator estimator type fitted value return. Default use BMA models. Options include 'HPM' highest probability model 'BMA' Bayesian model averaging, using optionally 'top' models 'MPM' median probability model Barbieri Berger. 'BPM' model closest BMA predictions squared error loss top optional argument specifying 'top' models used constructing BMA prediction, NULL models used. top=1, equivalent 'HPM' na.action function determining done missing values newdata. default predict NA. ... optional arguments, used currently","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/fitted.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Fitted values for a BAS BMA objects — fitted.bas","text":"vector length n fitted values.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/fitted.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Fitted values for a BAS BMA objects — fitted.bas","text":"Calculates fitted values observed design matrix using either highest probability model, 'HPM', posterior mean (BMA) 'BMA', median probability model 'MPM' best predictive model 'BPM\". median probability model defined including variable marginal inclusion probability greater equal 1/2. type=\"BMA\", weighted average may based using subset highest probability models optional argument given top. default BMA uses sampled models, may take compute number variables number models large. \"BPM\" found computing squared distance vector fitted values model fitted values BMA returns model smallest distance. presence multicollinearity may quite different MPM, extreme collinearity may drop relevant predictors.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/fitted.html","id":"references","dir":"Reference","previous_headings":"","what":"References","title":"Fitted values for a BAS BMA objects — fitted.bas","text":"Barbieri, M. Berger, J.O. (2004) Optimal predictive model selection. Annals Statistics. 32, 870-897. https://projecteuclid.org/euclid.aos/1085408489&url=/UI/1.0/Summarize/euclid.aos/1085408489 Clyde, M. Ghosh, J. Littman, M. (2010) Bayesian Adaptive Sampling Variable Selection Model Averaging. Journal Computational Graphics Statistics. 20:80-101 doi:10.1198/jcgs.2010.09049","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/fitted.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Fitted values for a BAS BMA objects — fitted.bas","text":"Merlise Clyde clyde@duke.edu","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/fitted.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Fitted values for a BAS BMA objects — fitted.bas","text":"","code":"data(Hald) hald.gprior = bas.lm(Y~ ., data=Hald, prior=\"ZS-null\", initprobs=\"Uniform\") plot(Hald$Y, fitted(hald.gprior, estimator=\"HPM\")) plot(Hald$Y, fitted(hald.gprior, estimator=\"BMA\", top=3)) plot(Hald$Y, fitted(hald.gprior, estimator=\"MPM\")) plot(Hald$Y, fitted(hald.gprior, estimator=\"BPM\"))"},{"path":"http://merliseclyde.github.io/BAS/reference/force.heredity.bas.html","id":null,"dir":"Reference","previous_headings":"","what":"Post processing function to force constraints on interaction inclusion bas BMA objects — force.heredity.bas","title":"Post processing function to force constraints on interaction inclusion bas BMA objects — force.heredity.bas","text":"function takes output bas object allows higher order interactions included parent lower order interactions terms model, assigning zero prior probability, hence posterior probability, models include respective parents.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/force.heredity.bas.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Post processing function to force constraints on interaction inclusion bas BMA objects — force.heredity.bas","text":"","code":"force.heredity.bas(object, prior.prob = 0.5)"},{"path":"http://merliseclyde.github.io/BAS/reference/force.heredity.bas.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Post processing function to force constraints on interaction inclusion bas BMA objects — force.heredity.bas","text":"object bas linear model generalized linear model object prior.prob prior probability term included conditional parents included","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/force.heredity.bas.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Post processing function to force constraints on interaction inclusion bas BMA objects — force.heredity.bas","text":"bas object updated models, coefficients summaries obtained removing models zero prior posterior probabilities.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/force.heredity.bas.html","id":"note","dir":"Reference","previous_headings":"","what":"Note","title":"Post processing function to force constraints on interaction inclusion bas BMA objects — force.heredity.bas","text":"Currently prior probabilities computed using conditional Bernoulli distributions, .e. P(gamma_j = 1 | Parents(gamma_j) = 1) = prior.prob. efficient models large number levels. Future updates force time sampling.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/force.heredity.bas.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Post processing function to force constraints on interaction inclusion bas BMA objects — force.heredity.bas","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/force.heredity.bas.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Post processing function to force constraints on interaction inclusion bas BMA objects — force.heredity.bas","text":"","code":"data(\"chickwts\") bas.chk <- bas.lm(weight ~ feed, data = chickwts) # summary(bas.chk) # 2^5 = 32 models bas.chk.int <- force.heredity.bas(bas.chk) # summary(bas.chk.int) # two models now data(Hald) bas.hald <- bas.lm(Y ~ .^2, data = Hald) bas.hald.int <- force.heredity.bas(bas.hald) image(bas.hald.int) image(bas.hald.int) # two-way interactions data(ToothGrowth) ToothGrowth$dose <- factor(ToothGrowth$dose) levels(ToothGrowth$dose) <- c(\"Low\", \"Medium\", \"High\") TG.bas <- bas.lm(len ~ supp * dose, data = ToothGrowth, modelprior = uniform()) TG.bas.int <- force.heredity.bas(TG.bas) image(TG.bas.int)"},{"path":"http://merliseclyde.github.io/BAS/reference/g.prior.html","id":null,"dir":"Reference","previous_headings":"","what":"Families of G-Prior Distribution for Coefficients in BMA Models — g.prior","title":"Families of G-Prior Distribution for Coefficients in BMA Models — g.prior","text":"Creates object representing g-prior distribution coefficients BAS.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/g.prior.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Families of G-Prior Distribution for Coefficients in BMA Models — g.prior","text":"","code":"g.prior(g)"},{"path":"http://merliseclyde.github.io/BAS/reference/g.prior.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Families of G-Prior Distribution for Coefficients in BMA Models — g.prior","text":"g scalar used covariance Zellner's g-prior, Cov(beta) = sigma^2 g (X'X)^-1","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/g.prior.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Families of G-Prior Distribution for Coefficients in BMA Models — g.prior","text":"returns object class \"prior\", family hyerparameters.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/g.prior.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Families of G-Prior Distribution for Coefficients in BMA Models — g.prior","text":"Creates structure used BAS.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/g.prior.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Families of G-Prior Distribution for Coefficients in BMA Models — g.prior","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/g.prior.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Families of G-Prior Distribution for Coefficients in BMA Models — g.prior","text":"","code":"g.prior(100) #> $family #> [1] \"g.prior\" #> #> $g #> [1] 100 #> #> $class #> [1] \"g-prior\" #> #> $hyper #> [1] 100 #> #> $hyper.parameters #> $hyper.parameters$g #> [1] 100 #> #> #> attr(,\"class\") #> [1] \"prior\""},{"path":"http://merliseclyde.github.io/BAS/reference/hyper.g.html","id":null,"dir":"Reference","previous_headings":"","what":"Hyper-g-Prior Distribution for Coefficients in BMA Models — hyper.g","title":"Hyper-g-Prior Distribution for Coefficients in BMA Models — hyper.g","text":"Creates object representing hyper-g mixture g-priors coefficients BAS.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/hyper.g.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Hyper-g-Prior Distribution for Coefficients in BMA Models — hyper.g","text":"","code":"hyper.g(alpha = 3)"},{"path":"http://merliseclyde.github.io/BAS/reference/hyper.g.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Hyper-g-Prior Distribution for Coefficients in BMA Models — hyper.g","text":"alpha scalar > 0. hyper.g(alpha) equivalent CCH(alpha -2, 2, 0). Liang et al recommended values range 2 < alpha_h <= 3","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/hyper.g.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Hyper-g-Prior Distribution for Coefficients in BMA Models — hyper.g","text":"returns object class \"prior\", family hyerparameters.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/hyper.g.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Hyper-g-Prior Distribution for Coefficients in BMA Models — hyper.g","text":"Creates structure used bas.glm.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/hyper.g.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Hyper-g-Prior Distribution for Coefficients in BMA Models — hyper.g","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/hyper.g.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Hyper-g-Prior Distribution for Coefficients in BMA Models — hyper.g","text":"","code":"hyper.g(alpha = 3) #> $family #> [1] \"CCH\" #> #> $class #> [1] \"TCCH\" #> #> $hyper.parameters #> $hyper.parameters$alpha #> [1] 1 #> #> $hyper.parameters$beta #> [1] 2 #> #> $hyper.parameters$s #> [1] 0 #> #> #> attr(,\"class\") #> [1] \"prior\""},{"path":"http://merliseclyde.github.io/BAS/reference/hyper.g.n.html","id":null,"dir":"Reference","previous_headings":"","what":"Generalized hyper-g/n Prior Distribution for g for mixtures of g-priors on\nCoefficients in BMA Models — hyper.g.n","title":"Generalized hyper-g/n Prior Distribution for g for mixtures of g-priors on\nCoefficients in BMA Models — hyper.g.n","text":"Creates object representing hyper-g/n mixture g-priors coefficients BAS. special case tCCH prior","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/hyper.g.n.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Generalized hyper-g/n Prior Distribution for g for mixtures of g-priors on\nCoefficients in BMA Models — hyper.g.n","text":"","code":"hyper.g.n(alpha = 3, n = NULL)"},{"path":"http://merliseclyde.github.io/BAS/reference/hyper.g.n.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Generalized hyper-g/n Prior Distribution for g for mixtures of g-priors on\nCoefficients in BMA Models — hyper.g.n","text":"alpha scalar > 0, recommended 2 < alpha <= 3 n sample size; NULL, value derived data call `bas.glm` used.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/hyper.g.n.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Generalized hyper-g/n Prior Distribution for g for mixtures of g-priors on\nCoefficients in BMA Models — hyper.g.n","text":"returns object class \"prior\", family hyerparameters.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/hyper.g.n.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Generalized hyper-g/n Prior Distribution for g for mixtures of g-priors on\nCoefficients in BMA Models — hyper.g.n","text":"Creates structure used bas.glm. special case tCCH, hyper.g.n(alpha=3, n) equivalent tCCH(alpha=1, beta=2, s=0, r=1.5, v = 1, theta=1/n)","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/hyper.g.n.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Generalized hyper-g/n Prior Distribution for g for mixtures of g-priors on\nCoefficients in BMA Models — hyper.g.n","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/hyper.g.n.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Generalized hyper-g/n Prior Distribution for g for mixtures of g-priors on\nCoefficients in BMA Models — hyper.g.n","text":"","code":"n <- 500 hyper.g.n(alpha = 3, n = n) #> $family #> [1] \"hyper-g/n\" #> #> $class #> [1] \"TCCH\" #> #> $hyper.parameters #> $hyper.parameters$alpha #> [1] 1 #> #> $hyper.parameters$beta #> [1] 2 #> #> $hyper.parameters$s #> [1] 0 #> #> $hyper.parameters$r #> [1] 1.5 #> #> $hyper.parameters$v #> [1] 1 #> #> $hyper.parameters$theta #> [1] 0.002 #> #> #> $n #> [1] 500 #> #> attr(,\"class\") #> [1] \"prior\""},{"path":"http://merliseclyde.github.io/BAS/reference/hypergeometric1F1.html","id":null,"dir":"Reference","previous_headings":"","what":"Confluent hypergeometric1F1 function — hypergeometric1F1","title":"Confluent hypergeometric1F1 function — hypergeometric1F1","text":"Compute Confluent Hypergeometric function: 1F1(,b,c,t) = Gamma(b)/(Gamma(b-)Gamma()) Int_0^1 t^(-1) (1 - t)^(b--1) exp(c t) dt","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/hypergeometric1F1.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Confluent hypergeometric1F1 function — hypergeometric1F1","text":"","code":"hypergeometric1F1(a, b, c, laplace = FALSE, log = TRUE)"},{"path":"http://merliseclyde.github.io/BAS/reference/hypergeometric1F1.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Confluent hypergeometric1F1 function — hypergeometric1F1","text":"arbitrary b Must greater 0 c arbitrary laplace default use Cephes library; large s may return NA, Inf negative values,, case use Laplace approximation. log TRUE, return log(1F1)","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/hypergeometric1F1.html","id":"references","dir":"Reference","previous_headings":"","what":"References","title":"Confluent hypergeometric1F1 function — hypergeometric1F1","text":"Cephes library hyp1f1.c","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/hypergeometric1F1.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Confluent hypergeometric1F1 function — hypergeometric1F1","text":"Merlise Clyde (clyde@stat.duke.edu)","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/hypergeometric1F1.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Confluent hypergeometric1F1 function — hypergeometric1F1","text":"","code":"hypergeometric1F1(11.14756, 0.5, 0.00175097) #> [1] 0.03856253"},{"path":"http://merliseclyde.github.io/BAS/reference/hypergeometric2F1.html","id":null,"dir":"Reference","previous_headings":"","what":"Gaussian hypergeometric2F1 function — hypergeometric2F1","title":"Gaussian hypergeometric2F1 function — hypergeometric2F1","text":"Compute Gaussian Hypergeometric2F1 function: 2F1(,b,c,z) = Gamma(b-c) Int_0^1 t^(b-1) (1 - t)^(c -b -1) (1 - t z)^(-) dt","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/hypergeometric2F1.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Gaussian hypergeometric2F1 function — hypergeometric2F1","text":"","code":"hypergeometric2F1(a, b, c, z, method = \"Cephes\", log = TRUE)"},{"path":"http://merliseclyde.github.io/BAS/reference/hypergeometric2F1.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Gaussian hypergeometric2F1 function — hypergeometric2F1","text":"arbitrary b Must greater 0 c Must greater b |z| < 1, c > b + z = 1 z |z| <= 1 method default use Cephes library routine. sometimes unstable large z near one returning Inf negative values. case, try method=\"Laplace\", use Laplace approximation tau = exp(t/(1-t)). log TRUE, return log(2F1)","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/hypergeometric2F1.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Gaussian hypergeometric2F1 function — hypergeometric2F1","text":"log=T returns log 2F1 function; otherwise 2F1 function.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/hypergeometric2F1.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Gaussian hypergeometric2F1 function — hypergeometric2F1","text":"default use routine hyp2f1.c Cephes library. return negative value Inf, one try method=\"Laplace\" based Laplace approximation described Liang et al JASA 2008. used hyper-g prior calculate marginal likelihoods.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/hypergeometric2F1.html","id":"references","dir":"Reference","previous_headings":"","what":"References","title":"Gaussian hypergeometric2F1 function — hypergeometric2F1","text":"Cephes library hyp2f1.c Liang, F., Paulo, R., Molina, G., Clyde, M. Berger, J.O. (2005) Mixtures g-priors Bayesian Variable Selection. Journal American Statistical Association. 103:410-423. doi:10.1198/016214507000001337","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/hypergeometric2F1.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Gaussian hypergeometric2F1 function — hypergeometric2F1","text":"Merlise Clyde (clyde@duke.edu)","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/hypergeometric2F1.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Gaussian hypergeometric2F1 function — hypergeometric2F1","text":"","code":"hypergeometric2F1(12, 1, 2, .65) #> [1] 9.580921"},{"path":"http://merliseclyde.github.io/BAS/reference/image.bas.html","id":null,"dir":"Reference","previous_headings":"","what":"Images of models used in Bayesian model averaging — image.bas","title":"Images of models used in Bayesian model averaging — image.bas","text":"Creates image models selected using bas.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/image.bas.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Images of models used in Bayesian model averaging — image.bas","text":"","code":"# S3 method for bas image( x, top.models = 20, intensity = TRUE, prob = TRUE, log = TRUE, rotate = TRUE, color = \"rainbow\", subset = NULL, drop.always.included = FALSE, offset = 0.75, digits = 3, vlas = 2, plas = 0, rlas = 0, ... )"},{"path":"http://merliseclyde.github.io/BAS/reference/image.bas.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Images of models used in Bayesian model averaging — image.bas","text":"x BMA object type 'bas' created BAS top.models Number top ranked models plot intensity Logical variable, TRUE image intensity proportional probability log(probability) model, FALSE, intensity binary indicating just presence (light) absence (dark) variable. prob Logical variable whether area image model proportional posterior probability (log probability) model (TRUE) equal area (FALSE). log Logical variable indicating whether intensities based log posterior odds (TRUE) posterior probabilities (FALSE). log posterior odds comparing model worst model top.models. rotate image models rotated models y-axis variables x-axis (TRUE) color color scheme image intensities. value \"rainbow\" uses rainbow palette. value \"blackandwhite\" produces black white image (greyscale image) subset indices variables include/exclude plot drop.always.included logical variable drop variables always forced model. FALSE default. offset numeric value add intensity digits number digits posterior probabilities keep vlas las parameter placing variable names; see par plas las parameter posterior probability axis rlas las parameter model ranks ... parameters passed image axis functions.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/image.bas.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Images of models used in Bayesian model averaging — image.bas","text":"Creates image model space sampled using bas. subset top models plotted, probabilities renormalized subset.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/image.bas.html","id":"note","dir":"Reference","previous_headings":"","what":"Note","title":"Images of models used in Bayesian model averaging — image.bas","text":"Suggestion allow area models proportional posterior probability due Thomas Lumley","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/image.bas.html","id":"references","dir":"Reference","previous_headings":"","what":"References","title":"Images of models used in Bayesian model averaging — image.bas","text":"Clyde, M. (1999) Bayesian Model Averaging Model Search Strategies (discussion). Bayesian Statistics 6. J.M. Bernardo, .P. Dawid, J.O. Berger, .F.M. Smith eds. Oxford University Press, pages 157-185.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/image.bas.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Images of models used in Bayesian model averaging — image.bas","text":"Merlise Clyde clyde@stat.duke.edu","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/image.bas.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Images of models used in Bayesian model averaging — image.bas","text":"","code":"require(graphics) data(\"Hald\") hald.ZSprior <- bas.lm(Y ~ ., data = Hald, prior = \"ZS-null\") image(hald.ZSprior, drop.always.included = TRUE) # drop the intercept"},{"path":"http://merliseclyde.github.io/BAS/reference/intrinsic.html","id":null,"dir":"Reference","previous_headings":"","what":"Intrinsic Prior Distribution for Coefficients in BMA Models — intrinsic","title":"Intrinsic Prior Distribution for Coefficients in BMA Models — intrinsic","text":"Creates object representing intrinsic prior g, special case tCCH mixture g-priors coefficients BAS.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/intrinsic.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Intrinsic Prior Distribution for Coefficients in BMA Models — intrinsic","text":"","code":"intrinsic(n = NULL)"},{"path":"http://merliseclyde.github.io/BAS/reference/intrinsic.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Intrinsic Prior Distribution for Coefficients in BMA Models — intrinsic","text":"n sample size; NULL, value derived data call `bas.glm` used.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/intrinsic.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Intrinsic Prior Distribution for Coefficients in BMA Models — intrinsic","text":"returns object class \"prior\", family \"intrinsic\" class \"TCCH\" hyperparameters alpha = 1, beta = 1, s = 0, r = 1, n = n tCCH prior theta tCCH prior determined model size sample size.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/intrinsic.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Intrinsic Prior Distribution for Coefficients in BMA Models — intrinsic","text":"Creates structure used bas.glm.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/intrinsic.html","id":"references","dir":"Reference","previous_headings":"","what":"References","title":"Intrinsic Prior Distribution for Coefficients in BMA Models — intrinsic","text":"Womack, ., Novelo,L.L., Casella, G. (2014). \"Inference Intrinsic Bayes' Procedures Model Selection Uncertainty\". Journal American Statistical Association. 109:1040-1053. doi:10.1080/01621459.2014.880348","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/intrinsic.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Intrinsic Prior Distribution for Coefficients in BMA Models — intrinsic","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/intrinsic.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Intrinsic Prior Distribution for Coefficients in BMA Models — intrinsic","text":"","code":"n <- 500 tCCH(alpha = 1, beta = 2, s = 0, r = 1.5, v = 1, theta = 1 / n) #> $family #> [1] \"tCCH\" #> #> $class #> [1] \"TCCH\" #> #> $hyper.parameters #> $hyper.parameters$alpha #> [1] 1 #> #> $hyper.parameters$beta #> [1] 2 #> #> $hyper.parameters$s #> [1] 0 #> #> $hyper.parameters$r #> [1] 1.5 #> #> $hyper.parameters$v #> [1] 1 #> #> $hyper.parameters$theta #> [1] 0.002 #> #> #> attr(,\"class\") #> [1] \"prior\""},{"path":"http://merliseclyde.github.io/BAS/reference/list2matrix.html","id":null,"dir":"Reference","previous_headings":"","what":"Coerce a BAS list object into a matrix. — list2matrix.bas","title":"Coerce a BAS list object into a matrix. — list2matrix.bas","text":"Models, coefficients, standard errors objects class 'bas' represented list lists reduce storage omitting zero entries. functions coerce list object matrix fill zeros facilitate computations.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/list2matrix.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Coerce a BAS list object into a matrix. — list2matrix.bas","text":"","code":"list2matrix.bas(x, what, which.models = NULL)"},{"path":"http://merliseclyde.github.io/BAS/reference/list2matrix.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Coerce a BAS list object into a matrix. — list2matrix.bas","text":"x 'bas' object name bas list coerce .models vector indices use extract subset","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/list2matrix.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Coerce a BAS list object into a matrix. — list2matrix.bas","text":"matrix representation x$, number rows equal length .models total number models number columns x$n.vars","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/list2matrix.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Coerce a BAS list object into a matrix. — list2matrix.bas","text":"list2matrix.bas(x, ) equivalent list2matrix.(x), however, latter uses sapply rather loop. list2matrix..matrix coerce x$matrix.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/list2matrix.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Coerce a BAS list object into a matrix. — list2matrix.bas","text":"Merlise Clyde clyde@duke.edu","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/list2matrix.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Coerce a BAS list object into a matrix. — list2matrix.bas","text":"","code":"data(Hald) hald.bic <- bas.lm(Y ~ ., data=Hald, prior=\"BIC\", initprobs= \"eplogp\") coef <- list2matrix.bas(hald.bic, \"mle\") # extract all coefficients se <- list2matrix.bas(hald.bic, \"mle.se\") models <- list2matrix.which(hald.bic) #matrix of model indicators models <- which.matrix(hald.bic$which, hald.bic$n.vars) #matrix of model indicators"},{"path":"http://merliseclyde.github.io/BAS/reference/list2matrix.which.html","id":null,"dir":"Reference","previous_headings":"","what":"Coerce a BAS list object into a matrix. — list2matrix.which","title":"Coerce a BAS list object into a matrix. — list2matrix.which","text":"Models, coefficients, standard errors objects class 'bas' represented list lists reduce storage omitting zero entries. functions coerce list object matrix fill zeros facilitate computations.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/list2matrix.which.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Coerce a BAS list object into a matrix. — list2matrix.which","text":"","code":"list2matrix.which(x, which.models = NULL)"},{"path":"http://merliseclyde.github.io/BAS/reference/list2matrix.which.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Coerce a BAS list object into a matrix. — list2matrix.which","text":"x 'bas' object .models vector indices use extract subset","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/list2matrix.which.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Coerce a BAS list object into a matrix. — list2matrix.which","text":"matrix representation x$, number rows equal length .models total number models number columns x$n.vars","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/list2matrix.which.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Coerce a BAS list object into a matrix. — list2matrix.which","text":"list2matrix.bas(x, ) equivalent list2matrix.(x), however, latter uses sapply rather loop. list2matrix..matrix coerce x$matrix.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/list2matrix.which.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Coerce a BAS list object into a matrix. — list2matrix.which","text":"Merlise Clyde clyde@duke.edu","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/list2matrix.which.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Coerce a BAS list object into a matrix. — list2matrix.which","text":"","code":"data(Hald) Hald.bic <- bas.lm(Y ~ ., data=Hald, prior=\"BIC\", initprobs=\"eplogp\") coef <- list2matrix.bas(Hald.bic, \"mle\") # extract all ols coefficients se <- list2matrix.bas(Hald.bic, \"mle.se\") models <- list2matrix.which(Hald.bic) #matrix of model indicators models <- which.matrix(Hald.bic$which, Hald.bic$n.vars) #matrix of model indicators"},{"path":"http://merliseclyde.github.io/BAS/reference/phi1.html","id":null,"dir":"Reference","previous_headings":"","what":"Compound Confluent hypergeometric function of two variables — phi1","title":"Compound Confluent hypergeometric function of two variables — phi1","text":"Compute Confluent Hypergeometric function two variables, also know Horn hypergeometric function Humbert's hypergeometric used Gordy (1998) integral representation:","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/phi1.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Compound Confluent hypergeometric function of two variables — phi1","text":"","code":"phi1(a, b, c, x, y, log = FALSE)"},{"path":"http://merliseclyde.github.io/BAS/reference/phi1.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Compound Confluent hypergeometric function of two variables — phi1","text":"> 0 b arbitrary c c > 0 x x > 0 y y > 0 log logical indicating whether return phi1 log scale","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/phi1.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Compound Confluent hypergeometric function of two variables — phi1","text":"phi_1(,b,c,x,y) = [(Gamma(c)/Gamma() Gamma(-c))] Int_0^1 t^(-1) (1 - t)^(c--1) (1 - yt)^(-b) exp(x t) dt https://en.wikipedia.org/wiki/Humbert_series Note Gordy's arguments x y reversed reference . original `phi1` function `BAS` based `C` code provided Gordy. function returns NA's x greater `log(.Machine$double.xmax)/2`. stable method calculating `phi1` function using R's `integrate` suggested Daniel Heemann now option whenever $x$ large. calculating Bayes factors use `phi1` function recommend using `log=TRUE` option compute log Bayes factors.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/phi1.html","id":"references","dir":"Reference","previous_headings":"","what":"References","title":"Compound Confluent hypergeometric function of two variables — phi1","text":"Gordy 1998","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/phi1.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Compound Confluent hypergeometric function of two variables — phi1","text":"Merlise Clyde (clyde@duke.edu) Daniel Heemann (df.heemann@gmail.com)","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/phi1.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Compound Confluent hypergeometric function of two variables — phi1","text":"","code":"# special cases # phi1(a, b, c, x=0, y) is the same as 2F1(b, a; c, y) phi1(1, 2, 1.5, 0, 1 / 100, log=FALSE) #> [1] 1.013495 hypergeometric2F1(2, 1, 1.5, 1 / 100, log = FALSE) #> [1] 1.013495 # phi1(a,0,c,x,y) is the same as 1F1(a,c,x) phi1(1, 0, 1.5, 3, 1 / 100) #> [1] 10.13001 hypergeometric1F1(1, 1.5, 3, log = FALSE) #> [1] 10.13001 # use direct integration phi1(1, 2, 1.5, 1000, 0, log=TRUE) #> [1] 996.4253"},{"path":"http://merliseclyde.github.io/BAS/reference/plot.coef.html","id":null,"dir":"Reference","previous_headings":"","what":"Plots the posterior distributions of coefficients derived from Bayesian\nmodel averaging — plot.coef.bas","title":"Plots the posterior distributions of coefficients derived from Bayesian\nmodel averaging — plot.coef.bas","text":"Displays plots posterior distributions coefficients generated Bayesian model averaging linear regression.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/plot.coef.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Plots the posterior distributions of coefficients derived from Bayesian\nmodel averaging — plot.coef.bas","text":"","code":"# S3 method for coef.bas plot(x, e = 1e-04, subset = 1:x$n.vars, ask = TRUE, ...)"},{"path":"http://merliseclyde.github.io/BAS/reference/plot.coef.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Plots the posterior distributions of coefficients derived from Bayesian\nmodel averaging — plot.coef.bas","text":"x object class coef.bas e optional numeric value specifying range distributions graphed. subset optional numerical vector specifying variables graph (including intercept) ask Prompt next plot ... parameters passed plot lines","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/plot.coef.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Plots the posterior distributions of coefficients derived from Bayesian\nmodel averaging — plot.coef.bas","text":"Produces plots posterior distributions coefficients model averaging. posterior probability coefficient zero represented solid line zero, height equal probability. nonzero part distribution scaled maximum height equal probability coefficient nonzero. parameter e specifies range distributions graphed specifying tail probabilities dictate range plot .","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/plot.coef.html","id":"note","dir":"Reference","previous_headings":"","what":"Note","title":"Plots the posterior distributions of coefficients derived from Bayesian\nmodel averaging — plot.coef.bas","text":"mixtures g-priors, uncertainty g incorporated time, thus results approximate","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/plot.coef.html","id":"references","dir":"Reference","previous_headings":"","what":"References","title":"Plots the posterior distributions of coefficients derived from Bayesian\nmodel averaging — plot.coef.bas","text":"Hoeting, J.., Raftery, .E. Madigan, D. (1996). method simultaneous variable selection outlier identification linear regression. Computational Statistics Data Analysis, 22, 251-270.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/plot.coef.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Plots the posterior distributions of coefficients derived from Bayesian\nmodel averaging — plot.coef.bas","text":"based function plot.bic Ian Painter package BMA; adapted 'bas' class Merlise Clyde clyde@stat.duke.edu","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/plot.coef.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Plots the posterior distributions of coefficients derived from Bayesian\nmodel averaging — plot.coef.bas","text":"","code":"if (FALSE) library(MASS) data(UScrime) UScrime[,-2] <- log(UScrime[,-2]) crime_bic <- bas.lm(y ~ ., data=UScrime, n.models=2^15, prior=\"BIC\") plot(coefficients(crime_bic), ask=TRUE)"},{"path":"http://merliseclyde.github.io/BAS/reference/plot.confint.html","id":null,"dir":"Reference","previous_headings":"","what":"Plot Bayesian Confidence Intervals — plot.confint.bas","title":"Plot Bayesian Confidence Intervals — plot.confint.bas","text":"Function takes output functions return credible intervals BAS objects, creates plot posterior mean segments representing credible interval. function . ~~","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/plot.confint.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Plot Bayesian Confidence Intervals — plot.confint.bas","text":"","code":"# S3 method for confint.bas plot(x, horizontal = FALSE, ...)"},{"path":"http://merliseclyde.github.io/BAS/reference/plot.confint.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Plot Bayesian Confidence Intervals — plot.confint.bas","text":"x output confint.coef.bas confint.pred.bas containing credible intervals estimates. horizontal orientation plot ... optional graphical arguments pass plot","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/plot.confint.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Plot Bayesian Confidence Intervals — plot.confint.bas","text":"plot credible intervals.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/plot.confint.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Plot Bayesian Confidence Intervals — plot.confint.bas","text":"function takes HPD intervals credible intervals created confint.coef.bas confint.pred.bas BAS objects, creates plot posterior mean segments representing credible interval. BAS tries return HPD intervals, model averaging may symmetric. description ~~","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/plot.confint.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Plot Bayesian Confidence Intervals — plot.confint.bas","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/plot.confint.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Plot Bayesian Confidence Intervals — plot.confint.bas","text":"","code":"data(Hald) hald.ZS = bas.lm(Y ~ ., data=Hald, prior=\"ZS-null\", modelprior=uniform()) hald.coef = confint(coef(hald.ZS), parm=2:5) plot(hald.coef) #> NULL plot(hald.coef, horizontal=TRUE) #> NULL plot(confint(predict(hald.ZS, se.fit=TRUE), parm=\"mean\")) #> NULL"},{"path":"http://merliseclyde.github.io/BAS/reference/plot.html","id":null,"dir":"Reference","previous_headings":"","what":"Plot Diagnostics for an BAS Object — plot.bas","title":"Plot Diagnostics for an BAS Object — plot.bas","text":"Four plots (selectable '') currently available: plot residuals fitted values, Cumulative Model Probabilities, log marginal likelihoods versus model dimension, marginal inclusion probabilities.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/plot.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Plot Diagnostics for an BAS Object — plot.bas","text":"","code":"# S3 method for bas plot( x, which = c(1:4), caption = c(\"Residuals vs Fitted\", \"Model Probabilities\", \"Model Complexity\", \"Inclusion Probabilities\"), panel = if (add.smooth) panel.smooth else points, sub.caption = NULL, main = \"\", ask = prod(par(\"mfcol\")) < length(which) && dev.interactive(), col.in = 2, col.ex = 1, col.pch = 1, cex.lab = 1, ..., id.n = 3, labels.id = NULL, cex.id = 0.75, add.smooth = getOption(\"add.smooth\"), label.pos = c(4, 2), subset = NULL, drop.always.included = FALSE )"},{"path":"http://merliseclyde.github.io/BAS/reference/plot.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Plot Diagnostics for an BAS Object — plot.bas","text":"x bas BMA object result 'bas' subset plots required, specify subset numbers '1:4' caption captions appear plots panel panel function. useful alternative 'points', 'panel.smooth' can chosen 'add.smooth = TRUE' sub.caption common title-figures multiple; used 'sub' (s.'title') otherwise. 'NULL', default, possible shortened version deparse(x$call) used main title plot-addition 'caption' ask logical; 'TRUE', user asked plot, see 'par(ask=.)' col.color included variables col.ex color excluded variables col.pch color points panels 1-3 cex.lab graphics parameter control size variable names ... parameters passed plotting functions id.n number points labeled plot, starting extreme labels.id vector labels, labels extreme points chosen. 'NULL' uses observation numbers cex.id magnification point labels. add.smooth logical indicating smoother added plots; see also 'panel' label.pos positioning labels, left half right half graph respectively, plots 1-4 subset indices variables include/exclude plot marginal posterior inclusion probabilities (NULL). drop.always.included logical variable drop marginal posterior inclusion probabilities variables always forced model. FALSE default.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/plot.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Plot Diagnostics for an BAS Object — plot.bas","text":"provides panel 4 plots: first plot residuals versus fitted values BMA. second plot cumulative marginal likelihoods models; model space enumerated provides indication whether probabilities leveling . third plot log marginal likelihood versus model dimension fourth plot show posterior marginal inclusion probabilities.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/plot.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Plot Diagnostics for an BAS Object — plot.bas","text":"Merlise Clyde, based plot.lm John Maindonald Martin Maechler","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/plot.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Plot Diagnostics for an BAS Object — plot.bas","text":"","code":"data(Hald) hald.gprior = bas.lm(Y~ ., data=Hald, prior=\"g-prior\", alpha=13, modelprior=beta.binomial(1,1), initprobs=\"eplogp\") plot(hald.gprior)"},{"path":"http://merliseclyde.github.io/BAS/reference/predict.bas.html","id":null,"dir":"Reference","previous_headings":"","what":"Prediction Method for an object of class BAS — predict.bas","title":"Prediction Method for an object of class BAS — predict.bas","text":"Predictions model averaging estimators BMA object class inheriting 'bas'.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/predict.bas.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Prediction Method for an object of class BAS — predict.bas","text":"","code":"# S3 method for bas predict( object, newdata, se.fit = FALSE, type = \"link\", top = NULL, estimator = \"BMA\", na.action = na.pass, ... )"},{"path":"http://merliseclyde.github.io/BAS/reference/predict.bas.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Prediction Method for an object of class BAS — predict.bas","text":"object object class BAS, created bas newdata dataframe predictions. missing, use dataframe used fitting obtaining fitted predicted values. se.fit indicator whether compute se fitted predicted values type Type predictions required. \"link\" scale linear predictor option currently linear models, normal model equivalent type='response'. top scalar integer M. supplied, subset top M models, based posterior probabilities model predictions BMA. estimator estimator used predictions. Currently supported options include: 'HPM' highest probability model 'BMA' Bayesian model averaging, using optionally 'top' models 'MPM' median probability model Barbieri Berger. 'BPM' model closest BMA predictions squared error loss. BMA may computed using 'top' models supplied na.action function determining done missing values newdata. default predict NA. ... optional extra arguments","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/predict.bas.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Prediction Method for an object of class BAS — predict.bas","text":"list fit fitted values based selected estimator Ybma predictions using BMA, fit non-BMA methods compatibility; deprecated Ypred matrix predictions model BMA se.fit se fitted values; case BMA matrix se.pred se predicted values; case BMA matrix se.bma.fit vector posterior sd BMA posterior mean regression function. NULL estimator 'BMA' se.bma.pred vector posterior sd BMA posterior predictive values. NULL estimator 'BMA' best index top models included bestmodels subset bestmodels used fitting prediction best.vars names variables top model; NULL estimator='BMA' df scalar vector degrees freedom models estimator estimator upon 'fit' based.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/predict.bas.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Prediction Method for an object of class BAS — predict.bas","text":"Use BMA /model selection form predictions using top highest probability models.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/predict.bas.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Prediction Method for an object of class BAS — predict.bas","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/predict.bas.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Prediction Method for an object of class BAS — predict.bas","text":"","code":"data(\"Hald\") hald.gprior = bas.lm(Y ~ ., data=Hald, alpha=13, prior=\"g-prior\") predict(hald.gprior, newdata=Hald, estimator=\"BPM\", se.fit=TRUE) #> $fit #> [1] 79.65151 74.47846 105.42183 89.83174 95.62799 104.59616 103.50684 #> [8] 77.00839 92.07571 114.10876 82.68233 111.04286 110.46741 #> attr(,\"model\") #> [1] 0 1 2 4 #> attr(,\"best\") #> [1] 15 #> attr(,\"estimator\") #> [1] \"BPM\" #> #> $Ybma #> [,1] #> [1,] 79.68307 #> [2,] 74.69127 #> [3,] 105.63258 #> [4,] 89.91648 #> [5,] 95.67480 #> [6,] 104.57616 #> [7,] 103.47945 #> [8,] 76.96808 #> [9,] 92.22184 #> [10,] 113.84918 #> [11,] 82.59035 #> [12,] 110.87673 #> [13,] 110.34001 #> #> $Ypred #> [,1] [,2] [,3] [,4] [,5] [,6] [,7] #> [1,] 81.17036 74.83464 105.07248 89.69881 97.15898 104.45753 103.38927 #> [2,] 77.70296 74.24113 105.85537 90.46267 93.09565 104.71517 103.13993 #> [3,] 79.70437 74.40553 105.21752 89.76253 95.63309 104.57088 103.52541 #> [4,] 79.65151 74.47846 105.42183 89.83174 95.62799 104.59616 103.50684 #> [5,] 79.84321 74.31409 104.90632 89.65651 95.70301 104.52849 103.54760 #> [6,] 79.26248 74.75042 106.28314 90.16732 95.37830 104.70862 103.39893 #> [7,] 78.80123 75.69457 108.22151 90.62061 95.54467 104.84276 103.50032 #> [8,] 81.66556 77.02098 106.35099 88.18423 99.83232 103.89115 105.74346 #> [9,] 85.78065 79.39070 104.28069 87.30339 103.43704 102.66524 106.03984 #> [10,] 74.86000 80.34349 102.27744 83.77067 93.36677 100.90656 111.87354 #> [11,] 79.18965 81.38793 101.17241 82.85345 98.24138 100.43966 112.16380 #> [12,] 76.29823 80.55874 101.93127 83.25765 95.26054 100.79397 112.20198 #> [13,] 94.62219 84.21059 101.56325 101.56325 94.62219 101.56325 87.68112 #> [14,] 95.42308 95.42308 95.42308 95.42308 95.42308 95.42308 95.42308 #> [15,] 91.78308 83.03167 101.29055 101.29055 91.78308 101.74970 88.24455 #> [16,] 102.15048 91.65573 99.81831 99.81831 102.15048 98.65223 89.32357 #> [,8] [,9] [,10] [,11] [,12] [,13] #> [1,] 76.06454 91.57174 113.17222 81.59906 111.22195 111.08841 #> [2,] 78.80193 92.68123 115.80581 84.50293 110.41616 109.07906 #> [3,] 77.08557 91.98604 114.17593 82.78145 111.11959 110.53210 #> [4,] 77.00839 92.07571 114.10876 82.68233 111.04286 110.46741 #> [5,] 77.15919 91.83513 114.23530 82.88128 111.23840 110.65147 #> [6,] 76.86019 92.49134 113.99208 82.44826 110.67744 110.08148 #> [7,] 76.13446 93.59932 112.64184 81.53107 109.86900 109.49863 #> [8,] 74.60469 93.86382 106.77052 80.21897 110.61958 111.73373 #> [9,] 74.19437 93.55892 101.91430 79.36984 110.13525 112.42979 #> [10,] 85.82697 100.90656 98.16482 92.68133 107.76092 107.76092 #> [11,] 82.85345 99.70690 94.57759 89.44827 108.50000 109.96552 #> [12,] 84.53056 100.50527 96.78718 91.37187 108.21267 108.79006 #> [13,] 84.21059 85.94586 118.91590 84.21059 101.56325 99.82798 #> [14,] 95.42308 95.42308 95.42308 95.42308 95.42308 95.42308 #> [15,] 86.24572 86.55641 120.92687 86.70486 101.74970 99.14326 #> [16,] 83.49316 88.15749 104.48264 82.32707 98.65223 99.81831 #> #> $postprobs #> [1] 2.432256e-01 1.684081e-01 1.312165e-01 1.224293e-01 1.220358e-01 #> [6] 1.145513e-01 6.888252e-02 2.709377e-02 1.481347e-03 2.891971e-04 #> [11] 2.559516e-04 5.597869e-05 4.790052e-05 1.177702e-05 1.000762e-05 #> [16] 5.009504e-06 #> #> $se.fit #> 1 2 3 4 5 6 7 8 #> 3.117350 2.283957 1.602160 2.149087 2.589321 1.508471 2.610923 2.545817 #> 9 10 11 12 13 #> 1.990817 3.485929 2.456636 1.951456 2.212238 #> #> $se.pred #> 1 2 3 4 5 6 7 8 #> 5.440156 5.009380 4.737547 4.949344 5.155775 4.706689 5.166658 5.134065 #> 9 10 11 12 13 #> 4.882702 5.659428 5.090431 4.866787 4.977090 #> #> $se.bma.fit #> NULL #> #> $se.bma.pred #> NULL #> #> $df #> [1] 12 #> #> $best #> [1] 15 #> #> $bestmodel #> [1] 0 1 2 4 #> #> $best.vars #> [1] \"Intercept\" \"X1\" \"X2\" \"X4\" #> #> $estimator #> [1] \"BPM\" #> #> attr(,\"class\") #> [1] \"pred.bas\" # same as fitted fitted(hald.gprior,estimator=\"BPM\") #> [1] 79.65151 74.47846 105.42183 89.83174 95.62799 104.59616 103.50684 #> [8] 77.00839 92.07571 114.10876 82.68233 111.04286 110.46741 # default is BMA and estimation of mean vector hald.bma = predict(hald.gprior, top=5, se.fit=TRUE) confint(hald.bma) #> 2.5% 97.5% pred #> [1,] 68.27724 91.37182 79.74246 #> [2,] 63.66525 85.76692 74.50010 #> [3,] 94.86215 116.36788 105.29268 #> [4,] 78.39566 100.44548 89.88693 #> [5,] 84.39637 106.24466 95.57177 #> [6,] 94.50137 115.25047 104.56409 #> [7,] 92.27172 115.13803 103.40145 #> [8,] 65.98258 88.63189 77.13668 #> [9,] 81.46505 103.06572 91.99731 #> [10,] 101.28694 126.36327 114.21325 #> [11,] 72.14095 94.50244 82.78446 #> [12,] 99.74081 121.39665 111.00723 #> [13,] 99.34598 121.57452 110.40160 #> attr(,\"Probability\") #> [1] 0.95 #> attr(,\"class\") #> [1] \"confint.bas\" hald.bpm = predict(hald.gprior, newdata=Hald[1,], se.fit=TRUE, estimator=\"BPM\") confint(hald.bpm) #> 2.5% 97.5% pred #> [1,] 67.74454 91.66421 79.70437 #> attr(,\"Probability\") #> [1] 0.95 #> attr(,\"class\") #> [1] \"confint.bas\" # extract variables variable.names(hald.bpm) #> [1] \"Intercept\" \"X1\" \"X2\" \"X3\" \"X4\" hald.hpm = predict(hald.gprior, newdata=Hald[1,], se.fit=TRUE, estimator=\"HPM\") confint(hald.hpm) #> 2.5% 97.5% pred #> [1,] 70.15171 92.18902 81.17036 #> attr(,\"Probability\") #> [1] 0.95 #> attr(,\"class\") #> [1] \"confint.bas\" variable.names(hald.hpm) #> [1] \"Intercept\" \"X1\" \"X2\" hald.mpm = predict(hald.gprior, newdata=Hald[1,], se.fit=TRUE, estimator=\"MPM\") confint(hald.mpm) #> 2.5% 97.5% pred #> [1,] 67.79843 91.50459 79.65151 #> attr(,\"Probability\") #> [1] 0.95 #> attr(,\"class\") #> [1] \"confint.bas\" variable.names(hald.mpm) #> [1] \"Intercept\" \"X1\" \"X2\" \"X4\""},{"path":"http://merliseclyde.github.io/BAS/reference/predict.basglm.html","id":null,"dir":"Reference","previous_headings":"","what":"Prediction Method for an Object of Class basglm — predict.basglm","title":"Prediction Method for an Object of Class basglm — predict.basglm","text":"Predictions model averaging BMA (BAS) object GLMs different loss functions.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/predict.basglm.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Prediction Method for an Object of Class basglm — predict.basglm","text":"","code":"# S3 method for basglm predict( object, newdata, se.fit = FALSE, type = c(\"response\", \"link\"), top = NULL, estimator = \"BMA\", na.action = na.pass, ... )"},{"path":"http://merliseclyde.github.io/BAS/reference/predict.basglm.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Prediction Method for an Object of Class basglm — predict.basglm","text":"object object class \"basglm\", created bas.glm newdata dataframe, new matrix vector data predictions. May include column intercept just predictor variables. dataframe, variables extracted using model.matrix using call created 'object'. May missing case data used fitting used prediction. se.fit indicator whether compute se fitted predicted values type Type predictions required. default \"response\" scale response variable, alternative linear predictor scale, `type ='link'`. Thus default binomial model `type = 'response'` gives predicted probabilities, `'link'`, estimates log-odds (probabilities logit scale). top scalar integer M. supplied, calculate results using subset top M models based posterior probabilities. estimator estimator used predictions. Currently supported options include: 'HPM' highest probability model 'BMA' Bayesian model averaging, using optionally 'top' models 'MPM' median probability model Barbieri Berger. 'BPM' model closest BMA predictions squared error loss. BMA may computed using 'top' models supplied na.action function determining done missing values newdata. default predict NA. ... optional extra arguments","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/predict.basglm.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Prediction Method for an Object of Class basglm — predict.basglm","text":"list fit predictions using BMA estimators Ypred matrix predictions model(s) postprobs renormalized probabilities top models best index top models included","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/predict.basglm.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Prediction Method for an Object of Class basglm — predict.basglm","text":"function first calls predict method class bas (linear models) form predictions linear predictor scale `BMA`, `HPM`, `MPM` etc. estimator `BMA` `type='response'` inverse link applied fitted values type equal `'link'` model averaging takes place `response` scale. Thus applying inverse link BMA estimate `type = 'link'` equal fitted values `type = 'response'` BMA due nonlinear transformation inverse link.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/predict.basglm.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Prediction Method for an Object of Class basglm — predict.basglm","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/predict.basglm.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Prediction Method for an Object of Class basglm — predict.basglm","text":"","code":"data(Pima.tr, package=\"MASS\") data(Pima.te, package=\"MASS\") Pima.bas = bas.glm(type ~ ., data=Pima.tr, n.models= 2^7, method=\"BAS\", betaprior=CCH(a=1, b=nrow(Pima.tr)/2, s=0), family=binomial(), modelprior=uniform()) pred = predict(Pima.bas, newdata=Pima.te, top=1) # Highest Probability model cv.summary.bas(pred$fit, Pima.te$type, score=\"miss-class\") #> [1] 0.2108434"},{"path":"http://merliseclyde.github.io/BAS/reference/print.bas.html","id":null,"dir":"Reference","previous_headings":"","what":"Print a Summary of Bayesian Model Averaging objects from BAS — print.bas","title":"Print a Summary of Bayesian Model Averaging objects from BAS — print.bas","text":"summary print methods Bayesian model averaging objects created bas Bayesian Adaptive Sampling","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/print.bas.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Print a Summary of Bayesian Model Averaging objects from BAS — print.bas","text":"","code":"# S3 method for bas print(x, digits = max(3L, getOption(\"digits\") - 3L), ...)"},{"path":"http://merliseclyde.github.io/BAS/reference/print.bas.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Print a Summary of Bayesian Model Averaging objects from BAS — print.bas","text":"x object class 'bas' digits optional number specifying number digits display ... parameters passed print.default","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/print.bas.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Print a Summary of Bayesian Model Averaging objects from BAS — print.bas","text":"print methods display view similar print.lm . summary methods display view specific Bayesian model averaging giving top 5 highest probability models represented inclusion indicators. Summaries models include Bayes Factor (BF) model model largest marginal likelihood, posterior probability models, R2, dim (includes intercept) log marginal likelihood.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/print.bas.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Print a Summary of Bayesian Model Averaging objects from BAS — print.bas","text":"Merlise Clyde clyde@stat.duke.edu","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/print.bas.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Print a Summary of Bayesian Model Averaging objects from BAS — print.bas","text":"","code":"library(MASS) data(UScrime) UScrime[, -2] <- log(UScrime[, -2]) crime.bic <- bas.lm(y ~ ., data = UScrime, n.models = 2^15, prior = \"BIC\", initprobs = \"eplogp\") print(crime.bic) #> #> Call: #> bas.lm(formula = y ~ ., data = UScrime, n.models = 2^15, prior = \"BIC\", #> initprobs = \"eplogp\") #> #> #> Marginal Posterior Inclusion Probabilities: #> Intercept M So Ed Po1 Po2 LF #> 1.0000 0.9335 0.3277 0.9910 0.7247 0.4602 0.2935 #> M.F Pop NW U1 U2 GDP Ineq #> 0.3298 0.4963 0.8346 0.3481 0.7752 0.5254 0.9992 #> Prob Time #> 0.9541 0.5433 summary(crime.bic) #> P(B != 0 | Y) model 1 model 2 model 3 model 4 #> Intercept 1.0000000 1.00000 1.000000e+00 1.0000000 1.0000000 #> M 0.9335117 1.00000 1.000000e+00 1.0000000 1.0000000 #> So 0.3276563 0.00000 1.000000e+00 0.0000000 0.0000000 #> Ed 0.9910219 1.00000 1.000000e+00 1.0000000 1.0000000 #> Po1 0.7246635 1.00000 1.000000e+00 1.0000000 1.0000000 #> Po2 0.4602481 0.00000 1.000000e+00 0.0000000 0.0000000 #> LF 0.2935326 0.00000 1.000000e+00 0.0000000 0.0000000 #> M.F 0.3298168 0.00000 1.000000e+00 0.0000000 0.0000000 #> Pop 0.4962869 0.00000 1.000000e+00 0.0000000 0.0000000 #> NW 0.8346412 1.00000 1.000000e+00 1.0000000 1.0000000 #> U1 0.3481266 0.00000 1.000000e+00 0.0000000 0.0000000 #> U2 0.7752102 1.00000 1.000000e+00 1.0000000 1.0000000 #> GDP 0.5253694 0.00000 1.000000e+00 0.0000000 1.0000000 #> Ineq 0.9992058 1.00000 1.000000e+00 1.0000000 1.0000000 #> Prob 0.9541470 1.00000 1.000000e+00 1.0000000 1.0000000 #> Time 0.5432686 1.00000 1.000000e+00 0.0000000 1.0000000 #> BF NA 1.00000 1.267935e-04 0.7609295 0.5431578 #> PostProbs NA 0.01910 1.560000e-02 0.0145000 0.0133000 #> R2 NA 0.84200 8.695000e-01 0.8265000 0.8506000 #> dim NA 9.00000 1.600000e+01 8.0000000 10.0000000 #> logmarg NA -22.15855 -3.113150e+01 -22.4317627 -22.7689035 #> model 5 #> Intercept 1.0000000 #> M 1.0000000 #> So 0.0000000 #> Ed 1.0000000 #> Po1 1.0000000 #> Po2 0.0000000 #> LF 0.0000000 #> M.F 0.0000000 #> Pop 1.0000000 #> NW 1.0000000 #> U1 0.0000000 #> U2 1.0000000 #> GDP 0.0000000 #> Ineq 1.0000000 #> Prob 1.0000000 #> Time 0.0000000 #> BF 0.5203179 #> PostProbs 0.0099000 #> R2 0.8375000 #> dim 9.0000000 #> logmarg -22.8118635"},{"path":"http://merliseclyde.github.io/BAS/reference/protein.html","id":null,"dir":"Reference","previous_headings":"","what":"Protein Activity Data — protein","title":"Protein Activity Data — protein","text":"data sets includes several predictors protein activity experiment run Glaxo.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/protein.html","id":"format","dir":"Reference","previous_headings":"","what":"Format","title":"Protein Activity Data — protein","text":"protein dataframe 96 observations 8 predictor variables protein activity:","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/protein.html","id":"source","dir":"Reference","previous_headings":"","what":"Source","title":"Protein Activity Data — protein","text":"Clyde, M. . Parmigiani, G. (1998), Protein Construct Storage: Bayesian Variable Selection Prediction Mixtures, Journal Biopharmaceutical Statistics, 8, 431-443","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/robust.html","id":null,"dir":"Reference","previous_headings":"","what":"Robust-Prior Distribution for Coefficients in BMA Model — robust","title":"Robust-Prior Distribution for Coefficients in BMA Model — robust","text":"Creates object representing robust prior Bayarri et al (2012) mixture g-priors coefficients BAS.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/robust.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Robust-Prior Distribution for Coefficients in BMA Model — robust","text":"","code":"robust(n = NULL)"},{"path":"http://merliseclyde.github.io/BAS/reference/robust.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Robust-Prior Distribution for Coefficients in BMA Model — robust","text":"n sample size.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/robust.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Robust-Prior Distribution for Coefficients in BMA Model — robust","text":"returns object class \"prior\", family hyerparameters.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/robust.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Robust-Prior Distribution for Coefficients in BMA Model — robust","text":"Creates prior structure used bas.glm.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/robust.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Robust-Prior Distribution for Coefficients in BMA Model — robust","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/robust.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Robust-Prior Distribution for Coefficients in BMA Model — robust","text":"","code":"robust(100) #> $family #> [1] \"robust\" #> #> $class #> [1] \"TCCH\" #> #> $hyper.parameters #> $hyper.parameters$n #> [1] 100 #> #> #> attr(,\"class\") #> [1] \"prior\""},{"path":"http://merliseclyde.github.io/BAS/reference/summary.html","id":null,"dir":"Reference","previous_headings":"","what":"Summaries of Bayesian Model Averaging objects from BAS — summary.bas","title":"Summaries of Bayesian Model Averaging objects from BAS — summary.bas","text":"summary print methods Bayesian model averaging objects created bas Bayesian Adaptive Sampling","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/summary.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Summaries of Bayesian Model Averaging objects from BAS — summary.bas","text":"","code":"# S3 method for bas summary(object, n.models = 5, ...)"},{"path":"http://merliseclyde.github.io/BAS/reference/summary.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Summaries of Bayesian Model Averaging objects from BAS — summary.bas","text":"object object class 'bas' n.models optional number specifying number best models display summary ... parameters passed summary.default","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/summary.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Summaries of Bayesian Model Averaging objects from BAS — summary.bas","text":"print methods display view similar print.lm . summary methods display view specific Bayesian model averaging giving top 5 highest probability models represented inclusion indicators. Summaries models include Bayes Factor (BF) model model largest marginal likelihood, posterior probability models, R2, dim (includes intercept) log marginal likelihood.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/summary.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Summaries of Bayesian Model Averaging objects from BAS — summary.bas","text":"Merlise Clyde clyde@duke.edu","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/summary.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Summaries of Bayesian Model Averaging objects from BAS — summary.bas","text":"","code":"data(UScrime, package = \"MASS\") UScrime[, -2] <- log(UScrime[, -2]) crime.bic <- bas.lm(y ~ ., data = UScrime, n.models = 2^15, prior = \"BIC\", initprobs = \"eplogp\") print(crime.bic) #> #> Call: #> bas.lm(formula = y ~ ., data = UScrime, n.models = 2^15, prior = \"BIC\", #> initprobs = \"eplogp\") #> #> #> Marginal Posterior Inclusion Probabilities: #> Intercept M So Ed Po1 Po2 LF #> 1.0000 0.9335 0.3277 0.9910 0.7247 0.4602 0.2935 #> M.F Pop NW U1 U2 GDP Ineq #> 0.3298 0.4963 0.8346 0.3481 0.7752 0.5254 0.9992 #> Prob Time #> 0.9541 0.5433 summary(crime.bic) #> P(B != 0 | Y) model 1 model 2 model 3 model 4 #> Intercept 1.0000000 1.00000 1.000000e+00 1.0000000 1.0000000 #> M 0.9335117 1.00000 1.000000e+00 1.0000000 1.0000000 #> So 0.3276563 0.00000 1.000000e+00 0.0000000 0.0000000 #> Ed 0.9910219 1.00000 1.000000e+00 1.0000000 1.0000000 #> Po1 0.7246635 1.00000 1.000000e+00 1.0000000 1.0000000 #> Po2 0.4602481 0.00000 1.000000e+00 0.0000000 0.0000000 #> LF 0.2935326 0.00000 1.000000e+00 0.0000000 0.0000000 #> M.F 0.3298168 0.00000 1.000000e+00 0.0000000 0.0000000 #> Pop 0.4962869 0.00000 1.000000e+00 0.0000000 0.0000000 #> NW 0.8346412 1.00000 1.000000e+00 1.0000000 1.0000000 #> U1 0.3481266 0.00000 1.000000e+00 0.0000000 0.0000000 #> U2 0.7752102 1.00000 1.000000e+00 1.0000000 1.0000000 #> GDP 0.5253694 0.00000 1.000000e+00 0.0000000 1.0000000 #> Ineq 0.9992058 1.00000 1.000000e+00 1.0000000 1.0000000 #> Prob 0.9541470 1.00000 1.000000e+00 1.0000000 1.0000000 #> Time 0.5432686 1.00000 1.000000e+00 0.0000000 1.0000000 #> BF NA 1.00000 1.267935e-04 0.7609295 0.5431578 #> PostProbs NA 0.01910 1.560000e-02 0.0145000 0.0133000 #> R2 NA 0.84200 8.695000e-01 0.8265000 0.8506000 #> dim NA 9.00000 1.600000e+01 8.0000000 10.0000000 #> logmarg NA -22.15855 -3.113150e+01 -22.4317627 -22.7689035 #> model 5 #> Intercept 1.0000000 #> M 1.0000000 #> So 0.0000000 #> Ed 1.0000000 #> Po1 1.0000000 #> Po2 0.0000000 #> LF 0.0000000 #> M.F 0.0000000 #> Pop 1.0000000 #> NW 1.0000000 #> U1 0.0000000 #> U2 1.0000000 #> GDP 0.0000000 #> Ineq 1.0000000 #> Prob 1.0000000 #> Time 0.0000000 #> BF 0.5203179 #> PostProbs 0.0099000 #> R2 0.8375000 #> dim 9.0000000 #> logmarg -22.8118635"},{"path":"http://merliseclyde.github.io/BAS/reference/tCCH.html","id":null,"dir":"Reference","previous_headings":"","what":"Generalized tCCH g-Prior Distribution for Coefficients in BMA Models — tCCH","title":"Generalized tCCH g-Prior Distribution for Coefficients in BMA Models — tCCH","text":"Creates object representing tCCH mixture g-priors coefficients BAS.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/tCCH.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Generalized tCCH g-Prior Distribution for Coefficients in BMA Models — tCCH","text":"","code":"tCCH(alpha = 1, beta = 2, s = 0, r = 3/2, v = 1, theta = 1)"},{"path":"http://merliseclyde.github.io/BAS/reference/tCCH.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Generalized tCCH g-Prior Distribution for Coefficients in BMA Models — tCCH","text":"alpha scalar > 0, recommended alpha=.5 (betaprime) 1. beta scalar > 0. value updated data; beta function n consistency null model. s scalar, recommended s=0 priori r r arbitrary; hyper-g-n prior sets r = (alpha + 2) v 0 < v theta theta > 1","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/tCCH.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Generalized tCCH g-Prior Distribution for Coefficients in BMA Models — tCCH","text":"returns object class \"prior\", family hyerparameters.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/tCCH.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Generalized tCCH g-Prior Distribution for Coefficients in BMA Models — tCCH","text":"Creates structure used bas.glm.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/tCCH.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Generalized tCCH g-Prior Distribution for Coefficients in BMA Models — tCCH","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/tCCH.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Generalized tCCH g-Prior Distribution for Coefficients in BMA Models — tCCH","text":"","code":"n <- 500 tCCH(alpha = 1, beta = 2, s = 0, r = 1.5, v = 1, theta = 1 / n) #> $family #> [1] \"tCCH\" #> #> $class #> [1] \"TCCH\" #> #> $hyper.parameters #> $hyper.parameters$alpha #> [1] 1 #> #> $hyper.parameters$beta #> [1] 2 #> #> $hyper.parameters$s #> [1] 0 #> #> $hyper.parameters$r #> [1] 1.5 #> #> $hyper.parameters$v #> [1] 1 #> #> $hyper.parameters$theta #> [1] 0.002 #> #> #> attr(,\"class\") #> [1] \"prior\""},{"path":"http://merliseclyde.github.io/BAS/reference/testBF.prior.html","id":null,"dir":"Reference","previous_headings":"","what":"Test based Bayes Factors for BMA Models — testBF.prior","title":"Test based Bayes Factors for BMA Models — testBF.prior","text":"Creates object representing prior distribution coefficients BAS corresponds test-based Bayes Factors.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/testBF.prior.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Test based Bayes Factors for BMA Models — testBF.prior","text":"","code":"testBF.prior(g)"},{"path":"http://merliseclyde.github.io/BAS/reference/testBF.prior.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Test based Bayes Factors for BMA Models — testBF.prior","text":"g scalar used covariance Zellner's g-prior, Cov(beta) = sigma^2 g (X'X)^-","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/testBF.prior.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Test based Bayes Factors for BMA Models — testBF.prior","text":"returns object class \"prior\", family hyerparameters.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/testBF.prior.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Test based Bayes Factors for BMA Models — testBF.prior","text":"Creates prior object structure used BAS `bas.glm`.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/testBF.prior.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Test based Bayes Factors for BMA Models — testBF.prior","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/testBF.prior.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Test based Bayes Factors for BMA Models — testBF.prior","text":"","code":"testBF.prior(100) #> $family #> [1] \"testBF.prior\" #> #> $g #> [1] 100 #> #> $class #> [1] \"g-prior\" #> #> $hyper #> [1] 100 #> #> $hyper.parameters #> $hyper.parameters$g #> [1] 100 #> #> $hyper.parameters$loglik_null #> NULL #> #> #> attr(,\"class\") #> [1] \"prior\" library(MASS) data(Pima.tr) # use g = n bas.glm(type ~ ., data = Pima.tr, family = binomial(), betaprior = testBF.prior(nrow(Pima.tr)), modelprior = uniform(), method = \"BAS\" ) #> #> Call: #> bas.glm(formula = type ~ ., family = binomial(), data = Pima.tr, #> betaprior = testBF.prior(nrow(Pima.tr)), modelprior = uniform(), #> method = \"BAS\") #> #> #> Marginal Posterior Inclusion Probabilities: #> Intercept npreg glu bp skin bmi ped #> 1.0000 0.4252 1.0000 0.0706 0.1264 0.6139 0.8075 #> age #> 0.6705"},{"path":"http://merliseclyde.github.io/BAS/reference/tr.beta.binomial.html","id":null,"dir":"Reference","previous_headings":"","what":"Truncated Beta-Binomial Prior Distribution for Models — tr.beta.binomial","title":"Truncated Beta-Binomial Prior Distribution for Models — tr.beta.binomial","text":"Creates object representing prior distribution models BAS using truncated Beta-Binomial Distribution Model Size","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/tr.beta.binomial.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Truncated Beta-Binomial Prior Distribution for Models — tr.beta.binomial","text":"","code":"tr.beta.binomial(alpha = 1, beta = 1, trunc)"},{"path":"http://merliseclyde.github.io/BAS/reference/tr.beta.binomial.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Truncated Beta-Binomial Prior Distribution for Models — tr.beta.binomial","text":"alpha parameter beta prior distribution beta parameter beta prior distribution trunc parameter determines truncation distribution .e. P(M; alpha, beta, trunc) = 0 M > trunc.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/tr.beta.binomial.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Truncated Beta-Binomial Prior Distribution for Models — tr.beta.binomial","text":"returns object class \"prior\", family hyperparameters.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/tr.beta.binomial.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Truncated Beta-Binomial Prior Distribution for Models — tr.beta.binomial","text":"beta-binomial distribution model size obtained assigning variable inclusion indicator independent Bernoulli distributions probability w, giving w beta(alpha,beta) distribution. Marginalizing w leads number included predictors beta-binomial distribution. default hyperparameters lead uniform distribution model size. Truncated version assigns zero probability models size > trunc.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/tr.beta.binomial.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Truncated Beta-Binomial Prior Distribution for Models — tr.beta.binomial","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/tr.beta.binomial.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Truncated Beta-Binomial Prior Distribution for Models — tr.beta.binomial","text":"","code":"tr.beta.binomial(1, 10, 5) #> $family #> [1] \"Trunc-Beta-Binomial\" #> #> $hyper.parameters #> [1] 1 10 5 #> #> attr(,\"class\") #> [1] \"prior\" library(MASS) data(UScrime) UScrime[, -2] <- log(UScrime[, -2]) crime.bic <- bas.lm(y ~ ., data = UScrime, n.models = 2^15, prior = \"BIC\", modelprior = tr.beta.binomial(1, 1, 8), initprobs = \"eplogp\" )"},{"path":"http://merliseclyde.github.io/BAS/reference/tr.poisson.html","id":null,"dir":"Reference","previous_headings":"","what":"Truncated Poisson Prior Distribution for Models — tr.poisson","title":"Truncated Poisson Prior Distribution for Models — tr.poisson","text":"Creates object representing prior distribution models BAS using truncated Poisson Distribution Model Size","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/tr.poisson.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Truncated Poisson Prior Distribution for Models — tr.poisson","text":"","code":"tr.poisson(lambda, trunc)"},{"path":"http://merliseclyde.github.io/BAS/reference/tr.poisson.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Truncated Poisson Prior Distribution for Models — tr.poisson","text":"lambda parameter Poisson distribution representing expected model size infinite predictors trunc parameter determines truncation distribution .e. P(M; lambda, trunc) = 0 M > trunc","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/tr.poisson.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Truncated Poisson Prior Distribution for Models — tr.poisson","text":"returns object class \"prior\", family hyperparameters.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/tr.poisson.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Truncated Poisson Prior Distribution for Models — tr.poisson","text":"Poisson prior distribution model size obtained assigning variable inclusion indicator independent Bernoulli distributions probability w, taking limit p goes infinity w goes zero, p*w converges lambda. Truncated version assigns zero probability models size M > trunc.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/tr.poisson.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Truncated Poisson Prior Distribution for Models — tr.poisson","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/tr.poisson.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Truncated Poisson Prior Distribution for Models — tr.poisson","text":"","code":"tr.poisson(10, 50) #> $family #> [1] \"Trunc-Poisson\" #> #> $hyper.parameters #> [1] 10 50 #> #> attr(,\"class\") #> [1] \"prior\""},{"path":"http://merliseclyde.github.io/BAS/reference/tr.power.prior.html","id":null,"dir":"Reference","previous_headings":"","what":"Truncated Power Prior Distribution for Models — tr.power.prior","title":"Truncated Power Prior Distribution for Models — tr.power.prior","text":"Creates object representing prior distribution models BAS using truncated Distribution Model Size probability gamma = p^-kappa |gamma| gamma vector model indicators","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/tr.power.prior.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Truncated Power Prior Distribution for Models — tr.power.prior","text":"","code":"tr.power.prior(kappa = 2, trunc)"},{"path":"http://merliseclyde.github.io/BAS/reference/tr.power.prior.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Truncated Power Prior Distribution for Models — tr.power.prior","text":"kappa parameter prior distribution controls sparsity trunc parameter determines truncation distribution .e. P(gamma; alpha, beta, trunc) = 0 |gamma| > trunc.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/tr.power.prior.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Truncated Power Prior Distribution for Models — tr.power.prior","text":"returns object class \"prior\", family hyperparameters.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/tr.power.prior.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Truncated Power Prior Distribution for Models — tr.power.prior","text":"beta-binomial distribution model size obtained assigning variable inclusion indicator independent Bernoulli distributions probability w, giving w beta(alpha,beta) distribution. Marginalizing w leads number included predictors beta-binomial distribution. default hyperparameters lead uniform distribution model size. Truncated version assigns zero probability models size > trunc.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/tr.power.prior.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Truncated Power Prior Distribution for Models — tr.power.prior","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/tr.power.prior.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Truncated Power Prior Distribution for Models — tr.power.prior","text":"","code":"tr.power.prior(2, 8) #> $family #> [1] \"Trunc-Power-Prior\" #> #> $hyper.parameters #> [1] 2 8 #> #> attr(,\"class\") #> [1] \"prior\" library(MASS) data(UScrime) UScrime[, -2] <- log(UScrime[, -2]) crime.bic <- bas.lm(y ~ ., data = UScrime, n.models = 2^15, prior = \"BIC\", modelprior = tr.power.prior(2, 8), initprobs = \"eplogp\" )"},{"path":"http://merliseclyde.github.io/BAS/reference/trCCH.html","id":null,"dir":"Reference","previous_headings":"","what":"Truncated Compound Confluent Hypergeometric function — trCCH","title":"Truncated Compound Confluent Hypergeometric function — trCCH","text":"Compute Truncated Confluent Hypergeometric function Li Clyde (2018) normalizing constant tcch density Gordy (1998) integral representation:","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/trCCH.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Truncated Compound Confluent Hypergeometric function — trCCH","text":"","code":"trCCH(a, b, r, s, v, k, log = FALSE)"},{"path":"http://merliseclyde.github.io/BAS/reference/trCCH.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Truncated Compound Confluent Hypergeometric function — trCCH","text":"> 0 b b > 0 r r >= 0 s arbitrary v 0 < v k arbitrary log logical indicating whether return values log scale; useful Bayes Factor calculations","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/trCCH.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Truncated Compound Confluent Hypergeometric function — trCCH","text":"tr.cch(,b,r,s,v,k) = Int_0^1/v u^(-1) (1 - vu)^(b -1) (k + (1 - k)vu)^(-r) exp(-s u) du uses stable method calculating normalizing constant using R's `integrate` function rather version Gordy 1998. calculating Bayes factors use `trCCH` function recommend using `log=TRUE` option compute log Bayes factors.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/trCCH.html","id":"references","dir":"Reference","previous_headings":"","what":"References","title":"Truncated Compound Confluent Hypergeometric function — trCCH","text":"Gordy 1998 Li & Clyde 2018","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/trCCH.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Truncated Compound Confluent Hypergeometric function — trCCH","text":"Merlise Clyde (clyde@duke.edu)","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/trCCH.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Truncated Compound Confluent Hypergeometric function — trCCH","text":"","code":"# special cases # trCCH(a, b, r, s=0, v = 1, k) is the same as # 2F1(a, r, a + b, 1 - 1/k)*beta(a, b)/k^r k = 10; a = 1.5; b = 2; r = 2; trCCH(a, b, r, s=0, v = 1, k=k) *k^r/beta(a,b) #> [1] 4.74679 hypergeometric2F1(a, r, a + b, 1 - 1/k, log = FALSE) #> [1] 4.746772 # trCCH(a,b,0,s,1,1) is the same as # beta(a, b) 1F1(a, a + b, -s, log=FALSE) s = 3; r = 0; v = 1; k = 1 beta(a, b)*hypergeometric1F1(a, a+b, -s, log = FALSE) #> [1] 0.0923551 trCCH(a, b, r, s, v, k) #> [1] 0.09235518 # Equivalence with the Phi1 function a = 1.5; b = 3; k = 1.25; s = 400; r = 2; v = 1; phi1(a, r, a + b, -s, 1 - 1/k, log=FALSE)*(k^-r)*gamma(a)*gamma(b)/gamma(a+b) #> [1] 7.04733e-05 trCCH(a,b,r,s,v,k) #> [1] 7.052186e-05"},{"path":"http://merliseclyde.github.io/BAS/reference/uniform.html","id":null,"dir":"Reference","previous_headings":"","what":"Uniform Prior Distribution for Models — uniform","title":"Uniform Prior Distribution for Models — uniform","text":"Creates object representing prior distribution models BAS.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/uniform.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Uniform Prior Distribution for Models — uniform","text":"","code":"uniform()"},{"path":"http://merliseclyde.github.io/BAS/reference/uniform.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Uniform Prior Distribution for Models — uniform","text":"returns object class \"prior\", family name Uniform.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/uniform.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Uniform Prior Distribution for Models — uniform","text":"Uniform prior distribution commonly used prior BMA, special case independent Bernoulli prior probs=.5. implied prior distribution model size binomial(p, .5).","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/uniform.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Uniform Prior Distribution for Models — uniform","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/uniform.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Uniform Prior Distribution for Models — uniform","text":"","code":"uniform() #> $family #> [1] \"Uniform\" #> #> $hyper.parameters #> [1] 0.5 #> #> attr(,\"class\") #> [1] \"prior\""},{"path":"http://merliseclyde.github.io/BAS/reference/update.html","id":null,"dir":"Reference","previous_headings":"","what":"Update BAS object using a new prior — update.bas","title":"Update BAS object using a new prior — update.bas","text":"Update BMA object using new prior distribution coefficients.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/update.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Update BAS object using a new prior — update.bas","text":"","code":"# S3 method for bas update(object, newprior, alpha = NULL, ...)"},{"path":"http://merliseclyde.github.io/BAS/reference/update.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Update BAS object using a new prior — update.bas","text":"object BMA object update newprior Update posterior model probabilities, probne0, shrinkage, logmarg, etc, using prior based newprior. See bas available methods alpha optional new value hyperparameter prior method ... optional arguments","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/update.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Update BAS object using a new prior — update.bas","text":"new object class BMA","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/update.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Update BAS object using a new prior — update.bas","text":"Recomputes marginal likelihoods new methods models already sampled current object.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/update.html","id":"references","dir":"Reference","previous_headings":"","what":"References","title":"Update BAS object using a new prior — update.bas","text":"Clyde, M. Ghosh, J. Littman, M. (2010) Bayesian Adaptive Sampling Variable Selection Model Averaging. Journal Computational Graphics Statistics. 20:80-101 doi:10.1198/jcgs.2010.09049","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/update.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Update BAS object using a new prior — update.bas","text":"Merlise Clyde clyde@stat.duke.edu","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/update.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Update BAS object using a new prior — update.bas","text":"","code":"# \\donttest{ library(MASS) data(UScrime) UScrime[,-2] <- log(UScrime[,-2]) crime.bic <- bas.lm(y ~ ., data=UScrime, n.models=2^10, prior=\"BIC\",initprobs= \"eplogp\") crime.ebg <- update(crime.bic, newprior=\"EB-global\") crime.zs <- update(crime.bic, newprior=\"ZS-null\") # }"},{"path":"http://merliseclyde.github.io/BAS/reference/variable.names.pred.bas.html","id":null,"dir":"Reference","previous_headings":"","what":"Extract the variable names for a model from a BAS prediction object — variable.names.pred.bas","title":"Extract the variable names for a model from a BAS prediction object — variable.names.pred.bas","text":"S3 method class 'pred.bas'. Simple utility function extract variable names. Used print names selected models using estimators 'HPM', 'MPM' 'BPM\". selected model created predict BAS objects.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/variable.names.pred.bas.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Extract the variable names for a model from a BAS prediction object — variable.names.pred.bas","text":"","code":"# S3 method for pred.bas variable.names(object, ...)"},{"path":"http://merliseclyde.github.io/BAS/reference/variable.names.pred.bas.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Extract the variable names for a model from a BAS prediction object — variable.names.pred.bas","text":"object BAS object created predict BAS `bas.lm` `bas.glm` object ... arguments pass ","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/variable.names.pred.bas.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Extract the variable names for a model from a BAS prediction object — variable.names.pred.bas","text":"character vector names variables included selected model; case 'BMA' variables","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/variable.names.pred.bas.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Extract the variable names for a model from a BAS prediction object — variable.names.pred.bas","text":"","code":"data(Hald) hald.gprior = bas.lm(Y~ ., data=Hald, prior=\"ZS-null\", modelprior=uniform()) hald.bpm = predict(hald.gprior, newdata=Hald[1,], se.fit=TRUE, estimator=\"BPM\") variable.names(hald.bpm) #> [1] \"Intercept\" \"X2\""},{"path":"http://merliseclyde.github.io/BAS/reference/which.matrix.html","id":null,"dir":"Reference","previous_headings":"","what":"Coerce a BAS list object of models into a matrix. — which.matrix","title":"Coerce a BAS list object of models into a matrix. — which.matrix","text":"function coerces list object models matrix fill zeros facilitate computations.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/which.matrix.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Coerce a BAS list object of models into a matrix. — which.matrix","text":"","code":"which.matrix(which, n.vars)"},{"path":"http://merliseclyde.github.io/BAS/reference/which.matrix.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Coerce a BAS list object of models into a matrix. — which.matrix","text":"'bas' model object x$n.vars total number predictors, x$n.vars","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/which.matrix.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Coerce a BAS list object of models into a matrix. — which.matrix","text":"matrix representation x$, number rows equal length .models total number models number columns x$n.vars","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/which.matrix.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Coerce a BAS list object of models into a matrix. — which.matrix","text":".matrix coerces x$matrix.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/which.matrix.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Coerce a BAS list object of models into a matrix. — which.matrix","text":"Merlise Clyde clyde@duke.edu","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/which.matrix.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Coerce a BAS list object of models into a matrix. — which.matrix","text":"","code":"data(Hald) Hald.bic <- bas.lm(Y ~ ., data=Hald, prior=\"BIC\", initprobs=\"eplogp\") # matrix of model indicators models <- which.matrix(Hald.bic$which, Hald.bic$n.vars)"},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-development-version","dir":"Changelog","previous_headings":"","what":"BAS (development version)","title":"BAS (development version)","text":"added unit tests link functions implemented family.c","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-171","dir":"Changelog","previous_headings":"","what":"BAS 1.7.1","title":"BAS 1.7.1","text":"CRAN release: 2023-12-06","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"minor-improvements-and-fixes-1-7-1","dir":"Changelog","previous_headings":"","what":"Minor Improvements and Fixes","title":"BAS 1.7.1","text":"Initialized vector se via memset disp = 1.0 fit_glm.c (issue #72) Initialized variables hyp1f1.c testthat (issue #75) Removed models zero prior probability bas.lm bas.glm (issue #74) Fixed error bayesglm.fit check arguments x y correct type calling C added unit test (issue #67)","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-166","dir":"Changelog","previous_headings":"","what":"BAS 1.6.6","title":"BAS 1.6.6","text":"CRAN release: 2023-11-28","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"new-features-1-6-6","dir":"Changelog","previous_headings":"","what":"New Features","title":"BAS 1.6.6","text":"Added support Gamma regression bas.glm, unit tests example (Code contributed @betsyberrson) added error supplied initial model bas.lm sampling methods “MCMC” “MCMC+BAS” prior probability zero. fixed printing problems identified via checks fixed indexing error bas.lm method = \"MCMC+BAS\" bas.lm using method = \"MCMC+BAS\" crashed segmentation fault bestmodel NULL null model. GitHub issue #69 fixed error predict.bas se.fit=TRUE one predictor. GitHub issue #68 reported @AleCarminati added unit test test-predict.R Fixed error coef bas.glm objects using betaprior class IC, including AIC BIC Github issue #65 Fixed error using Jeffreys prior bas.glm include.always option added unit test test-bas-glm.R. Github issue #61 Fixed error extracting coefficients median probability model formula passed object rather literal, added unit test test-coefficients.R Github issues #39 #56","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-164","dir":"Changelog","previous_headings":"","what":"BAS 1.6.4","title":"BAS 1.6.4","text":"CRAN release: 2022-11-02","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"changes-1-6-4","dir":"Changelog","previous_headings":"","what":"Changes","title":"BAS 1.6.4","text":"skipped test CRAN fails show warning non full rank case pivot=FALSE bas.lm default uses pivoting documentation indicates pivot=FALSE used full rank case users encounter issue practice. Users continue see warning NA’s returned, aware platforms may produce warning (M1mac). Github issue #62","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-163","dir":"Changelog","previous_headings":"","what":"BAS 1.6.3","title":"BAS 1.6.3","text":"CRAN release: 2022-10-19","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"changes-1-6-3","dir":"Changelog","previous_headings":"","what":"Changes","title":"BAS 1.6.3","text":"Added checks unit-tests see modelprior class ‘prior’ resolving Github Issue #57 Removed polevl.c, psi.c gamma.c Cephes longer used switching R’s internal functions","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-162","dir":"Changelog","previous_headings":"","what":"BAS 1.6.2","title":"BAS 1.6.2","text":"CRAN release: 2022-04-26 replaced deprecated DOUBLE_EPS DBL_EPSILON R 4.2.0 release (two places) restore CRAN","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"changes-1-6-1","dir":"Changelog","previous_headings":"","what":"Changes","title":"BAS 1.6.1","text":"replaced deprecated DOUBLE_EPS DBL_EPSILON R 4.2.0 release fixed warnings CRAN checks R devel (use | class) added function trCCH uses integration compute normalizing constant Truncated Compound Confluent Hypergeometric distribution provides correct normalizing constant Gordy (1998) stable large values compared current phi1 function. now used TCCH prior bas.glm. Rewrote phi1 function use direct numerical integration (phi1_int) Wald statistic large marginal likelihoods NA suggested Daniel Heeman Alexander Ly (see ). improve stability estimates Bayes Factors model probabilities bas.glm used HyperTwo function, including coefficient priors hyper.g.n(), robust(), intrinsic(). Added additional unit tests. Added thin option bas.glm added unit tests examples show connections special functions trCCH, phi1, 1F1 2F1","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bug-fixes-1-6-1","dir":"Changelog","previous_headings":"","what":"Bug Fixes","title":"BAS 1.6.1","text":"added internal function phi1_int original HyperTwo function returns NA Issue #55 See details . corrected shrinkage estimate CCH prior include terms involving beta function.","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-160","dir":"Changelog","previous_headings":"","what":"BAS 1.6.0","title":"BAS 1.6.0","text":"CRAN release: 2021-11-12","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"changes-1-6-0","dir":"Changelog","previous_headings":"","what":"Changes","title":"BAS 1.6.0","text":"update FORTRAN code compliant USE_FC_LEN_T character strings","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bug-fixes-1-6-0","dir":"Changelog","previous_headings":"","what":"Bug Fixes","title":"BAS 1.6.0","text":"fixed warning src code log_laplace_F21 uninitialized variable leading NaN returned R function hypergeometric2F1","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-155","dir":"Changelog","previous_headings":"","what":"BAS 1.5.5","title":"BAS 1.5.5","text":"CRAN release: 2020-01-24","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"changes-1-5-5","dir":"Changelog","previous_headings":"","what":"Changes","title":"BAS 1.5.5","text":"Fixed WARNING fedora-clang-devel. Added climate.dat file package building vignette package violate CRAN’s policy accessing internet resources permanent file location/url changes locally. Fixed testthat errors Solaris. Default settings force.heredity set back FALSE bas.lm bas.glm methods work platforms. Solaris, users wish impose force.heredity constraint may use post-processing function.","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-154","dir":"Changelog","previous_headings":"","what":"BAS 1.5.4","title":"BAS 1.5.4","text":"CRAN release: 2020-01-19","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"features-1-5-4","dir":"Changelog","previous_headings":"","what":"Features","title":"BAS 1.5.4","text":"Modified prior probabilities adjust number variables always included using include.always. Pull request #41 Don van de Bergh. Issue #40","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bug-fixes-1-5-4","dir":"Changelog","previous_headings":"","what":"Bug Fixes","title":"BAS 1.5.4","text":"Fixed valgrind error src/ZS_approx_null_np.c invalid write noted CRAN checks fixed function declaration type-mismatch argument errors identified LTO noted CRAN checks Added contrast=NULL argument bas.lm bas.glm non-NULL contrasts trigger warning model.matrix R 3.6.0. Bug #44 Added check sample size equal zero due subsetting missing data Bug #37","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"other-1-5-4","dir":"Changelog","previous_headings":"","what":"Other","title":"BAS 1.5.4","text":"Put ORCID quotes author list (per R-dev changes)","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-153","dir":"Changelog","previous_headings":"","what":"BAS 1.5.3","title":"BAS 1.5.3","text":"CRAN release: 2018-10-30","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bug-fixes-1-5-3","dir":"Changelog","previous_headings":"","what":"Bug Fixes","title":"BAS 1.5.3","text":"Fixed errors identified cran checks https://cran.r-project.org/web/checks/check_results_BAS.html initialize R2_m = 0.0 lm_mcmcbas.c (lead NA’s clang debian fedora ) switch default pivot = TRUE bas.lm, adding tol argument control tolerance cholregpovot improved stability across platforms singular nearly singular designs. valgrind messages: Conditional jump move depends uninitialized value(s). Initialize vectors allocated via R_alloc lm_deterministic.c glm_deterministic.c.","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-152","dir":"Changelog","previous_headings":"","what":"BAS 1.5.2","title":"BAS 1.5.2","text":"CRAN release: 2018-10-25","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"features-1-5-2","dir":"Changelog","previous_headings":"","what":"Features","title":"BAS 1.5.2","text":"Included option pivot=TRUE bas.lm fit models using pivoted Cholesky decomposition allow models rank-deficient. Enhancement #24 Bug #21. Currently coefficients -estimable set zero predict methods work . vector rank added output (see documentation bas.lm) degrees freedom methods assume uniform prior obtaining estimates (AIC BIC) adjusted use rank rather size. Added option force.heredity=TRUEto force lower order terms included higher order terms present (hierarchical constraint) method='MCMC' method='BAS' bas.lm bas.glm. Updated Vignette illustrate. enhancement #19. Checks see parents included using include.always pass issue #26. Added option drop.always.included image.bas variables always included may excluded image. default shown enhancement #23 Added option drop.always.included subset plot.bas variables always included may excluded plot showing marginal posterior inclusion probabilities (=4). default shown enhancement #23 update fitted.bas use predict code covers GLM LM cases type='link' type='response' Updates package CII Best Practices Badge certification Added Code Coverage support extensive tests using test_that.","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bugs-1-5-2","dir":"Changelog","previous_headings":"","what":"Bugs","title":"BAS 1.5.2","text":"fixed issue #36 Errors prior = “ZS-null” R2 finite range due model full rank. Change gexpectations function file bayesreg.c fixed issue #35 method=\"MCMC+BAS\" bas.glm glm_mcmcbas.c values provided MCMC.iterations n.models defaults used. Added unit test test-bas-glm.R fixed issue #34 bas.glm variables include.always marginal inclusion probabilities incorrect. Added unit test test-bas-glm.R fixed issue #33 Jeffreys prior marginal inclusion probabilities renormalized dropping intercept model fixed issue #32 allow vectorization phi1 function R/cch.R added unit test “tests/testthat/test-special-functions.R” fixed issue #31 coerce g REAL g.prior prior IC.prior bas.glm; added unit-test “tests/testthat/test-bas-glm.R” fixed issue #30 added n hyper-parameter NULL coerced REAL intrinsic prior bas.glm; added unit-test fixed issue #29 added n hyper-parameter NULL coerced REAL beta.prime prior bas.glm; added unit-test fixed issue #28 fixed length MCMC estimates marginal inclusion probabilities; added unit-test fixed issue #27 expected shrinkage JZS prior greater 1. Added unit test. fixed output include.always include intercept issue #26 always drop.always.included = TRUE drops intercept variables forced . include.always force.heredity=TRUE can now used together method=\"BAS\". added warning marginal likelihoods/posterior probabilities NA default model fitting method suggestion models rerun pivot = TRUE. uses modified Cholesky decomposition pivoting model rank deficient nearly singular dimensionality reduced. Bug #21. corrected count first model method='MCMC' lead potential model 0 probability errors image. coerced predicted values vector BMA (matrix) fixed size using method=deterministic bas.glm (updated) fixed problem confint horizontal=TRUE intervals point mass zero.","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"other-1-5-2","dir":"Changelog","previous_headings":"","what":"Other","title":"BAS 1.5.2","text":"suppress warning sampling probabilities 1 0 number models decrementedIssue #25 changed force.heredity.bas re-normalize prior probabilities rather use new prior probability based heredity constraints. future, add new priors models based heredity. See comment issue #26. Changed License GPL 3.0","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-151-june-6-2018","dir":"Changelog","previous_headings":"","what":"BAS 1.5.1 June 6, 2018","title":"BAS 1.5.1 June 6, 2018","text":"CRAN release: 2018-06-07","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"features-1-5-1","dir":"Changelog","previous_headings":"","what":"Features","title":"BAS 1.5.1 June 6, 2018","text":"added S3 method variable.names extract variable names highest probability model, median probability model, best probability model objects created predict.","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bugs-1-5-1","dir":"Changelog","previous_headings":"","what":"Bugs","title":"BAS 1.5.1 June 6, 2018","text":"Fixed incorrect documentation predict.basglm type = \"link\" default prediction issue #18","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-150-may-2-2018","dir":"Changelog","previous_headings":"","what":"BAS 1.5.0 May 2, 2018","title":"BAS 1.5.0 May 2, 2018","text":"CRAN release: 2018-05-03","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"features-1-5-0","dir":"Changelog","previous_headings":"","what":"Features","title":"BAS 1.5.0 May 2, 2018","text":"add na.action handling NA’s predict methods issue #10 added include.always new argument bas.lm. allows formula specify terms always included models. default intercept always included. added section vignette illustrate weighted regression force.heredity.bas function group levels factor enter leave model together.","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bugs-1-5-0","dir":"Changelog","previous_headings":"","what":"Bugs","title":"BAS 1.5.0 May 2, 2018","text":"fixed problem one model image function; github issue #11 fixed error bas.lm non-equal weights R2 incorrect. issue #17 ## Deprecated deprecate predict argument predict.bas, predict.basglm internal functions utilized","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-149-march-24-2018","dir":"Changelog","previous_headings":"","what":"BAS 1.4.9 March 24, 2018","title":"BAS 1.4.9 March 24, 2018","text":"CRAN release: 2018-03-25","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bugs-1-4-9","dir":"Changelog","previous_headings":"","what":"Bugs","title":"BAS 1.4.9 March 24, 2018","text":"fixed bug confint.coef.bas parm character string added parentheses betafamily.c line 382 indicated CRAN check R devel","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"features-1-4-9","dir":"Changelog","previous_headings":"","what":"Features","title":"BAS 1.4.9 March 24, 2018","text":"added option determine k Bayes.outlier prior probability outliers provided","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-148-march-10-2018","dir":"Changelog","previous_headings":"","what":"BAS 1.4.8 March 10, 2018","title":"BAS 1.4.8 March 10, 2018","text":"CRAN release: 2018-03-12","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bugs-1-4-8","dir":"Changelog","previous_headings":"","what":"Bugs","title":"BAS 1.4.8 March 10, 2018","text":"fixed issue scoping eval data predict.bas dataname defined local env. fixed issue 10 github (predict estimator=‘BPM’ failed NA’s X data. Delete NA’s finding closest model. fixed bug ‘JZS’ prior - merged pull request #12 vandenman/master fixed bug bas.glm default betaprior (CCH) used inputs INTEGER instead REAL removed warning use ‘ZS-null’ backwards compatibility","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"features-added-1-4-8","dir":"Changelog","previous_headings":"","what":"Features added","title":"BAS 1.4.8 March 10, 2018","text":"updated print.bas reflect changes print.lm Added Bayes.outlier function calculate posterior probabilities outliers using method Chaloner & Brant linear models.","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-147-october-22-2017","dir":"Changelog","previous_headings":"","what":"BAS 1.4.7 October 22, 2017","title":"BAS 1.4.7 October 22, 2017","text":"CRAN release: 2017-10-22","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"updates-1-4-7","dir":"Changelog","previous_headings":"","what":"Updates","title":"BAS 1.4.7 October 22, 2017","text":"Added new method bas.lm obtain marginal likelihoods Zellner-Siow Priors “prior= ‘JZS’ using QUADPATH routines numerical integration. optional hyper parameter alpha may now used adjust scaling ZS prior g ~ G(1/2, alpha*n/2) BayesFactor package Morey, default alpha=1 corresponding ZS prior used Liang et al (2008). also uses stable evaluations log(1 + x) prevent underflow/overflow. Priors ZS-full bas.lm planned deprecated. replaced math functions use portable C code Rmath consolidated header files","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-146-may-24-2017","dir":"Changelog","previous_headings":"","what":"BAS 1.4.6 May 24, 2017","title":"BAS 1.4.6 May 24, 2017","text":"CRAN release: 2017-05-26","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"updates-1-4-6","dir":"Changelog","previous_headings":"","what":"Updates","title":"BAS 1.4.6 May 24, 2017","text":"Added force.heredity.interaction function allow higher order interactions included “parents” lower order interactions main effects included. Currently tested two way interactions. implemented post-sampling; future updates add sampling stage reduce memory usage sampling times reducing number models consideration.","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bugs-1-4-6","dir":"Changelog","previous_headings":"","what":"Bugs","title":"BAS 1.4.6 May 24, 2017","text":"Fixed unprotected ANS C code glm_sampleworep.c sampleworep.c call PutRNGstate possible stack imbalance glm_mcmc. Fixed problem predict estimator=BPM newdata one row","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-145-march-28-2017","dir":"Changelog","previous_headings":"","what":"BAS 1.4.5 March 28, 2017","title":"BAS 1.4.5 March 28, 2017","text":"CRAN release: 2017-03-31","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bugs-1-4-5","dir":"Changelog","previous_headings":"","what":"Bugs","title":"BAS 1.4.5 March 28, 2017","text":"Fixed non-conformable error predict new data dataframe one row. Fixed problem missing weights prediction using median probability model new data.","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-144-march-14-2017","dir":"Changelog","previous_headings":"","what":"BAS 1.4.4 March 14, 2017","title":"BAS 1.4.4 March 14, 2017","text":"CRAN release: 2017-03-14","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"updates-1-4-4","dir":"Changelog","previous_headings":"","what":"Updates","title":"BAS 1.4.4 March 14, 2017","text":"Extract coefficient summaries, credible intervals plots HPM MPM addition default BMA adding new estimator argument coef function. new n.models argument coef provides summaries based top n.models highest probability models reduce computation time. ‘n.models = 1’ equivalent highest probability model. use newdata vector now deprecated predict.bas; newdata must dataframe missing, case fitted values based dataframe used fitting used factor levels handled lm glm prediction may level factor newdata","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bugs-1-4-4","dir":"Changelog","previous_headings":"","what":"Bugs","title":"BAS 1.4.4 March 14, 2017","text":"fixed issue prediction newdata just one row fixed missing id plot.bas =3","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-143-february-18-2017","dir":"Changelog","previous_headings":"","what":"BAS 1.4.3 February 18, 2017","title":"BAS 1.4.3 February 18, 2017","text":"CRAN release: 2017-02-21","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"updates-1-4-3","dir":"Changelog","previous_headings":"","what":"Updates","title":"BAS 1.4.3 February 18, 2017","text":"Register symbols foreign function calls bin2int now deprecated fixed default MCMC.iteration bas.lm agree documentation updated vignette include examples, outlier detection, finding best predictive probability model set flag MCMC sampling renormalize selects whether Monte Carlo frequencies used estimate posterior model marginal inclusion probabilities (default renormalize = FALSE) marginal likelihoods time prior probabilities renormalized sum 1 used. (latter option methods); new slots probne0.MCMC, probne0.RN, postprobs.RN postprobs.MCMC.","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bug-fixes-1-4-3","dir":"Changelog","previous_headings":"","what":"Bug fixes","title":"BAS 1.4.3 February 18, 2017","text":"fixed problem prior.bic, robust, hyper.g.n default missing n set hyperparameters fixed error predict plot GLMs family provided function","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-142-october-12-2016","dir":"Changelog","previous_headings":"","what":"BAS 1.4.2 October 12, 2016","title":"BAS 1.4.2 October 12, 2016","text":"CRAN release: 2016-10-13","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"updates-1-4-2","dir":"Changelog","previous_headings":"","what":"Updates","title":"BAS 1.4.2 October 12, 2016","text":"added df object returned bas.glm simplify coefficients function.","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bug-fixes-1-4-2","dir":"Changelog","previous_headings":"","what":"Bug Fixes","title":"BAS 1.4.2 October 12, 2016","text":"corrected expected value shrinkage intrinsic, hyper-g/n TCCH priors glms","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-141-september-17-2016","dir":"Changelog","previous_headings":"","what":"BAS 1.4.1 September 17, 2016","title":"BAS 1.4.1 September 17, 2016","text":"CRAN release: 2016-09-20","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bug-fixes-1-4-1","dir":"Changelog","previous_headings":"","what":"Bug Fixes","title":"BAS 1.4.1 September 17, 2016","text":"modification 1.4.0 automatically handle NA’s led errors response transformed part formula; fixed","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"features-1-4-1","dir":"Changelog","previous_headings":"","what":"Features","title":"BAS 1.4.1 September 17, 2016","text":"added subset argument bas.lm bas.glm","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-140-august-25-2016","dir":"Changelog","previous_headings":"","what":"BAS 1.4.0 August 25, 2016","title":"BAS 1.4.0 August 25, 2016","text":"CRAN release: 2016-08-27","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"new-features-1-4-0","dir":"Changelog","previous_headings":"","what":"New features","title":"BAS 1.4.0 August 25, 2016","text":"added na.action bas.lm bas.glm omit missing data. new function plot credible intervals created confint.pred.bas confint.coef.bas. See help files example vignette. added se.fit option predict.basglm. Added testBF betaprior option bas.glm implement Bayes Factors based likelihood ratio statistic’s distribution GLMs. DOI version http://dx.doi.org/10.5281/zenodo.60948","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-130-july-15-2016","dir":"Changelog","previous_headings":"","what":"BAS 1.3.0 July 15, 2016","title":"BAS 1.3.0 July 15, 2016","text":"CRAN release: 2016-07-16","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"new-features-1-3-0","dir":"Changelog","previous_headings":"","what":"New Features","title":"BAS 1.3.0 July 15, 2016","text":"vignette added long last! illustrates several new features BAS new functions computing credible intervals fitted predicted values confint.pred.bas() new function adding credible intervals coefficients confint.coef.bas() added posterior standard deviations fitted values predicted values predict.bas()","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"deprecation-1-3-0","dir":"Changelog","previous_headings":"","what":"Deprecation","title":"BAS 1.3.0 July 15, 2016","text":"deprecated use type specify estimator fitted.bas replaced estimator predict() fitted() compatible S3 methods. updated functions class bas avoid NAMESPACE conflicts libraries","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-122-june-29-2016","dir":"Changelog","previous_headings":"","what":"BAS 1.2.2 June 29, 2016","title":"BAS 1.2.2 June 29, 2016","text":"CRAN release: 2016-07-01","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"new-features-1-2-2","dir":"Changelog","previous_headings":"","what":"New Features","title":"BAS 1.2.2 June 29, 2016","text":"added option find “Best Predictive Model” “BPM” fitted.bas predict.bas added local Empirical Bayes prior fixed g-prior bas.glm added diagnostic() function checking convergence bas objects created method = \"MCMC\"” added truncated power prior Yang, Wainwright & Jordan (2016)","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"minor-changes-1-2-2","dir":"Changelog","previous_headings":"","what":"Minor Changes","title":"BAS 1.2.2 June 29, 2016","text":"bug fix plot.bas appears Sweave bug fix coef.bma just one predictor","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-121-april-16-2016","dir":"Changelog","previous_headings":"","what":"BAS 1.2.1 April 16, 2016","title":"BAS 1.2.1 April 16, 2016","text":"CRAN release: 2016-04-16 bug fix method=“MCMC” truncated prior distributions MH ratio incorrect allowing models 0 probability sampled. fixed error Zellner-Siow prior (ZS-null) n=p+1 saturated model log marginal likelihood 0","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-120-april-11-2016","dir":"Changelog","previous_headings":"","what":"BAS 1.2.0 April 11, 2016","title":"BAS 1.2.0 April 11, 2016","text":"CRAN release: 2016-04-12 removed unsafe code Rbestmarg (input) overwritten .Call end corruption constant pool byte-code (Thanks Tomas Kalibera catching !) fixed issue dimensions use Simple Linear Regression","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-110-march-31-2016","dir":"Changelog","previous_headings":"","what":"BAS 1.1.0 March 31, 2016","title":"BAS 1.1.0 March 31, 2016","text":"CRAN release: 2016-03-31","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"new-features-1-1-0","dir":"Changelog","previous_headings":"","what":"New Features","title":"BAS 1.1.0 March 31, 2016","text":"added truncated Beta-Binomial prior truncated Poisson (works MCMC currently) improved code finding fitted values Median deprecated method = “AMCMC” issue warning message","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"minor-changes-1-1-0","dir":"Changelog","previous_headings":"","what":"Minor Changes","title":"BAS 1.1.0 March 31, 2016","text":"Changed S3 method plot image use class bas rather bma avoid name conflicts packages","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-109","dir":"Changelog","previous_headings":"","what":"BAS 1.09","title":"BAS 1.09","text":"","code":"- added weights for linear models - switched LINPACK calls in bayesreg to LAPACK finally should be faster - fixed bug in intercept calculation for glms - fixed inclusion probabilities to be a vector in the global EB methods for linear models"},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-108","dir":"Changelog","previous_headings":"","what":"BAS 1.08","title":"BAS 1.08","text":"","code":"- added intrinsic prior for GLMs - fixed problems for linear models for p > n and R2 not correct"},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-107","dir":"Changelog","previous_headings":"","what":"BAS 1.07","title":"BAS 1.07","text":"","code":"- added phi1 function from Gordy (1998) confluent hypergeometric function of two variables also known as one of the Horn hypergeometric functions or Humbert's phi1 - added Jeffrey's prior on g - added the general tCCH prior and special cases of the hyper-g/n. - TODO check shrinkage functions for all"},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-106","dir":"Changelog","previous_headings":"","what":"BAS 1.06","title":"BAS 1.06","text":"","code":"- new improved Laplace approximation for hypergeometric1F1 - added class basglm for predict - predict function now handles glm output - added dataframe option for newdata in predict.bas and predict.basglm - renamed coefficients in output to be 'mle' in bas.lm to be consistent across lm and glm versions so that predict methods can handle both cases. (This may lead to errors in other external code that expects object$ols or object$coefficients) - fixed bug with initprobs that did not include an intercept for bas.lm"},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-105","dir":"Changelog","previous_headings":"","what":"BAS 1.05","title":"BAS 1.05","text":"","code":"- added thinning option for MCMC method for bas.lm - returned posterior expected shrinkage for bas.glm - added option for initprobs = \"marg-eplogp\" for using marginal SLR models to create starting probabilities or order variables especially for p > n case - added standalone function for hypergeometric1F1 using Cephes library and a Laplace approximation -Added class \"BAS\" so that predict and fitted functions (S3 methods) are not masked by functions in the BVS package: to do modify the rest of the S3 methods."},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-104","dir":"Changelog","previous_headings":"","what":"BAS 1.04","title":"BAS 1.04","text":"","code":"- added bas.glm for model averaging/section using mixture of g-priors for GLMs. Currently limited to Logistic Regression - added Poisson family for glm.fit"},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-10","dir":"Changelog","previous_headings":"","what":"BAS 1.0","title":"BAS 1.0","text":"CRAN release: 2012-06-01","code":"- cleaned up MCMC method code"},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-093","dir":"Changelog","previous_headings":"","what":"BAS 0.93","title":"BAS 0.93","text":"","code":"- removed internal print statements in bayesglm.c - Bug fixes in AMCMC algorithm"},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-092","dir":"Changelog","previous_headings":"","what":"BAS 0.92","title":"BAS 0.92","text":"CRAN release: 2010-10-01","code":"- fixed glm-fit.R so that hyper parameter for BIC is numeric"},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-091","dir":"Changelog","previous_headings":"","what":"BAS 0.91","title":"BAS 0.91","text":"CRAN release: 2010-09-09","code":"- added new AMCMC algorithm"},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-091-1","dir":"Changelog","previous_headings":"","what":"BAS 0.91","title":"BAS 0.91","text":"CRAN release: 2010-09-09","code":"- bug fix in bayes.glm"},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-090","dir":"Changelog","previous_headings":"","what":"BAS 0.90","title":"BAS 0.90","text":"CRAN release: 2010-07-24","code":"- added C routines for fitting glms"},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-085","dir":"Changelog","previous_headings":"","what":"BAS 0.85","title":"BAS 0.85","text":"CRAN release: 2010-04-29 restricting n.models correct fitted values (broken version 0.80)","code":"- fixed problem with duplicate models if n.models was > 2^(p-1) by - save original X as part of object so that fitted.bma gives the"},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-080","dir":"Changelog","previous_headings":"","what":"BAS 0.80","title":"BAS 0.80","text":"CRAN release: 2010-04-06 shrinkage - changed predict.bma center newdata using mean(X) - Added new Adaptive MCMC option (method = “AMCMC”) (stable point)","code":"- Added `hypergeometric2F1` function that is callable by R - centered X's in bas.lm so that the intercept has the correct"},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-07","dir":"Changelog","previous_headings":"","what":"BAS 0.7","title":"BAS 0.7","text":"","code":"-Allowed pruning of model tree to eliminate rejected models"},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-06","dir":"Changelog","previous_headings":"","what":"BAS 0.6","title":"BAS 0.6","text":"","code":"- Added MCMC option to create starting values for BAS (`method = \"MCMC+BAS\"`)"},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-05","dir":"Changelog","previous_headings":"","what":"BAS 0.5","title":"BAS 0.5","text":"allocated within code","code":"-Cleaned up all .Call routines so that all objects are duplicated or"},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-045","dir":"Changelog","previous_headings":"","what":"BAS 0.45","title":"BAS 0.45","text":"CRAN release: 2009-12-30","code":"- fixed ch2inv that prevented building on Windows in bayes glm_fit"},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-04","dir":"Changelog","previous_headings":"","what":"BAS 0.4","title":"BAS 0.4","text":"CRAN release: 2009-12-28","code":"- fixed FORTRAN calls to use F77_NAME macro - changed allocation of objects for .Call to prevent some objects from being overwritten."},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-03","dir":"Changelog","previous_headings":"","what":"BAS 0.3","title":"BAS 0.3","text":"CRAN release: 2009-05-29","code":"- fixed EB.global function to include prior probabilities on models - fixed update function"},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-02","dir":"Changelog","previous_headings":"","what":"BAS 0.2","title":"BAS 0.2","text":"column ones intercept optionally included. - fixed help file predict - added modelprior argument bas.lm users may now use beta-binomial prior distribution model size addition default uniform distribution - added functions uniform(), beta-binomial() Bernoulli() create model prior objects - added vector user specified initial probabilities option argument initprobs bas.lm removed separate argument user.prob","code":"- fixed predict.bma to allow newdata to be a matrix or vector with the"}] +[{"path":[]},{"path":"http://merliseclyde.github.io/BAS/CODE_OF_CONDUCT.html","id":"our-pledge","dir":"","previous_headings":"","what":"Our Pledge","title":"Contributor Covenant Code of Conduct","text":"interest fostering open welcoming environment, contributors maintainers pledge making participation project community harassment-free experience everyone, regardless age, body size, disability, ethnicity, gender identity expression, level experience, nationality, personal appearance, race, religion, sexual identity orientation.","code":""},{"path":"http://merliseclyde.github.io/BAS/CODE_OF_CONDUCT.html","id":"our-standards","dir":"","previous_headings":"","what":"Our Standards","title":"Contributor Covenant Code of Conduct","text":"Examples behavior contributes creating positive environment include: Using welcoming inclusive language respectful differing viewpoints experiences Gracefully accepting constructive criticism Focusing best community Showing empathy towards community members Examples unacceptable behavior participants include: use sexualized language imagery unwelcome sexual attention advances Trolling, insulting/derogatory comments, personal political attacks Public private harassment Publishing others’ private information, physical electronic address, without explicit permission conduct reasonably considered inappropriate professional setting","code":""},{"path":"http://merliseclyde.github.io/BAS/CODE_OF_CONDUCT.html","id":"our-responsibilities","dir":"","previous_headings":"","what":"Our Responsibilities","title":"Contributor Covenant Code of Conduct","text":"Project maintainers responsible clarifying standards acceptable behavior expected take appropriate fair corrective action response instances unacceptable behavior. Project maintainers right responsibility remove, edit, reject comments, commits, code, wiki edits, issues, contributions aligned Code Conduct, ban temporarily permanently contributor behaviors deem inappropriate, threatening, offensive, harmful.","code":""},{"path":"http://merliseclyde.github.io/BAS/CODE_OF_CONDUCT.html","id":"scope","dir":"","previous_headings":"","what":"Scope","title":"Contributor Covenant Code of Conduct","text":"Code Conduct applies within project spaces public spaces individual representing project community. Examples representing project community include using official project e-mail address, posting via official social media account, acting appointed representative online offline event. Representation project may defined clarified project maintainers.","code":""},{"path":"http://merliseclyde.github.io/BAS/CODE_OF_CONDUCT.html","id":"enforcement","dir":"","previous_headings":"","what":"Enforcement","title":"Contributor Covenant Code of Conduct","text":"Instances abusive, harassing, otherwise unacceptable behavior may reported contacting project team clyde@duke.edu. project team review investigate complaints, respond way deems appropriate circumstances. project team obligated maintain confidentiality regard reporter incident. details specific enforcement policies may posted separately. Project maintainers follow enforce Code Conduct good faith may face temporary permanent repercussions determined members project’s leadership.","code":""},{"path":"http://merliseclyde.github.io/BAS/CODE_OF_CONDUCT.html","id":"attribution","dir":"","previous_headings":"","what":"Attribution","title":"Contributor Covenant Code of Conduct","text":"Code Conduct adapted Contributor Covenant, version 1.4, available http://contributor-covenant.org/version/1/4","code":""},{"path":"http://merliseclyde.github.io/BAS/CONTRIBUTING.html","id":null,"dir":"","previous_headings":"","what":"Contributing to BAS development","title":"Contributing to BAS development","text":"goal guide help contribute BAS. guide divided three main pieces: Filing bug report feature request issue Github. Suggesting change via pull request. Coding Style Guide Contributions BAS","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/CONTRIBUTING.html","id":"feature-requests","dir":"","previous_headings":"Issues","what":"Feature Requests","title":"Contributing to BAS development","text":"wish easily extract additional information BAS objects ? like see new functionality available BAS? , feel free fill feature request! Please describe much detail like added. can anything just idea code advanced user!","code":""},{"path":"http://merliseclyde.github.io/BAS/CONTRIBUTING.html","id":"bug-reports","dir":"","previous_headings":"Issues","what":"Bug Reports","title":"Contributing to BAS development","text":"filing bug report issue, important thing include minimal reproducible example can quickly verify problem, figure fix . three things need include make example reproducible: required packages, data, code. Packages loaded top script, ’s easy see ones example needs. easiest way include data use dput() generate R code recreate . example, recreate mtcars dataset R, ’d perform following steps: Run dput(mtcars) R Copy output reproducible script, type mtcars <- paste. even better can create data.frame() just handful rows columns still illustrates problem. Spend little bit time ensuring code easy others read: make sure ’ve used spaces variable names concise, informative (OK using “.”, camel case “_” variable names improve readibility. details see Style Guide use comments indicate problem lies best remove everything related problem. shorter code , easier understand. can check actually made reproducible example starting fresh R session pasting script . (Unless ’ve specifically asked , please don’t include output sessionInfo().)","code":""},{"path":"http://merliseclyde.github.io/BAS/CONTRIBUTING.html","id":"other-issues","dir":"","previous_headings":"Issues","what":"Other issues","title":"Contributing to BAS development","text":"sure something bug undocumented feature, see possible errors help files documentation use clarification (issue) please file regular issue","code":""},{"path":"http://merliseclyde.github.io/BAS/CONTRIBUTING.html","id":"pull-requests","dir":"","previous_headings":"","what":"Pull requests","title":"Contributing to BAS development","text":"contribute change BAS, follow steps: Create branch git make changes, ideally using commit -s sign-commits Developer Certificate Origin. Make sure branch passes R CMD check. Push branch github issue pull request (PR). Discuss pull request. Iterate either accept PR decide ’s good fit BAS. steps described detail . might feel overwhelming first time get set , gets easier practice. get stuck point, please reach help. ’re familiar git github, please start reading http://r-pkgs..co.nz/git.html Pull requests evaluated following checklist: Motivation. pull request clearly concisely motivates need change. Please describe problem show pull request solves concisely possible. Also include motivation NEWS new release BAS comes ’s easy users see ’s changed. Add item top file use markdown formatting. news item end (@yourGithubUsername, #the_issue_number). related changes. submit pull request, please check make sure haven’t accidentally included unrelated changes. make harder see exactly ’s changed, evaluate unexpected side effects. PR corresponds git branch, expect submit multiple changes make sure create multiple branches. multiple changes depend , start first one don’t submit others first one processed. Document ’re adding new parameters new function, ’ll also need document roxygen. Please add short example appropriate function optionally package vignettes. Make sure re-run devtools::document() code submitting. (sure include name authors function!) Testing fixing bug adding new feature, add testthat unit test. seems like lot work don’t worry pull request isn’t perfect. ’s learning process hand help . pull request process, unless ’ve submitted past ’s unlikely pull request accepted . Please don’t submit pull requests change existing behaviour. Instead, think can add new feature minimally invasive way.","code":""},{"path":"http://merliseclyde.github.io/BAS/CONTRIBUTING.html","id":"style-guide-for-contributing-to-bas","dir":"","previous_headings":"","what":"Style Guide for Contributing to BAS","title":"Contributing to BAS development","text":"consistent style improves readibility code. wed particular style generally draw Google Style Guide well Hadley Wickham’s Style Guide noted . Using package styler enforce styling based TidyVerse helpful, required. Function Variable names: Use informative names using “.”, camel case, “_” improve readibility, .e. variable.name, VariableName variable_name, rather foo xxx. tend avoid _ historical reasons going back S. Assignment: Use either <- = assignment consistent within contribution. many style guides prefer <- suggest using styler enforce use <-, OK = shorter type! Just consistent within contributed code. Spaces: Include spaces around operators =, +, -, <-, == etc improve readibility. Put space comman, . : :: never spaces around . Additional spaces newlines fine improve readibilty code (e.g. aligmnent arguments). Comments: Comment code whenever can. Explain clear code. Use # start comment followed space capitalize first letter; short inline comments (comments line code) need two spaces # Curly Braces: opening curly brace never go line, closing curly brace go line. exception short conditional statement shuch else code may fit one line. Indentation: Use 2 spaces rather tabs per level indentation. Indent code inside curly braces. Semi-colons: use semi-colons put one statement line. Line Length: Use 80 characters per line code. RStudio setting display vertical line 80 characters visually assist . Turn going Tools -> Global Options… -> Code -> Display -> Show margin File names R code informative end .R. Use - improve readibility. include spaces file names! Contributing adopted ggplot2’s CONTRIBUTING.md","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/SECURITY.html","id":"supported-versions","dir":"","previous_headings":"","what":"Supported Versions","title":"Security Policy","text":"Supported security updates.","code":""},{"path":"http://merliseclyde.github.io/BAS/SECURITY.html","id":"reporting-a-vulnerability","dir":"","previous_headings":"","what":"Reporting a Vulnerability","title":"Security Policy","text":"Please submit vulnerability reports Github Issues maintainers address soon possibl","code":""},{"path":"http://merliseclyde.github.io/BAS/SECURITY.html","id":"expectations","dir":"","previous_headings":"","what":"Expectations","title":"Security Policy","text":"package utilizes C code efficiency allocates/frees memory. package checked memory leaks prior releases CRAN using ASAN/UBSBAN. package distributed via CRAN https://CRAN.R-project.org/package=bark reports additional checks. development version may installed GitHub https://github.com/merliseclyde/bark checked via github actions (users may check current version passing badge installing) Bugs reported via Issue tracker handled soon possible. (See link )","code":""},{"path":"http://merliseclyde.github.io/BAS/SECURITY.html","id":"assurance","dir":"","previous_headings":"","what":"Assurance","title":"Security Policy","text":"highly unlikely malicious code added package. submissions CRAN require verification via maintainer’s email, protected via two factor authentication. pull requests contributions github verified lead maintainer. Based Code Conduct Contributing Guidelines modifications include unit tests cover additional code blocks.","code":""},{"path":"http://merliseclyde.github.io/BAS/articles/BAS-vignette.html","id":"installing-bas","dir":"Articles","previous_headings":"","what":"Installing BAS","title":"Using the Bayesian Adaptive Sampling (BAS) Package for Bayesian Model Averaging and Variable Selection","text":"stable version can installed easily R console like package: hand, welcome everyone use recent version package quick-fixes, new features probably new bugs. get latest development version GitHub, use devtools package CRAN enter R: package depend BLAS LAPACK, installing GitHub require FORTRAN C compilers system.","code":"install.packages(\"BAS\") devtools::install_github(\"merliseclyde/BAS\")"},{"path":"http://merliseclyde.github.io/BAS/articles/BAS-vignette.html","id":"demo","dir":"Articles","previous_headings":"","what":"Demo","title":"Using the Bayesian Adaptive Sampling (BAS) Package for Bayesian Model Averaging and Variable Selection","text":"use UScrime data illustrate commands functionality. Following analyses, go ahead log transform variables except column 2, indicator variable state southern state. get started, use BAS Zellner-Siow Cauchy prior coefficients. BAS uses model formula similar lm specify full model potential predictors. using shorthand . indicate remaining variables data frame provided data argument. Different prior distributions regression coefficients may specified using prior argument, include “BIC” “AIC “g-prior” “hyper-g” “hyper-g-laplace” “hyper-g-n” “JZS” “ZS-null” “ZS-full” “EB-local” “EB-global” default Zellner-Siow prior, ZS-null, Bayes factors compared null model. newest prior option, “JZS”, also corresponds Zellner-Siow prior coefficients, uses numerical integration rather Laplace approximation obtain marginal likelihood models. default, BAS try enumerate models \\(p < 19\\) using default method=\"BAS\". prior distribution models uniform() distribution assigns equal probabilities models. last optional argument initprobs = eplogp provides way initialize sampling algorithm order variables tree structure represents model space BAS. eplogp option uses Bayes factor calibration p-values \\(-e p \\log(p)\\) provide approximation marginal inclusion probability coefficient predictor zero, using p-values full model. options initprobs include “marg-eplogp”” “uniform” numeric vector length p option “marg-eplogp” uses p-values \\(p\\) simple linear regressions (useful large p highly correlated variables). Since enumerating possible models options important method=\"deterministic\" may faster factors interactions model.","code":"data(UScrime, package = \"MASS\") UScrime[, -2] <- log(UScrime[, -2]) library(BAS) crime.ZS <- bas.lm(y ~ ., data = UScrime, prior = \"ZS-null\", modelprior = uniform(), initprobs = \"eplogp\", force.heredity = FALSE, pivot = TRUE )"},{"path":"http://merliseclyde.github.io/BAS/articles/BAS-vignette.html","id":"plots","dir":"Articles","previous_headings":"","what":"Plots","title":"Using the Bayesian Adaptive Sampling (BAS) Package for Bayesian Model Averaging and Variable Selection","text":"graphical summaries output may obtained plot function produces panel four plots. first plot residuals fitted values Bayesian Model Averaging. Ideally, model assumptions hold, see outliers non-constant variance. second plot shows cumulative probability models order sampled. plot indicates cumulative probability leveling additional model adds small increment cumulative probability, earlier, larger jumps corresponding discovering new high probability model. third plot shows dimension model (number regression coefficients including intercept) versus log marginal likelihood model. last plot shows marginal posterior inclusion probabilities (pip) covariates, marginal pips greater 0.5 shown red. variables pip > 0.5 correspond known median probability model. Variables high inclusion probabilities generally important explaining data prediction, marginal inclusion probabilities may small predictors highly correlated, similar p-values may large presence multicollinearity. Individual plots may obtained using option. BAS print summary methods defined objects class bas. Typing objects name returns summary marginal inclusion probabilities, summary function provides list top 5 models (terms posterior probability) zero-one indicators variable inclusion. columns summary Bayes factor model highest probability model (hence Bayes factor 1), posterior probabilities models, ordinary \\(R^2\\) models, dimension models (number coefficients including intercept) log marginal likelihood selected prior distribution.","code":"plot(crime.ZS, ask = F) plot(crime.ZS, which = 4, ask = FALSE, caption = \"\", sub.caption = \"\") crime.ZS ## ## Call: ## bas.lm(formula = y ~ ., data = UScrime, prior = \"ZS-null\", modelprior = uniform(), ## initprobs = \"eplogp\", force.heredity = FALSE, pivot = TRUE) ## ## ## Marginal Posterior Inclusion Probabilities: ## Intercept M So Ed Po1 Po2 LF ## 1.0000 0.8536 0.2737 0.9747 0.6652 0.4490 0.2022 ## M.F Pop NW U1 U2 GDP Ineq ## 0.2050 0.3696 0.6944 0.2526 0.6149 0.3601 0.9965 ## Prob Time ## 0.8992 0.3718 options(width = 80) summary(crime.ZS) ## P(B != 0 | Y) model 1 model 2 model 3 model 4 model 5 ## Intercept 1.0000000 1.00000 1.0000000 1.0000000 1.000000 1.0000000 ## M 0.8535720 1.00000 1.0000000 1.0000000 1.000000 1.0000000 ## So 0.2737083 0.00000 0.0000000 0.0000000 0.000000 0.0000000 ## Ed 0.9746605 1.00000 1.0000000 1.0000000 1.000000 1.0000000 ## Po1 0.6651553 1.00000 1.0000000 0.0000000 1.000000 1.0000000 ## Po2 0.4490097 0.00000 0.0000000 1.0000000 0.000000 0.0000000 ## LF 0.2022374 0.00000 0.0000000 0.0000000 0.000000 0.0000000 ## M.F 0.2049659 0.00000 0.0000000 0.0000000 0.000000 0.0000000 ## Pop 0.3696150 0.00000 0.0000000 0.0000000 1.000000 0.0000000 ## NW 0.6944069 1.00000 1.0000000 1.0000000 1.000000 0.0000000 ## U1 0.2525834 0.00000 0.0000000 0.0000000 0.000000 0.0000000 ## U2 0.6149388 1.00000 1.0000000 1.0000000 1.000000 1.0000000 ## GDP 0.3601179 0.00000 0.0000000 0.0000000 0.000000 0.0000000 ## Ineq 0.9965359 1.00000 1.0000000 1.0000000 1.000000 1.0000000 ## Prob 0.8991841 1.00000 1.0000000 1.0000000 1.000000 1.0000000 ## Time 0.3717976 1.00000 0.0000000 0.0000000 0.000000 0.0000000 ## BF NA 1.00000 0.9416178 0.6369712 0.594453 0.5301269 ## PostProbs NA 0.01820 0.0172000 0.0116000 0.010800 0.0097000 ## R2 NA 0.84200 0.8265000 0.8229000 0.837500 0.8046000 ## dim NA 9.00000 8.0000000 8.0000000 9.000000 7.0000000 ## logmarg NA 23.65111 23.5909572 23.2000822 23.130999 23.0164741"},{"path":"http://merliseclyde.github.io/BAS/articles/BAS-vignette.html","id":"visualization-of-the-model-space","dir":"Articles","previous_headings":"","what":"Visualization of the Model Space","title":"Using the Bayesian Adaptive Sampling (BAS) Package for Bayesian Model Averaging and Variable Selection","text":"see beyond first five models, can represent collection models via image plot. default shows top 20 models. image rows correspond variables intercept, labels variables y-axis. x-axis corresponds possible models. sorted posterior probability best left worst right rank top x-axis. column represents one 16 models. variables excluded model shown black column, variables included colored, color related log posterior probability. color column proportional log posterior probabilities (lower x-axis) model. log posterior probabilities actually scaled 0 corresponds lowest probability model top 20, values axis correspond log Bayes factors comparing model lowest probability model top 20 models. Models color similar log Bayes factors allows us view models clustered together Bayes Factors differences “worth bare mention”. plot indicates police expenditure two years enter model together, indication high correlation two variables.","code":"image(crime.ZS, rotate = F)"},{"path":"http://merliseclyde.github.io/BAS/articles/BAS-vignette.html","id":"posterior-distributions-of-coefficients","dir":"Articles","previous_headings":"","what":"Posterior Distributions of Coefficients","title":"Using the Bayesian Adaptive Sampling (BAS) Package for Bayesian Model Averaging and Variable Selection","text":"examine marginal distributions two coefficients police expenditures, can extract coefficients estimates standard deviations BMA. optional argument, n.models coef use top n.models BMA may computationally efficient large problems. Plots posterior distributions averaging models obtained using plot method bas coefficient object. vertical bar represents posterior probability coefficient 0 bell shaped curve represents density plausible values models coefficient non-zero. scaled height density non-zero values probability coefficient non-zero. Omitting subset argument provides marginal distributions. obtain credible intervals coefficients, BAS includes confint method create Highest Posterior Density intervals summaries coef. third column posterior mean. uses Monte Carlo sampling draw mixture model coefficient models sampled based posterior probabilities. can also plot via using parm argument select coefficients plot (intercept parm=1). estimation selection, BAS supports additional arguments via estimator. default estimator=\"BMA\" uses models n.models. options include estimation highest probability model median probability model variables excluded distributions point masses zero selection.","code":"coef.ZS <- coef(crime.ZS) plot(coef.ZS, subset = c(5:6), ask = F) confint(coef.ZS) ## 2.5% 97.5% beta ## Intercept 6.66770273 6.781702951 6.72493620 ## M 0.00000000 2.177381010 1.14359433 ## So -0.05485621 0.307111466 0.03547522 ## Ed 0.56732766 3.136097257 1.85848834 ## Po1 0.00000000 1.455247021 0.60067372 ## Po2 -0.25023581 1.433650732 0.31841766 ## LF -0.48970270 1.071017370 0.05933737 ## M.F -2.25829665 1.784670735 -0.02702786 ## Pop -0.12285039 0.008864886 -0.02248283 ## NW 0.00000000 0.166754621 0.06668437 ## U1 -0.52224407 0.353015104 -0.02456854 ## U2 0.00000000 0.665710068 0.20702927 ## GDP -0.04790262 1.171018509 0.20625063 ## Ineq 0.65578748 2.107592475 1.39012647 ## Prob -0.41394961 0.000000000 -0.21536203 ## Time -0.51467783 0.060187459 -0.08433479 ## attr(,\"Probability\") ## [1] 0.95 ## attr(,\"class\") ## [1] \"confint.bas\" plot(confint(coef.ZS, parm = 2:16)) ## NULL plot(confint(coef(crime.ZS, estimator = \"HPM\"))) ## NULL plot(confint(coef(crime.ZS, estimator = \"MPM\")))"},{"path":"http://merliseclyde.github.io/BAS/articles/BAS-vignette.html","id":"prediction","dir":"Articles","previous_headings":"","what":"Prediction","title":"Using the Bayesian Adaptive Sampling (BAS) Package for Bayesian Model Averaging and Variable Selection","text":"BAS methods defined return fitted values, fitted, using observed design matrix predictions either observed data potentially new values, predict, lm. Plotting two sets fitted values, see perfect agreement. always case posterior mean regression mean function point \\(x\\) expected posterior predictive value \\(Y\\) \\(x\\). true estimators BMA, expected values model selection.","code":"muhat.BMA <- fitted(crime.ZS, estimator = \"BMA\") BMA <- predict(crime.ZS, estimator = \"BMA\") # predict has additional slots for fitted values under BMA, predictions under each model names(BMA) ## [1] \"fit\" \"Ybma\" \"Ypred\" \"postprobs\" \"se.fit\" ## [6] \"se.pred\" \"se.bma.fit\" \"se.bma.pred\" \"df\" \"best\" ## [11] \"bestmodel\" \"best.vars\" \"estimator\" par(mar = c(9, 9, 3, 3)) plot(muhat.BMA, BMA$fit, pch = 16, xlab = expression(hat(mu[i])), ylab = expression(hat(Y[i])) ) abline(0, 1)"},{"path":"http://merliseclyde.github.io/BAS/articles/BAS-vignette.html","id":"inference-with-model-selection","dir":"Articles","previous_headings":"Prediction","what":"Inference with model selection","title":"Using the Bayesian Adaptive Sampling (BAS) Package for Bayesian Model Averaging and Variable Selection","text":"addition using BMA, can use posterior means model selection. corresponds decision rule combines estimation selection. BAS currently implements following options highest probability model: little interpretable version names: median probability model: model predictors inclusion probability greater equal 0.5. coincides HPM predictors mutually orthogonal, case best predictive model squared error loss. Note can also extract best model attribute fitted values well. best predictive model: general, HPM MPM best predictive models, Bayesian decision theory perspective model closest BMA predictions squared error loss. Let’s see compare: Using se.fit = TRUE option predict can also calculate standard deviations prediction mean use input confint function prediction object. prediction new points, can supply new dataframe predict function lm.","code":"HPM <- predict(crime.ZS, estimator = \"HPM\") # show the indices of variables in the best model where 0 is the intercept HPM$bestmodel ## [1] 0 1 3 4 9 11 13 14 15 variable.names(HPM) ## [1] \"Intercept\" \"M\" \"Ed\" \"Po1\" \"NW\" \"U2\" ## [7] \"Ineq\" \"Prob\" \"Time\" MPM <- predict(crime.ZS, estimator = \"MPM\") variable.names(MPM) ## [1] \"Intercept\" \"M\" \"Ed\" \"Po1\" \"NW\" \"U2\" ## [7] \"Ineq\" \"Prob\" BPM <- predict(crime.ZS, estimator = \"BPM\") variable.names(BPM) ## [1] \"Intercept\" \"M\" \"So\" \"Ed\" \"Po1\" \"Po2\" ## [7] \"M.F\" \"NW\" \"U2\" \"Ineq\" \"Prob\" GGally::ggpairs(data.frame( HPM = as.vector(HPM$fit), # this used predict so we need to extract fitted values MPM = as.vector(MPM$fit), # this used fitted BPM = as.vector(BPM$fit), # this used fitted BMA = as.vector(BMA$fit) )) # this used predict BPM <- predict(crime.ZS, estimator = \"BPM\", se.fit = TRUE) crime.conf.fit <- confint(BPM, parm = \"mean\") crime.conf.pred <- confint(BPM, parm = \"pred\") plot(crime.conf.fit) ## NULL plot(crime.conf.pred) ## NULL new.pred <- predict(crime.ZS, newdata = UScrime, estimator = \"MPM\")"},{"path":"http://merliseclyde.github.io/BAS/articles/BAS-vignette.html","id":"alternative-algorithms","dir":"Articles","previous_headings":"","what":"Alternative algorithms","title":"Using the Bayesian Adaptive Sampling (BAS) Package for Bayesian Model Averaging and Variable Selection","text":"BAS several options sampling model space without enumeration. (current) default method=\"BAS\" samples models without replacement using estimates marginal inclusion probabilities using algorithm described Clyde et al (2011). initial sampling probabilities provided initprobs updated based sampled models, every update iterations. can efficient cases large fraction model space sampled, however, cases high correlation large number predictors, can lead biased estimates Clyde Ghosh (2012), case MCMC preferred. method=\"MCMC\" described better large \\(p\\). deterministic sampling scheme also available enumeration; faster enumeration default method=“BAS”.","code":"system.time( for (i in 1:10) { crime.ZS <- bas.lm(y ~ ., data = UScrime, prior = \"ZS-null\", method = \"BAS\", modelprior = uniform(), initprobs = \"eplogp\" ) } ) ## user system elapsed ## 1.391 0.000 1.390 system.time( for (i in 1:10) { crime.ZS <- bas.lm(y ~ ., data = UScrime, prior = \"ZS-null\", method = \"deterministic\", modelprior = uniform(), initprobs = \"eplogp\" ) } ) ## user system elapsed ## 1.215 0.000 1.215"},{"path":"http://merliseclyde.github.io/BAS/articles/BAS-vignette.html","id":"beyond-enumeration","dir":"Articles","previous_headings":"","what":"Beyond Enumeration","title":"Using the Bayesian Adaptive Sampling (BAS) Package for Bayesian Model Averaging and Variable Selection","text":"Many problems large enumerate possible models. cases may use method=\"BAS\" sample without replacement method=\"MCMC\" option sample models using Markov Chain Monte Carlo sampling sample models based posterior probabilities. spaces number models greatly exceeds number models sample, MCMC option recommended provides estimates low bias compared sampling without replacement BAS (Clyde Ghosh 2011). run MCMC sampler number unique sampled models exceeds n.models \\(2^p\\) (\\(p < 19\\)) default MCMC.iterations exceeded, MCMC.iterations = n.models*2 default.","code":"crime.ZS <- bas.lm(y ~ ., data = UScrime, prior = \"ZS-null\", modelprior = uniform(), method = \"MCMC\" )"},{"path":"http://merliseclyde.github.io/BAS/articles/BAS-vignette.html","id":"estimates-of-marginal-posterior-inclusion-probabilities-pip","dir":"Articles","previous_headings":"Beyond Enumeration","what":"Estimates of Marginal Posterior Inclusion Probabilities (pip)","title":"Using the Bayesian Adaptive Sampling (BAS) Package for Bayesian Model Averaging and Variable Selection","text":"MCMC sampling two estimates marginal inclusion probabilities: object$probne0 obtained using re-normalized posterior odds sampled models estimate probabilities estimates based Monte Carlo frequencies object$probs.MCMC. close agreement MCMC sampler run enough iterations. BAS includes diagnostic function compare two sets estimates posterior inclusion probabilities posterior model probabilities left hand plot pips, point represents one posterior inclusion probability 15 variables estimated two methods. two estimators pretty close agreement. plot model probabilities suggests use MCMC.iterations want accurate estimates posterior model probabilities.","code":"diagnostics(crime.ZS, type = \"pip\", pch = 16) diagnostics(crime.ZS, type = \"model\", pch = 16) crime.ZS <- bas.lm(y ~ ., data = UScrime, prior = \"ZS-null\", modelprior = uniform(), method = \"MCMC\", MCMC.iterations = 10^6 ) diagnostics(crime.ZS, type=\"model\", pch=16)"},{"path":"http://merliseclyde.github.io/BAS/articles/BAS-vignette.html","id":"outliers","dir":"Articles","previous_headings":"","what":"Outliers","title":"Using the Bayesian Adaptive Sampling (BAS) Package for Bayesian Model Averaging and Variable Selection","text":"BAS can also used exploring mean shift variance inflation outliers adding indicator variables case outlier (mean given regression) . similar MC3.REG function BMA, although using g-prior mixture g-priors coefficients outlier means. Using Stackloss data, can add identify matrix original dataframe, column indicator ith variable outlier. call introduces using truncated prior distributions model space; case distribution number variables included Poisson distribution, mean 4 (truncation), truncation point 10, models 10 (one half cases rounded ) probability zero. avoids exploration models full rank. Looking summaries","code":"data(\"stackloss\") stackloss <- cbind(stackloss, diag(nrow(stackloss))) stack.bas <- bas.lm(stack.loss ~ ., data = stackloss, method = \"MCMC\", initprobs = \"marg-eplogp\", prior = \"ZS-null\", modelprior = tr.poisson(4, 10), MCMC.iterations = 200000 ) knitr::kable(as.data.frame(summary(stack.bas)))"},{"path":"http://merliseclyde.github.io/BAS/articles/BAS-vignette.html","id":"factors-and-hierarchical-heredity","dir":"Articles","previous_headings":"","what":"Factors and Hierarchical Heredity","title":"Using the Bayesian Adaptive Sampling (BAS) Package for Bayesian Model Averaging and Variable Selection","text":"BAS now includes constraints factors terms represent factor either included excluded together. illustrate, use data set ToothGrowth convert dose factor: fit model main effects two way interaction without constraints: image model space, see levels factor enter drop model independently interactions may included without main effects. may lead parsimonious models, however, hypotheses tested coefficients represent factor depend choice reference group. force levels factor enter leave together can use force.heredity = TRUE. force.heredity option also forces interactions included main effects also included, models several factors higher order interactions, heredity constraint implies lower order interactions must included adding higher order interactions. force.heredity set FALSE sampling methods MCMC+BAS deterministic. 20 predictors factors, recommend using MCMC enforce constraints. Alternatively, function, force.heredity.bas, post-process output drop models violate hierarchical heredity constraint: can used sampling methods.","code":"data(ToothGrowth) ToothGrowth$dose <- factor(ToothGrowth$dose) levels(ToothGrowth$dose) <- c(\"Low\", \"Medium\", \"High\") TG.bas <- bas.lm(len ~ supp*dose, data = ToothGrowth, modelprior = uniform(), method = \"BAS\" ) image(TG.bas) TG.bas <- bas.lm(len ~ supp * dose, data = ToothGrowth, modelprior = uniform(), method = \"BAS\", force.heredity = TRUE ) image(TG.bas) TG.bas <- bas.lm(len ~ supp * dose, data = ToothGrowth, modelprior = uniform(), method = \"BAS\", force.heredity = FALSE ) TG.herid.bas <- force.heredity.bas(TG.bas)"},{"path":"http://merliseclyde.github.io/BAS/articles/BAS-vignette.html","id":"weighted-regression","dir":"Articles","previous_headings":"","what":"Weighted Regression","title":"Using the Bayesian Adaptive Sampling (BAS) Package for Bayesian Model Averaging and Variable Selection","text":"BAS can perform weighted regression supplying optional weight vector length response assumption variance response proportional 1/weights. g-prior incorporates weights prior covariance, \\[ \\sigma^2 g (X_\\gamma^T W X_\\gamma)^{-1} \\] \\(X_\\gamma\\) design matrix model \\(\\gamma\\) \\(W\\) \\(n \\times n\\) diagonal matrix weights diagonal. illustrate, use climate data, available url includes measurements changes temperature (deltaT) various latitudes well measure accuracy measured values sdev 8 different types proxy obtaining measurements. use explore weighted regression option group terms factors poly. illustration purposes, eliminate proxy == 6 one level interactions estimable, convert proxy factor. can fit weighted regression weights = 1/sdev^2 following code Examining image top models, see levels factor enter drop model together, well vectors design matrix represent term poly. Rerunning without constraint, allows one see factors levels different reference group.","code":"data(climate, package=\"BAS\") str(climate) ## 'data.frame': 63 obs. of 5 variables: ## $ deltaT : num -2.6 -2.6 -2.9 -2.4 -2.8 -1.2 -2.4 -2.6 -2.4 -2.5 ... ## $ sdev : num 0.7 0.8 0.9 0.7 0.7 0.3 1.3 1.3 1.3 0.5 ... ## $ proxy : int 1 1 1 1 1 1 1 1 1 1 ... ## $ T.M : int 1 1 1 1 1 1 1 1 1 1 ... ## $ latitude: num 2.5 2.2 0.5 0.3 0.2 -1.1 5.2 11.4 14.6 6.3 ... summary(climate) ## deltaT sdev proxy T.M ## Min. :-7.000 Min. :0.1500 Min. :1.000 Min. :0.0000 ## 1st Qu.:-3.900 1st Qu.:0.5000 1st Qu.:2.000 1st Qu.:1.0000 ## Median :-2.900 Median :0.7000 Median :3.000 Median :1.0000 ## Mean :-3.111 Mean :0.8579 Mean :3.333 Mean :0.8254 ## 3rd Qu.:-2.000 3rd Qu.:1.3000 3rd Qu.:5.000 3rd Qu.:1.0000 ## Max. : 0.200 Max. :2.5000 Max. :8.000 Max. :1.0000 ## latitude ## Min. :-22.500 ## 1st Qu.: -3.450 ## Median : 0.200 ## Mean : 2.187 ## 3rd Qu.: 9.700 ## Max. : 29.000 library(dplyr) climate <- filter(climate, proxy != 6) %>% mutate(proxy = factor(proxy)) climate.bas <- bas.lm(deltaT ~ proxy * poly(latitude, 2), data = climate, weights = 1 / sdev^2, prior = \"hyper-g-n\", alpha = 3.0, n.models = 2^20, force.heredity=TRUE, modelprior = uniform() ) image(climate.bas, rotate = F) # May take a while to enumerate all 2^20 models climate.bas <- bas.lm(deltaT ~ proxy * poly(latitude, 2), data = climate, weights = 1 / sdev^2, prior = \"hyper-g-n\", alpha = 3.0, n.models = 2^20, modelprior = uniform(), force.heredity = FALSE ) image(climate.bas)"},{"path":"http://merliseclyde.github.io/BAS/articles/BAS-vignette.html","id":"summary","dir":"Articles","previous_headings":"","what":"Summary","title":"Using the Bayesian Adaptive Sampling (BAS) Package for Bayesian Model Averaging and Variable Selection","text":"BAS includes prior distributions coefficients models, well bas.glm fitting Generalized Linear Models. syntax bas.glm bas.lm yet , particularly priors coefficients represented, please see documentation features details updated another vignette added! issues feature requests please submit via package’s github page merliseclyde/BAS","code":""},{"path":"http://merliseclyde.github.io/BAS/authors.html","id":null,"dir":"","previous_headings":"","what":"Authors","title":"Authors and Citation","text":"Merlise Clyde. Author, maintainer, copyright holder. ORCID=0000-0002-3595-1872 Michael Littman. Contributor. Joyee Ghosh. Contributor. Yingbo Li. Contributor. Betsy Bersson. Contributor. Don van de Bergh. Contributor. Quanli Wang. Contributor.","code":""},{"path":"http://merliseclyde.github.io/BAS/authors.html","id":"citation","dir":"","previous_headings":"","what":"Citation","title":"Authors and Citation","text":"Clyde, Merlise (2024) BAS: Bayesian Variable Selection Model Averaging using Bayesian Adaptive Sampling, R package version 1.7.1.9000","code":"@Manual{, title = {{BAS}: Bayesian Variable Selection and Model Averaging using Bayesian Adaptive Sampling}, author = {Merlise Clyde}, year = {2024}, note = {R package version 1.7.1.9000}, }"},{"path":"http://merliseclyde.github.io/BAS/index.html","id":"bas-bayesian-variable-selection-and-model-averaging-using-bayesian-adaptive-sampling","dir":"","previous_headings":"","what":"Bayesian Variable Selection and Model Averaging using Bayesian Adaptive Sampling","title":"Bayesian Variable Selection and Model Averaging using Bayesian Adaptive Sampling","text":"BAS R package designed provide easy use package fast code implementing Bayesian Model Averaging Model Selection R using state art prior distributions linear generalized linear models. prior distributions BAS based Zellner’s g-prior mixtures g-priors linear generalized linear models. shown consistent asymptotically model selection inference number computational advantages. BAS implements three main algorithms sampling space potential models: deterministic algorithm efficient enumeration, adaptive sampling without replacement algorithm modest problems, MCMC algorithm utilizes swapping escape local modes standard Metropolis-Hastings proposals.","code":""},{"path":"http://merliseclyde.github.io/BAS/index.html","id":"installation","dir":"","previous_headings":"","what":"Installation","title":"Bayesian Variable Selection and Model Averaging using Bayesian Adaptive Sampling","text":"stable version can installed easily R console like package: hand, welcome everyone use recent version package quick-fixes, new features probably new bugs. ’s currently hosted GitHub. get latest development version GitHub, use devtools package CRAN enter R: can check current build status installing. Installing package source require compilation C FORTRAN code library makes use BLAS LAPACK efficient model fitting. See CRAN manuals installing packages source different operating systems.","code":"install.packages('BAS') devtools::install_github('merliseclyde/BAS')"},{"path":"http://merliseclyde.github.io/BAS/index.html","id":"usage","dir":"","previous_headings":"","what":"Usage","title":"Bayesian Variable Selection and Model Averaging using Bayesian Adaptive Sampling","text":"begin load package: two main function BAS bas.lm bas.glm implementing Bayesian Model Averaging Variable Selection using Zellner’s g-prior mixtures g priors. functions syntax similar lm glm functions respectively. illustrate using BAS simple example famous Hald data set using Zellner-Siow Cauchy prior via BAS summary, plot coef, predict fitted functions like lm/glm functions. Images model space highlighting variable important may obtained via Run demo(\"BAS.hald\") demo(\"BAS.USCrime\") see package vignette examples options using MCMC model spaces enumerated.","code":"library(BAS) data(Hald) hald.ZS = bas.lm(Y ~ ., data=Hald, prior=\"ZS-null\", modelprior=uniform(), method=\"BAS\") image(hald.ZS)"},{"path":"http://merliseclyde.github.io/BAS/index.html","id":"generalized-linear-models","dir":"","previous_headings":"Usage","what":"Generalized Linear Models","title":"Bayesian Variable Selection and Model Averaging using Bayesian Adaptive Sampling","text":"BAS now includes support binomial binary regression, Poisson regression, Gamma regression using Laplace approximations obtain Bayes Factors used calculating posterior probabilities models sampling models. example using Pima diabetes data set hyper-g/n prior: Note, syntax specifying priors coefficients bas.glm uses function arguments specify hyper-parameters, rather text string specify prior name separate argument hyper-parameters. bas.lm moving format sometime future.","code":"library(MASS) data(Pima.tr) Pima.hgn = bas.glm(type ~ ., data=Pima.tr, method=\"BAS\", family=binomial(), betaprior=hyper.g.n(), modelprior=uniform())"},{"path":"http://merliseclyde.github.io/BAS/index.html","id":"feature-requests-and-issues","dir":"","previous_headings":"","what":"Feature Requests and Issues","title":"Bayesian Variable Selection and Model Averaging using Bayesian Adaptive Sampling","text":"Feel free report issues request features added via github issues page. current documentation vignettes see BAS website","code":""},{"path":"http://merliseclyde.github.io/BAS/index.html","id":"support","dir":"","previous_headings":"Feature Requests and Issues","what":"Support","title":"Bayesian Variable Selection and Model Averaging using Bayesian Adaptive Sampling","text":"material based upon work supported National Science Foundation Grant DMS-1106891. opinions, findings, conclusions recommendations expressed material author(s) necessarily reflect views National Science Foundation.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/BAS.html","id":null,"dir":"Reference","previous_headings":"","what":"BAS: Bayesian Model Averaging using Bayesian Adaptive Sampling — BAS","title":"BAS: Bayesian Model Averaging using Bayesian Adaptive Sampling — BAS","text":"Implementation Bayesian Model Averaging linear models using stochastic deterministic sampling without replacement posterior distributions. Prior distributions coefficients form Zellner's g-prior mixtures g-priors. Options include Zellner-Siow Cauchy Priors, Liang et al hyper-g priors, Local Global Empirical Bayes estimates g, default model selection criteria AIC BIC. Sampling probabilities may updated based sampled models.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/BAS.html","id":"references","dir":"Reference","previous_headings":"","what":"References","title":"BAS: Bayesian Model Averaging using Bayesian Adaptive Sampling — BAS","text":"Clyde, M. Ghosh, J. Littman, M. (2010) Bayesian Adaptive Sampling Variable Selection Model Averaging. Journal Computational Graphics Statistics. 20:80-101 doi:10.1198/jcgs.2010.09049 Clyde, M. George, E. . (2004) Model uncertainty. Statist. Sci., 19, 81-94. doi:10.1214/088342304000000035 Clyde, M. (1999) Bayesian Model Averaging Model Search Strategies (discussion). Bayesian Statistics 6. J.M. Bernardo, .P. Dawid, J.O. Berger, .F.M. Smith eds. Oxford University Press, pages 157-185. Li, Y. Clyde, M. (2018) Mixtures g-priors Generalized Linear Models. Journal American Statistical Association, 113:524, 1828-1845 doi:10.1080/01621459.2018.1469992 Liang, F., Paulo, R., Molina, G., Clyde, M. Berger, J.O. (2008) Mixtures g-priors Bayesian Variable Selection. Journal American Statistical Association. 103:410-423. doi:10.1198/016214507000001337","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/BAS.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"BAS: Bayesian Model Averaging using Bayesian Adaptive Sampling — BAS","text":"Merlise Clyde, Maintainer: Merlise Clyde ","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/BAS.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"BAS: Bayesian Model Averaging using Bayesian Adaptive Sampling — BAS","text":"","code":"data(\"Hald\") hald.gprior = bas.lm(Y ~ ., data=Hald, alpha=13, prior=\"g-prior\") # more complete demos demo(BAS.hald) #> #> #> \tdemo(BAS.hald) #> \t---- ~~~~~~~~ #> #> > data(Hald) #> #> > hald.gprior = bas.lm(Y~ ., data=Hald, prior=\"g-prior\", alpha=13, #> + modelprior=beta.binomial(1,1), #> + initprobs=\"eplogp\") #> #> > hald.gprior #> #> Call: #> bas.lm(formula = Y ~ ., data = Hald, prior = \"g-prior\", alpha = 13, #> modelprior = beta.binomial(1, 1), initprobs = \"eplogp\") #> #> #> Marginal Posterior Inclusion Probabilities: #> Intercept X1 X2 X3 X4 #> 1.0000 0.9019 0.6896 0.4653 0.6329 #> #> > plot(hald.gprior) #> #> > summary(hald.gprior) #> P(B != 0 | Y) model 1 model 2 model 3 model 4 model 5 #> Intercept 1.0000000 1.00000 1.0000000 1.00000000 1.0000000 1.0000000 #> X1 0.9019245 1.00000 1.0000000 1.00000000 1.0000000 1.0000000 #> X2 0.6895830 1.00000 0.0000000 1.00000000 1.0000000 1.0000000 #> X3 0.4652762 0.00000 0.0000000 1.00000000 0.0000000 1.0000000 #> X4 0.6329266 0.00000 1.0000000 1.00000000 1.0000000 0.0000000 #> BF NA 1.00000 0.6923944 0.08991408 0.3355714 0.3344926 #> PostProbs NA 0.24320 0.1684000 0.13120000 0.1224000 0.1220000 #> R2 NA 0.97870 0.9725000 0.98240000 0.9823000 0.9823000 #> dim NA 3.00000 3.0000000 5.00000000 4.0000000 4.0000000 #> logmarg NA 11.72735 11.3597547 9.31845348 10.6354335 10.6322138 #> #> > image(hald.gprior, subset=-1, vlas=0) #> #> > hald.coef = coefficients(hald.gprior) #> #> > hald.coef #> #> Marginal Posterior Summaries of Coefficients: #> #> Using BMA #> #> Based on the top 16 models #> post mean post SD post p(B != 0) #> Intercept 95.4231 0.7107 1.0000 #> X1 1.2150 0.5190 0.9019 #> X2 0.2756 0.4832 0.6896 #> X3 -0.1271 0.4976 0.4653 #> X4 -0.3269 0.4717 0.6329 #> #> > plot(hald.coef) #> #> > predict(hald.gprior, top=5, se.fit=TRUE) #> $fit #> [1] 79.74246 74.50010 105.29268 89.88693 95.57177 104.56409 103.40145 #> [8] 77.13668 91.99731 114.21325 82.78446 111.00723 110.40160 #> #> $Ybma #> [,1] #> [1,] 79.74246 #> [2,] 74.50010 #> [3,] 105.29268 #> [4,] 89.88693 #> [5,] 95.57177 #> [6,] 104.56409 #> [7,] 103.40145 #> [8,] 77.13668 #> [9,] 91.99731 #> [10,] 114.21325 #> [11,] 82.78446 #> [12,] 111.00723 #> [13,] 110.40160 #> #> $Ypred #> [,1] [,2] [,3] [,4] [,5] [,6] [,7] [,8] #> [1,] 81.17036 74.83464 105.0725 89.69881 97.15898 104.4575 103.3893 76.06454 #> [2,] 77.70296 74.24113 105.8554 90.46267 93.09565 104.7152 103.1399 78.80193 #> [3,] 79.70437 74.40553 105.2175 89.76253 95.63309 104.5709 103.5254 77.08557 #> [4,] 79.65151 74.47846 105.4218 89.83174 95.62799 104.5962 103.5068 77.00839 #> [5,] 79.84321 74.31409 104.9063 89.65651 95.70301 104.5285 103.5476 77.15919 #> [,9] [,10] [,11] [,12] [,13] #> [1,] 91.57174 113.1722 81.59906 111.2219 111.0884 #> [2,] 92.68123 115.8058 84.50293 110.4162 109.0791 #> [3,] 91.98604 114.1759 82.78145 111.1196 110.5321 #> [4,] 92.07571 114.1088 82.68233 111.0429 110.4674 #> [5,] 91.83513 114.2353 82.88128 111.2384 110.6515 #> #> $postprobs #> [1] 0.3089304 0.2139017 0.1666632 0.1555023 0.1550024 #> #> $se.fit #> [,1] [,2] [,3] [,4] [,5] [,6] [,7] [,8] #> [1,] 2.220164 2.265862 1.546911 2.181188 1.310135 1.523300 2.655096 2.176560 #> [2,] 2.716798 2.389723 1.633637 2.179215 1.321062 1.581232 2.721957 2.078129 #> [3,] 3.203405 2.501485 3.279273 2.357164 2.589756 1.549136 2.623290 2.765255 #> [4,] 3.117350 2.283957 1.602160 2.149087 2.589321 1.508471 2.610923 2.545817 #> [5,] 2.932580 2.353352 1.538009 2.141694 2.507848 1.498758 2.616407 2.680289 #> [,9] [,10] [,11] [,12] [,13] #> [1,] 1.883610 3.264656 1.908238 1.970691 2.054234 #> [2,] 2.013244 3.298134 1.933819 1.964374 1.924460 #> [3,] 2.353516 3.609909 2.821295 2.227363 2.390135 #> [4,] 1.990817 3.485929 2.456636 1.951456 2.212238 #> [5,] 1.889302 3.569065 2.665166 1.934336 2.117189 #> #> $se.pred #> [,1] [,2] [,3] [,4] [,5] [,6] [,7] [,8] #> [1,] 5.057182 5.077410 4.799885 5.040193 4.728892 4.792328 5.262651 5.038191 #> [2,] 5.415848 5.259391 4.961773 5.167146 4.867815 4.944766 5.418438 5.125333 #> [3,] 5.489152 5.111401 5.533771 5.042342 5.155175 4.718984 5.172102 5.245534 #> [4,] 5.440156 5.009380 4.737547 4.949344 5.155775 4.706689 5.166658 5.134065 #> [5,] 5.337427 5.042456 4.717369 4.947217 5.116386 4.704719 5.170463 5.203081 #> [,9] [,10] [,11] [,12] [,13] #> [1,] 4.918734 5.594992 4.928218 4.952735 4.986566 #> [2,] 5.099370 5.729582 5.068538 5.080274 5.064974 #> [3,] 5.040638 5.735890 5.275291 4.982985 5.057839 #> [4,] 4.882702 5.659428 5.090431 4.866787 4.977090 #> [5,] 4.843301 5.711946 5.195307 4.861045 4.936658 #> #> $se.bma.fit #> [1] 2.688224 2.095245 1.769625 1.970919 2.197285 1.363804 2.356457 2.302631 #> [9] 1.822084 3.141443 2.237663 1.801849 1.991374 #> #> $se.bma.pred #> [1] 4.838655 4.536087 4.395180 4.480017 4.584113 4.248058 4.662502 4.635531 #> [9] 4.416563 5.104380 4.603604 4.408253 4.489054 #> #> $df #> [1] 12 12 12 12 12 #> #> $best #> [1] 3 6 4 13 15 #> #> $bestmodel #> $bestmodel[[1]] #> [1] 0 1 2 #> #> $bestmodel[[2]] #> [1] 0 1 4 #> #> $bestmodel[[3]] #> [1] 0 1 2 3 4 #> #> $bestmodel[[4]] #> [1] 0 1 2 4 #> #> $bestmodel[[5]] #> [1] 0 1 2 3 #> #> #> $best.vars #> [1] \"Intercept\" \"X1\" \"X2\" \"X3\" \"X4\" #> #> $estimator #> [1] \"BMA\" #> #> attr(,\"class\") #> [1] \"pred.bas\" #> #> > confint(predict(hald.gprior, Hald, estimator=\"BMA\", se.fit=TRUE, top=5), parm=\"mean\") #> 2.5% 97.5% mean #> [1,] 73.17015 86.09252 79.74246 #> [2,] 69.48178 79.49934 74.50010 #> [3,] 101.18320 110.09817 105.29268 #> [4,] 85.06175 94.69350 89.88693 #> [5,] 90.49213 100.40376 95.57177 #> [6,] 101.23478 107.96299 104.56409 #> [7,] 97.63448 109.07312 103.40145 #> [8,] 71.49627 82.42323 77.13668 #> [9,] 87.73351 96.35950 91.99731 #> [10,] 106.67366 121.85448 114.21325 #> [11,] 77.58914 88.14563 82.78446 #> [12,] 106.56487 115.34932 111.00723 #> [13,] 105.51356 114.94017 110.40160 #> attr(,\"Probability\") #> [1] 0.95 #> attr(,\"class\") #> [1] \"confint.bas\" #> #> > predict(hald.gprior, estimator=\"MPM\", se.fit=TRUE) #> $fit #> [1] 79.65151 74.47846 105.42183 89.83174 95.62799 104.59616 103.50684 #> [8] 77.00839 92.07571 114.10876 82.68233 111.04286 110.46741 #> attr(,\"model\") #> [1] 0 1 2 4 #> attr(,\"best\") #> [1] 1 #> attr(,\"estimator\") #> [1] \"MPM\" #> #> $Ybma #> [1] 79.65151 74.47846 105.42183 89.83174 95.62799 104.59616 103.50684 #> [8] 77.00839 92.07571 114.10876 82.68233 111.04286 110.46741 #> attr(,\"model\") #> [1] 0 1 2 4 #> attr(,\"best\") #> [1] 1 #> attr(,\"estimator\") #> [1] \"MPM\" #> #> $Ypred #> NULL #> #> $postprobs #> NULL #> #> $se.fit #> [1] 3.117350 2.283957 1.602160 2.149087 2.589321 1.508471 2.610923 2.545817 #> [9] 1.990817 3.485929 2.456636 1.951456 2.212238 #> #> $se.pred #> [1] 5.440156 5.009380 4.737547 4.949344 5.155775 4.706689 5.166658 5.134065 #> [9] 4.882702 5.659428 5.090431 4.866787 4.977090 #> #> $se.bma.fit #> NULL #> #> $se.bma.pred #> NULL #> #> $df #> [1] 12 #> #> $best #> NULL #> #> $bestmodel #> [1] 0 1 2 4 #> #> $best.vars #> [1] \"Intercept\" \"X1\" \"X2\" \"X4\" #> #> $estimator #> [1] \"MPM\" #> #> attr(,\"class\") #> [1] \"pred.bas\" #> #> > confint(predict(hald.gprior, Hald, estimator=\"MPM\", se.fit=TRUE), parm=\"mean\") #> 2.5% 97.5% mean #> [1,] 72.85939 86.44363 79.65151 #> [2,] 69.50215 79.45478 74.47846 #> [3,] 101.93102 108.91264 105.42183 #> [4,] 85.14928 94.51420 89.83174 #> [5,] 89.98634 101.26964 95.62799 #> [6,] 101.30948 107.88283 104.59616 #> [7,] 97.81813 109.19556 103.50684 #> [8,] 71.46153 82.55525 77.00839 #> [9,] 87.73810 96.41333 92.07571 #> [10,] 106.51357 121.70394 114.10876 #> [11,] 77.32978 88.03488 82.68233 #> [12,] 106.79101 115.29472 111.04286 #> [13,] 105.64736 115.28746 110.46741 #> attr(,\"Probability\") #> [1] 0.95 #> attr(,\"class\") #> [1] \"confint.bas\" #> #> > fitted(hald.gprior, estimator=\"HPM\") #> [1] 81.17036 74.83464 105.07248 89.69881 97.15898 104.45753 103.38927 #> [8] 76.06454 91.57174 113.17222 81.59906 111.22195 111.08841 #> #> > hald.gprior = bas.lm(Y~ ., data=Hald, n.models=2^4, #> + prior=\"g-prior\", alpha=13, modelprior=uniform(), #> + initprobs=\"eplogp\") #> #> > hald.EB = update(hald.gprior, newprior=\"EB-global\") #> #> > hald.bic = update(hald.gprior,newprior=\"BIC\") #> #> > hald.zs = update(hald.bic, newprior=\"ZS-null\") if (FALSE) { demo(BAS.USCrime) }"},{"path":"http://merliseclyde.github.io/BAS/reference/Bayes.outlier.html","id":null,"dir":"Reference","previous_headings":"","what":"Bayesian Outlier Detection — Bayes.outlier","title":"Bayesian Outlier Detection — Bayes.outlier","text":"Calculate posterior probability absolute value error exceeds k standard deviations P(|epsilon_j| > k sigma | data) model Y = X B + epsilon, epsilon ~ N(0, sigma^2 ) based paper Chaloner & Brant Biometrika (1988). Either k prior probability outliers must provided. uses reference prior p(B, sigma) = 1; priors model averaging come.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/Bayes.outlier.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Bayesian Outlier Detection — Bayes.outlier","text":"","code":"Bayes.outlier(lmobj, k, prior.prob)"},{"path":"http://merliseclyde.github.io/BAS/reference/Bayes.outlier.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Bayesian Outlier Detection — Bayes.outlier","text":"lmobj object class `lm` k number standard deviations used calculating probability individual case outlier, P(|error| > k sigma | data) prior.prob prior probability outliers sample size n","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/Bayes.outlier.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Bayesian Outlier Detection — Bayes.outlier","text":"Returns list three items: e residuals hat leverage values prob.outlier posterior probabilities point outlier prior.prob prior probability point outlier","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/Bayes.outlier.html","id":"references","dir":"Reference","previous_headings":"","what":"References","title":"Bayesian Outlier Detection — Bayes.outlier","text":"Chaloner & Brant (1988) Bayesian Approach Outlier Detection Residual Analysis Biometrika (1988) 75, 651-659","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/Bayes.outlier.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Bayesian Outlier Detection — Bayes.outlier","text":"","code":"data(\"stackloss\") stack.lm <- lm(stack.loss ~ ., data = stackloss) stack.outliers <- Bayes.outlier(stack.lm, k = 3) plot(stack.outliers$prob.outlier, type = \"h\", ylab = \"Posterior Probability\") # adjust for sample size for calculating prior prob that a # a case is an outlier stack.outliers <- Bayes.outlier(stack.lm, prior.prob = 0.95) # cases where posterior probability exceeds prior probability which(stack.outliers$prob.outlier > stack.outliers$prior.prob) #> [1] 4 21"},{"path":"http://merliseclyde.github.io/BAS/reference/Bernoulli.heredity.html","id":null,"dir":"Reference","previous_headings":"","what":"Independent Bernoulli prior on models that with constraints for\nmodel hierarchy induced by interactions — Bernoulli.heredity","title":"Independent Bernoulli prior on models that with constraints for\nmodel hierarchy induced by interactions — Bernoulli.heredity","text":"Independent Bernoulli prior models constraints model hierarchy induced interactions","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/Bernoulli.heredity.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Independent Bernoulli prior on models that with constraints for\nmodel hierarchy induced by interactions — Bernoulli.heredity","text":"","code":"Bernoulli.heredity(pi = 0.5, parents)"},{"path":"http://merliseclyde.github.io/BAS/reference/Bernoulli.heredity.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Independent Bernoulli prior on models that with constraints for\nmodel hierarchy induced by interactions — Bernoulli.heredity","text":"pi Bernoulli probability term included parents matrix terms parents indicators terms parents term","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/Bernoulli.heredity.html","id":"note","dir":"Reference","previous_headings":"","what":"Note","title":"Independent Bernoulli prior on models that with constraints for\nmodel hierarchy induced by interactions — Bernoulli.heredity","text":"implemented yet use bas.lm bas.glm","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/Bernoulli.html","id":null,"dir":"Reference","previous_headings":"","what":"Independent Bernoulli Prior Distribution for Models — Bernoulli","title":"Independent Bernoulli Prior Distribution for Models — Bernoulli","text":"Creates object representing prior distribution models BAS.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/Bernoulli.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Independent Bernoulli Prior Distribution for Models — Bernoulli","text":"","code":"Bernoulli(probs = 0.5)"},{"path":"http://merliseclyde.github.io/BAS/reference/Bernoulli.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Independent Bernoulli Prior Distribution for Models — Bernoulli","text":"probs scalar vector prior inclusion probabilities. scalar, values replicated variables ans 1 added intercept. BAS checks see length equal dimension parameter vector full model adds 1 include intercept.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/Bernoulli.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Independent Bernoulli Prior Distribution for Models — Bernoulli","text":"returns object class \"prior\", family hyperparameters.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/Bernoulli.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Independent Bernoulli Prior Distribution for Models — Bernoulli","text":"independent Bernoulli prior distribution commonly used prior BMA, Uniform distribution special case probs=.5. indicator variables independent Bernoulli distributions common probability probs, distribution model size binomial(p, probs) distribution.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/Bernoulli.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Independent Bernoulli Prior Distribution for Models — Bernoulli","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/Bernoulli.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Independent Bernoulli Prior Distribution for Models — Bernoulli","text":"","code":"Bernoulli(.9) #> $family #> [1] \"Bernoulli\" #> #> $hyper.parameters #> [1] 0.9 #> #> attr(,\"class\") #> [1] \"prior\""},{"path":"http://merliseclyde.github.io/BAS/reference/CCH.html","id":null,"dir":"Reference","previous_headings":"","what":"Generalized g-Prior Distribution for Coefficients in BMA Models — CCH","title":"Generalized g-Prior Distribution for Coefficients in BMA Models — CCH","text":"Creates object representing CCH mixture g-priors coefficients BAS .","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/CCH.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Generalized g-Prior Distribution for Coefficients in BMA Models — CCH","text":"","code":"CCH(alpha, beta, s = 0)"},{"path":"http://merliseclyde.github.io/BAS/reference/CCH.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Generalized g-Prior Distribution for Coefficients in BMA Models — CCH","text":"alpha scalar > 0, recommended alpha=.5 (betaprime) 1 CCH. hyper.g(alpha) equivalent CCH(alpha -2, 2, 0). Liang et al recommended values range 2 < alpha_h <= 4 beta scalar > 0. value updated data; beta function n consistency null model. hyper-g corresponds b = 2 s scalar, recommended s=0","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/CCH.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Generalized g-Prior Distribution for Coefficients in BMA Models — CCH","text":"returns object class \"prior\", family hyperparameters.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/CCH.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Generalized g-Prior Distribution for Coefficients in BMA Models — CCH","text":"Creates structure used bas.glm.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/CCH.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Generalized g-Prior Distribution for Coefficients in BMA Models — CCH","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/CCH.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Generalized g-Prior Distribution for Coefficients in BMA Models — CCH","text":"","code":"CCH(alpha = .5, beta = 100, s = 0) #> $family #> [1] \"CCH\" #> #> $class #> [1] \"TCCH\" #> #> $hyper.parameters #> $hyper.parameters$alpha #> [1] 0.5 #> #> $hyper.parameters$beta #> [1] 100 #> #> $hyper.parameters$s #> [1] 0 #> #> #> attr(,\"class\") #> [1] \"prior\""},{"path":"http://merliseclyde.github.io/BAS/reference/EB.global.html","id":null,"dir":"Reference","previous_headings":"","what":"Find the global Empirical Bayes estimates for BMA — EB.global","title":"Find the global Empirical Bayes estimates for BMA — EB.global","text":"Finds global Empirical Bayes estimates g Zellner's g-prior model probabilities","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/EB.global.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Find the global Empirical Bayes estimates for BMA — EB.global","text":"","code":"EB.global(object, tol = 0.1, g.0 = NULL, max.iterations = 100)"},{"path":"http://merliseclyde.github.io/BAS/reference/EB.global.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Find the global Empirical Bayes estimates for BMA — EB.global","text":"object 'bas' object created bas tol tolerance estimating g g.0 initial value g max.iterations Maximum number iterations EM algorithm","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/EB.global.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Find the global Empirical Bayes estimates for BMA — EB.global","text":"object class 'bas' using Zellner's g prior estimate g based models","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/EB.global.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Find the global Empirical Bayes estimates for BMA — EB.global","text":"Uses EM algorithm Liang et al estimate type II MLE g Zellner's g prior","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/EB.global.html","id":"references","dir":"Reference","previous_headings":"","what":"References","title":"Find the global Empirical Bayes estimates for BMA — EB.global","text":"Liang, F., Paulo, R., Molina, G., Clyde, M. Berger, J.O. (2008) Mixtures g-priors Bayesian Variable Selection. Journal American Statistical Association. 103:410-423. doi:10.1198/016214507000001337","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/EB.global.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Find the global Empirical Bayes estimates for BMA — EB.global","text":"Merlise Clyde clyde@stat.duke.edu","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/EB.global.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Find the global Empirical Bayes estimates for BMA — EB.global","text":"","code":"library(MASS) data(UScrime) UScrime[,-2] = log(UScrime[,-2]) # EB local uses a different g within each model crime.EBL = bas.lm(y ~ ., data=UScrime, n.models=2^15, prior=\"EB-local\", initprobs= \"eplogp\") # use a common (global) estimate of g crime.EBG = EB.global(crime.EBL)"},{"path":"http://merliseclyde.github.io/BAS/reference/EB.local.html","id":null,"dir":"Reference","previous_headings":"","what":"Empirical Bayes Prior Distribution for Coefficients in BMA Model — EB.local","title":"Empirical Bayes Prior Distribution for Coefficients in BMA Model — EB.local","text":"Creates object representing EB prior BAS GLM.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/EB.local.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Empirical Bayes Prior Distribution for Coefficients in BMA Model — EB.local","text":"","code":"EB.local()"},{"path":"http://merliseclyde.github.io/BAS/reference/EB.local.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Empirical Bayes Prior Distribution for Coefficients in BMA Model — EB.local","text":"returns object class \"prior\", family hyerparameters.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/EB.local.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Empirical Bayes Prior Distribution for Coefficients in BMA Model — EB.local","text":"Creates structure used bas.glm.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/EB.local.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Empirical Bayes Prior Distribution for Coefficients in BMA Model — EB.local","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/EB.local.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Empirical Bayes Prior Distribution for Coefficients in BMA Model — EB.local","text":"","code":"EB.local() #> $family #> [1] \"EB-local\" #> #> $class #> [1] \"EB\" #> #> $hyper.parameters #> $hyper.parameters$local #> [1] TRUE #> #> #> attr(,\"class\") #> [1] \"prior\""},{"path":"http://merliseclyde.github.io/BAS/reference/Hald.html","id":null,"dir":"Reference","previous_headings":"","what":"Hald Data — Hald","title":"Hald Data — Hald","text":"Hald data used many books papers illustrate variable selection. data relate engineering application concerned effect composition cement heat evolved hardening. response variable Y heat evolved cement mix. four explanatory variables ingredients mix, X1: tricalcium aluminate, X2: tricalcium silicate, X3: tetracalcium alumino ferrite, X4: dicalcium silicate. important feature data variables X1 X3 highly correlated, well variables X2 X4. Thus expect subset (X1,X2,X3,X4) includes one variable highly correlated pair subset also includes member.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/Hald.html","id":"format","dir":"Reference","previous_headings":"","what":"Format","title":"Hald Data — Hald","text":"hald dataframe 13 observations 5 variables (columns), Y: Heat evolved per gram cement (calories) X1: Amount tricalcium aluminate X2: Amount tricalcium silicate X3: Amount tetracalcium alumino ferrite X4: Amount dicalcium silicate","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/Hald.html","id":"source","dir":"Reference","previous_headings":"","what":"Source","title":"Hald Data — Hald","text":"Wood, H., Steinour, H.H., Starke, H.R. (1932). \"Effect Composition Portland cement Heat Evolved Hardening\", Industrial Engineering Chemistry, 24, 1207-1214.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/IC.prior.html","id":null,"dir":"Reference","previous_headings":"","what":"Information Criterion Families of Prior Distribution for Coefficients in BMA\nModels — IC.prior","title":"Information Criterion Families of Prior Distribution for Coefficients in BMA\nModels — IC.prior","text":"Creates object representing prior distribution coefficients BAS.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/IC.prior.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Information Criterion Families of Prior Distribution for Coefficients in BMA\nModels — IC.prior","text":"","code":"IC.prior(penalty)"},{"path":"http://merliseclyde.github.io/BAS/reference/IC.prior.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Information Criterion Families of Prior Distribution for Coefficients in BMA\nModels — IC.prior","text":"penalty scalar used penalized loglikelihood form penalty*dimension","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/IC.prior.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Information Criterion Families of Prior Distribution for Coefficients in BMA\nModels — IC.prior","text":"returns object class \"prior\", family hyerparameters.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/IC.prior.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Information Criterion Families of Prior Distribution for Coefficients in BMA\nModels — IC.prior","text":"log marginal likelihood approximated -2*(deviance + penalty*dimension). Allows alternatives AIC (penalty = 2) BIC (penalty = log(n)). BIC, argument may missing, case sample size determined call `bas.glm` used determine penalty.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/IC.prior.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Information Criterion Families of Prior Distribution for Coefficients in BMA\nModels — IC.prior","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/IC.prior.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Information Criterion Families of Prior Distribution for Coefficients in BMA\nModels — IC.prior","text":"","code":"IC.prior(2) #> $family #> [1] \"IC\" #> #> $class #> [1] \"IC\" #> #> $hyper #> [1] 2 #> #> $hyper.parameters #> $hyper.parameters$penalty #> [1] 2 #> #> #> attr(,\"class\") #> [1] \"prior\" aic.prior() #> $family #> [1] \"AIC\" #> #> $class #> [1] \"IC\" #> #> $hyper.parameters #> $hyper.parameters$penalty #> [1] 2 #> #> #> $hyper #> [1] 2 #> #> attr(,\"class\") #> [1] \"prior\" bic.prior(100) #> $family #> [1] \"BIC\" #> #> $class #> [1] \"IC\" #> #> $hyper.parameters #> $hyper.parameters$penalty #> [1] 4.60517 #> #> $hyper.parameters$n #> [1] 100 #> #> #> $hyper #> [1] 4.60517 #> #> attr(,\"class\") #> [1] \"prior\""},{"path":"http://merliseclyde.github.io/BAS/reference/Jeffreys.html","id":null,"dir":"Reference","previous_headings":"","what":"Jeffreys Prior Distribution for $g$ for Mixtures of g-Priors for\nCoefficients in BMA Models — Jeffreys","title":"Jeffreys Prior Distribution for $g$ for Mixtures of g-Priors for\nCoefficients in BMA Models — Jeffreys","text":"Creates object representing Jeffrey's Prior g mixture g-priors coefficients BAS. equivalent limiting version CCH(, 2, 0) = 0 hyper-g(= 2) improper prior. $g$ appear Null Model, Bayes Factors model probabilities well-defined arbitrary normalizing constants, reason null model excluded constants used across models.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/Jeffreys.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Jeffreys Prior Distribution for $g$ for Mixtures of g-Priors for\nCoefficients in BMA Models — Jeffreys","text":"","code":"Jeffreys()"},{"path":"http://merliseclyde.github.io/BAS/reference/Jeffreys.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Jeffreys Prior Distribution for $g$ for Mixtures of g-Priors for\nCoefficients in BMA Models — Jeffreys","text":"returns object class \"prior\", family hyerparameters.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/Jeffreys.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Jeffreys Prior Distribution for $g$ for Mixtures of g-Priors for\nCoefficients in BMA Models — Jeffreys","text":"Creates structure used bas.glm.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/Jeffreys.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Jeffreys Prior Distribution for $g$ for Mixtures of g-Priors for\nCoefficients in BMA Models — Jeffreys","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/Jeffreys.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Jeffreys Prior Distribution for $g$ for Mixtures of g-Priors for\nCoefficients in BMA Models — Jeffreys","text":"","code":"Jeffreys() #> $family #> [1] \"Jeffreys\" #> #> $class #> [1] \"TCCH\" #> #> $hyper.parameters #> $hyper.parameters$alpha #> [1] 0 #> #> $hyper.parameters$beta #> [1] 2 #> #> $hyper.parameters$s #> [1] 0 #> #> #> attr(,\"class\") #> [1] \"prior\""},{"path":"http://merliseclyde.github.io/BAS/reference/TG.html","id":null,"dir":"Reference","previous_headings":"","what":"Generalized g-Prior Distribution for Coefficients in BMA Models — TG","title":"Generalized g-Prior Distribution for Coefficients in BMA Models — TG","text":"Creates object representing Truncated Gamma (tCCH) mixture g-priors coefficients BAS, u = 1/(1+g) Gamma distribution supported (0, 1].","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/TG.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Generalized g-Prior Distribution for Coefficients in BMA Models — TG","text":"","code":"TG(alpha = 2)"},{"path":"http://merliseclyde.github.io/BAS/reference/TG.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Generalized g-Prior Distribution for Coefficients in BMA Models — TG","text":"alpha scalar > 0, recommended alpha=.5 (betaprime) 1. alpha=2 corresponds uniform prior shrinkage factor.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/TG.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Generalized g-Prior Distribution for Coefficients in BMA Models — TG","text":"returns object class \"prior\", family hyerparameters.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/TG.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Generalized g-Prior Distribution for Coefficients in BMA Models — TG","text":"Creates structure used bas.glm.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/TG.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Generalized g-Prior Distribution for Coefficients in BMA Models — TG","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/TG.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Generalized g-Prior Distribution for Coefficients in BMA Models — TG","text":"","code":"TG(alpha = 2) #> $family #> [1] \"TG\" #> #> $class #> [1] \"TCCH\" #> #> $hyper.parameters #> $hyper.parameters$alpha #> [1] 2 #> #> $hyper.parameters$beta #> [1] 2 #> #> $hyper.parameters$s #> [1] 0 #> #> #> attr(,\"class\") #> [1] \"prior\" CCH(alpha = 2, beta = 100, s = 0) #> $family #> [1] \"CCH\" #> #> $class #> [1] \"TCCH\" #> #> $hyper.parameters #> $hyper.parameters$alpha #> [1] 2 #> #> $hyper.parameters$beta #> [1] 100 #> #> $hyper.parameters$s #> [1] 0 #> #> #> attr(,\"class\") #> [1] \"prior\""},{"path":"http://merliseclyde.github.io/BAS/reference/bas.glm.html","id":null,"dir":"Reference","previous_headings":"","what":"Bayesian Adaptive Sampling Without Replacement for Variable Selection in\nGeneralized Linear Models — bas.glm","title":"Bayesian Adaptive Sampling Without Replacement for Variable Selection in\nGeneralized Linear Models — bas.glm","text":"Sample without replacement posterior distribution GLMs","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/bas.glm.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Bayesian Adaptive Sampling Without Replacement for Variable Selection in\nGeneralized Linear Models — bas.glm","text":"","code":"bas.glm( formula, family = binomial(link = \"logit\"), data, weights, subset, contrasts = NULL, offset, na.action = \"na.omit\", n.models = NULL, betaprior = CCH(alpha = 0.5, beta = as.numeric(nrow(data)), s = 0), modelprior = beta.binomial(1, 1), initprobs = \"Uniform\", include.always = ~1, method = \"MCMC\", update = NULL, bestmodel = NULL, prob.rw = 0.5, MCMC.iterations = NULL, thin = 1, control = glm.control(), laplace = FALSE, renormalize = FALSE, force.heredity = FALSE, bigmem = FALSE )"},{"path":"http://merliseclyde.github.io/BAS/reference/bas.glm.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Bayesian Adaptive Sampling Without Replacement for Variable Selection in\nGeneralized Linear Models — bas.glm","text":"formula generalized linear model formula full model predictors, Y ~ X. code assumes intercept included model. family description error distribution link function exponential family; currently `binomial()` logistic link `poisson()` `Gamma()`log link available. data data frame weights optional vector weights used fitting process. May missing case weights 1. subset subset data used fitting contrasts optional list. See contrasts.arg `model.matrix.default()`. offset priori known component included linear predictor; default 0. na.action function indicates happen data contain NAs. default \"na.omit\". n.models number unique models keep. NULL, BAS attempt enumerate unless p > 35 method=\"MCMC\". methods using MCMC algorithms sample replacement, sampling stop number iterations exceeds min 'n.models' 'MCMC.iterations' exit 'n.models' updated reflect unique number models sampled. betaprior Prior coefficients model coefficients (except intercept). Options include g.prior, CCH, robust, intrinsic, beta.prime, EB.local, AIC, BIC. modelprior Family prior distribution models. Choices include uniform, Bernoulli, beta.binomial, truncated Beta-Binomial, tr.beta.binomial, truncated power family tr.power.prior. initprobs vector length p initial inclusion probabilities used sampling without replacement (intercept included probability one need added ) character string giving method used construct sampling probabilities \"Uniform\" predictor variable equally likely sampled (equivalent random sampling without replacement). \"eplogp\", use eplogprob function approximate Bayes factor using p-values find initial marginal inclusion probabilities sample without replacement using inclusion probabilities, may updated using estimates marginal inclusion probabilities. \"eplogp\" assumes MLEs full model exist; problems case 'p' large, initial sampling probabilities may obtained using eplogprob.marg fits model predictor separately. run Markov Chain provide initial estimates marginal inclusion probabilities, use method=\"MCMC+BAS\" . initprobs used sampling method=\"MCMC\", determines order variables lookup table affects memory allocation large problems enumeration feasible. variables always included set corresponding initprobs 1, override `modelprior` use `include.always` force variables always included model. include.always formula terms always included model probability one. default `~ 1` meaning intercept always included. also override values `initprobs` setting 1. method character variable indicating sampling method use: method=\"BAS\" uses Bayesian Adaptive Sampling (without replacement) using sampling probabilities given initprobs updates using marginal inclusion probabilities direct search/sample; method=\"MCMC\" combines random walk Metropolis Hastings (MC3 Raftery et al 1997) random swap variable included variable currently excluded (see Clyde, Ghosh, Littman (2010) details); method=\"MCMC+BAS\" runs initial MCMC calculate marginal inclusion probabilities samples without replacement BAS; method = \"deterministic\" runs deterministic sampling using initial probabilities (updating); recommended fast enumeration model independence good approximation joint posterior distribution model indicators. BAS, sampling probabilities can updated models sampled. (see 'update' ). recommend \"MCMC+BAS\" \"MCMC\" high dimensional problems. update number iterations potential updates sampling probabilities \"BAS\" method. NULL update, otherwise algorithm update using marginal inclusion probabilities change sampling takes place. large model spaces, updating recommended. model space enumerated, leave default. bestmodel optional binary vector representing model initialize sampling. NULL sampling starts null model prob.rw MCMC methods, probability using random-walk proposal; otherwise use random \"flip\" move propose new model. MCMC.iterations Number models sample using MCMC options; greater 'n.models'. default 10*n.models. thin oFr \"MCMC\", thin MCMC chain every \"thin\" iterations; default thinning. large p, thinning can used significantly reduce memory requirements models associated summaries saved every thin iterations. thin = p, model associated output recorded every p iterations,similar Gibbs sampler SSVS. control list parameters control convergence fitting process. See documentation glm.control() laplace logical variable whether use Laplace approximate integration respect g obtain marginal likelihood. FALSE Cephes library used may inaccurate large n large values Wald Chisquared statistic. renormalize logical variable whether posterior probabilities based renormalizing marginal likelihoods times prior probabilities use Monte Carlo frequencies. Applies MCMC sampling. force.heredity Logical variable force levels factor included together include higher order interactions lower order terms included. Currently supported `method='MCMC'` `method='BAS'` (experimental) non-Solaris platforms. Default FALSE. bigmem Logical variable indicate access large amounts memory (physical virtual) enumeration large model spaces, e.g. > 2^25.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/bas.glm.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Bayesian Adaptive Sampling Without Replacement for Variable Selection in\nGeneralized Linear Models — bas.glm","text":"bas.glm returns object class basglm object class basglm list containing least following components: postprobs posterior probabilities models selected priorprobs prior probabilities models selected logmarg values log marginal likelihood models n.vars total number independent variables full model, including intercept size number independent variables models, includes intercept list lists one list per model variables included model probne0 posterior probability variable non-zero mle list lists one list per model giving GLM estimate (nonzero) coefficient model. mle.se list lists one list per model giving GLM standard error coefficient model deviance GLM deviance model modelprior prior distribution models created BMA object Q Q statistic model used marginal likelihood approximation Y response X matrix predictors family family object original call betaprior family object prior coefficients, including hyperparameters modelprior family object prior models include.always indices variables forced model","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/bas.glm.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Bayesian Adaptive Sampling Without Replacement for Variable Selection in\nGeneralized Linear Models — bas.glm","text":"BAS provides several search algorithms find high probability models use Bayesian Model Averaging Bayesian model selection. p less 20-25, BAS can enumerate models depending memory availability, larger p, BAS samples without replacement using random deterministic sampling. Bayesian Adaptive Sampling algorithm Clyde, Ghosh, Littman (2010) samples models without replacement using initial sampling probabilities, optionally update sampling probabilities every \"update\" models using estimated marginal inclusion probabilities. BAS uses different methods obtain initprobs, may impact results high-dimensional problems. deterministic sampler provides list top models order approximation independence using provided initprobs. may effective running algorithms identify high probability models works well correlations variables small modest. priors coefficients mixtures g-priors provide approximations power prior.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/bas.glm.html","id":"references","dir":"Reference","previous_headings":"","what":"References","title":"Bayesian Adaptive Sampling Without Replacement for Variable Selection in\nGeneralized Linear Models — bas.glm","text":"Li, Y. Clyde, M. (2018) Mixtures g-priors Generalized Linear Models. Journal American Statistical Association. 113:1828-1845 doi:10.1080/01621459.2018.1469992 Clyde, M. Ghosh, J. Littman, M. (2010) Bayesian Adaptive Sampling Variable Selection Model Averaging. Journal Computational Graphics Statistics. 20:80-101 doi:10.1198/jcgs.2010.09049 Raftery, .E, Madigan, D. Hoeting, J.. (1997) Bayesian Model Averaging Linear Regression Models. Journal American Statistical Association.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/bas.glm.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Bayesian Adaptive Sampling Without Replacement for Variable Selection in\nGeneralized Linear Models — bas.glm","text":"Merlise Clyde (clyde@duke.edu), Quanli Wang Yingbo Li","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/bas.glm.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Bayesian Adaptive Sampling Without Replacement for Variable Selection in\nGeneralized Linear Models — bas.glm","text":"","code":"library(MASS) data(Pima.tr) # enumeration with default method=\"BAS\" pima.cch = bas.glm(type ~ ., data=Pima.tr, n.models= 2^7, method=\"BAS\", betaprior=CCH(a=1, b=532/2, s=0), family=binomial(), modelprior=beta.binomial(1,1)) summary(pima.cch) #> P(B != 0 | Y) model 1 model 2 model 3 model 4 #> Intercept 1.0000000 1.0000 1.0000000 1.0000000 1.0000000 #> npreg 0.5684414 0.0000 1.0000000 1.0000000 0.0000000 #> glu 0.9999949 1.0000 1.0000000 1.0000000 1.0000000 #> bp 0.2198720 0.0000 0.0000000 0.0000000 0.0000000 #> skin 0.2653924 0.0000 0.0000000 0.0000000 0.0000000 #> bmi 0.7425039 1.0000 1.0000000 1.0000000 0.0000000 #> ped 0.8860972 1.0000 1.0000000 1.0000000 1.0000000 #> age 0.7459954 1.0000 1.0000000 0.0000000 1.0000000 #> BF NA 1.0000 0.4406494 0.6209086 0.4628319 #> PostProbs NA 0.1596 0.1172000 0.0991000 0.0739000 #> R2 NA 0.2938 0.3040000 0.2901000 0.2703000 #> dim NA 5.0000 6.0000000 5.0000000 4.0000000 #> logmarg NA -101.7878 -102.6072611 -102.2643268 -102.5581467 #> model 5 #> Intercept 1.000000e+00 #> npreg 1.000000e+00 #> glu 1.000000e+00 #> bp 1.000000e+00 #> skin 1.000000e+00 #> bmi 1.000000e+00 #> ped 1.000000e+00 #> age 1.000000e+00 #> BF 8.659168e-03 #> PostProbs 4.840000e-02 #> R2 3.043000e-01 #> dim 8.000000e+00 #> logmarg -1.065369e+02 image(pima.cch) # Note MCMC.iterations are set to 2500 for illustration purposes due to time # limitations for running examples on CRAN servers. # Please check convergence diagnostics and run longer in practice pima.robust = bas.glm(type ~ ., data=Pima.tr, n.models= 2^7, method=\"MCMC\", MCMC.iterations=2500, betaprior=robust(), family=binomial(), modelprior=beta.binomial(1,1)) pima.BIC = bas.glm(type ~ ., data=Pima.tr, n.models= 2^7, method=\"BAS+MCMC\", MCMC.iterations=2500, betaprior=bic.prior(), family=binomial(), modelprior=uniform()) #> Warning: no non-missing arguments to min; returning Inf # Poisson example if(requireNamespace(\"glmbb\", quietly=TRUE)) { data(crabs, package='glmbb') #short run for illustration crabs.bas = bas.glm(satell ~ color*spine*width + weight, data=crabs, family=poisson(), betaprior=EB.local(), modelprior=uniform(), method='MCMC', n.models=2^10, MCMC.iterations=2500, prob.rw=.95) # Gamma example if(requireNamespace(\"faraway\", quietly=TRUE)) { data(wafer, package='faraway') wafer_bas = bas.glm(resist~ ., data=wafer, include.always = ~ ., betaprior = bic.prior() , family = Gamma(link = \"log\")) } }"},{"path":"http://merliseclyde.github.io/BAS/reference/bas.lm.html","id":null,"dir":"Reference","previous_headings":"","what":"Bayesian Adaptive Sampling for Bayesian Model Averaging and Variable Selection in\nLinear Models — bas.lm","title":"Bayesian Adaptive Sampling for Bayesian Model Averaging and Variable Selection in\nLinear Models — bas.lm","text":"Sample without replacement posterior distribution models","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/bas.lm.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Bayesian Adaptive Sampling for Bayesian Model Averaging and Variable Selection in\nLinear Models — bas.lm","text":"","code":"bas.lm( formula, data, subset, weights, contrasts = NULL, na.action = \"na.omit\", n.models = NULL, prior = \"ZS-null\", alpha = NULL, modelprior = beta.binomial(1, 1), initprobs = \"Uniform\", include.always = ~1, method = \"BAS\", update = NULL, bestmodel = NULL, prob.local = 0, prob.rw = 0.5, MCMC.iterations = NULL, lambda = NULL, delta = 0.025, thin = 1, renormalize = FALSE, force.heredity = FALSE, pivot = TRUE, tol = 1e-07, bigmem = FALSE )"},{"path":"http://merliseclyde.github.io/BAS/reference/bas.lm.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Bayesian Adaptive Sampling for Bayesian Model Averaging and Variable Selection in\nLinear Models — bas.lm","text":"formula linear model formula full model predictors, Y ~ X. code assumes intercept included model X's centered. data data frame. Factors converted numerical vectors based using `model.matrix`. subset optional vector specifying subset observations used fitting process. weights optional vector weights used fitting process. NULL numeric vector. non-NULL, Bayes estimates obtained assuming \\(Y_i \\sim N(x^T_i\\beta, \\sigma^2/w_i)\\). contrasts optional list. See contrasts.arg `model.matrix.default()`. na.action function indicates happen data contain NAs. default \"na.omit\". n.models number models sample either without replacement (method=\"BAS\" \"MCMC+BAS\") replacement (method=\"MCMC\"). NULL, BAS method=\"BAS\" try enumerate 2^p models. enumeration possible (memory time) value supplied controls number sampled models using 'n.models'. method=\"MCMC\", sampling stop min(n.models, MCMC.iterations) occurs MCMC.iterations significantly larger n.models order explore model space. exit method= \"MCMC\" number unique models sampled counts stored output \"freq\". prior prior distribution regression coefficients. Choices include \"AIC\" \"BIC\" \"g-prior\", Zellner's g prior `g` specified using argument `alpha` \"JZS\" Jeffreys-Zellner-Siow prior uses Jeffreys prior sigma Zellner-Siow Cauchy prior coefficients. optional parameter `alpha` can used control squared scale prior, default alpha=1. Setting `alpha` equal rscale^2 BayesFactor package Morey. uses QUADMATH numerical integration g. \"ZS-null\", Laplace approximation 'JZS' prior integration g. alpha = 1 . recommend using 'JZS' accuracy compatibility BayesFactor package, although slower. \"ZS-full\" (deprecated) \"hyper-g\", mixture g-priors prior g/(1+g) Beta(1, alpha/2) Liang et al (2008). uses Cephes library evaluation marginal likelihoods may numerically unstable large n R2 close 1. Default choice alpha 3. \"hyper-g-laplace\", using Laplace approximation integrate prior g. \"hyper-g-n\", mixture g-priors u = g/n u ~ Beta(1, alpha/2) provide consistency null model true. \"EB-local\", use MLE g marginal likelihood within model \"EB-global\" uses EM algorithm find common global estimate g, averaged models. possible enumerate models, EM algorithm uses models sampled EB-local. alpha optional hyperparameter g-prior hyper g-prior. Zellner's g-prior, alpha = g, Liang et al hyper-g hyper-g-n method, recommended choice alpha (2 < alpha < 4), alpha = 3 default. Zellner-Siow prior alpha = 1 default, can used modify rate parameter gamma prior g, $$1/g \\sim G(1/2, n*\\alpha/2)$$ $$\\beta \\sim C(0, \\sigma^2 \\alpha (X'X/n)^{-1})$$. modelprior function family prior distribution models. Choices include uniform Bernoulli beta.binomial, tr.beta.binomial, (truncation) tr.poisson (truncated Poisson), tr.power.prior (truncated power family), default beta.binomial(1,1). Truncated versions useful p > n. initprobs Vector length p character string specifying method used create vector. used order variables sampling methods potentially efficient storage sampling provides initial inclusion probabilities used sampling without replacement method=\"BAS\". Options character string giving method : \"Uniform\" \"uniform\" predictor variable equally likely sampled (equivalent random sampling without replacement); \"eplogp\" uses eplogprob function approximate Bayes factor p-values full model find initial marginal inclusion probabilities; \"marg-eplogp\" useseplogprob.marg function approximate Bayes factor p-values full model simple linear regression. run Markov Chain provide initial estimates marginal inclusion probabilities \"BAS\", use method=\"MCMC+BAS\" . initprobs used sampling method=\"MCMC\", determines order variables lookup table affects memory allocation large problems enumeration feasible. variables always included set corresponding initprobs 1, override `modelprior` use `include.always` force variables always included model. include.always formula terms always included model probability one. default `~ 1` meaning intercept always included. also override values `initprobs` setting 1. method character variable indicating sampling method use: \"deterministic\" uses \"top k\" algorithm described Ghosh Clyde (2011) sample models order approximate probability conditional independence using \"initprobs\". efficient algorithm enumeration. \"BAS\" uses Bayesian Adaptive Sampling (without replacement) using sampling probabilities given initprobs model conditional independence. can updated based estimates marginal inclusion probabilities. \"MCMC\" samples replacement via MCMC algorithm combines birth/death random walk Hoeting et al (1997) MC3 random swap move interchange variable model one currently excluded described Clyde, Ghosh Littman (2010). \"MCMC+BAS\" runs initial MCMC calculate marginal inclusion probabilities samples without replacement BAS. BAS, sampling probabilities can updated models sampled. (see update ). update number iterations potential updates sampling probabilities method \"BAS\" \"MCMC+BAS\". NULL update, otherwise algorithm update using marginal inclusion probabilities change sampling takes place. large model spaces, updating recommended. model space enumerated, leave default. bestmodel optional binary vector representing model initialize sampling. NULL sampling starts null model prob.local future option allow sampling models \"near\" median probability model. used time. prob.rw MCMC methods, probability using random-walk Metropolis proposal; otherwise use random \"flip\" move propose swap variable excluded variable model. MCMC.iterations Number iterations MCMC sampler; default n.models*10 set user. lambda Parameter AMCMC algorithm (deprecated). delta truncation parameter prevent sampling probabilities degenerate 0 1 prior enumeration sampling without replacement. thin \"MCMC\" \"MCMC+BAS\", thin MCMC chain every \"thin\" iterations; default thinning. large p, thinning can used significantly reduce memory requirements models associated summaries saved every thin iterations. thin = p, model associated output recorded every p iterations, similar Gibbs sampler SSVS. renormalize MCMC sampling, posterior probabilities based renormalizing marginal likelihoods times prior probabilities (TRUE) frequencies MCMC. latter unbiased long runs, former may less variability. May compared via diagnostic plot function diagnostics. See details Clyde Ghosh (2012). force.heredity Logical variable force levels factor included together include higher order interactions lower order terms included. Currently supported `method='MCMC'` experimentally `method='BAS'` non-Solaris platforms. Default FALSE. pivot Logical variable allow pivoting columns obtaining OLS estimates model models full rank can fit. Defaults TRUE. Currently coefficients estimable set zero. Use caution interpreting BMA estimates parameters. tol 1e-7 bigmem Logical variable indicate access large amounts memory (physical virtual) enumeration large model spaces, e.g. > 2^25. default; used determining rank X^TX cholesky decomposition pivoting.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/bas.lm.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Bayesian Adaptive Sampling for Bayesian Model Averaging and Variable Selection in\nLinear Models — bas.lm","text":"bas returns object class bas object class BAS list containing least following components: postprob posterior probabilities models selected priorprobs prior probabilities models selected namesx names variables R2 R2 values models logmarg values log marginal likelihood models. equivalent log Bayes Factor comparing model base model intercept . n.vars total number independent variables full model, including intercept size number independent variables models, includes intercept rank rank design matrix; `pivot = FALSE`, size checking rank conducted. list lists one list per model variables included model probne0 posterior probability variable non-zero computed using renormalized marginal likelihoods sampled models. may biased number sampled models much smaller total number models. Unbiased estimates may obtained using method \"MCMC\". mle list lists one list per model giving MLE (OLS) estimate (nonzero) coefficient model. NOTE: intercept mean Y column X centered subtracting mean. mle.se list lists one list per model giving MLE (OLS) standard error coefficient model prior name prior created BMA object alpha value hyperparameter coefficient prior used create BMA object. modelprior prior distribution models created BMA object Y response X matrix predictors mean.x vector means column X (used predict.bas) include.always indices variables forced model function summary.bas, used print summary results. function plot.bas used plot posterior distributions coefficients image.bas provides image distribution models. Posterior summaries coefficients can extracted using coefficients.bas. Fitted values predictions can obtained using S3 functions fitted.bas predict.bas. BAS objects may updated use different prior (without rerunning sampler) using function update.bas. MCMC sampling diagnostics can used assess whether MCMC run long enough posterior probabilities stable. details see associated demos vignette.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/bas.lm.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Bayesian Adaptive Sampling for Bayesian Model Averaging and Variable Selection in\nLinear Models — bas.lm","text":"BAS provides several algorithms sample posterior distributions models use Bayesian Model Averaging Bayesian variable selection. p less 20-25, BAS can enumerate models depending memory availability. BAS saves models, MLEs, standard errors, log marginal likelihoods, prior posterior probabilities memory requirements grow linearly M*p M number models p number predictors. example, enumeration p=21 2,097,152 takes just 2 Gigabytes 64 bit machine store summaries needed model averaging. (future version likely include option store summaries users plan using model averaging model selection Best Predictive models.) larger p, BAS samples without replacement using random deterministic sampling. Bayesian Adaptive Sampling algorithm Clyde, Ghosh, Littman (2010) samples models without replacement using initial sampling probabilities, optionally update sampling probabilities every \"update\" models using estimated marginal inclusion probabilities. BAS uses different methods obtain initprobs, may impact results high-dimensional problems. deterministic sampler provides list top models order approximation independence using provided initprobs. may effective running algorithms identify high probability models works well correlations variables small modest. recommend \"MCMC\" problems enumeration feasible (memory time constrained) even modest p number models sampled close number possible models /significant correlations among predictors bias estimates inclusion probabilities \"BAS\" \"MCMC+BAS\" may large relative reduced variability using normalized model probabilities shown Clyde Ghosh, 2012. Diagnostic plots MCMC can used assess convergence. large problems recommend thinning MCMC reduce memory requirements. priors coefficients include Zellner's g-prior, Hyper-g prior (Liang et al 2008, Zellner-Siow Cauchy prior, Empirical Bayes (local global) g-priors. AIC BIC also included, range priors model space available.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/bas.lm.html","id":"references","dir":"Reference","previous_headings":"","what":"References","title":"Bayesian Adaptive Sampling for Bayesian Model Averaging and Variable Selection in\nLinear Models — bas.lm","text":"Clyde, M. Ghosh, J. Littman, M. (2010) Bayesian Adaptive Sampling Variable Selection Model Averaging. Journal Computational Graphics Statistics. 20:80-101 doi:10.1198/jcgs.2010.09049 Clyde, M. Ghosh. J. (2012) Finite population estimators stochastic search variable selection. Biometrika, 99 (4), 981-988. doi:10.1093/biomet/ass040 Clyde, M. George, E. . (2004) Model Uncertainty. Statist. Sci., 19, 81-94. doi:10.1214/088342304000000035 Clyde, M. (1999) Bayesian Model Averaging Model Search Strategies (discussion). Bayesian Statistics 6. J.M. Bernardo, .P. Dawid, J.O. Berger, .F.M. Smith eds. Oxford University Press, pages 157-185. Hoeting, J. ., Madigan, D., Raftery, . E. Volinsky, C. T. (1999) Bayesian model averaging: tutorial (discussion). Statist. Sci., 14, 382-401. doi:10.1214/ss/1009212519 Liang, F., Paulo, R., Molina, G., Clyde, M. Berger, J.O. (2008) Mixtures g-priors Bayesian Variable Selection. Journal American Statistical Association. 103:410-423. doi:10.1198/016214507000001337 Zellner, . (1986) assessing prior distributions Bayesian regression analysis g-prior distributions. Bayesian Inference Decision Techniques: Essays Honor Bruno de Finetti, pp. 233-243. North-Holland/Elsevier. Zellner, . Siow, . (1980) Posterior odds ratios selected regression hypotheses. Bayesian Statistics: Proceedings First International Meeting held Valencia (Spain), pp. 585-603. Rouder, J. N., Speckman, P. L., Sun, D., Morey, R. D., Iverson, G. (2009). Bayesian t-tests accepting rejecting null hypothesis. Psychonomic Bulletin & Review, 16, 225-237 Rouder, J. N., Morey, R. D., Speckman, P. L., Province, J. M., (2012) Default Bayes Factors ANOVA Designs. Journal Mathematical Psychology. 56. p. 356-374.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/bas.lm.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Bayesian Adaptive Sampling for Bayesian Model Averaging and Variable Selection in\nLinear Models — bas.lm","text":"Merlise Clyde (clyde@duke.edu) Michael Littman","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/bas.lm.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Bayesian Adaptive Sampling for Bayesian Model Averaging and Variable Selection in\nLinear Models — bas.lm","text":"","code":"library(MASS) data(UScrime) # pivot=FALSE is faster, but should only be used in full rank case # default is pivot = TRUE crime.bic <- bas.lm(log(y) ~ log(M) + So + log(Ed) + log(Po1) + log(Po2) + log(LF) + log(M.F) + log(Pop) + log(NW) + log(U1) + log(U2) + log(GDP) + log(Ineq) + log(Prob) + log(Time), data = UScrime, n.models = 2^15, prior = \"BIC\", modelprior = beta.binomial(1, 1), initprobs = \"eplogp\", pivot = FALSE ) # use MCMC rather than enumeration crime.mcmc <- bas.lm(log(y) ~ log(M) + So + log(Ed) + log(Po1) + log(Po2) + log(LF) + log(M.F) + log(Pop) + log(NW) + log(U1) + log(U2) + log(GDP) + log(Ineq) + log(Prob) + log(Time), data = UScrime, method = \"MCMC\", MCMC.iterations = 20000, prior = \"BIC\", modelprior = beta.binomial(1, 1), initprobs = \"eplogp\", pivot = FALSE ) summary(crime.bic) #> P(B != 0 | Y) model 1 model 2 model 3 model 4 #> Intercept 1.0000000 1.00000 1.000000e+00 1.0000000 1.0000000 #> log(M) 0.9335117 1.00000 1.000000e+00 1.0000000 1.0000000 #> So 0.3276563 0.00000 1.000000e+00 0.0000000 0.0000000 #> log(Ed) 0.9910219 1.00000 1.000000e+00 1.0000000 1.0000000 #> log(Po1) 0.7246635 1.00000 1.000000e+00 1.0000000 1.0000000 #> log(Po2) 0.4602481 0.00000 1.000000e+00 0.0000000 0.0000000 #> log(LF) 0.2935326 0.00000 1.000000e+00 0.0000000 0.0000000 #> log(M.F) 0.3298168 0.00000 1.000000e+00 0.0000000 0.0000000 #> log(Pop) 0.4962869 0.00000 1.000000e+00 0.0000000 0.0000000 #> log(NW) 0.8346412 1.00000 1.000000e+00 1.0000000 1.0000000 #> log(U1) 0.3481266 0.00000 1.000000e+00 0.0000000 0.0000000 #> log(U2) 0.7752102 1.00000 1.000000e+00 1.0000000 1.0000000 #> log(GDP) 0.5253694 0.00000 1.000000e+00 0.0000000 1.0000000 #> log(Ineq) 0.9992058 1.00000 1.000000e+00 1.0000000 1.0000000 #> log(Prob) 0.9541470 1.00000 1.000000e+00 1.0000000 1.0000000 #> log(Time) 0.5432686 1.00000 1.000000e+00 0.0000000 1.0000000 #> BF NA 1.00000 1.267935e-04 0.7609295 0.5431578 #> PostProbs NA 0.01910 1.560000e-02 0.0145000 0.0133000 #> R2 NA 0.84200 8.695000e-01 0.8265000 0.8506000 #> dim NA 9.00000 1.600000e+01 8.0000000 10.0000000 #> logmarg NA -22.15855 -3.113150e+01 -22.4317627 -22.7689035 #> model 5 #> Intercept 1.0000000 #> log(M) 1.0000000 #> So 0.0000000 #> log(Ed) 1.0000000 #> log(Po1) 1.0000000 #> log(Po2) 0.0000000 #> log(LF) 0.0000000 #> log(M.F) 0.0000000 #> log(Pop) 1.0000000 #> log(NW) 1.0000000 #> log(U1) 0.0000000 #> log(U2) 1.0000000 #> log(GDP) 0.0000000 #> log(Ineq) 1.0000000 #> log(Prob) 1.0000000 #> log(Time) 0.0000000 #> BF 0.5203179 #> PostProbs 0.0099000 #> R2 0.8375000 #> dim 9.0000000 #> logmarg -22.8118635 plot(crime.bic) image(crime.bic, subset = -1) # example with two-way interactions and hierarchical constraints data(ToothGrowth) ToothGrowth$dose <- factor(ToothGrowth$dose) levels(ToothGrowth$dose) <- c(\"Low\", \"Medium\", \"High\") TG.bas <- bas.lm(len ~ supp * dose, data = ToothGrowth, modelprior = uniform(), method = \"BAS\", force.heredity = TRUE ) summary(TG.bas) #> P(B != 0 | Y) model 1 model 2 model 3 model 4 #> Intercept 1.0000000 1.00000 1.0000000 1.00000000 1.000000e+00 #> suppVC 0.9910702 1.00000 1.0000000 0.00000000 0.000000e+00 #> doseMedium 1.0000000 1.00000 1.0000000 1.00000000 0.000000e+00 #> doseHigh 1.0000000 1.00000 1.0000000 1.00000000 0.000000e+00 #> suppVC:doseMedium 0.4500943 0.00000 1.0000000 0.00000000 0.000000e+00 #> suppVC:doseHigh 0.4500943 0.00000 1.0000000 0.00000000 0.000000e+00 #> BF NA 1.00000 0.8320043 0.01650685 2.812754e-15 #> PostProbs NA 0.54100 0.4501000 0.00890000 0.000000e+00 #> R2 NA 0.76230 0.7937000 0.70290000 0.000000e+00 #> dim NA 4.00000 6.0000000 3.00000000 1.000000e+00 #> logmarg NA 33.50461 33.3206946 29.40063248 0.000000e+00 #> model 5 #> Intercept 1.000000e+00 #> suppVC 1.000000e+00 #> doseMedium 0.000000e+00 #> doseHigh 0.000000e+00 #> suppVC:doseMedium 0.000000e+00 #> suppVC:doseHigh 0.000000e+00 #> BF 7.895214e-16 #> PostProbs 0.000000e+00 #> R2 5.950000e-02 #> dim 2.000000e+00 #> logmarg -1.270492e+00 image(TG.bas) # don't run the following due to time limits on CRAN if (FALSE) { # exmple with non-full rank case loc <- system.file(\"testdata\", package = \"BAS\") d <- read.csv(paste(loc, \"JASP-testdata.csv\", sep = \"/\")) fullModelFormula <- as.formula(\"contNormal ~ contGamma * contExpon + contGamma * contcor1 + contExpon * contcor1\") # should trigger a warning (default is to use pivoting, so use pivot=FALSE # only for full rank case) out = bas.lm(fullModelFormula, data = d, alpha = 0.125316, prior = \"JZS\", weights = facFifty, force.heredity = FALSE, pivot = FALSE) # use pivot = TRUE to fit non-full rank case (default) # This is slower but safer out = bas.lm(fullModelFormula, data = d, alpha = 0.125316, prior = \"JZS\", weights = facFifty, force.heredity = FALSE, pivot = TRUE) } # more complete demo's demo(BAS.hald) #> #> #> \tdemo(BAS.hald) #> \t---- ~~~~~~~~ #> #> > data(Hald) #> #> > hald.gprior = bas.lm(Y~ ., data=Hald, prior=\"g-prior\", alpha=13, #> + modelprior=beta.binomial(1,1), #> + initprobs=\"eplogp\") #> #> > hald.gprior #> #> Call: #> bas.lm(formula = Y ~ ., data = Hald, prior = \"g-prior\", alpha = 13, #> modelprior = beta.binomial(1, 1), initprobs = \"eplogp\") #> #> #> Marginal Posterior Inclusion Probabilities: #> Intercept X1 X2 X3 X4 #> 1.0000 0.9019 0.6896 0.4653 0.6329 #> #> > plot(hald.gprior) #> #> > summary(hald.gprior) #> P(B != 0 | Y) model 1 model 2 model 3 model 4 model 5 #> Intercept 1.0000000 1.00000 1.0000000 1.00000000 1.0000000 1.0000000 #> X1 0.9019245 1.00000 1.0000000 1.00000000 1.0000000 1.0000000 #> X2 0.6895830 1.00000 0.0000000 1.00000000 1.0000000 1.0000000 #> X3 0.4652762 0.00000 0.0000000 1.00000000 0.0000000 1.0000000 #> X4 0.6329266 0.00000 1.0000000 1.00000000 1.0000000 0.0000000 #> BF NA 1.00000 0.6923944 0.08991408 0.3355714 0.3344926 #> PostProbs NA 0.24320 0.1684000 0.13120000 0.1224000 0.1220000 #> R2 NA 0.97870 0.9725000 0.98240000 0.9823000 0.9823000 #> dim NA 3.00000 3.0000000 5.00000000 4.0000000 4.0000000 #> logmarg NA 11.72735 11.3597547 9.31845348 10.6354335 10.6322138 #> #> > image(hald.gprior, subset=-1, vlas=0) #> #> > hald.coef = coefficients(hald.gprior) #> #> > hald.coef #> #> Marginal Posterior Summaries of Coefficients: #> #> Using BMA #> #> Based on the top 16 models #> post mean post SD post p(B != 0) #> Intercept 95.4231 0.7107 1.0000 #> X1 1.2150 0.5190 0.9019 #> X2 0.2756 0.4832 0.6896 #> X3 -0.1271 0.4976 0.4653 #> X4 -0.3269 0.4717 0.6329 #> #> > plot(hald.coef) #> #> > predict(hald.gprior, top=5, se.fit=TRUE) #> $fit #> [1] 79.74246 74.50010 105.29268 89.88693 95.57177 104.56409 103.40145 #> [8] 77.13668 91.99731 114.21325 82.78446 111.00723 110.40160 #> #> $Ybma #> [,1] #> [1,] 79.74246 #> [2,] 74.50010 #> [3,] 105.29268 #> [4,] 89.88693 #> [5,] 95.57177 #> [6,] 104.56409 #> [7,] 103.40145 #> [8,] 77.13668 #> [9,] 91.99731 #> [10,] 114.21325 #> [11,] 82.78446 #> [12,] 111.00723 #> [13,] 110.40160 #> #> $Ypred #> [,1] [,2] [,3] [,4] [,5] [,6] [,7] [,8] #> [1,] 81.17036 74.83464 105.0725 89.69881 97.15898 104.4575 103.3893 76.06454 #> [2,] 77.70296 74.24113 105.8554 90.46267 93.09565 104.7152 103.1399 78.80193 #> [3,] 79.70437 74.40553 105.2175 89.76253 95.63309 104.5709 103.5254 77.08557 #> [4,] 79.65151 74.47846 105.4218 89.83174 95.62799 104.5962 103.5068 77.00839 #> [5,] 79.84321 74.31409 104.9063 89.65651 95.70301 104.5285 103.5476 77.15919 #> [,9] [,10] [,11] [,12] [,13] #> [1,] 91.57174 113.1722 81.59906 111.2219 111.0884 #> [2,] 92.68123 115.8058 84.50293 110.4162 109.0791 #> [3,] 91.98604 114.1759 82.78145 111.1196 110.5321 #> [4,] 92.07571 114.1088 82.68233 111.0429 110.4674 #> [5,] 91.83513 114.2353 82.88128 111.2384 110.6515 #> #> $postprobs #> [1] 0.3089304 0.2139017 0.1666632 0.1555023 0.1550024 #> #> $se.fit #> [,1] [,2] [,3] [,4] [,5] [,6] [,7] [,8] #> [1,] 2.220164 2.265862 1.546911 2.181188 1.310135 1.523300 2.655096 2.176560 #> [2,] 2.716798 2.389723 1.633637 2.179215 1.321062 1.581232 2.721957 2.078129 #> [3,] 3.203405 2.501485 3.279273 2.357164 2.589756 1.549136 2.623290 2.765255 #> [4,] 3.117350 2.283957 1.602160 2.149087 2.589321 1.508471 2.610923 2.545817 #> [5,] 2.932580 2.353352 1.538009 2.141694 2.507848 1.498758 2.616407 2.680289 #> [,9] [,10] [,11] [,12] [,13] #> [1,] 1.883610 3.264656 1.908238 1.970691 2.054234 #> [2,] 2.013244 3.298134 1.933819 1.964374 1.924460 #> [3,] 2.353516 3.609909 2.821295 2.227363 2.390135 #> [4,] 1.990817 3.485929 2.456636 1.951456 2.212238 #> [5,] 1.889302 3.569065 2.665166 1.934336 2.117189 #> #> $se.pred #> [,1] [,2] [,3] [,4] [,5] [,6] [,7] [,8] #> [1,] 5.057182 5.077410 4.799885 5.040193 4.728892 4.792328 5.262651 5.038191 #> [2,] 5.415848 5.259391 4.961773 5.167146 4.867815 4.944766 5.418438 5.125333 #> [3,] 5.489152 5.111401 5.533771 5.042342 5.155175 4.718984 5.172102 5.245534 #> [4,] 5.440156 5.009380 4.737547 4.949344 5.155775 4.706689 5.166658 5.134065 #> [5,] 5.337427 5.042456 4.717369 4.947217 5.116386 4.704719 5.170463 5.203081 #> [,9] [,10] [,11] [,12] [,13] #> [1,] 4.918734 5.594992 4.928218 4.952735 4.986566 #> [2,] 5.099370 5.729582 5.068538 5.080274 5.064974 #> [3,] 5.040638 5.735890 5.275291 4.982985 5.057839 #> [4,] 4.882702 5.659428 5.090431 4.866787 4.977090 #> [5,] 4.843301 5.711946 5.195307 4.861045 4.936658 #> #> $se.bma.fit #> [1] 2.688224 2.095245 1.769625 1.970919 2.197285 1.363804 2.356457 2.302631 #> [9] 1.822084 3.141443 2.237663 1.801849 1.991374 #> #> $se.bma.pred #> [1] 4.838655 4.536087 4.395180 4.480017 4.584113 4.248058 4.662502 4.635531 #> [9] 4.416563 5.104380 4.603604 4.408253 4.489054 #> #> $df #> [1] 12 12 12 12 12 #> #> $best #> [1] 5 13 3 6 4 #> #> $bestmodel #> $bestmodel[[1]] #> [1] 0 1 2 #> #> $bestmodel[[2]] #> [1] 0 1 4 #> #> $bestmodel[[3]] #> [1] 0 1 2 3 4 #> #> $bestmodel[[4]] #> [1] 0 1 2 4 #> #> $bestmodel[[5]] #> [1] 0 1 2 3 #> #> #> $best.vars #> [1] \"Intercept\" \"X1\" \"X2\" \"X3\" \"X4\" #> #> $estimator #> [1] \"BMA\" #> #> attr(,\"class\") #> [1] \"pred.bas\" #> #> > confint(predict(hald.gprior, Hald, estimator=\"BMA\", se.fit=TRUE, top=5), parm=\"mean\") #> 2.5% 97.5% mean #> [1,] 72.82752 85.85915 79.74246 #> [2,] 69.12925 79.49711 74.50010 #> [3,] 101.00483 109.62215 105.29268 #> [4,] 85.03125 94.49408 89.88693 #> [5,] 90.33108 100.35580 95.57177 #> [6,] 101.28114 107.89645 104.56409 #> [7,] 97.65077 109.24776 103.40145 #> [8,] 71.65790 82.82641 77.13668 #> [9,] 87.50634 96.49823 91.99731 #> [10,] 106.69784 121.76761 114.21325 #> [11,] 77.27222 87.98703 82.78446 #> [12,] 106.67049 115.50991 111.00723 #> [13,] 105.72994 115.21142 110.40160 #> attr(,\"Probability\") #> [1] 0.95 #> attr(,\"class\") #> [1] \"confint.bas\" #> #> > predict(hald.gprior, estimator=\"MPM\", se.fit=TRUE) #> $fit #> [1] 79.65151 74.47846 105.42183 89.83174 95.62799 104.59616 103.50684 #> [8] 77.00839 92.07571 114.10876 82.68233 111.04286 110.46741 #> attr(,\"model\") #> [1] 0 1 2 4 #> attr(,\"best\") #> [1] 1 #> attr(,\"estimator\") #> [1] \"MPM\" #> #> $Ybma #> [1] 79.65151 74.47846 105.42183 89.83174 95.62799 104.59616 103.50684 #> [8] 77.00839 92.07571 114.10876 82.68233 111.04286 110.46741 #> attr(,\"model\") #> [1] 0 1 2 4 #> attr(,\"best\") #> [1] 1 #> attr(,\"estimator\") #> [1] \"MPM\" #> #> $Ypred #> NULL #> #> $postprobs #> NULL #> #> $se.fit #> [1] 3.117350 2.283957 1.602160 2.149087 2.589321 1.508471 2.610923 2.545817 #> [9] 1.990817 3.485929 2.456636 1.951456 2.212238 #> #> $se.pred #> [1] 5.440156 5.009380 4.737547 4.949344 5.155775 4.706689 5.166658 5.134065 #> [9] 4.882702 5.659428 5.090431 4.866787 4.977090 #> #> $se.bma.fit #> NULL #> #> $se.bma.pred #> NULL #> #> $df #> [1] 12 #> #> $best #> NULL #> #> $bestmodel #> [1] 0 1 2 4 #> #> $best.vars #> [1] \"Intercept\" \"X1\" \"X2\" \"X4\" #> #> $estimator #> [1] \"MPM\" #> #> attr(,\"class\") #> [1] \"pred.bas\" #> #> > confint(predict(hald.gprior, Hald, estimator=\"MPM\", se.fit=TRUE), parm=\"mean\") #> 2.5% 97.5% mean #> [1,] 72.85939 86.44363 79.65151 #> [2,] 69.50215 79.45478 74.47846 #> [3,] 101.93102 108.91264 105.42183 #> [4,] 85.14928 94.51420 89.83174 #> [5,] 89.98634 101.26964 95.62799 #> [6,] 101.30948 107.88283 104.59616 #> [7,] 97.81813 109.19556 103.50684 #> [8,] 71.46153 82.55525 77.00839 #> [9,] 87.73810 96.41333 92.07571 #> [10,] 106.51357 121.70394 114.10876 #> [11,] 77.32978 88.03488 82.68233 #> [12,] 106.79101 115.29472 111.04286 #> [13,] 105.64736 115.28746 110.46741 #> attr(,\"Probability\") #> [1] 0.95 #> attr(,\"class\") #> [1] \"confint.bas\" #> #> > fitted(hald.gprior, estimator=\"HPM\") #> [1] 81.17036 74.83464 105.07248 89.69881 97.15898 104.45753 103.38927 #> [8] 76.06454 91.57174 113.17222 81.59906 111.22195 111.08841 #> #> > hald.gprior = bas.lm(Y~ ., data=Hald, n.models=2^4, #> + prior=\"g-prior\", alpha=13, modelprior=uniform(), #> + initprobs=\"eplogp\") #> #> > hald.EB = update(hald.gprior, newprior=\"EB-global\") #> #> > hald.bic = update(hald.gprior,newprior=\"BIC\") #> #> > hald.zs = update(hald.bic, newprior=\"ZS-null\") if (FALSE) { demo(BAS.USCrime) }"},{"path":"http://merliseclyde.github.io/BAS/reference/bayesglm.fit.html","id":null,"dir":"Reference","previous_headings":"","what":"Fitting Generalized Linear Models and Bayesian marginal likelihood\nevaluation — bayesglm.fit","title":"Fitting Generalized Linear Models and Bayesian marginal likelihood\nevaluation — bayesglm.fit","text":"version glm.fit rewritten C; also returns marginal likelihoods Bayesian model comparison","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/bayesglm.fit.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Fitting Generalized Linear Models and Bayesian marginal likelihood\nevaluation — bayesglm.fit","text":"","code":"bayesglm.fit( x, y, weights = rep(1, nobs), start = NULL, etastart = NULL, mustart = NULL, offset = rep(0, nobs), family = binomial(), coefprior = bic.prior(nobs), control = glm.control(), intercept = TRUE )"},{"path":"http://merliseclyde.github.io/BAS/reference/bayesglm.fit.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Fitting Generalized Linear Models and Bayesian marginal likelihood\nevaluation — bayesglm.fit","text":"x design matrix y response weights optional vector weights used fitting process. NULL numeric vector. start starting value coefficients linear predictor etastart starting values linear predictor mustart starting values vectors means offset priori known component included linear predictor family description error distribution link function exponential family; currently binomial(), poisson(), Gamma() canonical links implemented. coefprior function specifying prior distribution coefficients optional hyperparameters leading marginal likelihood calculations; options include bic.prior(), aic.prior(), ic.prior() control list parameters control convergence fitting process. See documentation glm.control() intercept intercept included null model?","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/bayesglm.fit.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Fitting Generalized Linear Models and Bayesian marginal likelihood\nevaluation — bayesglm.fit","text":"coefficients MLEs se Standard errors coefficients based sqrt diagonal inverse information matrix mu fitted mean rank numeric rank fitted linear model deviance minus twice log likelihood evaluated MLEs g value g g-priors shrinkage shrinkage factor coefficients linear predictor RegSS quadratic form beta'(beta)beta used shrinkage logmarglik log marginal integrated log likelihood (constant)","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/bayesglm.fit.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Fitting Generalized Linear Models and Bayesian marginal likelihood\nevaluation — bayesglm.fit","text":"C version glm-fit. different prior choices returns, marginal likelihood model using Laplace approximation.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/bayesglm.fit.html","id":"references","dir":"Reference","previous_headings":"","what":"References","title":"Fitting Generalized Linear Models and Bayesian marginal likelihood\nevaluation — bayesglm.fit","text":"glm","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/bayesglm.fit.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Fitting Generalized Linear Models and Bayesian marginal likelihood\nevaluation — bayesglm.fit","text":"Merlise Clyde translated glm.fit R base C using .Call interface","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/bayesglm.fit.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Fitting Generalized Linear Models and Bayesian marginal likelihood\nevaluation — bayesglm.fit","text":"","code":"data(Pima.tr, package=\"MASS\") Y <- as.numeric(Pima.tr$type) - 1 X <- cbind(1, as.matrix(Pima.tr[,1:7])) out <- bayesglm.fit(X, Y, family=binomial(),coefprior=bic.prior(n=length(Y))) out$coef #> [1] -9.773061533 0.103183427 0.032116823 -0.004767542 -0.001916632 #> [6] 0.083623912 1.820410367 0.041183529 out$se #> [1] 1.770386016 0.064694153 0.006787299 0.018540741 0.022499541 0.042826888 #> [7] 0.665513776 0.022090978 # using built in function glm(type ~ ., family=binomial(), data=Pima.tr) #> #> Call: glm(formula = type ~ ., family = binomial(), data = Pima.tr) #> #> Coefficients: #> (Intercept) npreg glu bp skin bmi #> -9.773062 0.103183 0.032117 -0.004768 -0.001917 0.083624 #> ped age #> 1.820410 0.041184 #> #> Degrees of Freedom: 199 Total (i.e. Null); 192 Residual #> Null Deviance:\t 256.4 #> Residual Deviance: 178.4 \tAIC: 194.4"},{"path":"http://merliseclyde.github.io/BAS/reference/beta.binomial.html","id":null,"dir":"Reference","previous_headings":"","what":"Beta-Binomial Prior Distribution for Models — beta.binomial","title":"Beta-Binomial Prior Distribution for Models — beta.binomial","text":"Creates object representing prior distribution models BAS.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/beta.binomial.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Beta-Binomial Prior Distribution for Models — beta.binomial","text":"","code":"beta.binomial(alpha = 1, beta = 1)"},{"path":"http://merliseclyde.github.io/BAS/reference/beta.binomial.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Beta-Binomial Prior Distribution for Models — beta.binomial","text":"alpha parameter beta prior distribution beta parameter beta prior distribution","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/beta.binomial.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Beta-Binomial Prior Distribution for Models — beta.binomial","text":"returns object class \"prior\", family hyperparameters.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/beta.binomial.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Beta-Binomial Prior Distribution for Models — beta.binomial","text":"beta-binomial distribution model size obtained assigning variable inclusion indicator independent Bernoulli distributions probability w, giving w beta(alpha,beta) distribution. Marginalizing w leads distribution model size beta-binomial distribution. default hyperparameters lead uniform distribution model size.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/beta.binomial.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Beta-Binomial Prior Distribution for Models — beta.binomial","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/beta.binomial.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Beta-Binomial Prior Distribution for Models — beta.binomial","text":"","code":"beta.binomial(1, 10) #' @family priors modelpriors #> $family #> [1] \"Beta-Binomial\" #> #> $hyper.parameters #> [1] 1 10 #> #> attr(,\"class\") #> [1] \"prior\""},{"path":"http://merliseclyde.github.io/BAS/reference/beta.prime.html","id":null,"dir":"Reference","previous_headings":"","what":"Beta-Prime Prior Distribution for Coefficients in BMA Model — beta.prime","title":"Beta-Prime Prior Distribution for Coefficients in BMA Model — beta.prime","text":"Creates object representing Beta-Prime prior mixture g-priors coefficients BAS.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/beta.prime.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Beta-Prime Prior Distribution for Coefficients in BMA Model — beta.prime","text":"","code":"beta.prime(n = NULL)"},{"path":"http://merliseclyde.github.io/BAS/reference/beta.prime.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Beta-Prime Prior Distribution for Coefficients in BMA Model — beta.prime","text":"n sample size; NULL, value derived data call `bas.glm` used.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/beta.prime.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Beta-Prime Prior Distribution for Coefficients in BMA Model — beta.prime","text":"returns object class \"prior\", family hyerparameters.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/beta.prime.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Beta-Prime Prior Distribution for Coefficients in BMA Model — beta.prime","text":"Creates structure used bas.glm.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/beta.prime.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Beta-Prime Prior Distribution for Coefficients in BMA Model — beta.prime","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/beta.prime.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Beta-Prime Prior Distribution for Coefficients in BMA Model — beta.prime","text":"","code":"beta.prime(n = 100) #> $family #> [1] \"betaprime\" #> #> $class #> [1] \"TCCH\" #> #> $hyper.parameters #> $hyper.parameters$n #> [1] 100 #> #> $hyper.parameters$alpha #> [1] 0.5 #> #> #> attr(,\"class\") #> [1] \"prior\""},{"path":"http://merliseclyde.github.io/BAS/reference/bodyfat.html","id":null,"dir":"Reference","previous_headings":"","what":"Bodyfat Data — bodyfat","title":"Bodyfat Data — bodyfat","text":"Lists estimates percentage body fat determined underwater weighing various body circumference measurements 252 men. Accurate measurement body fat inconvenient/costly desirable easy methods estimating body fat inconvenient/costly.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/bodyfat.html","id":"format","dir":"Reference","previous_headings":"","what":"Format","title":"Bodyfat Data — bodyfat","text":"data frame 252 observations following 15 variables. Density numeric vector density determined underwater weighing Bodyfat percent body fat Siri's (1956) equation Age age individual years Weight weight individual pounds Height height individual inches Neck neck circumference centimeters (cm) Chest chest circumference (cm) Abdomen abdomen circumference (cm) Hip hip circumference (cm) \"Thigh\" thigh circumference (cm) \"Knee\" knee circumference (cm) Ankle ankle circumference (cm) Biceps bicep (extended) circumference (cm) Forearm forearm circumference (cm) Wrist wrist circumference (cm)","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/bodyfat.html","id":"source","dir":"Reference","previous_headings":"","what":"Source","title":"Bodyfat Data — bodyfat","text":"data used produce predictive equations lean body weight given abstract \"Generalized body composition prediction equation men using simple measurement techniques\", K.W. Penrose, .G. Nelson, .G. Fisher, FACSM, Human Performance Research Center, Brigham Young University, Provo, Utah 84602 listed _Medicine Science Sports Exercise_, vol. 17, . 2, April 1985, p. 189. (predictive equations obtained first 143 252 cases listed ). data generously supplied Dr. . Garth Fisher gave permission freely distribute data use non-commercial purposes.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/bodyfat.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Bodyfat Data — bodyfat","text":"variety popular health books suggest readers assess health, least part, estimating percentage body fat. Bailey (1994), instance, reader can estimate body fat tables using age various skin-fold measurements obtained using caliper. texts give predictive equations body fat using body circumference measurements (e.g. abdominal circumference) /skin-fold measurements. See, instance, Behnke Wilmore (1974), pp. 66-67; Wilmore (1976), p. 247; Katch McArdle (1977), pp. 120-132).# Percentage body fat individual can estimated body density determined. Folks (e.g. Siri (1956)) assume body consists two components - lean body tissue fat tissue. Letting D = Body Density (gm/cm^3) = proportion lean body tissue B = proportion fat tissue (+B=1) = density lean body tissue (gm/cm^3) b = density fat tissue (gm/cm^3) D = 1/[(/) + (B/b)] solving B find B = (1/D)*[ab/(-b)] - [b/(-b)]. Using estimates =1.10 gm/cm^3 b=0.90 gm/cm^3 (see Katch McArdle (1977), p. 111 Wilmore (1976), p. 123) come \"Siri's equation\": Percentage Body Fat (.e. 100*B) = 495/D - 450.# Volume, hence body density, can accurately measured variety ways. technique underwater weighing \"computes body volume difference body weight measured air weight measured water submersion. words, body volume equal loss weight water appropriate temperature correction water's density\" (Katch McArdle (1977), p. 113). Using technique, Body Density = WA/[(WA-WW)/c.f. - LV] WA = Weight air (kg) WW = Weight water (kg) c.f. = Water correction factor (=1 39.2 deg F one-gram water occupies exactly one cm^3 temperature, =.997 76-78 deg F) LV = Residual Lung Volume (liters) (Katch McArdle (1977), p. 115). methods determining body volume given Behnke Wilmore (1974), p. 22 ff. Measurement standards apparently listed Behnke Wilmore (1974), pp. 45-48 , instance, abdomen circumference measured \"laterally, level iliac crests, anteriorly, umbilicus\".)","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/bodyfat.html","id":"references","dir":"Reference","previous_headings":"","what":"References","title":"Bodyfat Data — bodyfat","text":"Bailey, Covert (1994). Smart Exercise: Burning Fat, Getting Fit, Houghton-Mifflin Co., Boston, pp. 179-186. Behnke, .R. Wilmore, J.H. (1974). Evaluation Regulation Body Build Composition, Prentice-Hall, Englewood Cliffs, N.J. Siri, W.E. (1956), \"Gross composition body\", Advances Biological Medical Physics, vol. IV, edited J.H. Lawrence C.. Tobias, Academic Press, Inc., New York. Katch, Frank McArdle, William (1977). Nutrition, Weight Control, Exercise, Houghton Mifflin Co., Boston. Wilmore, Jack (1976). Athletic Training Physical Fitness: Physiological Principles Conditioning Process, Allyn Bacon, Inc., Boston.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/bodyfat.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Bodyfat Data — bodyfat","text":"","code":"data(bodyfat) bodyfat.bas = bas.lm(Bodyfat ~ Abdomen, data=bodyfat, prior=\"ZS-null\") summary(bodyfat.bas) #> P(B != 0 | Y) model 1 model 2 #> Intercept 1 1.0000 1.000000e+00 #> Abdomen 1 1.0000 0.000000e+00 #> BF NA 1.0000 1.039211e-57 #> PostProbs NA 1.0000 0.000000e+00 #> R2 NA 0.6617 0.000000e+00 #> dim NA 2.0000 1.000000e+00 #> logmarg NA 131.2089 0.000000e+00 plot(Bodyfat ~ Abdomen, data=bodyfat, xlab=\"abdomen circumference (cm)\") betas = coef(bodyfat.bas)$postmean # current version has that intercept is ybar betas[1] = betas[1] - betas[2]*bodyfat.bas$mean.x abline(betas) abline(coef(lm(Bodyfat ~ Abdomen, data=bodyfat)), col=2, lty=2)"},{"path":"http://merliseclyde.github.io/BAS/reference/climate.html","id":null,"dir":"Reference","previous_headings":"","what":"Climate Data — climate","title":"Climate Data — climate","text":"Climate Data","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/climate.html","id":"format","dir":"Reference","previous_headings":"","what":"Format","title":"Climate Data — climate","text":"Scientists interested Earth's temperature change since last glacial maximum, 20,000 years ago. first study estimate temperature change published 1980, estimated change -1.5 degrees C, +/- 1.2 degrees C tropical sea surface temperatures. negative value means Earth colder now. Since 1980 many studies. climate dataset 63 measurements 5 variables: sdev standard deviation calculated deltaT; proxy number 1-8 reflecting type measurement system used derive deltaT. proxies can used land, others water. proxies coded 1 \"Mg/Ca\" 2 \"alkenone\" 3 \"Faunal\" 4 \"Sr/Ca\" 5 \"del 180\" 6 \"Ice Core\" 7 \"Pollen\" 8 \"Noble Gas\" T/M , indicator whether terrestrial marine study (T/M), coded 0 Terrestrial, 1 Marine; latitude latitude data collected.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/climate.html","id":"source","dir":"Reference","previous_headings":"","what":"Source","title":"Climate Data — climate","text":"Data provided originally Michael Lavine","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/coef.html","id":null,"dir":"Reference","previous_headings":"","what":"Coefficients of a Bayesian Model Average object — coef.bas","title":"Coefficients of a Bayesian Model Average object — coef.bas","text":"Extract conditional posterior means standard deviations, marginal posterior means standard deviations, posterior probabilities, marginal inclusions probabilities Bayesian Model Averaging object class 'bas'","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/coef.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Coefficients of a Bayesian Model Average object — coef.bas","text":"","code":"# S3 method for bas coef(object, n.models, estimator = \"BMA\", ...) # S3 method for coef.bas print(x, digits = max(3, getOption(\"digits\") - 3), ...)"},{"path":"http://merliseclyde.github.io/BAS/reference/coef.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Coefficients of a Bayesian Model Average object — coef.bas","text":"object object class 'bas' created BAS n.models Number top models report printed summary, coef default use models. extract summaries Highest Probability Model, use n.models=1 estimator=\"HPM\". estimator return summaries selected model, rather using BMA. Options 'HPM' (highest posterior probability model) ,'MPM' (median probability model), 'BMA' ... optional arguments x object class 'coef.bas' print digits number significant digits print","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/coef.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Coefficients of a Bayesian Model Average object — coef.bas","text":"coefficients returns object class coef.bas following: conditionalmeans matrix conditional posterior means model conditionalsd standard deviations model postmean marginal posterior means regression coefficient using BMA postsd marginal posterior standard deviations using BMA postne0 vector posterior inclusion probabilities, marginal probability coefficient non-zero","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/coef.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Coefficients of a Bayesian Model Average object — coef.bas","text":"Calculates posterior means (approximate) standard deviations regression coefficients Bayesian Model averaging using g-priors mixtures g-priors. Print returns overall summaries. fully Bayesian methods place prior g, posterior standard deviations take account full uncertainty regarding g. updated future releases.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/coef.html","id":"note","dir":"Reference","previous_headings":"","what":"Note","title":"Coefficients of a Bayesian Model Average object — coef.bas","text":"highly correlated variables, marginal summaries may representative joint distribution. Use plot.coef.bas view distributions. value reported intercept centered parameterization. Gaussian error model centered sample mean Y.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/coef.html","id":"references","dir":"Reference","previous_headings":"","what":"References","title":"Coefficients of a Bayesian Model Average object — coef.bas","text":"Liang, F., Paulo, R., Molina, G., Clyde, M. Berger, J.O. (2005) Mixtures g-priors Bayesian Variable Selection. Journal American Statistical Association. 103:410-423. doi:10.1198/016214507000001337","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/coef.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Coefficients of a Bayesian Model Average object — coef.bas","text":"Merlise Clyde clyde@duke.edu","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/coef.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Coefficients of a Bayesian Model Average object — coef.bas","text":"","code":"data(\"Hald\") hald.gprior = bas.lm(Y~ ., data=Hald, n.models=2^4, alpha=13, prior=\"ZS-null\", initprobs=\"Uniform\", update=10) coef.hald.gprior = coefficients(hald.gprior) coef.hald.gprior #> #> Marginal Posterior Summaries of Coefficients: #> #> Using BMA #> #> Based on the top 16 models #> post mean post SD post p(B != 0) #> Intercept 95.42308 0.67885 1.00000 #> X1 1.40116 0.35351 0.97454 #> X2 0.42326 0.38407 0.76017 #> X3 -0.03997 0.33398 0.30660 #> X4 -0.22077 0.36931 0.44354 plot(coef.hald.gprior) confint(coef.hald.gprior) #> 2.5% 97.5% beta #> Intercept 93.9672078 96.8511631 95.42307692 #> X1 0.6460259 2.1282986 1.40116123 #> X2 -0.1039008 0.8768755 0.42325794 #> X3 -0.7828122 0.6575582 -0.03997087 #> X4 -0.7793374 0.2058685 -0.22076600 #> attr(,\"Probability\") #> [1] 0.95 #> attr(,\"class\") #> [1] \"confint.bas\" #Estimation under Median Probability Model coef.hald.gprior = coefficients(hald.gprior, estimator=\"MPM\") coef.hald.gprior #> #> Marginal Posterior Summaries of Coefficients: #> #> Using MPM #> #> Based on the top 1 models #> post mean post SD post p(B != 0) #> Intercept 95.42308 0.66740 1.00000 #> X1 1.45542 0.12077 1.00000 #> X2 0.65644 0.04565 1.00000 #> X3 0.00000 0.00000 0.00000 #> X4 0.00000 0.00000 0.00000 plot(coef.hald.gprior) plot(confint(coef.hald.gprior)) #> NULL coef.hald.gprior = coefficients(hald.gprior, estimator=\"HPM\") coef.hald.gprior #> #> Marginal Posterior Summaries of Coefficients: #> #> Using HPM #> #> Based on the top 1 models #> post mean post SD post p(B != 0) #> Intercept 95.42308 0.66740 1.00000 #> X1 1.45542 0.12077 0.97454 #> X2 0.65644 0.04565 0.76017 #> X3 0.00000 0.00000 0.30660 #> X4 0.00000 0.00000 0.44354 plot(coef.hald.gprior) confint(coef.hald.gprior) #> 2.5% 97.5% beta #> Intercept 93.9689432 96.877211 95.4230769 #> X1 1.1922938 1.718554 1.4554239 #> X2 0.5569707 0.755910 0.6564404 #> X3 0.0000000 0.000000 0.0000000 #> X4 0.0000000 0.000000 0.0000000 #> attr(,\"Probability\") #> [1] 0.95 #> attr(,\"class\") #> [1] \"confint.bas\" # To add estimation under Best Predictive Model"},{"path":"http://merliseclyde.github.io/BAS/reference/confint.coef.html","id":null,"dir":"Reference","previous_headings":"","what":"Compute Credible Intervals for BAS regression coefficients from BAS objects — confint.coef.bas","title":"Compute Credible Intervals for BAS regression coefficients from BAS objects — confint.coef.bas","text":"Uses Monte Carlo simulations using posterior means standard deviations coefficients generate draws posterior distributions returns highest posterior density (HPD) credible intervals. number models equals one, use t distribution find intervals. currently condition estimate $g$. description ~~","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/confint.coef.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Compute Credible Intervals for BAS regression coefficients from BAS objects — confint.coef.bas","text":"","code":"# S3 method for coef.bas confint(object, parm, level = 0.95, nsim = 10000, ...)"},{"path":"http://merliseclyde.github.io/BAS/reference/confint.coef.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Compute Credible Intervals for BAS regression coefficients from BAS objects — confint.coef.bas","text":"object coef.bas object parm specification parameters given credible intervals, either vector numbers vector names. missing, parameters considered. level probability coverage required nsim number Monte Carlo draws posterior distribution. Used number models greater 1. ... arguments passed; none currently","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/confint.coef.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Compute Credible Intervals for BAS regression coefficients from BAS objects — confint.coef.bas","text":"matrix (vector) columns giving lower upper HPD credible limits parameter. labeled 1-level)/2 1 - (1-level)/2 percent (default 2.5 97.5).","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/confint.coef.html","id":"note","dir":"Reference","previous_headings":"","what":"Note","title":"Compute Credible Intervals for BAS regression coefficients from BAS objects — confint.coef.bas","text":"mixture g-priors approximate. uses Monte Carlo sampling results may subject Monte Carlo variation larger values nsim may needed reduce variability.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/confint.coef.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Compute Credible Intervals for BAS regression coefficients from BAS objects — confint.coef.bas","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/confint.coef.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Compute Credible Intervals for BAS regression coefficients from BAS objects — confint.coef.bas","text":"","code":"data(\"Hald\") hald_gprior <- bas.lm(Y~ ., data=Hald, alpha=13, prior=\"g-prior\") coef_hald <- coef(hald_gprior) confint(coef_hald) #> 2.5% 97.5% beta #> Intercept 93.899749 96.9469774 95.4230769 #> X1 0.000000 1.8451082 1.2150202 #> X2 -1.114669 0.8562203 0.2756235 #> X3 -1.508182 0.5533747 -0.1270575 #> X4 -1.716110 0.2007243 -0.3268710 #> attr(,\"Probability\") #> [1] 0.95 #> attr(,\"class\") #> [1] \"confint.bas\" confint(coef_hald, approx=FALSE, nsim=5000) #> 2.5% 97.5% beta #> Intercept 93.940456 96.9940631 95.4230769 #> X1 0.000000 1.8753303 1.2150202 #> X2 -1.201605 0.8338886 0.2756235 #> X3 -1.538660 0.5621008 -0.1270575 #> X4 -1.762790 0.2190579 -0.3268710 #> attr(,\"Probability\") #> [1] 0.95 #> attr(,\"class\") #> [1] \"confint.bas\" # extract just the coefficient of X4 confint(coef_hald, parm=\"X4\") #> 2.5% 97.5% beta #> X4 -1.69165 0.2614025 -0.326871 #> attr(,\"Probability\") #> [1] 0.95 #> attr(,\"class\") #> [1] \"confint.bas\""},{"path":"http://merliseclyde.github.io/BAS/reference/confint.pred.html","id":null,"dir":"Reference","previous_headings":"","what":"Compute Credible (Bayesian Confidence) Intervals for a BAS predict object — confint.pred.bas","title":"Compute Credible (Bayesian Confidence) Intervals for a BAS predict object — confint.pred.bas","text":"Compute credible intervals -sample sample prediction regression function","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/confint.pred.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Compute Credible (Bayesian Confidence) Intervals for a BAS predict object — confint.pred.bas","text":"","code":"# S3 method for pred.bas confint(object, parm, level = 0.95, nsim = 10000, ...)"},{"path":"http://merliseclyde.github.io/BAS/reference/confint.pred.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Compute Credible (Bayesian Confidence) Intervals for a BAS predict object — confint.pred.bas","text":"object object created predict.bas parm character variable, \"mean\" \"pred\". missing parm='pred'. level nominal level (point-wise) credible interval nsim number Monte Carlo simulations sampling methods BMA ... optional arguments pass next function call; none time.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/confint.pred.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Compute Credible (Bayesian Confidence) Intervals for a BAS predict object — confint.pred.bas","text":"matrix lower upper level * 100 percent credible intervals either mean regression function predicted values.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/confint.pred.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Compute Credible (Bayesian Confidence) Intervals for a BAS predict object — confint.pred.bas","text":"constructs approximate 95 percent Highest Posterior Density intervals 'pred.bas' objects. estimator based model selection, intervals use Student t distribution using estimate g. estimator based BMA, nsim draws mixture Student t distributions obtained HPD interval obtained Monte Carlo draws.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/confint.pred.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Compute Credible (Bayesian Confidence) Intervals for a BAS predict object — confint.pred.bas","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/confint.pred.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Compute Credible (Bayesian Confidence) Intervals for a BAS predict object — confint.pred.bas","text":"","code":"data(\"Hald\") hald.gprior = bas.lm(Y~ ., data=Hald, alpha=13, prior=\"g-prior\") hald.pred = predict(hald.gprior, estimator=\"BPM\", predict=FALSE, se.fit=TRUE) confint(hald.pred, parm=\"mean\") #> 2.5% 97.5% mean #> [1,] 72.85939 86.44363 79.65151 #> [2,] 69.50215 79.45478 74.47846 #> [3,] 101.93102 108.91264 105.42183 #> [4,] 85.14928 94.51420 89.83174 #> [5,] 89.98634 101.26964 95.62799 #> [6,] 101.30948 107.88283 104.59616 #> [7,] 97.81813 109.19556 103.50684 #> [8,] 71.46153 82.55525 77.00839 #> [9,] 87.73810 96.41333 92.07571 #> [10,] 106.51357 121.70394 114.10876 #> [11,] 77.32978 88.03488 82.68233 #> [12,] 106.79101 115.29472 111.04286 #> [13,] 105.64736 115.28746 110.46741 #> attr(,\"Probability\") #> [1] 0.95 #> attr(,\"class\") #> [1] \"confint.bas\" confint(hald.pred) #default #> 2.5% 97.5% pred #> [1,] 67.79843 91.50459 79.65151 #> [2,] 63.56396 85.39296 74.47846 #> [3,] 95.09960 115.74406 105.42183 #> [4,] 79.04805 100.61543 89.83174 #> [5,] 84.39452 106.86146 95.62799 #> [6,] 94.34116 114.85115 104.59616 #> [7,] 92.24966 114.76402 103.50684 #> [8,] 65.82223 88.19456 77.00839 #> [9,] 81.43722 102.71421 92.07571 #> [10,] 101.77792 126.43959 114.10876 #> [11,] 71.59123 93.77342 82.68233 #> [12,] 100.43905 121.64668 111.04286 #> [13,] 99.62326 121.31156 110.46741 #> attr(,\"Probability\") #> [1] 0.95 #> attr(,\"class\") #> [1] \"confint.bas\" hald.pred = predict(hald.gprior, estimator=\"BMA\", predict=FALSE, se.fit=TRUE) confint(hald.pred) #> 2.5% 97.5% pred #> [1,] 68.07475 92.23188 79.68307 #> [2,] 63.57577 86.16319 74.69127 #> [3,] 94.31185 116.18094 105.63258 #> [4,] 78.93185 100.77629 89.91648 #> [5,] 84.19744 106.87413 95.67480 #> [6,] 93.94117 115.05853 104.57616 #> [7,] 91.77939 114.98347 103.47945 #> [8,] 65.47413 87.93638 76.96808 #> [9,] 81.55209 103.28904 92.22184 #> [10,] 101.37360 126.42092 113.84918 #> [11,] 70.95581 93.69435 82.59035 #> [12,] 99.95388 121.84674 110.87673 #> [13,] 99.55477 121.54222 110.34001 #> attr(,\"Probability\") #> [1] 0.95 #> attr(,\"class\") #> [1] \"confint.bas\""},{"path":"http://merliseclyde.github.io/BAS/reference/cv.summary.bas.html","id":null,"dir":"Reference","previous_headings":"","what":"Summaries for Out of Sample Prediction — cv.summary.bas","title":"Summaries for Out of Sample Prediction — cv.summary.bas","text":"Compute average prediction error sample predictions","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/cv.summary.bas.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Summaries for Out of Sample Prediction — cv.summary.bas","text":"","code":"cv.summary.bas(pred, ytrue, score = \"squared-error\")"},{"path":"http://merliseclyde.github.io/BAS/reference/cv.summary.bas.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Summaries for Out of Sample Prediction — cv.summary.bas","text":"pred fitted predicted value output predict.bas ytrue vector left response values score function used summarize error rate. Either \"squared-error\", \"miss-class\"","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/cv.summary.bas.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Summaries for Out of Sample Prediction — cv.summary.bas","text":"squared error, average prediction error Bayesian estimator error = sqrt(sum(ytrue - yhat)^2/npred) binary data misclassification rate appropriate.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/cv.summary.bas.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Summaries for Out of Sample Prediction — cv.summary.bas","text":"Merlise Clyde clyde@duke.edu","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/cv.summary.bas.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Summaries for Out of Sample Prediction — cv.summary.bas","text":"","code":"if (FALSE) { library(foreign) cognitive <- read.dta(\"https://www.stat.columbia.edu/~gelman/arm/examples/child.iq/kidiq.dta\") cognitive$mom_work <- as.numeric(cognitive$mom_work > 1) cognitive$mom_hs <- as.numeric(cognitive$mom_hs > 0) colnames(cognitive) <- c(\"kid_score\", \"hs\", \"iq\", \"work\", \"age\") set.seed(42) n <- nrow(cognitive) test <- sample(1:n, size = round(.20 * n), replace = FALSE) testdata <- cognitive[test, ] traindata <- cognitive[-test, ] cog_train <- bas.lm(kid_score ~ ., prior = \"BIC\", modelprior = uniform(), data = traindata) yhat <- predict(cog_train, newdata = testdata, estimator = \"BMA\", se = F) cv.summary.bas(yhat$fit, testdata$kid_score) }"},{"path":"http://merliseclyde.github.io/BAS/reference/diagnostics.html","id":null,"dir":"Reference","previous_headings":"","what":"BAS MCMC diagnostic plot — diagnostics","title":"BAS MCMC diagnostic plot — diagnostics","text":"Function help assess convergence MCMC sampling bas objects.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/diagnostics.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"BAS MCMC diagnostic plot — diagnostics","text":"","code":"diagnostics(obj, type = c(\"pip\", \"model\"), ...)"},{"path":"http://merliseclyde.github.io/BAS/reference/diagnostics.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"BAS MCMC diagnostic plot — diagnostics","text":"obj object created bas.lm bas.glm type type diagnostic plot. \"pip\" marginal inclusion probabilities used, \"model\", plot posterior model probabilities ... additional graphics parameters passed plot","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/diagnostics.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"BAS MCMC diagnostic plot — diagnostics","text":"plot marginal inclusion probabilities (pip) estimated MCMC renormalized marginal likelihoods times prior probabilities model probabilities.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/diagnostics.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"BAS MCMC diagnostic plot — diagnostics","text":"BAS calculates posterior model probabilities two ways method=\"MCMC\". first using relative Monte Carlo frequencies sampled models. second renormalize marginal likelihood times prior probabilities sampled models. Markov chain converged, two quantities fall 1-1 line. , running longer may required. chain converged, Monte Carlo frequencies may less bias, although may exhibit variability repeated runs.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/diagnostics.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"BAS MCMC diagnostic plot — diagnostics","text":"Merlise Clyde (clyde@duke.edu)","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/diagnostics.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"BAS MCMC diagnostic plot — diagnostics","text":"","code":"library(MASS) data(UScrime) UScrime[, -2] <- log(UScrime[, -2]) crime.ZS <- bas.lm(y ~ ., data = UScrime, prior = \"ZS-null\", modelprior = uniform(), method = \"MCMC\", MCMC.iter = 1000 ) # short run for the example diagnostics(crime.ZS)"},{"path":"http://merliseclyde.github.io/BAS/reference/eplogprob.html","id":null,"dir":"Reference","previous_headings":"","what":"eplogprob - Compute approximate marginal inclusion probabilities from\npvalues — eplogprob","title":"eplogprob - Compute approximate marginal inclusion probabilities from\npvalues — eplogprob","text":"eplogprob calculates approximate marginal posterior inclusion probabilities p-values computed linear model using lower bound approximation Bayes factors. Used obtain initial inclusion probabilities sampling using Bayesian Adaptive Sampling bas.lm","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/eplogprob.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"eplogprob - Compute approximate marginal inclusion probabilities from\npvalues — eplogprob","text":"","code":"eplogprob(lm.obj, thresh = 0.5, max = 0.99, int = TRUE)"},{"path":"http://merliseclyde.github.io/BAS/reference/eplogprob.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"eplogprob - Compute approximate marginal inclusion probabilities from\npvalues — eplogprob","text":"lm.obj linear model object thresh value inclusion probability p-value > 1/exp(1), lower bound approximation valid. max maximum value inclusion probability; used bas.lm function keep initial inclusion probabilities away 1. int Intercept included linear model, set marginal inclusion probability corresponding intercept 1","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/eplogprob.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"eplogprob - Compute approximate marginal inclusion probabilities from\npvalues — eplogprob","text":"eplogprob returns vector marginal posterior inclusion probabilities variables linear model. int = TRUE, inclusion probability intercept set 1. model full rank, variables linearly dependent base QR factorization NA p-values. bas.lm, probabilities used sampling, inclusion probability set 0.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/eplogprob.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"eplogprob - Compute approximate marginal inclusion probabilities from\npvalues — eplogprob","text":"Sellke, Bayarri Berger (2001) provide simple calibration p-values BF(p) = -e p log(p) provide lower bound Bayes factor comparing H0: beta = 0 versus H1: beta equal 0, p-value p less 1/e. Using equal prior odds hypotheses H0 H1, approximate marginal posterior inclusion probability p(beta != 0 | data ) = 1/(1 + BF(p)) p > 1/e, set marginal inclusion probability 0.5 value given thresh.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/eplogprob.html","id":"references","dir":"Reference","previous_headings":"","what":"References","title":"eplogprob - Compute approximate marginal inclusion probabilities from\npvalues — eplogprob","text":"Sellke, Thomas, Bayarri, M. J., Berger, James O. (2001), ``Calibration p-values testing precise null hypotheses'', American Statistician, 55, 62-71.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/eplogprob.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"eplogprob - Compute approximate marginal inclusion probabilities from\npvalues — eplogprob","text":"Merlise Clyde clyde@stat.duke.edu","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/eplogprob.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"eplogprob - Compute approximate marginal inclusion probabilities from\npvalues — eplogprob","text":"","code":"library(MASS) data(UScrime) UScrime[,-2] = log(UScrime[,-2]) eplogprob(lm(y ~ ., data=UScrime)) #> (Intercept) M So Ed Po1 Po2 #> 1.0000000 0.9480823 0.5000000 0.9883193 0.5045770 0.5000000 #> LF M.F Pop NW U1 U2 #> 0.5000000 0.5304659 0.5807429 0.8046414 0.5000000 0.6858642 #> GDP Ineq Prob Time #> 0.6069289 0.9900000 0.9412475 0.5782754"},{"path":"http://merliseclyde.github.io/BAS/reference/eplogprob.marg.html","id":null,"dir":"Reference","previous_headings":"","what":"eplogprob.marg - Compute approximate marginal inclusion probabilities from\npvalues — eplogprob.marg","title":"eplogprob.marg - Compute approximate marginal inclusion probabilities from\npvalues — eplogprob.marg","text":"eplogprob.marg calculates approximate marginal posterior inclusion probabilities p-values computed series simple linear regression models using lower bound approximation Bayes factors. Used order variables appropriate obtain initial inclusion probabilities sampling using Bayesian Adaptive Sampling bas.lm","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/eplogprob.marg.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"eplogprob.marg - Compute approximate marginal inclusion probabilities from\npvalues — eplogprob.marg","text":"","code":"eplogprob.marg(Y, X, thresh = 0.5, max = 0.99, int = TRUE)"},{"path":"http://merliseclyde.github.io/BAS/reference/eplogprob.marg.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"eplogprob.marg - Compute approximate marginal inclusion probabilities from\npvalues — eplogprob.marg","text":"Y response variable X design matrix column ones intercept thresh value inclusion probability p-value > 1/exp(1), lower bound approximation valid. max maximum value inclusion probability; used bas.lm function keep initial inclusion probabilities away 1. int Intercept included linear model, set marginal inclusion probability corresponding intercept 1","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/eplogprob.marg.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"eplogprob.marg - Compute approximate marginal inclusion probabilities from\npvalues — eplogprob.marg","text":"eplogprob.prob returns vector marginal posterior inclusion probabilities variables linear model. int = TRUE, inclusion probability intercept set 1.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/eplogprob.marg.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"eplogprob.marg - Compute approximate marginal inclusion probabilities from\npvalues — eplogprob.marg","text":"Sellke, Bayarri Berger (2001) provide simple calibration p-values BF(p) = -e p log(p) provide lower bound Bayes factor comparing H0: beta = 0 versus H1: beta equal 0, p-value p less 1/e. Using equal prior odds hypotheses H0 H1, approximate marginal posterior inclusion probability p(beta != 0 | data ) = 1/(1 + BF(p)) p > 1/e, set marginal inclusion probability 0.5 value given thresh. eplogprob.marg marginal p-values obtained using statistics p simple linear regressions P(F > (n-2) R2/(1 - R2)) F ~ F(1, n-2) R2 square correlation coefficient y X_j.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/eplogprob.marg.html","id":"references","dir":"Reference","previous_headings":"","what":"References","title":"eplogprob.marg - Compute approximate marginal inclusion probabilities from\npvalues — eplogprob.marg","text":"Sellke, Thomas, Bayarri, M. J., Berger, James O. (2001), ``Calibration p-values testing precise null hypotheses'', American Statistician, 55, 62-71.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/eplogprob.marg.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"eplogprob.marg - Compute approximate marginal inclusion probabilities from\npvalues — eplogprob.marg","text":"Merlise Clyde clyde@stat.duke.edu","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/eplogprob.marg.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"eplogprob.marg - Compute approximate marginal inclusion probabilities from\npvalues — eplogprob.marg","text":"","code":"library(MASS) data(UScrime) UScrime[,-2] = log(UScrime[,-2]) eplogprob(lm(y ~ ., data=UScrime)) #> (Intercept) M So Ed Po1 Po2 #> 1.0000000 0.9480823 0.5000000 0.9883193 0.5045770 0.5000000 #> LF M.F Pop NW U1 U2 #> 0.5000000 0.5304659 0.5807429 0.8046414 0.5000000 0.6858642 #> GDP Ineq Prob Time #> 0.6069289 0.9900000 0.9412475 0.5782754"},{"path":"http://merliseclyde.github.io/BAS/reference/fitted.html","id":null,"dir":"Reference","previous_headings":"","what":"Fitted values for a BAS BMA objects — fitted.bas","title":"Fitted values for a BAS BMA objects — fitted.bas","text":"Calculate fitted values BAS BMA object","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/fitted.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Fitted values for a BAS BMA objects — fitted.bas","text":"","code":"# S3 method for bas fitted( object, type = \"link\", estimator = \"BMA\", top = NULL, na.action = na.pass, ... )"},{"path":"http://merliseclyde.github.io/BAS/reference/fitted.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Fitted values for a BAS BMA objects — fitted.bas","text":"object object class 'bas' created bas type type equals \"response\" \"link\" case GLMs (default 'link') estimator estimator type fitted value return. Default use BMA models. Options include 'HPM' highest probability model 'BMA' Bayesian model averaging, using optionally 'top' models 'MPM' median probability model Barbieri Berger. 'BPM' model closest BMA predictions squared error loss top optional argument specifying 'top' models used constructing BMA prediction, NULL models used. top=1, equivalent 'HPM' na.action function determining done missing values newdata. default predict NA. ... optional arguments, used currently","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/fitted.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Fitted values for a BAS BMA objects — fitted.bas","text":"vector length n fitted values.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/fitted.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Fitted values for a BAS BMA objects — fitted.bas","text":"Calculates fitted values observed design matrix using either highest probability model, 'HPM', posterior mean (BMA) 'BMA', median probability model 'MPM' best predictive model 'BPM\". median probability model defined including variable marginal inclusion probability greater equal 1/2. type=\"BMA\", weighted average may based using subset highest probability models optional argument given top. default BMA uses sampled models, may take compute number variables number models large. \"BPM\" found computing squared distance vector fitted values model fitted values BMA returns model smallest distance. presence multicollinearity may quite different MPM, extreme collinearity may drop relevant predictors.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/fitted.html","id":"references","dir":"Reference","previous_headings":"","what":"References","title":"Fitted values for a BAS BMA objects — fitted.bas","text":"Barbieri, M. Berger, J.O. (2004) Optimal predictive model selection. Annals Statistics. 32, 870-897. https://projecteuclid.org/euclid.aos/1085408489&url=/UI/1.0/Summarize/euclid.aos/1085408489 Clyde, M. Ghosh, J. Littman, M. (2010) Bayesian Adaptive Sampling Variable Selection Model Averaging. Journal Computational Graphics Statistics. 20:80-101 doi:10.1198/jcgs.2010.09049","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/fitted.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Fitted values for a BAS BMA objects — fitted.bas","text":"Merlise Clyde clyde@duke.edu","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/fitted.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Fitted values for a BAS BMA objects — fitted.bas","text":"","code":"data(Hald) hald.gprior = bas.lm(Y~ ., data=Hald, prior=\"ZS-null\", initprobs=\"Uniform\") plot(Hald$Y, fitted(hald.gprior, estimator=\"HPM\")) plot(Hald$Y, fitted(hald.gprior, estimator=\"BMA\", top=3)) plot(Hald$Y, fitted(hald.gprior, estimator=\"MPM\")) plot(Hald$Y, fitted(hald.gprior, estimator=\"BPM\"))"},{"path":"http://merliseclyde.github.io/BAS/reference/force.heredity.bas.html","id":null,"dir":"Reference","previous_headings":"","what":"Post processing function to force constraints on interaction inclusion bas BMA objects — force.heredity.bas","title":"Post processing function to force constraints on interaction inclusion bas BMA objects — force.heredity.bas","text":"function takes output bas object allows higher order interactions included parent lower order interactions terms model, assigning zero prior probability, hence posterior probability, models include respective parents.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/force.heredity.bas.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Post processing function to force constraints on interaction inclusion bas BMA objects — force.heredity.bas","text":"","code":"force.heredity.bas(object, prior.prob = 0.5)"},{"path":"http://merliseclyde.github.io/BAS/reference/force.heredity.bas.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Post processing function to force constraints on interaction inclusion bas BMA objects — force.heredity.bas","text":"object bas linear model generalized linear model object prior.prob prior probability term included conditional parents included","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/force.heredity.bas.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Post processing function to force constraints on interaction inclusion bas BMA objects — force.heredity.bas","text":"bas object updated models, coefficients summaries obtained removing models zero prior posterior probabilities.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/force.heredity.bas.html","id":"note","dir":"Reference","previous_headings":"","what":"Note","title":"Post processing function to force constraints on interaction inclusion bas BMA objects — force.heredity.bas","text":"Currently prior probabilities computed using conditional Bernoulli distributions, .e. P(gamma_j = 1 | Parents(gamma_j) = 1) = prior.prob. efficient models large number levels. Future updates force time sampling.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/force.heredity.bas.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Post processing function to force constraints on interaction inclusion bas BMA objects — force.heredity.bas","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/force.heredity.bas.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Post processing function to force constraints on interaction inclusion bas BMA objects — force.heredity.bas","text":"","code":"data(\"chickwts\") bas.chk <- bas.lm(weight ~ feed, data = chickwts) # summary(bas.chk) # 2^5 = 32 models bas.chk.int <- force.heredity.bas(bas.chk) # summary(bas.chk.int) # two models now data(Hald) bas.hald <- bas.lm(Y ~ .^2, data = Hald) bas.hald.int <- force.heredity.bas(bas.hald) image(bas.hald.int) image(bas.hald.int) # two-way interactions data(ToothGrowth) ToothGrowth$dose <- factor(ToothGrowth$dose) levels(ToothGrowth$dose) <- c(\"Low\", \"Medium\", \"High\") TG.bas <- bas.lm(len ~ supp * dose, data = ToothGrowth, modelprior = uniform()) TG.bas.int <- force.heredity.bas(TG.bas) image(TG.bas.int)"},{"path":"http://merliseclyde.github.io/BAS/reference/g.prior.html","id":null,"dir":"Reference","previous_headings":"","what":"Families of G-Prior Distribution for Coefficients in BMA Models — g.prior","title":"Families of G-Prior Distribution for Coefficients in BMA Models — g.prior","text":"Creates object representing g-prior distribution coefficients BAS.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/g.prior.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Families of G-Prior Distribution for Coefficients in BMA Models — g.prior","text":"","code":"g.prior(g)"},{"path":"http://merliseclyde.github.io/BAS/reference/g.prior.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Families of G-Prior Distribution for Coefficients in BMA Models — g.prior","text":"g scalar used covariance Zellner's g-prior, Cov(beta) = sigma^2 g (X'X)^-1","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/g.prior.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Families of G-Prior Distribution for Coefficients in BMA Models — g.prior","text":"returns object class \"prior\", family hyerparameters.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/g.prior.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Families of G-Prior Distribution for Coefficients in BMA Models — g.prior","text":"Creates structure used BAS.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/g.prior.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Families of G-Prior Distribution for Coefficients in BMA Models — g.prior","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/g.prior.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Families of G-Prior Distribution for Coefficients in BMA Models — g.prior","text":"","code":"g.prior(100) #> $family #> [1] \"g.prior\" #> #> $g #> [1] 100 #> #> $class #> [1] \"g-prior\" #> #> $hyper #> [1] 100 #> #> $hyper.parameters #> $hyper.parameters$g #> [1] 100 #> #> #> attr(,\"class\") #> [1] \"prior\""},{"path":"http://merliseclyde.github.io/BAS/reference/hyper.g.html","id":null,"dir":"Reference","previous_headings":"","what":"Hyper-g-Prior Distribution for Coefficients in BMA Models — hyper.g","title":"Hyper-g-Prior Distribution for Coefficients in BMA Models — hyper.g","text":"Creates object representing hyper-g mixture g-priors coefficients BAS.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/hyper.g.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Hyper-g-Prior Distribution for Coefficients in BMA Models — hyper.g","text":"","code":"hyper.g(alpha = 3)"},{"path":"http://merliseclyde.github.io/BAS/reference/hyper.g.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Hyper-g-Prior Distribution for Coefficients in BMA Models — hyper.g","text":"alpha scalar > 0. hyper.g(alpha) equivalent CCH(alpha -2, 2, 0). Liang et al recommended values range 2 < alpha_h <= 3","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/hyper.g.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Hyper-g-Prior Distribution for Coefficients in BMA Models — hyper.g","text":"returns object class \"prior\", family hyerparameters.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/hyper.g.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Hyper-g-Prior Distribution for Coefficients in BMA Models — hyper.g","text":"Creates structure used bas.glm.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/hyper.g.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Hyper-g-Prior Distribution for Coefficients in BMA Models — hyper.g","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/hyper.g.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Hyper-g-Prior Distribution for Coefficients in BMA Models — hyper.g","text":"","code":"hyper.g(alpha = 3) #> $family #> [1] \"CCH\" #> #> $class #> [1] \"TCCH\" #> #> $hyper.parameters #> $hyper.parameters$alpha #> [1] 1 #> #> $hyper.parameters$beta #> [1] 2 #> #> $hyper.parameters$s #> [1] 0 #> #> #> attr(,\"class\") #> [1] \"prior\""},{"path":"http://merliseclyde.github.io/BAS/reference/hyper.g.n.html","id":null,"dir":"Reference","previous_headings":"","what":"Generalized hyper-g/n Prior Distribution for g for mixtures of g-priors on\nCoefficients in BMA Models — hyper.g.n","title":"Generalized hyper-g/n Prior Distribution for g for mixtures of g-priors on\nCoefficients in BMA Models — hyper.g.n","text":"Creates object representing hyper-g/n mixture g-priors coefficients BAS. special case tCCH prior","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/hyper.g.n.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Generalized hyper-g/n Prior Distribution for g for mixtures of g-priors on\nCoefficients in BMA Models — hyper.g.n","text":"","code":"hyper.g.n(alpha = 3, n = NULL)"},{"path":"http://merliseclyde.github.io/BAS/reference/hyper.g.n.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Generalized hyper-g/n Prior Distribution for g for mixtures of g-priors on\nCoefficients in BMA Models — hyper.g.n","text":"alpha scalar > 0, recommended 2 < alpha <= 3 n sample size; NULL, value derived data call `bas.glm` used.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/hyper.g.n.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Generalized hyper-g/n Prior Distribution for g for mixtures of g-priors on\nCoefficients in BMA Models — hyper.g.n","text":"returns object class \"prior\", family hyerparameters.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/hyper.g.n.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Generalized hyper-g/n Prior Distribution for g for mixtures of g-priors on\nCoefficients in BMA Models — hyper.g.n","text":"Creates structure used bas.glm. special case tCCH, hyper.g.n(alpha=3, n) equivalent tCCH(alpha=1, beta=2, s=0, r=1.5, v = 1, theta=1/n)","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/hyper.g.n.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Generalized hyper-g/n Prior Distribution for g for mixtures of g-priors on\nCoefficients in BMA Models — hyper.g.n","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/hyper.g.n.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Generalized hyper-g/n Prior Distribution for g for mixtures of g-priors on\nCoefficients in BMA Models — hyper.g.n","text":"","code":"n <- 500 hyper.g.n(alpha = 3, n = n) #> $family #> [1] \"hyper-g/n\" #> #> $class #> [1] \"TCCH\" #> #> $hyper.parameters #> $hyper.parameters$alpha #> [1] 1 #> #> $hyper.parameters$beta #> [1] 2 #> #> $hyper.parameters$s #> [1] 0 #> #> $hyper.parameters$r #> [1] 1.5 #> #> $hyper.parameters$v #> [1] 1 #> #> $hyper.parameters$theta #> [1] 0.002 #> #> #> $n #> [1] 500 #> #> attr(,\"class\") #> [1] \"prior\""},{"path":"http://merliseclyde.github.io/BAS/reference/hypergeometric1F1.html","id":null,"dir":"Reference","previous_headings":"","what":"Confluent hypergeometric1F1 function — hypergeometric1F1","title":"Confluent hypergeometric1F1 function — hypergeometric1F1","text":"Compute Confluent Hypergeometric function: 1F1(,b,c,t) = Gamma(b)/(Gamma(b-)Gamma()) Int_0^1 t^(-1) (1 - t)^(b--1) exp(c t) dt","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/hypergeometric1F1.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Confluent hypergeometric1F1 function — hypergeometric1F1","text":"","code":"hypergeometric1F1(a, b, c, laplace = FALSE, log = TRUE)"},{"path":"http://merliseclyde.github.io/BAS/reference/hypergeometric1F1.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Confluent hypergeometric1F1 function — hypergeometric1F1","text":"arbitrary b Must greater 0 c arbitrary laplace default use Cephes library; large s may return NA, Inf negative values,, case use Laplace approximation. log TRUE, return log(1F1)","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/hypergeometric1F1.html","id":"references","dir":"Reference","previous_headings":"","what":"References","title":"Confluent hypergeometric1F1 function — hypergeometric1F1","text":"Cephes library hyp1f1.c","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/hypergeometric1F1.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Confluent hypergeometric1F1 function — hypergeometric1F1","text":"Merlise Clyde (clyde@stat.duke.edu)","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/hypergeometric1F1.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Confluent hypergeometric1F1 function — hypergeometric1F1","text":"","code":"hypergeometric1F1(11.14756, 0.5, 0.00175097) #> [1] 0.03856253"},{"path":"http://merliseclyde.github.io/BAS/reference/hypergeometric2F1.html","id":null,"dir":"Reference","previous_headings":"","what":"Gaussian hypergeometric2F1 function — hypergeometric2F1","title":"Gaussian hypergeometric2F1 function — hypergeometric2F1","text":"Compute Gaussian Hypergeometric2F1 function: 2F1(,b,c,z) = Gamma(b-c) Int_0^1 t^(b-1) (1 - t)^(c -b -1) (1 - t z)^(-) dt","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/hypergeometric2F1.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Gaussian hypergeometric2F1 function — hypergeometric2F1","text":"","code":"hypergeometric2F1(a, b, c, z, method = \"Cephes\", log = TRUE)"},{"path":"http://merliseclyde.github.io/BAS/reference/hypergeometric2F1.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Gaussian hypergeometric2F1 function — hypergeometric2F1","text":"arbitrary b Must greater 0 c Must greater b |z| < 1, c > b + z = 1 z |z| <= 1 method default use Cephes library routine. sometimes unstable large z near one returning Inf negative values. case, try method=\"Laplace\", use Laplace approximation tau = exp(t/(1-t)). log TRUE, return log(2F1)","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/hypergeometric2F1.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Gaussian hypergeometric2F1 function — hypergeometric2F1","text":"log=T returns log 2F1 function; otherwise 2F1 function.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/hypergeometric2F1.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Gaussian hypergeometric2F1 function — hypergeometric2F1","text":"default use routine hyp2f1.c Cephes library. return negative value Inf, one try method=\"Laplace\" based Laplace approximation described Liang et al JASA 2008. used hyper-g prior calculate marginal likelihoods.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/hypergeometric2F1.html","id":"references","dir":"Reference","previous_headings":"","what":"References","title":"Gaussian hypergeometric2F1 function — hypergeometric2F1","text":"Cephes library hyp2f1.c Liang, F., Paulo, R., Molina, G., Clyde, M. Berger, J.O. (2005) Mixtures g-priors Bayesian Variable Selection. Journal American Statistical Association. 103:410-423. doi:10.1198/016214507000001337","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/hypergeometric2F1.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Gaussian hypergeometric2F1 function — hypergeometric2F1","text":"Merlise Clyde (clyde@duke.edu)","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/hypergeometric2F1.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Gaussian hypergeometric2F1 function — hypergeometric2F1","text":"","code":"hypergeometric2F1(12, 1, 2, .65) #> [1] 9.580921"},{"path":"http://merliseclyde.github.io/BAS/reference/image.bas.html","id":null,"dir":"Reference","previous_headings":"","what":"Images of models used in Bayesian model averaging — image.bas","title":"Images of models used in Bayesian model averaging — image.bas","text":"Creates image models selected using bas.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/image.bas.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Images of models used in Bayesian model averaging — image.bas","text":"","code":"# S3 method for bas image( x, top.models = 20, intensity = TRUE, prob = TRUE, log = TRUE, rotate = TRUE, color = \"rainbow\", subset = NULL, drop.always.included = FALSE, offset = 0.75, digits = 3, vlas = 2, plas = 0, rlas = 0, ... )"},{"path":"http://merliseclyde.github.io/BAS/reference/image.bas.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Images of models used in Bayesian model averaging — image.bas","text":"x BMA object type 'bas' created BAS top.models Number top ranked models plot intensity Logical variable, TRUE image intensity proportional probability log(probability) model, FALSE, intensity binary indicating just presence (light) absence (dark) variable. prob Logical variable whether area image model proportional posterior probability (log probability) model (TRUE) equal area (FALSE). log Logical variable indicating whether intensities based log posterior odds (TRUE) posterior probabilities (FALSE). log posterior odds comparing model worst model top.models. rotate image models rotated models y-axis variables x-axis (TRUE) color color scheme image intensities. value \"rainbow\" uses rainbow palette. value \"blackandwhite\" produces black white image (greyscale image) subset indices variables include/exclude plot drop.always.included logical variable drop variables always forced model. FALSE default. offset numeric value add intensity digits number digits posterior probabilities keep vlas las parameter placing variable names; see par plas las parameter posterior probability axis rlas las parameter model ranks ... parameters passed image axis functions.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/image.bas.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Images of models used in Bayesian model averaging — image.bas","text":"Creates image model space sampled using bas. subset top models plotted, probabilities renormalized subset.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/image.bas.html","id":"note","dir":"Reference","previous_headings":"","what":"Note","title":"Images of models used in Bayesian model averaging — image.bas","text":"Suggestion allow area models proportional posterior probability due Thomas Lumley","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/image.bas.html","id":"references","dir":"Reference","previous_headings":"","what":"References","title":"Images of models used in Bayesian model averaging — image.bas","text":"Clyde, M. (1999) Bayesian Model Averaging Model Search Strategies (discussion). Bayesian Statistics 6. J.M. Bernardo, .P. Dawid, J.O. Berger, .F.M. Smith eds. Oxford University Press, pages 157-185.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/image.bas.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Images of models used in Bayesian model averaging — image.bas","text":"Merlise Clyde clyde@stat.duke.edu","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/image.bas.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Images of models used in Bayesian model averaging — image.bas","text":"","code":"require(graphics) data(\"Hald\") hald.ZSprior <- bas.lm(Y ~ ., data = Hald, prior = \"ZS-null\") image(hald.ZSprior, drop.always.included = TRUE) # drop the intercept"},{"path":"http://merliseclyde.github.io/BAS/reference/intrinsic.html","id":null,"dir":"Reference","previous_headings":"","what":"Intrinsic Prior Distribution for Coefficients in BMA Models — intrinsic","title":"Intrinsic Prior Distribution for Coefficients in BMA Models — intrinsic","text":"Creates object representing intrinsic prior g, special case tCCH mixture g-priors coefficients BAS.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/intrinsic.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Intrinsic Prior Distribution for Coefficients in BMA Models — intrinsic","text":"","code":"intrinsic(n = NULL)"},{"path":"http://merliseclyde.github.io/BAS/reference/intrinsic.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Intrinsic Prior Distribution for Coefficients in BMA Models — intrinsic","text":"n sample size; NULL, value derived data call `bas.glm` used.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/intrinsic.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Intrinsic Prior Distribution for Coefficients in BMA Models — intrinsic","text":"returns object class \"prior\", family \"intrinsic\" class \"TCCH\" hyperparameters alpha = 1, beta = 1, s = 0, r = 1, n = n tCCH prior theta tCCH prior determined model size sample size.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/intrinsic.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Intrinsic Prior Distribution for Coefficients in BMA Models — intrinsic","text":"Creates structure used bas.glm.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/intrinsic.html","id":"references","dir":"Reference","previous_headings":"","what":"References","title":"Intrinsic Prior Distribution for Coefficients in BMA Models — intrinsic","text":"Womack, ., Novelo,L.L., Casella, G. (2014). \"Inference Intrinsic Bayes' Procedures Model Selection Uncertainty\". Journal American Statistical Association. 109:1040-1053. doi:10.1080/01621459.2014.880348","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/intrinsic.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Intrinsic Prior Distribution for Coefficients in BMA Models — intrinsic","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/intrinsic.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Intrinsic Prior Distribution for Coefficients in BMA Models — intrinsic","text":"","code":"n <- 500 tCCH(alpha = 1, beta = 2, s = 0, r = 1.5, v = 1, theta = 1 / n) #> $family #> [1] \"tCCH\" #> #> $class #> [1] \"TCCH\" #> #> $hyper.parameters #> $hyper.parameters$alpha #> [1] 1 #> #> $hyper.parameters$beta #> [1] 2 #> #> $hyper.parameters$s #> [1] 0 #> #> $hyper.parameters$r #> [1] 1.5 #> #> $hyper.parameters$v #> [1] 1 #> #> $hyper.parameters$theta #> [1] 0.002 #> #> #> attr(,\"class\") #> [1] \"prior\""},{"path":"http://merliseclyde.github.io/BAS/reference/list2matrix.html","id":null,"dir":"Reference","previous_headings":"","what":"Coerce a BAS list object into a matrix. — list2matrix.bas","title":"Coerce a BAS list object into a matrix. — list2matrix.bas","text":"Models, coefficients, standard errors objects class 'bas' represented list lists reduce storage omitting zero entries. functions coerce list object matrix fill zeros facilitate computations.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/list2matrix.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Coerce a BAS list object into a matrix. — list2matrix.bas","text":"","code":"list2matrix.bas(x, what, which.models = NULL)"},{"path":"http://merliseclyde.github.io/BAS/reference/list2matrix.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Coerce a BAS list object into a matrix. — list2matrix.bas","text":"x 'bas' object name bas list coerce .models vector indices use extract subset","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/list2matrix.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Coerce a BAS list object into a matrix. — list2matrix.bas","text":"matrix representation x$, number rows equal length .models total number models number columns x$n.vars","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/list2matrix.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Coerce a BAS list object into a matrix. — list2matrix.bas","text":"list2matrix.bas(x, ) equivalent list2matrix.(x), however, latter uses sapply rather loop. list2matrix..matrix coerce x$matrix.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/list2matrix.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Coerce a BAS list object into a matrix. — list2matrix.bas","text":"Merlise Clyde clyde@duke.edu","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/list2matrix.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Coerce a BAS list object into a matrix. — list2matrix.bas","text":"","code":"data(Hald) hald.bic <- bas.lm(Y ~ ., data=Hald, prior=\"BIC\", initprobs= \"eplogp\") coef <- list2matrix.bas(hald.bic, \"mle\") # extract all coefficients se <- list2matrix.bas(hald.bic, \"mle.se\") models <- list2matrix.which(hald.bic) #matrix of model indicators models <- which.matrix(hald.bic$which, hald.bic$n.vars) #matrix of model indicators"},{"path":"http://merliseclyde.github.io/BAS/reference/list2matrix.which.html","id":null,"dir":"Reference","previous_headings":"","what":"Coerce a BAS list object into a matrix. — list2matrix.which","title":"Coerce a BAS list object into a matrix. — list2matrix.which","text":"Models, coefficients, standard errors objects class 'bas' represented list lists reduce storage omitting zero entries. functions coerce list object matrix fill zeros facilitate computations.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/list2matrix.which.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Coerce a BAS list object into a matrix. — list2matrix.which","text":"","code":"list2matrix.which(x, which.models = NULL)"},{"path":"http://merliseclyde.github.io/BAS/reference/list2matrix.which.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Coerce a BAS list object into a matrix. — list2matrix.which","text":"x 'bas' object .models vector indices use extract subset","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/list2matrix.which.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Coerce a BAS list object into a matrix. — list2matrix.which","text":"matrix representation x$, number rows equal length .models total number models number columns x$n.vars","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/list2matrix.which.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Coerce a BAS list object into a matrix. — list2matrix.which","text":"list2matrix.bas(x, ) equivalent list2matrix.(x), however, latter uses sapply rather loop. list2matrix..matrix coerce x$matrix.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/list2matrix.which.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Coerce a BAS list object into a matrix. — list2matrix.which","text":"Merlise Clyde clyde@duke.edu","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/list2matrix.which.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Coerce a BAS list object into a matrix. — list2matrix.which","text":"","code":"data(Hald) Hald.bic <- bas.lm(Y ~ ., data=Hald, prior=\"BIC\", initprobs=\"eplogp\") coef <- list2matrix.bas(Hald.bic, \"mle\") # extract all ols coefficients se <- list2matrix.bas(Hald.bic, \"mle.se\") models <- list2matrix.which(Hald.bic) #matrix of model indicators models <- which.matrix(Hald.bic$which, Hald.bic$n.vars) #matrix of model indicators"},{"path":"http://merliseclyde.github.io/BAS/reference/phi1.html","id":null,"dir":"Reference","previous_headings":"","what":"Compound Confluent hypergeometric function of two variables — phi1","title":"Compound Confluent hypergeometric function of two variables — phi1","text":"Compute Confluent Hypergeometric function two variables, also know Horn hypergeometric function Humbert's hypergeometric used Gordy (1998) integral representation:","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/phi1.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Compound Confluent hypergeometric function of two variables — phi1","text":"","code":"phi1(a, b, c, x, y, log = FALSE)"},{"path":"http://merliseclyde.github.io/BAS/reference/phi1.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Compound Confluent hypergeometric function of two variables — phi1","text":"> 0 b arbitrary c c > 0 x x > 0 y y > 0 log logical indicating whether return phi1 log scale","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/phi1.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Compound Confluent hypergeometric function of two variables — phi1","text":"phi_1(,b,c,x,y) = [(Gamma(c)/Gamma() Gamma(-c))] Int_0^1 t^(-1) (1 - t)^(c--1) (1 - yt)^(-b) exp(x t) dt https://en.wikipedia.org/wiki/Humbert_series Note Gordy's arguments x y reversed reference . original `phi1` function `BAS` based `C` code provided Gordy. function returns NA's x greater `log(.Machine$double.xmax)/2`. stable method calculating `phi1` function using R's `integrate` suggested Daniel Heemann now option whenever $x$ large. calculating Bayes factors use `phi1` function recommend using `log=TRUE` option compute log Bayes factors.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/phi1.html","id":"references","dir":"Reference","previous_headings":"","what":"References","title":"Compound Confluent hypergeometric function of two variables — phi1","text":"Gordy 1998","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/phi1.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Compound Confluent hypergeometric function of two variables — phi1","text":"Merlise Clyde (clyde@duke.edu) Daniel Heemann (df.heemann@gmail.com)","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/phi1.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Compound Confluent hypergeometric function of two variables — phi1","text":"","code":"# special cases # phi1(a, b, c, x=0, y) is the same as 2F1(b, a; c, y) phi1(1, 2, 1.5, 0, 1 / 100, log=FALSE) #> [1] 1.013495 hypergeometric2F1(2, 1, 1.5, 1 / 100, log = FALSE) #> [1] 1.013495 # phi1(a,0,c,x,y) is the same as 1F1(a,c,x) phi1(1, 0, 1.5, 3, 1 / 100) #> [1] 10.13001 hypergeometric1F1(1, 1.5, 3, log = FALSE) #> [1] 10.13001 # use direct integration phi1(1, 2, 1.5, 1000, 0, log=TRUE) #> [1] 996.4253"},{"path":"http://merliseclyde.github.io/BAS/reference/plot.coef.html","id":null,"dir":"Reference","previous_headings":"","what":"Plots the posterior distributions of coefficients derived from Bayesian\nmodel averaging — plot.coef.bas","title":"Plots the posterior distributions of coefficients derived from Bayesian\nmodel averaging — plot.coef.bas","text":"Displays plots posterior distributions coefficients generated Bayesian model averaging linear regression.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/plot.coef.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Plots the posterior distributions of coefficients derived from Bayesian\nmodel averaging — plot.coef.bas","text":"","code":"# S3 method for coef.bas plot(x, e = 1e-04, subset = 1:x$n.vars, ask = TRUE, ...)"},{"path":"http://merliseclyde.github.io/BAS/reference/plot.coef.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Plots the posterior distributions of coefficients derived from Bayesian\nmodel averaging — plot.coef.bas","text":"x object class coef.bas e optional numeric value specifying range distributions graphed. subset optional numerical vector specifying variables graph (including intercept) ask Prompt next plot ... parameters passed plot lines","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/plot.coef.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Plots the posterior distributions of coefficients derived from Bayesian\nmodel averaging — plot.coef.bas","text":"Produces plots posterior distributions coefficients model averaging. posterior probability coefficient zero represented solid line zero, height equal probability. nonzero part distribution scaled maximum height equal probability coefficient nonzero. parameter e specifies range distributions graphed specifying tail probabilities dictate range plot .","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/plot.coef.html","id":"note","dir":"Reference","previous_headings":"","what":"Note","title":"Plots the posterior distributions of coefficients derived from Bayesian\nmodel averaging — plot.coef.bas","text":"mixtures g-priors, uncertainty g incorporated time, thus results approximate","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/plot.coef.html","id":"references","dir":"Reference","previous_headings":"","what":"References","title":"Plots the posterior distributions of coefficients derived from Bayesian\nmodel averaging — plot.coef.bas","text":"Hoeting, J.., Raftery, .E. Madigan, D. (1996). method simultaneous variable selection outlier identification linear regression. Computational Statistics Data Analysis, 22, 251-270.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/plot.coef.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Plots the posterior distributions of coefficients derived from Bayesian\nmodel averaging — plot.coef.bas","text":"based function plot.bic Ian Painter package BMA; adapted 'bas' class Merlise Clyde clyde@stat.duke.edu","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/plot.coef.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Plots the posterior distributions of coefficients derived from Bayesian\nmodel averaging — plot.coef.bas","text":"","code":"if (FALSE) library(MASS) data(UScrime) UScrime[,-2] <- log(UScrime[,-2]) crime_bic <- bas.lm(y ~ ., data=UScrime, n.models=2^15, prior=\"BIC\") plot(coefficients(crime_bic), ask=TRUE)"},{"path":"http://merliseclyde.github.io/BAS/reference/plot.confint.html","id":null,"dir":"Reference","previous_headings":"","what":"Plot Bayesian Confidence Intervals — plot.confint.bas","title":"Plot Bayesian Confidence Intervals — plot.confint.bas","text":"Function takes output functions return credible intervals BAS objects, creates plot posterior mean segments representing credible interval. function . ~~","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/plot.confint.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Plot Bayesian Confidence Intervals — plot.confint.bas","text":"","code":"# S3 method for confint.bas plot(x, horizontal = FALSE, ...)"},{"path":"http://merliseclyde.github.io/BAS/reference/plot.confint.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Plot Bayesian Confidence Intervals — plot.confint.bas","text":"x output confint.coef.bas confint.pred.bas containing credible intervals estimates. horizontal orientation plot ... optional graphical arguments pass plot","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/plot.confint.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Plot Bayesian Confidence Intervals — plot.confint.bas","text":"plot credible intervals.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/plot.confint.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Plot Bayesian Confidence Intervals — plot.confint.bas","text":"function takes HPD intervals credible intervals created confint.coef.bas confint.pred.bas BAS objects, creates plot posterior mean segments representing credible interval. BAS tries return HPD intervals, model averaging may symmetric. description ~~","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/plot.confint.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Plot Bayesian Confidence Intervals — plot.confint.bas","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/plot.confint.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Plot Bayesian Confidence Intervals — plot.confint.bas","text":"","code":"data(Hald) hald.ZS = bas.lm(Y ~ ., data=Hald, prior=\"ZS-null\", modelprior=uniform()) hald.coef = confint(coef(hald.ZS), parm=2:5) plot(hald.coef) #> NULL plot(hald.coef, horizontal=TRUE) #> NULL plot(confint(predict(hald.ZS, se.fit=TRUE), parm=\"mean\")) #> NULL"},{"path":"http://merliseclyde.github.io/BAS/reference/plot.html","id":null,"dir":"Reference","previous_headings":"","what":"Plot Diagnostics for an BAS Object — plot.bas","title":"Plot Diagnostics for an BAS Object — plot.bas","text":"Four plots (selectable '') currently available: plot residuals fitted values, Cumulative Model Probabilities, log marginal likelihoods versus model dimension, marginal inclusion probabilities.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/plot.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Plot Diagnostics for an BAS Object — plot.bas","text":"","code":"# S3 method for bas plot( x, which = c(1:4), caption = c(\"Residuals vs Fitted\", \"Model Probabilities\", \"Model Complexity\", \"Inclusion Probabilities\"), panel = if (add.smooth) panel.smooth else points, sub.caption = NULL, main = \"\", ask = prod(par(\"mfcol\")) < length(which) && dev.interactive(), col.in = 2, col.ex = 1, col.pch = 1, cex.lab = 1, ..., id.n = 3, labels.id = NULL, cex.id = 0.75, add.smooth = getOption(\"add.smooth\"), label.pos = c(4, 2), subset = NULL, drop.always.included = FALSE )"},{"path":"http://merliseclyde.github.io/BAS/reference/plot.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Plot Diagnostics for an BAS Object — plot.bas","text":"x bas BMA object result 'bas' subset plots required, specify subset numbers '1:4' caption captions appear plots panel panel function. useful alternative 'points', 'panel.smooth' can chosen 'add.smooth = TRUE' sub.caption common title-figures multiple; used 'sub' (s.'title') otherwise. 'NULL', default, possible shortened version deparse(x$call) used main title plot-addition 'caption' ask logical; 'TRUE', user asked plot, see 'par(ask=.)' col.color included variables col.ex color excluded variables col.pch color points panels 1-3 cex.lab graphics parameter control size variable names ... parameters passed plotting functions id.n number points labeled plot, starting extreme labels.id vector labels, labels extreme points chosen. 'NULL' uses observation numbers cex.id magnification point labels. add.smooth logical indicating smoother added plots; see also 'panel' label.pos positioning labels, left half right half graph respectively, plots 1-4 subset indices variables include/exclude plot marginal posterior inclusion probabilities (NULL). drop.always.included logical variable drop marginal posterior inclusion probabilities variables always forced model. FALSE default.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/plot.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Plot Diagnostics for an BAS Object — plot.bas","text":"provides panel 4 plots: first plot residuals versus fitted values BMA. second plot cumulative marginal likelihoods models; model space enumerated provides indication whether probabilities leveling . third plot log marginal likelihood versus model dimension fourth plot show posterior marginal inclusion probabilities.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/plot.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Plot Diagnostics for an BAS Object — plot.bas","text":"Merlise Clyde, based plot.lm John Maindonald Martin Maechler","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/plot.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Plot Diagnostics for an BAS Object — plot.bas","text":"","code":"data(Hald) hald.gprior = bas.lm(Y~ ., data=Hald, prior=\"g-prior\", alpha=13, modelprior=beta.binomial(1,1), initprobs=\"eplogp\") plot(hald.gprior)"},{"path":"http://merliseclyde.github.io/BAS/reference/predict.bas.html","id":null,"dir":"Reference","previous_headings":"","what":"Prediction Method for an object of class BAS — predict.bas","title":"Prediction Method for an object of class BAS — predict.bas","text":"Predictions model averaging estimators BMA object class inheriting 'bas'.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/predict.bas.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Prediction Method for an object of class BAS — predict.bas","text":"","code":"# S3 method for bas predict( object, newdata, se.fit = FALSE, type = \"link\", top = NULL, estimator = \"BMA\", na.action = na.pass, ... )"},{"path":"http://merliseclyde.github.io/BAS/reference/predict.bas.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Prediction Method for an object of class BAS — predict.bas","text":"object object class BAS, created bas newdata dataframe predictions. missing, use dataframe used fitting obtaining fitted predicted values. se.fit indicator whether compute se fitted predicted values type Type predictions required. \"link\" scale linear predictor option currently linear models, normal model equivalent type='response'. top scalar integer M. supplied, subset top M models, based posterior probabilities model predictions BMA. estimator estimator used predictions. Currently supported options include: 'HPM' highest probability model 'BMA' Bayesian model averaging, using optionally 'top' models 'MPM' median probability model Barbieri Berger. 'BPM' model closest BMA predictions squared error loss. BMA may computed using 'top' models supplied na.action function determining done missing values newdata. default predict NA. ... optional extra arguments","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/predict.bas.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Prediction Method for an object of class BAS — predict.bas","text":"list fit fitted values based selected estimator Ybma predictions using BMA, fit non-BMA methods compatibility; deprecated Ypred matrix predictions model BMA se.fit se fitted values; case BMA matrix se.pred se predicted values; case BMA matrix se.bma.fit vector posterior sd BMA posterior mean regression function. NULL estimator 'BMA' se.bma.pred vector posterior sd BMA posterior predictive values. NULL estimator 'BMA' best index top models included bestmodels subset bestmodels used fitting prediction best.vars names variables top model; NULL estimator='BMA' df scalar vector degrees freedom models estimator estimator upon 'fit' based.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/predict.bas.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Prediction Method for an object of class BAS — predict.bas","text":"Use BMA /model selection form predictions using top highest probability models.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/predict.bas.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Prediction Method for an object of class BAS — predict.bas","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/predict.bas.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Prediction Method for an object of class BAS — predict.bas","text":"","code":"data(\"Hald\") hald.gprior = bas.lm(Y ~ ., data=Hald, alpha=13, prior=\"g-prior\") predict(hald.gprior, newdata=Hald, estimator=\"BPM\", se.fit=TRUE) #> $fit #> [1] 79.65151 74.47846 105.42183 89.83174 95.62799 104.59616 103.50684 #> [8] 77.00839 92.07571 114.10876 82.68233 111.04286 110.46741 #> attr(,\"model\") #> [1] 0 1 2 4 #> attr(,\"best\") #> [1] 15 #> attr(,\"estimator\") #> [1] \"BPM\" #> #> $Ybma #> [,1] #> [1,] 79.68307 #> [2,] 74.69127 #> [3,] 105.63258 #> [4,] 89.91648 #> [5,] 95.67480 #> [6,] 104.57616 #> [7,] 103.47945 #> [8,] 76.96808 #> [9,] 92.22184 #> [10,] 113.84918 #> [11,] 82.59035 #> [12,] 110.87673 #> [13,] 110.34001 #> #> $Ypred #> [,1] [,2] [,3] [,4] [,5] [,6] [,7] #> [1,] 81.17036 74.83464 105.07248 89.69881 97.15898 104.45753 103.38927 #> [2,] 77.70296 74.24113 105.85537 90.46267 93.09565 104.71517 103.13993 #> [3,] 79.70437 74.40553 105.21752 89.76253 95.63309 104.57088 103.52541 #> [4,] 79.65151 74.47846 105.42183 89.83174 95.62799 104.59616 103.50684 #> [5,] 79.84321 74.31409 104.90632 89.65651 95.70301 104.52849 103.54760 #> [6,] 79.26248 74.75042 106.28314 90.16732 95.37830 104.70862 103.39893 #> [7,] 78.80123 75.69457 108.22151 90.62061 95.54467 104.84276 103.50032 #> [8,] 81.66556 77.02098 106.35099 88.18423 99.83232 103.89115 105.74346 #> [9,] 85.78065 79.39070 104.28069 87.30339 103.43704 102.66524 106.03984 #> [10,] 74.86000 80.34349 102.27744 83.77067 93.36677 100.90656 111.87354 #> [11,] 79.18965 81.38793 101.17241 82.85345 98.24138 100.43966 112.16380 #> [12,] 76.29823 80.55874 101.93127 83.25765 95.26054 100.79397 112.20198 #> [13,] 94.62219 84.21059 101.56325 101.56325 94.62219 101.56325 87.68112 #> [14,] 95.42308 95.42308 95.42308 95.42308 95.42308 95.42308 95.42308 #> [15,] 91.78308 83.03167 101.29055 101.29055 91.78308 101.74970 88.24455 #> [16,] 102.15048 91.65573 99.81831 99.81831 102.15048 98.65223 89.32357 #> [,8] [,9] [,10] [,11] [,12] [,13] #> [1,] 76.06454 91.57174 113.17222 81.59906 111.22195 111.08841 #> [2,] 78.80193 92.68123 115.80581 84.50293 110.41616 109.07906 #> [3,] 77.08557 91.98604 114.17593 82.78145 111.11959 110.53210 #> [4,] 77.00839 92.07571 114.10876 82.68233 111.04286 110.46741 #> [5,] 77.15919 91.83513 114.23530 82.88128 111.23840 110.65147 #> [6,] 76.86019 92.49134 113.99208 82.44826 110.67744 110.08148 #> [7,] 76.13446 93.59932 112.64184 81.53107 109.86900 109.49863 #> [8,] 74.60469 93.86382 106.77052 80.21897 110.61958 111.73373 #> [9,] 74.19437 93.55892 101.91430 79.36984 110.13525 112.42979 #> [10,] 85.82697 100.90656 98.16482 92.68133 107.76092 107.76092 #> [11,] 82.85345 99.70690 94.57759 89.44827 108.50000 109.96552 #> [12,] 84.53056 100.50527 96.78718 91.37187 108.21267 108.79006 #> [13,] 84.21059 85.94586 118.91590 84.21059 101.56325 99.82798 #> [14,] 95.42308 95.42308 95.42308 95.42308 95.42308 95.42308 #> [15,] 86.24572 86.55641 120.92687 86.70486 101.74970 99.14326 #> [16,] 83.49316 88.15749 104.48264 82.32707 98.65223 99.81831 #> #> $postprobs #> [1] 2.432256e-01 1.684081e-01 1.312165e-01 1.224293e-01 1.220358e-01 #> [6] 1.145513e-01 6.888252e-02 2.709377e-02 1.481347e-03 2.891971e-04 #> [11] 2.559516e-04 5.597869e-05 4.790052e-05 1.177702e-05 1.000762e-05 #> [16] 5.009504e-06 #> #> $se.fit #> 1 2 3 4 5 6 7 8 #> 3.117350 2.283957 1.602160 2.149087 2.589321 1.508471 2.610923 2.545817 #> 9 10 11 12 13 #> 1.990817 3.485929 2.456636 1.951456 2.212238 #> #> $se.pred #> 1 2 3 4 5 6 7 8 #> 5.440156 5.009380 4.737547 4.949344 5.155775 4.706689 5.166658 5.134065 #> 9 10 11 12 13 #> 4.882702 5.659428 5.090431 4.866787 4.977090 #> #> $se.bma.fit #> NULL #> #> $se.bma.pred #> NULL #> #> $df #> [1] 12 #> #> $best #> [1] 15 #> #> $bestmodel #> [1] 0 1 2 4 #> #> $best.vars #> [1] \"Intercept\" \"X1\" \"X2\" \"X4\" #> #> $estimator #> [1] \"BPM\" #> #> attr(,\"class\") #> [1] \"pred.bas\" # same as fitted fitted(hald.gprior,estimator=\"BPM\") #> [1] 79.65151 74.47846 105.42183 89.83174 95.62799 104.59616 103.50684 #> [8] 77.00839 92.07571 114.10876 82.68233 111.04286 110.46741 # default is BMA and estimation of mean vector hald.bma = predict(hald.gprior, top=5, se.fit=TRUE) confint(hald.bma) #> 2.5% 97.5% pred #> [1,] 68.27724 91.37182 79.74246 #> [2,] 63.66525 85.76692 74.50010 #> [3,] 94.86215 116.36788 105.29268 #> [4,] 78.39566 100.44548 89.88693 #> [5,] 84.39637 106.24466 95.57177 #> [6,] 94.50137 115.25047 104.56409 #> [7,] 92.27172 115.13803 103.40145 #> [8,] 65.98258 88.63189 77.13668 #> [9,] 81.46505 103.06572 91.99731 #> [10,] 101.28694 126.36327 114.21325 #> [11,] 72.14095 94.50244 82.78446 #> [12,] 99.74081 121.39665 111.00723 #> [13,] 99.34598 121.57452 110.40160 #> attr(,\"Probability\") #> [1] 0.95 #> attr(,\"class\") #> [1] \"confint.bas\" hald.bpm = predict(hald.gprior, newdata=Hald[1,], se.fit=TRUE, estimator=\"BPM\") confint(hald.bpm) #> 2.5% 97.5% pred #> [1,] 67.74454 91.66421 79.70437 #> attr(,\"Probability\") #> [1] 0.95 #> attr(,\"class\") #> [1] \"confint.bas\" # extract variables variable.names(hald.bpm) #> [1] \"Intercept\" \"X1\" \"X2\" \"X3\" \"X4\" hald.hpm = predict(hald.gprior, newdata=Hald[1,], se.fit=TRUE, estimator=\"HPM\") confint(hald.hpm) #> 2.5% 97.5% pred #> [1,] 70.15171 92.18902 81.17036 #> attr(,\"Probability\") #> [1] 0.95 #> attr(,\"class\") #> [1] \"confint.bas\" variable.names(hald.hpm) #> [1] \"Intercept\" \"X1\" \"X2\" hald.mpm = predict(hald.gprior, newdata=Hald[1,], se.fit=TRUE, estimator=\"MPM\") confint(hald.mpm) #> 2.5% 97.5% pred #> [1,] 67.79843 91.50459 79.65151 #> attr(,\"Probability\") #> [1] 0.95 #> attr(,\"class\") #> [1] \"confint.bas\" variable.names(hald.mpm) #> [1] \"Intercept\" \"X1\" \"X2\" \"X4\""},{"path":"http://merliseclyde.github.io/BAS/reference/predict.basglm.html","id":null,"dir":"Reference","previous_headings":"","what":"Prediction Method for an Object of Class basglm — predict.basglm","title":"Prediction Method for an Object of Class basglm — predict.basglm","text":"Predictions model averaging BMA (BAS) object GLMs different loss functions.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/predict.basglm.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Prediction Method for an Object of Class basglm — predict.basglm","text":"","code":"# S3 method for basglm predict( object, newdata, se.fit = FALSE, type = c(\"response\", \"link\"), top = NULL, estimator = \"BMA\", na.action = na.pass, ... )"},{"path":"http://merliseclyde.github.io/BAS/reference/predict.basglm.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Prediction Method for an Object of Class basglm — predict.basglm","text":"object object class \"basglm\", created bas.glm newdata dataframe, new matrix vector data predictions. May include column intercept just predictor variables. dataframe, variables extracted using model.matrix using call created 'object'. May missing case data used fitting used prediction. se.fit indicator whether compute se fitted predicted values type Type predictions required. default \"response\" scale response variable, alternative linear predictor scale, `type ='link'`. Thus default binomial model `type = 'response'` gives predicted probabilities, `'link'`, estimates log-odds (probabilities logit scale). top scalar integer M. supplied, calculate results using subset top M models based posterior probabilities. estimator estimator used predictions. Currently supported options include: 'HPM' highest probability model 'BMA' Bayesian model averaging, using optionally 'top' models 'MPM' median probability model Barbieri Berger. 'BPM' model closest BMA predictions squared error loss. BMA may computed using 'top' models supplied na.action function determining done missing values newdata. default predict NA. ... optional extra arguments","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/predict.basglm.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Prediction Method for an Object of Class basglm — predict.basglm","text":"list fit predictions using BMA estimators Ypred matrix predictions model(s) postprobs renormalized probabilities top models best index top models included","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/predict.basglm.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Prediction Method for an Object of Class basglm — predict.basglm","text":"function first calls predict method class bas (linear models) form predictions linear predictor scale `BMA`, `HPM`, `MPM` etc. estimator `BMA` `type='response'` inverse link applied fitted values type equal `'link'` model averaging takes place `response` scale. Thus applying inverse link BMA estimate `type = 'link'` equal fitted values `type = 'response'` BMA due nonlinear transformation inverse link.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/predict.basglm.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Prediction Method for an Object of Class basglm — predict.basglm","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/predict.basglm.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Prediction Method for an Object of Class basglm — predict.basglm","text":"","code":"data(Pima.tr, package=\"MASS\") data(Pima.te, package=\"MASS\") Pima.bas = bas.glm(type ~ ., data=Pima.tr, n.models= 2^7, method=\"BAS\", betaprior=CCH(a=1, b=nrow(Pima.tr)/2, s=0), family=binomial(), modelprior=uniform()) pred = predict(Pima.bas, newdata=Pima.te, top=1) # Highest Probability model cv.summary.bas(pred$fit, Pima.te$type, score=\"miss-class\") #> [1] 0.2108434"},{"path":"http://merliseclyde.github.io/BAS/reference/print.bas.html","id":null,"dir":"Reference","previous_headings":"","what":"Print a Summary of Bayesian Model Averaging objects from BAS — print.bas","title":"Print a Summary of Bayesian Model Averaging objects from BAS — print.bas","text":"summary print methods Bayesian model averaging objects created bas Bayesian Adaptive Sampling","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/print.bas.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Print a Summary of Bayesian Model Averaging objects from BAS — print.bas","text":"","code":"# S3 method for bas print(x, digits = max(3L, getOption(\"digits\") - 3L), ...)"},{"path":"http://merliseclyde.github.io/BAS/reference/print.bas.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Print a Summary of Bayesian Model Averaging objects from BAS — print.bas","text":"x object class 'bas' digits optional number specifying number digits display ... parameters passed print.default","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/print.bas.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Print a Summary of Bayesian Model Averaging objects from BAS — print.bas","text":"print methods display view similar print.lm . summary methods display view specific Bayesian model averaging giving top 5 highest probability models represented inclusion indicators. Summaries models include Bayes Factor (BF) model model largest marginal likelihood, posterior probability models, R2, dim (includes intercept) log marginal likelihood.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/print.bas.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Print a Summary of Bayesian Model Averaging objects from BAS — print.bas","text":"Merlise Clyde clyde@stat.duke.edu","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/print.bas.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Print a Summary of Bayesian Model Averaging objects from BAS — print.bas","text":"","code":"library(MASS) data(UScrime) UScrime[, -2] <- log(UScrime[, -2]) crime.bic <- bas.lm(y ~ ., data = UScrime, n.models = 2^15, prior = \"BIC\", initprobs = \"eplogp\") print(crime.bic) #> #> Call: #> bas.lm(formula = y ~ ., data = UScrime, n.models = 2^15, prior = \"BIC\", #> initprobs = \"eplogp\") #> #> #> Marginal Posterior Inclusion Probabilities: #> Intercept M So Ed Po1 Po2 LF #> 1.0000 0.9335 0.3277 0.9910 0.7247 0.4602 0.2935 #> M.F Pop NW U1 U2 GDP Ineq #> 0.3298 0.4963 0.8346 0.3481 0.7752 0.5254 0.9992 #> Prob Time #> 0.9541 0.5433 summary(crime.bic) #> P(B != 0 | Y) model 1 model 2 model 3 model 4 #> Intercept 1.0000000 1.00000 1.000000e+00 1.0000000 1.0000000 #> M 0.9335117 1.00000 1.000000e+00 1.0000000 1.0000000 #> So 0.3276563 0.00000 1.000000e+00 0.0000000 0.0000000 #> Ed 0.9910219 1.00000 1.000000e+00 1.0000000 1.0000000 #> Po1 0.7246635 1.00000 1.000000e+00 1.0000000 1.0000000 #> Po2 0.4602481 0.00000 1.000000e+00 0.0000000 0.0000000 #> LF 0.2935326 0.00000 1.000000e+00 0.0000000 0.0000000 #> M.F 0.3298168 0.00000 1.000000e+00 0.0000000 0.0000000 #> Pop 0.4962869 0.00000 1.000000e+00 0.0000000 0.0000000 #> NW 0.8346412 1.00000 1.000000e+00 1.0000000 1.0000000 #> U1 0.3481266 0.00000 1.000000e+00 0.0000000 0.0000000 #> U2 0.7752102 1.00000 1.000000e+00 1.0000000 1.0000000 #> GDP 0.5253694 0.00000 1.000000e+00 0.0000000 1.0000000 #> Ineq 0.9992058 1.00000 1.000000e+00 1.0000000 1.0000000 #> Prob 0.9541470 1.00000 1.000000e+00 1.0000000 1.0000000 #> Time 0.5432686 1.00000 1.000000e+00 0.0000000 1.0000000 #> BF NA 1.00000 1.267935e-04 0.7609295 0.5431578 #> PostProbs NA 0.01910 1.560000e-02 0.0145000 0.0133000 #> R2 NA 0.84200 8.695000e-01 0.8265000 0.8506000 #> dim NA 9.00000 1.600000e+01 8.0000000 10.0000000 #> logmarg NA -22.15855 -3.113150e+01 -22.4317627 -22.7689035 #> model 5 #> Intercept 1.0000000 #> M 1.0000000 #> So 0.0000000 #> Ed 1.0000000 #> Po1 1.0000000 #> Po2 0.0000000 #> LF 0.0000000 #> M.F 0.0000000 #> Pop 1.0000000 #> NW 1.0000000 #> U1 0.0000000 #> U2 1.0000000 #> GDP 0.0000000 #> Ineq 1.0000000 #> Prob 1.0000000 #> Time 0.0000000 #> BF 0.5203179 #> PostProbs 0.0099000 #> R2 0.8375000 #> dim 9.0000000 #> logmarg -22.8118635"},{"path":"http://merliseclyde.github.io/BAS/reference/protein.html","id":null,"dir":"Reference","previous_headings":"","what":"Protein Activity Data — protein","title":"Protein Activity Data — protein","text":"data sets includes several predictors protein activity experiment run Glaxo.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/protein.html","id":"format","dir":"Reference","previous_headings":"","what":"Format","title":"Protein Activity Data — protein","text":"protein dataframe 96 observations 8 predictor variables protein activity:","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/protein.html","id":"source","dir":"Reference","previous_headings":"","what":"Source","title":"Protein Activity Data — protein","text":"Clyde, M. . Parmigiani, G. (1998), Protein Construct Storage: Bayesian Variable Selection Prediction Mixtures, Journal Biopharmaceutical Statistics, 8, 431-443","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/robust.html","id":null,"dir":"Reference","previous_headings":"","what":"Robust-Prior Distribution for Coefficients in BMA Model — robust","title":"Robust-Prior Distribution for Coefficients in BMA Model — robust","text":"Creates object representing robust prior Bayarri et al (2012) mixture g-priors coefficients BAS.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/robust.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Robust-Prior Distribution for Coefficients in BMA Model — robust","text":"","code":"robust(n = NULL)"},{"path":"http://merliseclyde.github.io/BAS/reference/robust.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Robust-Prior Distribution for Coefficients in BMA Model — robust","text":"n sample size.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/robust.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Robust-Prior Distribution for Coefficients in BMA Model — robust","text":"returns object class \"prior\", family hyerparameters.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/robust.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Robust-Prior Distribution for Coefficients in BMA Model — robust","text":"Creates prior structure used bas.glm.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/robust.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Robust-Prior Distribution for Coefficients in BMA Model — robust","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/robust.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Robust-Prior Distribution for Coefficients in BMA Model — robust","text":"","code":"robust(100) #> $family #> [1] \"robust\" #> #> $class #> [1] \"TCCH\" #> #> $hyper.parameters #> $hyper.parameters$n #> [1] 100 #> #> #> attr(,\"class\") #> [1] \"prior\""},{"path":"http://merliseclyde.github.io/BAS/reference/summary.html","id":null,"dir":"Reference","previous_headings":"","what":"Summaries of Bayesian Model Averaging objects from BAS — summary.bas","title":"Summaries of Bayesian Model Averaging objects from BAS — summary.bas","text":"summary print methods Bayesian model averaging objects created bas Bayesian Adaptive Sampling","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/summary.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Summaries of Bayesian Model Averaging objects from BAS — summary.bas","text":"","code":"# S3 method for bas summary(object, n.models = 5, ...)"},{"path":"http://merliseclyde.github.io/BAS/reference/summary.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Summaries of Bayesian Model Averaging objects from BAS — summary.bas","text":"object object class 'bas' n.models optional number specifying number best models display summary ... parameters passed summary.default","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/summary.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Summaries of Bayesian Model Averaging objects from BAS — summary.bas","text":"print methods display view similar print.lm . summary methods display view specific Bayesian model averaging giving top 5 highest probability models represented inclusion indicators. Summaries models include Bayes Factor (BF) model model largest marginal likelihood, posterior probability models, R2, dim (includes intercept) log marginal likelihood.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/summary.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Summaries of Bayesian Model Averaging objects from BAS — summary.bas","text":"Merlise Clyde clyde@duke.edu","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/summary.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Summaries of Bayesian Model Averaging objects from BAS — summary.bas","text":"","code":"data(UScrime, package = \"MASS\") UScrime[, -2] <- log(UScrime[, -2]) crime.bic <- bas.lm(y ~ ., data = UScrime, n.models = 2^15, prior = \"BIC\", initprobs = \"eplogp\") print(crime.bic) #> #> Call: #> bas.lm(formula = y ~ ., data = UScrime, n.models = 2^15, prior = \"BIC\", #> initprobs = \"eplogp\") #> #> #> Marginal Posterior Inclusion Probabilities: #> Intercept M So Ed Po1 Po2 LF #> 1.0000 0.9335 0.3277 0.9910 0.7247 0.4602 0.2935 #> M.F Pop NW U1 U2 GDP Ineq #> 0.3298 0.4963 0.8346 0.3481 0.7752 0.5254 0.9992 #> Prob Time #> 0.9541 0.5433 summary(crime.bic) #> P(B != 0 | Y) model 1 model 2 model 3 model 4 #> Intercept 1.0000000 1.00000 1.000000e+00 1.0000000 1.0000000 #> M 0.9335117 1.00000 1.000000e+00 1.0000000 1.0000000 #> So 0.3276563 0.00000 1.000000e+00 0.0000000 0.0000000 #> Ed 0.9910219 1.00000 1.000000e+00 1.0000000 1.0000000 #> Po1 0.7246635 1.00000 1.000000e+00 1.0000000 1.0000000 #> Po2 0.4602481 0.00000 1.000000e+00 0.0000000 0.0000000 #> LF 0.2935326 0.00000 1.000000e+00 0.0000000 0.0000000 #> M.F 0.3298168 0.00000 1.000000e+00 0.0000000 0.0000000 #> Pop 0.4962869 0.00000 1.000000e+00 0.0000000 0.0000000 #> NW 0.8346412 1.00000 1.000000e+00 1.0000000 1.0000000 #> U1 0.3481266 0.00000 1.000000e+00 0.0000000 0.0000000 #> U2 0.7752102 1.00000 1.000000e+00 1.0000000 1.0000000 #> GDP 0.5253694 0.00000 1.000000e+00 0.0000000 1.0000000 #> Ineq 0.9992058 1.00000 1.000000e+00 1.0000000 1.0000000 #> Prob 0.9541470 1.00000 1.000000e+00 1.0000000 1.0000000 #> Time 0.5432686 1.00000 1.000000e+00 0.0000000 1.0000000 #> BF NA 1.00000 1.267935e-04 0.7609295 0.5431578 #> PostProbs NA 0.01910 1.560000e-02 0.0145000 0.0133000 #> R2 NA 0.84200 8.695000e-01 0.8265000 0.8506000 #> dim NA 9.00000 1.600000e+01 8.0000000 10.0000000 #> logmarg NA -22.15855 -3.113150e+01 -22.4317627 -22.7689035 #> model 5 #> Intercept 1.0000000 #> M 1.0000000 #> So 0.0000000 #> Ed 1.0000000 #> Po1 1.0000000 #> Po2 0.0000000 #> LF 0.0000000 #> M.F 0.0000000 #> Pop 1.0000000 #> NW 1.0000000 #> U1 0.0000000 #> U2 1.0000000 #> GDP 0.0000000 #> Ineq 1.0000000 #> Prob 1.0000000 #> Time 0.0000000 #> BF 0.5203179 #> PostProbs 0.0099000 #> R2 0.8375000 #> dim 9.0000000 #> logmarg -22.8118635"},{"path":"http://merliseclyde.github.io/BAS/reference/tCCH.html","id":null,"dir":"Reference","previous_headings":"","what":"Generalized tCCH g-Prior Distribution for Coefficients in BMA Models — tCCH","title":"Generalized tCCH g-Prior Distribution for Coefficients in BMA Models — tCCH","text":"Creates object representing tCCH mixture g-priors coefficients BAS.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/tCCH.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Generalized tCCH g-Prior Distribution for Coefficients in BMA Models — tCCH","text":"","code":"tCCH(alpha = 1, beta = 2, s = 0, r = 3/2, v = 1, theta = 1)"},{"path":"http://merliseclyde.github.io/BAS/reference/tCCH.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Generalized tCCH g-Prior Distribution for Coefficients in BMA Models — tCCH","text":"alpha scalar > 0, recommended alpha=.5 (betaprime) 1. beta scalar > 0. value updated data; beta function n consistency null model. s scalar, recommended s=0 priori r r arbitrary; hyper-g-n prior sets r = (alpha + 2) v 0 < v theta theta > 1","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/tCCH.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Generalized tCCH g-Prior Distribution for Coefficients in BMA Models — tCCH","text":"returns object class \"prior\", family hyerparameters.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/tCCH.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Generalized tCCH g-Prior Distribution for Coefficients in BMA Models — tCCH","text":"Creates structure used bas.glm.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/tCCH.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Generalized tCCH g-Prior Distribution for Coefficients in BMA Models — tCCH","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/tCCH.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Generalized tCCH g-Prior Distribution for Coefficients in BMA Models — tCCH","text":"","code":"n <- 500 tCCH(alpha = 1, beta = 2, s = 0, r = 1.5, v = 1, theta = 1 / n) #> $family #> [1] \"tCCH\" #> #> $class #> [1] \"TCCH\" #> #> $hyper.parameters #> $hyper.parameters$alpha #> [1] 1 #> #> $hyper.parameters$beta #> [1] 2 #> #> $hyper.parameters$s #> [1] 0 #> #> $hyper.parameters$r #> [1] 1.5 #> #> $hyper.parameters$v #> [1] 1 #> #> $hyper.parameters$theta #> [1] 0.002 #> #> #> attr(,\"class\") #> [1] \"prior\""},{"path":"http://merliseclyde.github.io/BAS/reference/testBF.prior.html","id":null,"dir":"Reference","previous_headings":"","what":"Test based Bayes Factors for BMA Models — testBF.prior","title":"Test based Bayes Factors for BMA Models — testBF.prior","text":"Creates object representing prior distribution coefficients BAS corresponds test-based Bayes Factors.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/testBF.prior.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Test based Bayes Factors for BMA Models — testBF.prior","text":"","code":"testBF.prior(g)"},{"path":"http://merliseclyde.github.io/BAS/reference/testBF.prior.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Test based Bayes Factors for BMA Models — testBF.prior","text":"g scalar used covariance Zellner's g-prior, Cov(beta) = sigma^2 g (X'X)^-","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/testBF.prior.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Test based Bayes Factors for BMA Models — testBF.prior","text":"returns object class \"prior\", family hyerparameters.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/testBF.prior.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Test based Bayes Factors for BMA Models — testBF.prior","text":"Creates prior object structure used BAS `bas.glm`.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/testBF.prior.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Test based Bayes Factors for BMA Models — testBF.prior","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/testBF.prior.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Test based Bayes Factors for BMA Models — testBF.prior","text":"","code":"testBF.prior(100) #> $family #> [1] \"testBF.prior\" #> #> $g #> [1] 100 #> #> $class #> [1] \"g-prior\" #> #> $hyper #> [1] 100 #> #> $hyper.parameters #> $hyper.parameters$g #> [1] 100 #> #> $hyper.parameters$loglik_null #> NULL #> #> #> attr(,\"class\") #> [1] \"prior\" library(MASS) data(Pima.tr) # use g = n bas.glm(type ~ ., data = Pima.tr, family = binomial(), betaprior = testBF.prior(nrow(Pima.tr)), modelprior = uniform(), method = \"BAS\" ) #> #> Call: #> bas.glm(formula = type ~ ., family = binomial(), data = Pima.tr, #> betaprior = testBF.prior(nrow(Pima.tr)), modelprior = uniform(), #> method = \"BAS\") #> #> #> Marginal Posterior Inclusion Probabilities: #> Intercept npreg glu bp skin bmi ped #> 1.0000 0.4252 1.0000 0.0706 0.1264 0.6139 0.8075 #> age #> 0.6705"},{"path":"http://merliseclyde.github.io/BAS/reference/tr.beta.binomial.html","id":null,"dir":"Reference","previous_headings":"","what":"Truncated Beta-Binomial Prior Distribution for Models — tr.beta.binomial","title":"Truncated Beta-Binomial Prior Distribution for Models — tr.beta.binomial","text":"Creates object representing prior distribution models BAS using truncated Beta-Binomial Distribution Model Size","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/tr.beta.binomial.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Truncated Beta-Binomial Prior Distribution for Models — tr.beta.binomial","text":"","code":"tr.beta.binomial(alpha = 1, beta = 1, trunc)"},{"path":"http://merliseclyde.github.io/BAS/reference/tr.beta.binomial.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Truncated Beta-Binomial Prior Distribution for Models — tr.beta.binomial","text":"alpha parameter beta prior distribution beta parameter beta prior distribution trunc parameter determines truncation distribution .e. P(M; alpha, beta, trunc) = 0 M > trunc.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/tr.beta.binomial.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Truncated Beta-Binomial Prior Distribution for Models — tr.beta.binomial","text":"returns object class \"prior\", family hyperparameters.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/tr.beta.binomial.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Truncated Beta-Binomial Prior Distribution for Models — tr.beta.binomial","text":"beta-binomial distribution model size obtained assigning variable inclusion indicator independent Bernoulli distributions probability w, giving w beta(alpha,beta) distribution. Marginalizing w leads number included predictors beta-binomial distribution. default hyperparameters lead uniform distribution model size. Truncated version assigns zero probability models size > trunc.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/tr.beta.binomial.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Truncated Beta-Binomial Prior Distribution for Models — tr.beta.binomial","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/tr.beta.binomial.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Truncated Beta-Binomial Prior Distribution for Models — tr.beta.binomial","text":"","code":"tr.beta.binomial(1, 10, 5) #> $family #> [1] \"Trunc-Beta-Binomial\" #> #> $hyper.parameters #> [1] 1 10 5 #> #> attr(,\"class\") #> [1] \"prior\" library(MASS) data(UScrime) UScrime[, -2] <- log(UScrime[, -2]) crime.bic <- bas.lm(y ~ ., data = UScrime, n.models = 2^15, prior = \"BIC\", modelprior = tr.beta.binomial(1, 1, 8), initprobs = \"eplogp\" )"},{"path":"http://merliseclyde.github.io/BAS/reference/tr.poisson.html","id":null,"dir":"Reference","previous_headings":"","what":"Truncated Poisson Prior Distribution for Models — tr.poisson","title":"Truncated Poisson Prior Distribution for Models — tr.poisson","text":"Creates object representing prior distribution models BAS using truncated Poisson Distribution Model Size","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/tr.poisson.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Truncated Poisson Prior Distribution for Models — tr.poisson","text":"","code":"tr.poisson(lambda, trunc)"},{"path":"http://merliseclyde.github.io/BAS/reference/tr.poisson.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Truncated Poisson Prior Distribution for Models — tr.poisson","text":"lambda parameter Poisson distribution representing expected model size infinite predictors trunc parameter determines truncation distribution .e. P(M; lambda, trunc) = 0 M > trunc","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/tr.poisson.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Truncated Poisson Prior Distribution for Models — tr.poisson","text":"returns object class \"prior\", family hyperparameters.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/tr.poisson.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Truncated Poisson Prior Distribution for Models — tr.poisson","text":"Poisson prior distribution model size obtained assigning variable inclusion indicator independent Bernoulli distributions probability w, taking limit p goes infinity w goes zero, p*w converges lambda. Truncated version assigns zero probability models size M > trunc.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/tr.poisson.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Truncated Poisson Prior Distribution for Models — tr.poisson","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/tr.poisson.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Truncated Poisson Prior Distribution for Models — tr.poisson","text":"","code":"tr.poisson(10, 50) #> $family #> [1] \"Trunc-Poisson\" #> #> $hyper.parameters #> [1] 10 50 #> #> attr(,\"class\") #> [1] \"prior\""},{"path":"http://merliseclyde.github.io/BAS/reference/tr.power.prior.html","id":null,"dir":"Reference","previous_headings":"","what":"Truncated Power Prior Distribution for Models — tr.power.prior","title":"Truncated Power Prior Distribution for Models — tr.power.prior","text":"Creates object representing prior distribution models BAS using truncated Distribution Model Size probability gamma = p^-kappa |gamma| gamma vector model indicators","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/tr.power.prior.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Truncated Power Prior Distribution for Models — tr.power.prior","text":"","code":"tr.power.prior(kappa = 2, trunc)"},{"path":"http://merliseclyde.github.io/BAS/reference/tr.power.prior.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Truncated Power Prior Distribution for Models — tr.power.prior","text":"kappa parameter prior distribution controls sparsity trunc parameter determines truncation distribution .e. P(gamma; alpha, beta, trunc) = 0 |gamma| > trunc.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/tr.power.prior.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Truncated Power Prior Distribution for Models — tr.power.prior","text":"returns object class \"prior\", family hyperparameters.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/tr.power.prior.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Truncated Power Prior Distribution for Models — tr.power.prior","text":"beta-binomial distribution model size obtained assigning variable inclusion indicator independent Bernoulli distributions probability w, giving w beta(alpha,beta) distribution. Marginalizing w leads number included predictors beta-binomial distribution. default hyperparameters lead uniform distribution model size. Truncated version assigns zero probability models size > trunc.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/tr.power.prior.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Truncated Power Prior Distribution for Models — tr.power.prior","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/tr.power.prior.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Truncated Power Prior Distribution for Models — tr.power.prior","text":"","code":"tr.power.prior(2, 8) #> $family #> [1] \"Trunc-Power-Prior\" #> #> $hyper.parameters #> [1] 2 8 #> #> attr(,\"class\") #> [1] \"prior\" library(MASS) data(UScrime) UScrime[, -2] <- log(UScrime[, -2]) crime.bic <- bas.lm(y ~ ., data = UScrime, n.models = 2^15, prior = \"BIC\", modelprior = tr.power.prior(2, 8), initprobs = \"eplogp\" )"},{"path":"http://merliseclyde.github.io/BAS/reference/trCCH.html","id":null,"dir":"Reference","previous_headings":"","what":"Truncated Compound Confluent Hypergeometric function — trCCH","title":"Truncated Compound Confluent Hypergeometric function — trCCH","text":"Compute Truncated Confluent Hypergeometric function Li Clyde (2018) normalizing constant tcch density Gordy (1998) integral representation:","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/trCCH.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Truncated Compound Confluent Hypergeometric function — trCCH","text":"","code":"trCCH(a, b, r, s, v, k, log = FALSE)"},{"path":"http://merliseclyde.github.io/BAS/reference/trCCH.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Truncated Compound Confluent Hypergeometric function — trCCH","text":"> 0 b b > 0 r r >= 0 s arbitrary v 0 < v k arbitrary log logical indicating whether return values log scale; useful Bayes Factor calculations","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/trCCH.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Truncated Compound Confluent Hypergeometric function — trCCH","text":"tr.cch(,b,r,s,v,k) = Int_0^1/v u^(-1) (1 - vu)^(b -1) (k + (1 - k)vu)^(-r) exp(-s u) du uses stable method calculating normalizing constant using R's `integrate` function rather version Gordy 1998. calculating Bayes factors use `trCCH` function recommend using `log=TRUE` option compute log Bayes factors.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/trCCH.html","id":"references","dir":"Reference","previous_headings":"","what":"References","title":"Truncated Compound Confluent Hypergeometric function — trCCH","text":"Gordy 1998 Li & Clyde 2018","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/trCCH.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Truncated Compound Confluent Hypergeometric function — trCCH","text":"Merlise Clyde (clyde@duke.edu)","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/trCCH.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Truncated Compound Confluent Hypergeometric function — trCCH","text":"","code":"# special cases # trCCH(a, b, r, s=0, v = 1, k) is the same as # 2F1(a, r, a + b, 1 - 1/k)*beta(a, b)/k^r k = 10; a = 1.5; b = 2; r = 2; trCCH(a, b, r, s=0, v = 1, k=k) *k^r/beta(a,b) #> [1] 4.74679 hypergeometric2F1(a, r, a + b, 1 - 1/k, log = FALSE) #> [1] 4.746772 # trCCH(a,b,0,s,1,1) is the same as # beta(a, b) 1F1(a, a + b, -s, log=FALSE) s = 3; r = 0; v = 1; k = 1 beta(a, b)*hypergeometric1F1(a, a+b, -s, log = FALSE) #> [1] 0.0923551 trCCH(a, b, r, s, v, k) #> [1] 0.09235518 # Equivalence with the Phi1 function a = 1.5; b = 3; k = 1.25; s = 400; r = 2; v = 1; phi1(a, r, a + b, -s, 1 - 1/k, log=FALSE)*(k^-r)*gamma(a)*gamma(b)/gamma(a+b) #> [1] 7.04733e-05 trCCH(a,b,r,s,v,k) #> [1] 7.052186e-05"},{"path":"http://merliseclyde.github.io/BAS/reference/uniform.html","id":null,"dir":"Reference","previous_headings":"","what":"Uniform Prior Distribution for Models — uniform","title":"Uniform Prior Distribution for Models — uniform","text":"Creates object representing prior distribution models BAS.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/uniform.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Uniform Prior Distribution for Models — uniform","text":"","code":"uniform()"},{"path":"http://merliseclyde.github.io/BAS/reference/uniform.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Uniform Prior Distribution for Models — uniform","text":"returns object class \"prior\", family name Uniform.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/uniform.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Uniform Prior Distribution for Models — uniform","text":"Uniform prior distribution commonly used prior BMA, special case independent Bernoulli prior probs=.5. implied prior distribution model size binomial(p, .5).","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/uniform.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Uniform Prior Distribution for Models — uniform","text":"Merlise Clyde","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/uniform.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Uniform Prior Distribution for Models — uniform","text":"","code":"uniform() #> $family #> [1] \"Uniform\" #> #> $hyper.parameters #> [1] 0.5 #> #> attr(,\"class\") #> [1] \"prior\""},{"path":"http://merliseclyde.github.io/BAS/reference/update.html","id":null,"dir":"Reference","previous_headings":"","what":"Update BAS object using a new prior — update.bas","title":"Update BAS object using a new prior — update.bas","text":"Update BMA object using new prior distribution coefficients.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/update.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Update BAS object using a new prior — update.bas","text":"","code":"# S3 method for bas update(object, newprior, alpha = NULL, ...)"},{"path":"http://merliseclyde.github.io/BAS/reference/update.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Update BAS object using a new prior — update.bas","text":"object BMA object update newprior Update posterior model probabilities, probne0, shrinkage, logmarg, etc, using prior based newprior. See bas available methods alpha optional new value hyperparameter prior method ... optional arguments","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/update.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Update BAS object using a new prior — update.bas","text":"new object class BMA","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/update.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Update BAS object using a new prior — update.bas","text":"Recomputes marginal likelihoods new methods models already sampled current object.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/update.html","id":"references","dir":"Reference","previous_headings":"","what":"References","title":"Update BAS object using a new prior — update.bas","text":"Clyde, M. Ghosh, J. Littman, M. (2010) Bayesian Adaptive Sampling Variable Selection Model Averaging. Journal Computational Graphics Statistics. 20:80-101 doi:10.1198/jcgs.2010.09049","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/update.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Update BAS object using a new prior — update.bas","text":"Merlise Clyde clyde@stat.duke.edu","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/update.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Update BAS object using a new prior — update.bas","text":"","code":"# \\donttest{ library(MASS) data(UScrime) UScrime[,-2] <- log(UScrime[,-2]) crime.bic <- bas.lm(y ~ ., data=UScrime, n.models=2^10, prior=\"BIC\",initprobs= \"eplogp\") crime.ebg <- update(crime.bic, newprior=\"EB-global\") crime.zs <- update(crime.bic, newprior=\"ZS-null\") # }"},{"path":"http://merliseclyde.github.io/BAS/reference/variable.names.pred.bas.html","id":null,"dir":"Reference","previous_headings":"","what":"Extract the variable names for a model from a BAS prediction object — variable.names.pred.bas","title":"Extract the variable names for a model from a BAS prediction object — variable.names.pred.bas","text":"S3 method class 'pred.bas'. Simple utility function extract variable names. Used print names selected models using estimators 'HPM', 'MPM' 'BPM\". selected model created predict BAS objects.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/variable.names.pred.bas.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Extract the variable names for a model from a BAS prediction object — variable.names.pred.bas","text":"","code":"# S3 method for pred.bas variable.names(object, ...)"},{"path":"http://merliseclyde.github.io/BAS/reference/variable.names.pred.bas.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Extract the variable names for a model from a BAS prediction object — variable.names.pred.bas","text":"object BAS object created predict BAS `bas.lm` `bas.glm` object ... arguments pass ","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/variable.names.pred.bas.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Extract the variable names for a model from a BAS prediction object — variable.names.pred.bas","text":"character vector names variables included selected model; case 'BMA' variables","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/variable.names.pred.bas.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Extract the variable names for a model from a BAS prediction object — variable.names.pred.bas","text":"","code":"data(Hald) hald.gprior = bas.lm(Y~ ., data=Hald, prior=\"ZS-null\", modelprior=uniform()) hald.bpm = predict(hald.gprior, newdata=Hald[1,], se.fit=TRUE, estimator=\"BPM\") variable.names(hald.bpm) #> [1] \"Intercept\" \"X2\""},{"path":"http://merliseclyde.github.io/BAS/reference/which.matrix.html","id":null,"dir":"Reference","previous_headings":"","what":"Coerce a BAS list object of models into a matrix. — which.matrix","title":"Coerce a BAS list object of models into a matrix. — which.matrix","text":"function coerces list object models matrix fill zeros facilitate computations.","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/which.matrix.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Coerce a BAS list object of models into a matrix. — which.matrix","text":"","code":"which.matrix(which, n.vars)"},{"path":"http://merliseclyde.github.io/BAS/reference/which.matrix.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Coerce a BAS list object of models into a matrix. — which.matrix","text":"'bas' model object x$n.vars total number predictors, x$n.vars","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/which.matrix.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Coerce a BAS list object of models into a matrix. — which.matrix","text":"matrix representation x$, number rows equal length .models total number models number columns x$n.vars","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/which.matrix.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Coerce a BAS list object of models into a matrix. — which.matrix","text":".matrix coerces x$matrix.","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/reference/which.matrix.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"Coerce a BAS list object of models into a matrix. — which.matrix","text":"Merlise Clyde clyde@duke.edu","code":""},{"path":"http://merliseclyde.github.io/BAS/reference/which.matrix.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Coerce a BAS list object of models into a matrix. — which.matrix","text":"","code":"data(Hald) Hald.bic <- bas.lm(Y ~ ., data=Hald, prior=\"BIC\", initprobs=\"eplogp\") # matrix of model indicators models <- which.matrix(Hald.bic$which, Hald.bic$n.vars)"},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-development-version","dir":"Changelog","previous_headings":"","what":"BAS (development version)","title":"BAS (development version)","text":"added unit tests link functions implemented family.c","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-171","dir":"Changelog","previous_headings":"","what":"BAS 1.7.1","title":"BAS 1.7.1","text":"CRAN release: 2023-12-06","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"minor-improvements-and-fixes-1-7-1","dir":"Changelog","previous_headings":"","what":"Minor Improvements and Fixes","title":"BAS 1.7.1","text":"Initialized vector se via memset disp = 1.0 fit_glm.c (issue #72) Initialized variables hyp1f1.c testthat (issue #75) Removed models zero prior probability bas.lm bas.glm (issue #74) Fixed error bayesglm.fit check arguments x y correct type calling C added unit test (issue #67)","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-166","dir":"Changelog","previous_headings":"","what":"BAS 1.6.6","title":"BAS 1.6.6","text":"CRAN release: 2023-11-28","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"new-features-1-6-6","dir":"Changelog","previous_headings":"","what":"New Features","title":"BAS 1.6.6","text":"Added support Gamma regression bas.glm, unit tests example (Code contributed @betsyberrson) added error supplied initial model bas.lm sampling methods “MCMC” “MCMC+BAS” prior probability zero. fixed printing problems identified via checks fixed indexing error bas.lm method = \"MCMC+BAS\" bas.lm using method = \"MCMC+BAS\" crashed segmentation fault bestmodel NULL null model. GitHub issue #69 fixed error predict.bas se.fit=TRUE one predictor. GitHub issue #68 reported @AleCarminati added unit test test-predict.R Fixed error coef bas.glm objects using betaprior class IC, including AIC BIC Github issue #65 Fixed error using Jeffreys prior bas.glm include.always option added unit test test-bas-glm.R. Github issue #61 Fixed error extracting coefficients median probability model formula passed object rather literal, added unit test test-coefficients.R Github issues #39 #56","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-164","dir":"Changelog","previous_headings":"","what":"BAS 1.6.4","title":"BAS 1.6.4","text":"CRAN release: 2022-11-02","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"changes-1-6-4","dir":"Changelog","previous_headings":"","what":"Changes","title":"BAS 1.6.4","text":"skipped test CRAN fails show warning non full rank case pivot=FALSE bas.lm default uses pivoting documentation indicates pivot=FALSE used full rank case users encounter issue practice. Users continue see warning NA’s returned, aware platforms may produce warning (M1mac). Github issue #62","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-163","dir":"Changelog","previous_headings":"","what":"BAS 1.6.3","title":"BAS 1.6.3","text":"CRAN release: 2022-10-19","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"changes-1-6-3","dir":"Changelog","previous_headings":"","what":"Changes","title":"BAS 1.6.3","text":"Added checks unit-tests see modelprior class ‘prior’ resolving Github Issue #57 Removed polevl.c, psi.c gamma.c Cephes longer used switching R’s internal functions","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-162","dir":"Changelog","previous_headings":"","what":"BAS 1.6.2","title":"BAS 1.6.2","text":"CRAN release: 2022-04-26 replaced deprecated DOUBLE_EPS DBL_EPSILON R 4.2.0 release (two places) restore CRAN","code":""},{"path":[]},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"changes-1-6-1","dir":"Changelog","previous_headings":"","what":"Changes","title":"BAS 1.6.1","text":"replaced deprecated DOUBLE_EPS DBL_EPSILON R 4.2.0 release fixed warnings CRAN checks R devel (use | class) added function trCCH uses integration compute normalizing constant Truncated Compound Confluent Hypergeometric distribution provides correct normalizing constant Gordy (1998) stable large values compared current phi1 function. now used TCCH prior bas.glm. Rewrote phi1 function use direct numerical integration (phi1_int) Wald statistic large marginal likelihoods NA suggested Daniel Heeman Alexander Ly (see ). improve stability estimates Bayes Factors model probabilities bas.glm used HyperTwo function, including coefficient priors hyper.g.n(), robust(), intrinsic(). Added additional unit tests. Added thin option bas.glm added unit tests examples show connections special functions trCCH, phi1, 1F1 2F1","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bug-fixes-1-6-1","dir":"Changelog","previous_headings":"","what":"Bug Fixes","title":"BAS 1.6.1","text":"added internal function phi1_int original HyperTwo function returns NA Issue #55 See details . corrected shrinkage estimate CCH prior include terms involving beta function.","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-160","dir":"Changelog","previous_headings":"","what":"BAS 1.6.0","title":"BAS 1.6.0","text":"CRAN release: 2021-11-12","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"changes-1-6-0","dir":"Changelog","previous_headings":"","what":"Changes","title":"BAS 1.6.0","text":"update FORTRAN code compliant USE_FC_LEN_T character strings","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bug-fixes-1-6-0","dir":"Changelog","previous_headings":"","what":"Bug Fixes","title":"BAS 1.6.0","text":"fixed warning src code log_laplace_F21 uninitialized variable leading NaN returned R function hypergeometric2F1","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-155","dir":"Changelog","previous_headings":"","what":"BAS 1.5.5","title":"BAS 1.5.5","text":"CRAN release: 2020-01-24","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"changes-1-5-5","dir":"Changelog","previous_headings":"","what":"Changes","title":"BAS 1.5.5","text":"Fixed WARNING fedora-clang-devel. Added climate.dat file package building vignette package violate CRAN’s policy accessing internet resources permanent file location/url changes locally. Fixed testthat errors Solaris. Default settings force.heredity set back FALSE bas.lm bas.glm methods work platforms. Solaris, users wish impose force.heredity constraint may use post-processing function.","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-154","dir":"Changelog","previous_headings":"","what":"BAS 1.5.4","title":"BAS 1.5.4","text":"CRAN release: 2020-01-19","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"features-1-5-4","dir":"Changelog","previous_headings":"","what":"Features","title":"BAS 1.5.4","text":"Modified prior probabilities adjust number variables always included using include.always. Pull request #41 Don van de Bergh. Issue #40","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bug-fixes-1-5-4","dir":"Changelog","previous_headings":"","what":"Bug Fixes","title":"BAS 1.5.4","text":"Fixed valgrind error src/ZS_approx_null_np.c invalid write noted CRAN checks fixed function declaration type-mismatch argument errors identified LTO noted CRAN checks Added contrast=NULL argument bas.lm bas.glm non-NULL contrasts trigger warning model.matrix R 3.6.0. Bug #44 Added check sample size equal zero due subsetting missing data Bug #37","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"other-1-5-4","dir":"Changelog","previous_headings":"","what":"Other","title":"BAS 1.5.4","text":"Put ORCID quotes author list (per R-dev changes)","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-153","dir":"Changelog","previous_headings":"","what":"BAS 1.5.3","title":"BAS 1.5.3","text":"CRAN release: 2018-10-30","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bug-fixes-1-5-3","dir":"Changelog","previous_headings":"","what":"Bug Fixes","title":"BAS 1.5.3","text":"Fixed errors identified cran checks https://cran.r-project.org/web/checks/check_results_BAS.html initialize R2_m = 0.0 lm_mcmcbas.c (lead NA’s clang debian fedora ) switch default pivot = TRUE bas.lm, adding tol argument control tolerance cholregpovot improved stability across platforms singular nearly singular designs. valgrind messages: Conditional jump move depends uninitialized value(s). Initialize vectors allocated via R_alloc lm_deterministic.c glm_deterministic.c.","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-152","dir":"Changelog","previous_headings":"","what":"BAS 1.5.2","title":"BAS 1.5.2","text":"CRAN release: 2018-10-25","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"features-1-5-2","dir":"Changelog","previous_headings":"","what":"Features","title":"BAS 1.5.2","text":"Included option pivot=TRUE bas.lm fit models using pivoted Cholesky decomposition allow models rank-deficient. Enhancement #24 Bug #21. Currently coefficients -estimable set zero predict methods work . vector rank added output (see documentation bas.lm) degrees freedom methods assume uniform prior obtaining estimates (AIC BIC) adjusted use rank rather size. Added option force.heredity=TRUEto force lower order terms included higher order terms present (hierarchical constraint) method='MCMC' method='BAS' bas.lm bas.glm. Updated Vignette illustrate. enhancement #19. Checks see parents included using include.always pass issue #26. Added option drop.always.included image.bas variables always included may excluded image. default shown enhancement #23 Added option drop.always.included subset plot.bas variables always included may excluded plot showing marginal posterior inclusion probabilities (=4). default shown enhancement #23 update fitted.bas use predict code covers GLM LM cases type='link' type='response' Updates package CII Best Practices Badge certification Added Code Coverage support extensive tests using test_that.","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bugs-1-5-2","dir":"Changelog","previous_headings":"","what":"Bugs","title":"BAS 1.5.2","text":"fixed issue #36 Errors prior = “ZS-null” R2 finite range due model full rank. Change gexpectations function file bayesreg.c fixed issue #35 method=\"MCMC+BAS\" bas.glm glm_mcmcbas.c values provided MCMC.iterations n.models defaults used. Added unit test test-bas-glm.R fixed issue #34 bas.glm variables include.always marginal inclusion probabilities incorrect. Added unit test test-bas-glm.R fixed issue #33 Jeffreys prior marginal inclusion probabilities renormalized dropping intercept model fixed issue #32 allow vectorization phi1 function R/cch.R added unit test “tests/testthat/test-special-functions.R” fixed issue #31 coerce g REAL g.prior prior IC.prior bas.glm; added unit-test “tests/testthat/test-bas-glm.R” fixed issue #30 added n hyper-parameter NULL coerced REAL intrinsic prior bas.glm; added unit-test fixed issue #29 added n hyper-parameter NULL coerced REAL beta.prime prior bas.glm; added unit-test fixed issue #28 fixed length MCMC estimates marginal inclusion probabilities; added unit-test fixed issue #27 expected shrinkage JZS prior greater 1. Added unit test. fixed output include.always include intercept issue #26 always drop.always.included = TRUE drops intercept variables forced . include.always force.heredity=TRUE can now used together method=\"BAS\". added warning marginal likelihoods/posterior probabilities NA default model fitting method suggestion models rerun pivot = TRUE. uses modified Cholesky decomposition pivoting model rank deficient nearly singular dimensionality reduced. Bug #21. corrected count first model method='MCMC' lead potential model 0 probability errors image. coerced predicted values vector BMA (matrix) fixed size using method=deterministic bas.glm (updated) fixed problem confint horizontal=TRUE intervals point mass zero.","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"other-1-5-2","dir":"Changelog","previous_headings":"","what":"Other","title":"BAS 1.5.2","text":"suppress warning sampling probabilities 1 0 number models decrementedIssue #25 changed force.heredity.bas re-normalize prior probabilities rather use new prior probability based heredity constraints. future, add new priors models based heredity. See comment issue #26. Changed License GPL 3.0","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-151-june-6-2018","dir":"Changelog","previous_headings":"","what":"BAS 1.5.1 June 6, 2018","title":"BAS 1.5.1 June 6, 2018","text":"CRAN release: 2018-06-07","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"features-1-5-1","dir":"Changelog","previous_headings":"","what":"Features","title":"BAS 1.5.1 June 6, 2018","text":"added S3 method variable.names extract variable names highest probability model, median probability model, best probability model objects created predict.","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bugs-1-5-1","dir":"Changelog","previous_headings":"","what":"Bugs","title":"BAS 1.5.1 June 6, 2018","text":"Fixed incorrect documentation predict.basglm type = \"link\" default prediction issue #18","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-150-may-2-2018","dir":"Changelog","previous_headings":"","what":"BAS 1.5.0 May 2, 2018","title":"BAS 1.5.0 May 2, 2018","text":"CRAN release: 2018-05-03","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"features-1-5-0","dir":"Changelog","previous_headings":"","what":"Features","title":"BAS 1.5.0 May 2, 2018","text":"add na.action handling NA’s predict methods issue #10 added include.always new argument bas.lm. allows formula specify terms always included models. default intercept always included. added section vignette illustrate weighted regression force.heredity.bas function group levels factor enter leave model together.","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bugs-1-5-0","dir":"Changelog","previous_headings":"","what":"Bugs","title":"BAS 1.5.0 May 2, 2018","text":"fixed problem one model image function; github issue #11 fixed error bas.lm non-equal weights R2 incorrect. issue #17 ## Deprecated deprecate predict argument predict.bas, predict.basglm internal functions utilized","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-149-march-24-2018","dir":"Changelog","previous_headings":"","what":"BAS 1.4.9 March 24, 2018","title":"BAS 1.4.9 March 24, 2018","text":"CRAN release: 2018-03-25","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bugs-1-4-9","dir":"Changelog","previous_headings":"","what":"Bugs","title":"BAS 1.4.9 March 24, 2018","text":"fixed bug confint.coef.bas parm character string added parentheses betafamily.c line 382 indicated CRAN check R devel","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"features-1-4-9","dir":"Changelog","previous_headings":"","what":"Features","title":"BAS 1.4.9 March 24, 2018","text":"added option determine k Bayes.outlier prior probability outliers provided","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-148-march-10-2018","dir":"Changelog","previous_headings":"","what":"BAS 1.4.8 March 10, 2018","title":"BAS 1.4.8 March 10, 2018","text":"CRAN release: 2018-03-12","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bugs-1-4-8","dir":"Changelog","previous_headings":"","what":"Bugs","title":"BAS 1.4.8 March 10, 2018","text":"fixed issue scoping eval data predict.bas dataname defined local env. fixed issue 10 github (predict estimator=‘BPM’ failed NA’s X data. Delete NA’s finding closest model. fixed bug ‘JZS’ prior - merged pull request #12 vandenman/master fixed bug bas.glm default betaprior (CCH) used inputs INTEGER instead REAL removed warning use ‘ZS-null’ backwards compatibility","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"features-added-1-4-8","dir":"Changelog","previous_headings":"","what":"Features added","title":"BAS 1.4.8 March 10, 2018","text":"updated print.bas reflect changes print.lm Added Bayes.outlier function calculate posterior probabilities outliers using method Chaloner & Brant linear models.","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-147-october-22-2017","dir":"Changelog","previous_headings":"","what":"BAS 1.4.7 October 22, 2017","title":"BAS 1.4.7 October 22, 2017","text":"CRAN release: 2017-10-22","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"updates-1-4-7","dir":"Changelog","previous_headings":"","what":"Updates","title":"BAS 1.4.7 October 22, 2017","text":"Added new method bas.lm obtain marginal likelihoods Zellner-Siow Priors “prior= ‘JZS’ using QUADPATH routines numerical integration. optional hyper parameter alpha may now used adjust scaling ZS prior g ~ G(1/2, alpha*n/2) BayesFactor package Morey, default alpha=1 corresponding ZS prior used Liang et al (2008). also uses stable evaluations log(1 + x) prevent underflow/overflow. Priors ZS-full bas.lm planned deprecated. replaced math functions use portable C code Rmath consolidated header files","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-146-may-24-2017","dir":"Changelog","previous_headings":"","what":"BAS 1.4.6 May 24, 2017","title":"BAS 1.4.6 May 24, 2017","text":"CRAN release: 2017-05-26","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"updates-1-4-6","dir":"Changelog","previous_headings":"","what":"Updates","title":"BAS 1.4.6 May 24, 2017","text":"Added force.heredity.interaction function allow higher order interactions included “parents” lower order interactions main effects included. Currently tested two way interactions. implemented post-sampling; future updates add sampling stage reduce memory usage sampling times reducing number models consideration.","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bugs-1-4-6","dir":"Changelog","previous_headings":"","what":"Bugs","title":"BAS 1.4.6 May 24, 2017","text":"Fixed unprotected ANS C code glm_sampleworep.c sampleworep.c call PutRNGstate possible stack imbalance glm_mcmc. Fixed problem predict estimator=BPM newdata one row","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-145-march-28-2017","dir":"Changelog","previous_headings":"","what":"BAS 1.4.5 March 28, 2017","title":"BAS 1.4.5 March 28, 2017","text":"CRAN release: 2017-03-31","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bugs-1-4-5","dir":"Changelog","previous_headings":"","what":"Bugs","title":"BAS 1.4.5 March 28, 2017","text":"Fixed non-conformable error predict new data dataframe one row. Fixed problem missing weights prediction using median probability model new data.","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-144-march-14-2017","dir":"Changelog","previous_headings":"","what":"BAS 1.4.4 March 14, 2017","title":"BAS 1.4.4 March 14, 2017","text":"CRAN release: 2017-03-14","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"updates-1-4-4","dir":"Changelog","previous_headings":"","what":"Updates","title":"BAS 1.4.4 March 14, 2017","text":"Extract coefficient summaries, credible intervals plots HPM MPM addition default BMA adding new estimator argument coef function. new n.models argument coef provides summaries based top n.models highest probability models reduce computation time. ‘n.models = 1’ equivalent highest probability model. use newdata vector now deprecated predict.bas; newdata must dataframe missing, case fitted values based dataframe used fitting used factor levels handled lm glm prediction may level factor newdata","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bugs-1-4-4","dir":"Changelog","previous_headings":"","what":"Bugs","title":"BAS 1.4.4 March 14, 2017","text":"fixed issue prediction newdata just one row fixed missing id plot.bas =3","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-143-february-18-2017","dir":"Changelog","previous_headings":"","what":"BAS 1.4.3 February 18, 2017","title":"BAS 1.4.3 February 18, 2017","text":"CRAN release: 2017-02-21","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"updates-1-4-3","dir":"Changelog","previous_headings":"","what":"Updates","title":"BAS 1.4.3 February 18, 2017","text":"Register symbols foreign function calls bin2int now deprecated fixed default MCMC.iteration bas.lm agree documentation updated vignette include examples, outlier detection, finding best predictive probability model set flag MCMC sampling renormalize selects whether Monte Carlo frequencies used estimate posterior model marginal inclusion probabilities (default renormalize = FALSE) marginal likelihoods time prior probabilities renormalized sum 1 used. (latter option methods); new slots probne0.MCMC, probne0.RN, postprobs.RN postprobs.MCMC.","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bug-fixes-1-4-3","dir":"Changelog","previous_headings":"","what":"Bug fixes","title":"BAS 1.4.3 February 18, 2017","text":"fixed problem prior.bic, robust, hyper.g.n default missing n set hyperparameters fixed error predict plot GLMs family provided function","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-142-october-12-2016","dir":"Changelog","previous_headings":"","what":"BAS 1.4.2 October 12, 2016","title":"BAS 1.4.2 October 12, 2016","text":"CRAN release: 2016-10-13","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"updates-1-4-2","dir":"Changelog","previous_headings":"","what":"Updates","title":"BAS 1.4.2 October 12, 2016","text":"added df object returned bas.glm simplify coefficients function.","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bug-fixes-1-4-2","dir":"Changelog","previous_headings":"","what":"Bug Fixes","title":"BAS 1.4.2 October 12, 2016","text":"corrected expected value shrinkage intrinsic, hyper-g/n TCCH priors glms","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-141-september-17-2016","dir":"Changelog","previous_headings":"","what":"BAS 1.4.1 September 17, 2016","title":"BAS 1.4.1 September 17, 2016","text":"CRAN release: 2016-09-20","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bug-fixes-1-4-1","dir":"Changelog","previous_headings":"","what":"Bug Fixes","title":"BAS 1.4.1 September 17, 2016","text":"modification 1.4.0 automatically handle NA’s led errors response transformed part formula; fixed","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"features-1-4-1","dir":"Changelog","previous_headings":"","what":"Features","title":"BAS 1.4.1 September 17, 2016","text":"added subset argument bas.lm bas.glm","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-140-august-25-2016","dir":"Changelog","previous_headings":"","what":"BAS 1.4.0 August 25, 2016","title":"BAS 1.4.0 August 25, 2016","text":"CRAN release: 2016-08-27","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"new-features-1-4-0","dir":"Changelog","previous_headings":"","what":"New features","title":"BAS 1.4.0 August 25, 2016","text":"added na.action bas.lm bas.glm omit missing data. new function plot credible intervals created confint.pred.bas confint.coef.bas. See help files example vignette. added se.fit option predict.basglm. Added testBF betaprior option bas.glm implement Bayes Factors based likelihood ratio statistic’s distribution GLMs. DOI version http://dx.doi.org/10.5281/zenodo.60948","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-130-july-15-2016","dir":"Changelog","previous_headings":"","what":"BAS 1.3.0 July 15, 2016","title":"BAS 1.3.0 July 15, 2016","text":"CRAN release: 2016-07-16","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"new-features-1-3-0","dir":"Changelog","previous_headings":"","what":"New Features","title":"BAS 1.3.0 July 15, 2016","text":"vignette added long last! illustrates several new features BAS new functions computing credible intervals fitted predicted values confint.pred.bas() new function adding credible intervals coefficients confint.coef.bas() added posterior standard deviations fitted values predicted values predict.bas()","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"deprecation-1-3-0","dir":"Changelog","previous_headings":"","what":"Deprecation","title":"BAS 1.3.0 July 15, 2016","text":"deprecated use type specify estimator fitted.bas replaced estimator predict() fitted() compatible S3 methods. updated functions class bas avoid NAMESPACE conflicts libraries","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-122-june-29-2016","dir":"Changelog","previous_headings":"","what":"BAS 1.2.2 June 29, 2016","title":"BAS 1.2.2 June 29, 2016","text":"CRAN release: 2016-07-01","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"new-features-1-2-2","dir":"Changelog","previous_headings":"","what":"New Features","title":"BAS 1.2.2 June 29, 2016","text":"added option find “Best Predictive Model” “BPM” fitted.bas predict.bas added local Empirical Bayes prior fixed g-prior bas.glm added diagnostic() function checking convergence bas objects created method = \"MCMC\"” added truncated power prior Yang, Wainwright & Jordan (2016)","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"minor-changes-1-2-2","dir":"Changelog","previous_headings":"","what":"Minor Changes","title":"BAS 1.2.2 June 29, 2016","text":"bug fix plot.bas appears Sweave bug fix coef.bma just one predictor","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-121-april-16-2016","dir":"Changelog","previous_headings":"","what":"BAS 1.2.1 April 16, 2016","title":"BAS 1.2.1 April 16, 2016","text":"CRAN release: 2016-04-16 bug fix method=“MCMC” truncated prior distributions MH ratio incorrect allowing models 0 probability sampled. fixed error Zellner-Siow prior (ZS-null) n=p+1 saturated model log marginal likelihood 0","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-120-april-11-2016","dir":"Changelog","previous_headings":"","what":"BAS 1.2.0 April 11, 2016","title":"BAS 1.2.0 April 11, 2016","text":"CRAN release: 2016-04-12 removed unsafe code Rbestmarg (input) overwritten .Call end corruption constant pool byte-code (Thanks Tomas Kalibera catching !) fixed issue dimensions use Simple Linear Regression","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-110-march-31-2016","dir":"Changelog","previous_headings":"","what":"BAS 1.1.0 March 31, 2016","title":"BAS 1.1.0 March 31, 2016","text":"CRAN release: 2016-03-31","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"new-features-1-1-0","dir":"Changelog","previous_headings":"","what":"New Features","title":"BAS 1.1.0 March 31, 2016","text":"added truncated Beta-Binomial prior truncated Poisson (works MCMC currently) improved code finding fitted values Median deprecated method = “AMCMC” issue warning message","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"minor-changes-1-1-0","dir":"Changelog","previous_headings":"","what":"Minor Changes","title":"BAS 1.1.0 March 31, 2016","text":"Changed S3 method plot image use class bas rather bma avoid name conflicts packages","code":""},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-109","dir":"Changelog","previous_headings":"","what":"BAS 1.09","title":"BAS 1.09","text":"","code":"- added weights for linear models - switched LINPACK calls in bayesreg to LAPACK finally should be faster - fixed bug in intercept calculation for glms - fixed inclusion probabilities to be a vector in the global EB methods for linear models"},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-108","dir":"Changelog","previous_headings":"","what":"BAS 1.08","title":"BAS 1.08","text":"","code":"- added intrinsic prior for GLMs - fixed problems for linear models for p > n and R2 not correct"},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-107","dir":"Changelog","previous_headings":"","what":"BAS 1.07","title":"BAS 1.07","text":"","code":"- added phi1 function from Gordy (1998) confluent hypergeometric function of two variables also known as one of the Horn hypergeometric functions or Humbert's phi1 - added Jeffrey's prior on g - added the general tCCH prior and special cases of the hyper-g/n. - TODO check shrinkage functions for all"},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-106","dir":"Changelog","previous_headings":"","what":"BAS 1.06","title":"BAS 1.06","text":"","code":"- new improved Laplace approximation for hypergeometric1F1 - added class basglm for predict - predict function now handles glm output - added dataframe option for newdata in predict.bas and predict.basglm - renamed coefficients in output to be 'mle' in bas.lm to be consistent across lm and glm versions so that predict methods can handle both cases. (This may lead to errors in other external code that expects object$ols or object$coefficients) - fixed bug with initprobs that did not include an intercept for bas.lm"},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-105","dir":"Changelog","previous_headings":"","what":"BAS 1.05","title":"BAS 1.05","text":"","code":"- added thinning option for MCMC method for bas.lm - returned posterior expected shrinkage for bas.glm - added option for initprobs = \"marg-eplogp\" for using marginal SLR models to create starting probabilities or order variables especially for p > n case - added standalone function for hypergeometric1F1 using Cephes library and a Laplace approximation -Added class \"BAS\" so that predict and fitted functions (S3 methods) are not masked by functions in the BVS package: to do modify the rest of the S3 methods."},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-104","dir":"Changelog","previous_headings":"","what":"BAS 1.04","title":"BAS 1.04","text":"","code":"- added bas.glm for model averaging/section using mixture of g-priors for GLMs. Currently limited to Logistic Regression - added Poisson family for glm.fit"},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-10","dir":"Changelog","previous_headings":"","what":"BAS 1.0","title":"BAS 1.0","text":"CRAN release: 2012-06-01","code":"- cleaned up MCMC method code"},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-093","dir":"Changelog","previous_headings":"","what":"BAS 0.93","title":"BAS 0.93","text":"","code":"- removed internal print statements in bayesglm.c - Bug fixes in AMCMC algorithm"},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-092","dir":"Changelog","previous_headings":"","what":"BAS 0.92","title":"BAS 0.92","text":"CRAN release: 2010-10-01","code":"- fixed glm-fit.R so that hyper parameter for BIC is numeric"},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-091","dir":"Changelog","previous_headings":"","what":"BAS 0.91","title":"BAS 0.91","text":"CRAN release: 2010-09-09","code":"- added new AMCMC algorithm"},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-091-1","dir":"Changelog","previous_headings":"","what":"BAS 0.91","title":"BAS 0.91","text":"CRAN release: 2010-09-09","code":"- bug fix in bayes.glm"},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-090","dir":"Changelog","previous_headings":"","what":"BAS 0.90","title":"BAS 0.90","text":"CRAN release: 2010-07-24","code":"- added C routines for fitting glms"},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-085","dir":"Changelog","previous_headings":"","what":"BAS 0.85","title":"BAS 0.85","text":"CRAN release: 2010-04-29 restricting n.models correct fitted values (broken version 0.80)","code":"- fixed problem with duplicate models if n.models was > 2^(p-1) by - save original X as part of object so that fitted.bma gives the"},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-080","dir":"Changelog","previous_headings":"","what":"BAS 0.80","title":"BAS 0.80","text":"CRAN release: 2010-04-06 shrinkage - changed predict.bma center newdata using mean(X) - Added new Adaptive MCMC option (method = “AMCMC”) (stable point)","code":"- Added `hypergeometric2F1` function that is callable by R - centered X's in bas.lm so that the intercept has the correct"},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-07","dir":"Changelog","previous_headings":"","what":"BAS 0.7","title":"BAS 0.7","text":"","code":"-Allowed pruning of model tree to eliminate rejected models"},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-06","dir":"Changelog","previous_headings":"","what":"BAS 0.6","title":"BAS 0.6","text":"","code":"- Added MCMC option to create starting values for BAS (`method = \"MCMC+BAS\"`)"},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-05","dir":"Changelog","previous_headings":"","what":"BAS 0.5","title":"BAS 0.5","text":"allocated within code","code":"-Cleaned up all .Call routines so that all objects are duplicated or"},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-045","dir":"Changelog","previous_headings":"","what":"BAS 0.45","title":"BAS 0.45","text":"CRAN release: 2009-12-30","code":"- fixed ch2inv that prevented building on Windows in bayes glm_fit"},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-04","dir":"Changelog","previous_headings":"","what":"BAS 0.4","title":"BAS 0.4","text":"CRAN release: 2009-12-28","code":"- fixed FORTRAN calls to use F77_NAME macro - changed allocation of objects for .Call to prevent some objects from being overwritten."},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-03","dir":"Changelog","previous_headings":"","what":"BAS 0.3","title":"BAS 0.3","text":"CRAN release: 2009-05-29","code":"- fixed EB.global function to include prior probabilities on models - fixed update function"},{"path":"http://merliseclyde.github.io/BAS/news/index.html","id":"bas-02","dir":"Changelog","previous_headings":"","what":"BAS 0.2","title":"BAS 0.2","text":"column ones intercept optionally included. - fixed help file predict - added modelprior argument bas.lm users may now use beta-binomial prior distribution model size addition default uniform distribution - added functions uniform(), beta-binomial() Bernoulli() create model prior objects - added vector user specified initial probabilities option argument initprobs bas.lm removed separate argument user.prob","code":"- fixed predict.bma to allow newdata to be a matrix or vector with the"}]