Confidence Interval

Psychological Science is a prestigious journal for psychological research. Its submission guidelines consist of specific guideline on the use of NHST:

Effective January 2014, Psychological Science recommends the use of the "new statistics" - effect sizes, confidence intervals, and meta-analysis - to avoid problems associated with null-hypothesis significance testing (NHST).

Confidence interval provides an alternative method to NHST, which some have argued provides more information on the NHST. A confidence interval (CI) is a type of interval estimate, instead of a point estimate, of a population parameter.

Formal definition

Let $\theta$ denote a population parameter (unknowns) and $X$ denote a random variable (e.g., GPA) from which the data can be observed. Assume the observed outcome for $X$ is $x$. We can calculate an interval $[l(x),u(x)]$ based on the observed data. More generally, we can define

\[\Pr(l(X) \leq \theta \leq u(X))=1-\alpha=C\].

Then $[l(X),u(X)]$ is a confidence interval with confidence level $1-\alpha=C$, or $100(1-\alpha)\%$. $l(X)$ and $u(X)$ are called confidence limits (bounds), lower limit and upper limit, respectively.

Remarks

  • A CI is an observed interval calculated based on a set of observed data. In general, it is different from sample to sample. Therefore, for two studies on the same topic, the CIs can be very different even following exactly the same study design.
  • Different from the point estimate, a CI consists of a range of potential values as good estimates of the unknown population parameter.
  • For a given CI, it either includes or does not include the population parameter value. Therefore, a CI does not necessarily cover the true parameter values at all.
  • If we conduct many separate data analyses of repeated experiment and each time we calculate a CI, the proportion of such intervals that contain the true value of the parameter matches the confidence level C ($1-\alpha$), This is called confidence level.
  • When we say, "we are 99% confident that the true value of the parameter is in our confidence interval", we express that 99% of the observed confidence intervals will contain the true value of the parameter.
  • The desired level of confidence is set by the researchers, not determined by data. If a corresponding hypothesis test is performed, the confidence level is the complement of respective level of significance, i.e. a 95% confidence interval reflects a significance level of 0.05.

How to obtain a confidence interval

The basic idea to get a CI is straightforward in theory but can be very difficult in practice. It involves three steps:

  1. Obtain a point estimate $\hat{\theta}$ for $\theta$. Note that $\hat{\theta}$ is a function of $x$ or your data.
  2. Find out the sampling distribution of $\hat{\theta}$.
  3. An equal-tail confidence interval with 95% confidence level can be constructed using the 2.5th and 97.5th percentiles of the sampling distribution.

An example

Suppose we want to estimate and obtain the confidence interval estimate of the average GPA ($\mu$) of all undergraduate students at University of Notre Dame. GPA typically follows a normal distribution \(X\sim N(\mu,\sigma)\). Instead of going out to collect data from students, we will simulate (generate) some data for our example. To simulate data, we need to know the population mean and standard deviation of GPA. Here we assume the mean is $\mu=3.5$ and the standard deviation $\sigma=.2$. Furthermore, we would like to generate a sample of data with the sample size 100.

In python, to generate random number from a normal distribution, the function numpy.random.normal(loc=0.0, scale=1.0, size=None) can be used. Specifically for this example, the code numpy.random.normal(loc=3.5, scale=0.2, size=100) generates 100 values from a normal distribution with mean 3.5 and standard deviation 0.2. Therefore, in the function, the first number is the number of the values to generate, the second is the mean and the third is the standard deviation. The code below generates the values, prints them in the output, and displays the histogram of the generated data. Note that the histogram shows a bell shape.


