Chapter 13 Test for a proportion (using simulation)

  • Suppose we have a sample of size \(n\) from a population with proportion \(p\) of a certain trait.

  • We want to test a null hypothesis for the value of \(p\), by modelling \(H_{0}\) by a box model (with “1” representing the trait) with \(n\) draws.

  • We simulate samples from the box model, and then compare our actual sample to these results - ie how common is our sample?


13.1 Simple balanced box

  • We want to test \(H_{0}\): \(p = 0.5\).

  • We can produce a picture of the box model modelling \(H_{0}\) (Ext).

library("DiagrammeR")
  
DiagrammeR::grViz(" 
digraph rmarkdown {
  
graph [fontsize = 16, fontname = Arial, nodesep = .1, ranksep = .8]
node [fontsize = 16, fontname = Arial, fontcolor = White]
edge [fontsize = 12, fontname = Arial, width = 2]

Box [shape=oval,style=filled, color=SteelBlue3,width=5, label='1    0']

Sample [shape=oval, style=filled, color=SteelBlue2, label='']

Box -> Sample [label='   n draws']

}
")
detach(package:DiagrammeR)
  • Now simulate draws from the box, and compare to your sample. Here, suppose that \(n=20\), and choose a simulation size of 100.
set.seed(1)

# Define box (modelling Ho)
box=c(0,1)

# # Simulate 100 samples of size 20 from the box
totals = replicate(100, sum(sample(box, 20, rep = T)))
table(totals)
hist(totals)


13.2 Unbalanced box

  • We want to test \(H_{0}\): \(p = 0.2\).

  • We can produce a picture of the box model modelling \(H_{0}\) (Ext).

library("DiagrammeR")
  
DiagrammeR::grViz(" 
digraph rmarkdown {
  
graph [fontsize = 16, fontname = Arial, nodesep = .1, ranksep = .8]
node [fontsize = 16, fontname = Arial, fontcolor = White]
edge [fontsize = 12, fontname = Arial, width = 2]

Box [shape=oval,style=filled, color=SteelBlue3,width=5, label='100p x 1    100(1-p) x 0']

Sample [shape=oval, style=filled, color=SteelBlue2, label='']

Box -> Sample [label='   n draws']

}
")
detach(package:DiagrammeR)
  • Now simulate draws from the box, and compare to your sample. Here, suppose that \(n=30\), and choose a simulation size of 1000
set.seed(1)

# Define box (modelling Ho)
box=c(0,1)

# Simulate 1000 samples of size 30 from the box
totals = replicate(1000, sum(sample(box, 30, prob=c(0.8,0.2), rep = T)))
table(totals)
hist(totals)