\documentclass{article} \topmargin -0.7in \textheight 9.0in %\textwidth 6in \textwidth 6.5in %\oddsidemargin 0.25in %\oddsidemargin -.25in \oddsidemargin 0.0in % \VignetteIndexEntry{exact2x2: Validation of Unconditional Exact Tests} % \VignetteKeyword{Confidence Interval} % \VignetteKeyword{Exact Test} \newcommand{\code}[1]{{\sf #1}} \begin{document} \SweaveOpts{concordance=TRUE} \begin{center} {\Large Validation of Some Functions in the exact2x2 R package} \\ Michael P. Fay, Sally Hunsberger \\ \today \end{center} \section*{Summary} This document details some of the checks that were done to ensure that the \code{uncondExact2x2}, \code{boschloo} and \code{binomMeld.test} functions were giving correct and reasonable results. \section{Introduction} Because some of the options in the functions \code{uncondExact2x2} and \code{boschloo} produce tests and confidence intervals that are not available elsewhere, there is not necessarily an existing gold standard to check each option. Nevertheless, we do check some options for which there are functions available in other R packages (most notably, the \code{Exact} package) or other software (SAS and StatXact). For the \code{binomMeld.test} function we create two different methods to calculate the p-values and confidence intervals and compare them. See Section~\ref{sec-binomMeldtest} for those tests. \section{The Fast Algorithm} For some options, specifically, in the case when: \begin{quote} (parmtype=="difference") \& (tsmethod == "central") \& \\ (gamma == 0) \& \\ (method == "simple" | method=="user-fixed" | method=="FisherAdj") \end{quote} Then the confidence intervals can be calculated using a faster algorithm, since we have monotonicity in the one-sided p-values. We test this by checking that the confidence intervals and p-values have unified inferences. Specifically, we calculate the 95\% confidence interval, then check the p-value for the test with \code{nullparm} equal to one limit of the interval and see if the p-value is equal to $0.05$. The check for \code{method=="FisherAdj"} is in \verb@\tests\testthat\test_FisherAdj.R@. \section{FisherAdj: The Slow Algorithm} For \code{parmtype="ratio"} or \code{parmtype="oddsratio"} with \code{method=="FisherAdj"} we must use the slower algorithm. We checked \code{method=="FisherAdj"} for whether the confidence intervals and p-values have unified inferences in \verb@\tests\testthat\test_FisherAdj.R@. \section{Boschloo Test} \label{sec-boschloo} The Boschloo test is run with the \code{boschloo} function. There is a separate function because unlike most unconditional exact tests, the traditional way of calculating the \code{alternative="less"} option uses a different ordering function than calculating the \code{alternative="greater"} option. The \code{boschloo} uses the appropriate one-sided p-value from the Fisher's exact test for ordering. We validate the p-values by testing them against the \code{Exact} R package and StatXact Version 11. They match for the data that we tested. The tests on the p-values are in \verb@\tests\testthat\test_Exact.R@ and \verb@\inst\slowTests\test_StatXact.R@. Note that the default for \code{alternative="two.sided"} in our \code{boschloo} function is \code{tsmethod="central"}, but the traditional two-sided p-value for Boschloo's test uses \code{tsmethod="minlike"}. Thus, we only tested the latter. There is no software of which we are aware that calculates the confidence intervals that match Boschloo's test. \section{Confidence Intervals on Odds Ratios with method="score" } Agresti and Min (2002) discussed two ways of calculating the exact unconditional confidence intervals for the odds ratio using the score statistic for ordering. The two ways correspond to the two options in tsmethod. But the function \code{uncondExact2x2} with \code{parmtype="oddsratio"} and \code{method="score"} does not match the results in the paper for either tsmethod, even though we used a more precise grid than the default (\verb@control$nPgrid=1000@). This could be due to using different algorithms for the calculation. Although Agresti and Min (2002) state that "There is no assurance that an algorithm such as just described produces the correct interval", the same can be said of the algorithms for \code{uncondExact2x2}. So it is not clear which software is closer to the true values. The tests are in \verb@\inst\slowTests\test_OddsRatioScore.R@. \section{The E+M Method} We check the E+M method of Lloyd (2008) by reproducing the some results on the example in Table~1 of that paper. We reproduce the p-values using the Wald-pooled difference example (T rows: top is one-sided, bottom is two-sided) and the E+M column (results are p=0.02518 [one-sided] and p=0.03681 [two-sided]). This test is in \verb@\inst\slowTests\test_EplusM.R@. \section{Berger and Boos Adjustment} Berger and Boos (1994) developed a method to adjust for nuisance parameters that tends to have better power when applied to the 2x2 unconditional exact tests. We calculated their adjustment for the data example in that paper, and the results agree between our \code{uncondExact2x2} and the \code{exact.test} from the \code{Exact} R package. Both these functions differ by a small amount from the value given in the paper (in the paper, p=0.037, while the functions give p=0.03781). The test is in \verb@\tests\testthat\test_Exact.R@. The \code{uncondExact2x2} results were fairly close for the examples we checked in StatXact 11 (difference in log values within 0.02). See \verb@\inst\slowTests\test_StatXact.R@. \section{Comparison with StatXact} We ran a comparison with StatXact version 11. The tests are in \verb@\inst\slowTests\test_StatXact.R@. We tested the \code{parmtype="difference"} and \code{parmtype="ratio"} with both tsmethod options with the \code{method="score"}. This is associated with either "invert two one-sided tests" (for \code{tsmethod="central"}) or "invert a two-sided test" (for \code{tsmethod="square"}). We found that in most cases with \code{tsmethod="central"} the agreement with "invert two one-sided tests" was close. But we found some big differences when \code{tsmethod="square"} and "invert a two-sided test". We mention one case where we can show clearly that the StatXact 11 is wrong (in the other cases, it is not as clear which software is more accurate). The case is $x_1/n_1 = 0/7$ and $x_2/n_2 = 13/13$. StatXact 11 using "invert a two-sided test" and Gamma=0 gives a 95\% confidence interval on that difference as $(0.6088,0.6101)$. This is wrong, because when $\theta_1 = 0$ and $\theta_2 = 1$ then the true differences is $1$, and the probability of observing $x_1/n_1 = 0/7$ and $x_2/n_2 = 13/13$ is also $1$. So the actual coverage under that assumption is $0$, and the confidence interval is clearly not exact. For $\theta_1 = \epsilon$ and $\theta_2 = 1-\epsilon$ with $\epsilon$ a very small positive value, we would similarly get coverage close to $0$. In contrast, the \code{uncondExact2x2} function with \code{parmtype="difference"}, \code{tsmethod="square"}, and \code{gamma=0} has the 95\% confidence interval as $(0.6088,1)$. In this case the coverage is 100\% (assuming the CI includes 1) when $\theta_1 = 0$ and $\theta_2 = 1$. Comparison of Boschloo values has previously been mentioned in Section~\ref{sec-boschloo}. \section{Comparison with SAS} We check some results and compared them with SAS version 9.4. Proc Freq has the Exact option, that gives p-values for the Barnard test (uncondExact2x2 test of $\theta_1=\theta_2$ with \code{method="wald-pooled"} and \code{parmtype="difference"}). The Exact option also gives confidence intervals for the ratio and difference (uncondExact2x2 with \code{method="score"}). The methods agree, and the tests are in \verb@\inst\slowTests\test_SAS.R@. The default control value for \verb@control$nPgrid@ option of the algorithm in \code{uncondExact2x2} must be increased for a few of the values to match. This suggests that the default for SAS is more accurate than the default of \verb@control$nPgrid=100@. \section{The binomMeld.test function} \label{sec-binomMeldtest} The option \code{nmc} in the \code{binomMeld.test} fucntion allows calculation by Monte Carlo simulation. That provides a separate check for the numeric integration calculations. We compare the two calculation methods in \\ \verb@\inst\slowTests\test_binomMeldtest.R@. \section*{References} \begin{description} \item Agresti, A., and Min, Y. (2002). Unconditional small-sample confidence intervals for the odds ratio. Biostatistics, 3(3), 379-386. \item Berger, R. L., and Boos, D. D. (1994). P values maximized over a confidence set for the nuisance parameter. Journal of the American Statistical Association, 89(427), 1012-1016. \item Lloyd, C (2008). Exact p-values for discrete models obtained by estimation and maximization. Australian \& New Zealand Journal of Statistics, 50(4): 329-345. \end{description} \end{document}