>>> import numpy as np >>> x = np.random.normal(3.5, 0.2, 100) >>> x array([3.30961096, 3.88621435, 3.43505387, 3.49904584, 3.26811514, 3.47317747, 3.50877987, 3.6799214 , 3.42220393, 3.41570962, 3.48750185, 3.42311069, 3.530337 , 3.83058861, 3.44719642, 3.48268287, 3.22625468, 3.40586892, 3.3036879 , 3.52873103, 3.44418364, 3.48677855, 3.32139049, 3.45456966, 3.39429753, 3.46509054, 3.51024033, 3.36258838, 3.53646295, 3.52188506, 3.37364676, 3.29766346, 3.47012037, 3.49302403, 3.62958945, 3.29032065, 3.41928737, 3.489416 , 3.48143222, 3.35678675, 3.65830239, 3.52627246, 3.76218119, 3.04731892, 3.22988685, 3.61551893, 3.41687378, 3.33199261, 3.24449944, 3.62486986, 3.40261059, 3.63538732, 3.09727252, 3.6383883 , 3.71274082, 3.06001471, 3.46404994, 3.43017074, 3.95067586, 3.63182096, 3.28586533, 3.49631723, 4.03283782, 3.00176406, 3.60466511, 3.51973291, 3.3615205 , 3.3287204 , 3.58694967, 3.71299154, 3.47639426, 3.61113161, 3.5318697 , 3.15036174, 3.59735245, 3.74597373, 3.44100258, 3.57232591, 3.11563701, 3.30917366, 3.33408031, 3.13811093, 3.48450674, 3.65874548, 3.29683862, 3.79257362, 3.44393652, 4.02971579, 3.81504204, 3.80754949, 3.72673935, 3.69432165, 3.182516 , 3.21247769, 3.53504549, 3.47730558, 3.98595787, 3.45669507, 3.57142525, 3.43027314]) >>> >>> ## histogram of the data >>> import matplotlib.pyplot as plt >>> import seaborn as sns >>> sns.histplot(x) >>> plt.savefig('hist.svg', format='svg') >>> plt.show()

With the simulated data for 100 students, an estimate of the average GPA ($\theta$) is \[\bar{x}=\frac{1}{100}\sum_{i=1}^{100}x_{i}.\] Based on the central limit theorem, if the population variance $\sigma$ is known, regardless of the shape of the population distribution, $\bar{x}$ is at least approximately normally distributed with mean ($\mu$) and standard deviation (standard error of the mean) \[s.e.(\bar{x})=\sqrt{\frac{1}{n}\sigma^{2}}=.1\sigma.\] Now we the point estimate is $\hat{\theta}=\bar{x}$ and its sampling distribution is a normal distribution. Then a 95% equal-tail confidence interval can be constructed using the 2.5% and 97.5% percentile of the normal distribution as $[\Phi^{-1}(0.025), \Phi^{-1}(0.975)]$ where $\Phi$ is the normal distribution function. The whole procedure to calculate a CI for a set of simulated data is shown below.
>>> import numpy as np >>> import scipy.stats as stats >>> >>> x = np.random.normal(3.5, 0.2, 100) >>> xbar = np.mean(x) >>> se = .2/np.sqrt(100) >>> L = xbar + stats.norm.ppf(.025)*se >>> U = xbar + stats.norm.ppf(.975)*se >>> >>> print(f'The 95% confidence interval is [{L:.3f}, {U:.3f}]') The 95% confidence interval is [3.507, 3.585] >>> >>> ## Another way to do it >>> stats.norm.ppf([0.025, 0.975], xbar, se) array([3.50666744, 3.585066 ])

Now, try run the code above one more time. Do you get the same confidence interval?

An experiment for CI interpretation

A CI changes each time with a study. If we repeat the same study again and again, $100(1-\alpha)\%$ of the time the obtained confidence intervals would cover the true population parameter value. This can be shown through a simulation study or experiment. Using the GPA example, we can conduct an experiment using the following steps:

  1. Generate a set of GPA data with 100 students from the population
  2. Calculate the observed sample mean of GPA and the standard error of x bar
  3. Calculate the confidence interval
  4. Check whether the confidence interval covers the population parameter value
  5. Repeat (1)-(4) 1000 times and count the total number of times that the confidence intervals cover the population value.
  6. For a 95% CI, one would expect about 950 times the CIs cover the population value.

The R code below carries out the experiment. The output shows that the among the 1000 sets of CIs calculated based on the 1000 sets of simulated data, 949 of them cover the population value 3.5.


>>> import numpy as np >>> import scipy.stats as stats >>> >>> ## create a matrix to save the data >>> R = 1000 >>> all_ci = np.zeros((R, 3)) >>> #all_ci >>> >>> for i in range(R): ... x = np.random.normal(3.5, 0.2, 100) ... xbar = np.mean(x) ... se = .2/np.sqrt(100) ... L = xbar + stats.norm.ppf(.025)*se ... U = xbar + stats.norm.ppf(.975)*se ... all_ci[i, 0] = L ... all_ci[i, 1] = U ... if (L <= 3.5) and (U >= 3.5): ... all_ci[i, 2] = 1.0 ... >>> >>> all_ci array([[3.43759554, 3.5159941 , 1. ], [3.47266448, 3.55106304, 1. ], [3.46610815, 3.54450671, 1. ], ..., [3.46547055, 3.54386911, 1. ], [3.41801182, 3.49641038, 0. ], [3.4860146 , 3.56441316, 1. ]]) >>> >>> np.mean(all_ci[0:R, 2]) np.float64(0.956)

For a given CI, it either covers the population value or not. This can be best demonstrated by plotting the CIs. The R code and output are given below. In the code, we generate 100 CIs, among which 97 cover the population value and 3 do not.


>>> import numpy as np >>> import scipy.stats as stats >>> import matplotlib.pyplot as plt >>> >>> ## create a matrix to save the data >>> R = 100 >>> all_ci = np.zeros((R, 2)) >>> #all_ci >>> >>> for i in range(R): ... x = np.random.normal(3.5, 0.2, 100) ... xbar = np.mean(x) ... se = .2/np.sqrt(100) ... L = xbar + stats.norm.ppf(.025)*se ... U = xbar + stats.norm.ppf(.975)*se ... all_ci[i, 0] = L ... all_ci[i, 1] = U ... >>> >>> # Create a figure and axis for plotting >>> fig, ax = plt.subplots() >>> >>> # Loop through each row and plot vertical lines >>> for i, row in enumerate(all_ci): ... _ = ax.plot([i, i], row, marker='o'); ... >>> ax.hlines(y=3.5, xmin=0, xmax=100, colors='r', linestyles='--') >>> >>> plt.savefig('test.svg', format='svg') >>> # Display the plot >>> plt.show()

Confidence interval and hypothesis testing

Confidence intervals do not require a-priori hypotheses, nor do they test trivial hypotheses. A confidence interval provides information on both the effect and its precision. A smaller interval usually suggests the estimate is more precise. For example, [3.3, 3.7] is more precise than [3,4].

A confidence interval can be used for hypothesis testing. For example, suppose the null hypothesis \[\theta=\theta_{0}\] for any value of $\theta_{0}$. If a confidence interval with confidence level $C=1-\alpha$ contains $\theta_{0}$, we fail to reject the corresponding null hypothesis at the significance level $\alpha$. Otherwise, we reject the null hypothesis at the significance level $\alpha$.

For example, suppose we are interested in testing whether a training intervention method is effective or not. Based on a pre- and post-test design, we find the confidence interval for the change after training is [0.7, 1.5] with the confidence level 0.95. Since this CI does not include 0, we would reject the null hypothesis that the change is 0 at the alpha level 0.05.

Using CI for hypothesis testing does not provide the exact p-value. However, a CI can be used to test multiple hypotheses. For example, for any null hypothesis that the change score is less than 0.7, one would reject it.

CI kinds of focuses on the alternative hypothesis, the effect of interest. It provides a range of plausible values to estimate the effect of interest.

Reichardt and Gollob (1997) discussed conditions that NHST and CI can be useful. NHST is shown generally to be more informative than confidence intervals when assessing (1) the probability that a parameter equals a pre-specified value; (2) the direction of a parameter relative to a pre-specified value (e.g., 0); and (3) the probability that a parameter lies within a pre-specified range.

On the other hand, confidence intervals are shown generally to be more informative than NHST when assessing the size of a parameter (1) without reference to a pre-specified value or range of values, and (2) with reference to many pre-specified values or ranges of values. Hagen (1997) pointed out: "We cannot escape the logic of NHST [null hypothesis statistical testing] by turning to point estimates and confidence intervals" (p. 22). In addition, Schmidt and Hunter (1997) suggested: "The assumption underlying this objection is that because confidence intervals can be interpreted as significance tests, they must be so interpreted. But this is a false assumption" (p. 50).

To cite the book, use: Zhang, Z. & Wang, L. (2017-2022). Advanced statistics using R. Granger, IN: ISDSA Press. https://doi.org/10.35566/advstats. ISBN: 978-1-946728-01-2.
To take the full advantage of the book such as running analysis within your web browser, please subscribe.