New Upstream Snapshot - r-cran-pwr

Ready changes

Summary

Merged new upstream version: 1.3-0+git20200520.2.2f64c78+dfsg (was: 1.3-0+git20200520.1.2f64c78+dfsg).

Resulting package

Built on 2023-01-19T12:27 (took 9m12s)

The resulting binary packages can be installed (if you have the apt repository enabled) by running one of:

apt install -t fresh-snapshots r-cran-pwr

Diff

diff --git a/DESCRIPTION b/DESCRIPTION
index e04d87f..c19a032 100644
--- a/DESCRIPTION
+++ b/DESCRIPTION
@@ -20,7 +20,7 @@ URL: https://github.com/heliosdrm/pwr
 VignetteBuilder: knitr
 RoxygenNote: 7.1.0
 NeedsCompilation: no
-Packaged: 2020-03-16 22:50:22 UTC; meliana
+Packaged: 2023-01-19 12:24:13 UTC; root
 Author: Stephane Champely [aut],
   Claus Ekstrom [ctb],
   Peter Dalgaard [ctb],
@@ -31,5 +31,3 @@ Author: Stephane Champely [aut],
   Robert Volcic [ctb],
   Helios De Rosario [cre]
 Maintainer: Helios De Rosario <helios.derosario@gmail.com>
-Repository: CRAN
-Date/Publication: 2020-03-17 12:10:02 UTC
diff --git a/MD5 b/MD5
deleted file mode 100644
index cd89d0b..0000000
--- a/MD5
+++ /dev/null
@@ -1,39 +0,0 @@
-5e52c09e3fbce1e663add5f95cda239f *DESCRIPTION
-6a2b948c4abdc27fa91f02422d949df4 *NAMESPACE
-2811235ff04a8343bf1b5e363f37a479 *NEWS
-b8a87f4ddac74d10af98b71c93eef5cb *R/ES.h.R
-20e4fa58c12b787eba3fdfbbdec1934e *R/ES.w1.R
-8d1b3ba98a6a3e6040a18ab99375c8ae *R/ES.w2.R
-8f43391c71c7d3c42056cad38f12ed5a *R/cohen.ES.R
-10f8ff8e86941758853581839d67fd6f *R/plot.power.htest.R
-7be17b1f29925bf7ff4d5f63d613815a *R/pwr.2p.test.R
-1cc4f70ac393ce714e60ec54f65e8fda *R/pwr.2p2n.test.R
-5f88fb35621733b32567fc966683f999 *R/pwr.anova.test.R
-488f443d4126d079818b525dc95f7ca2 *R/pwr.chisq.test.R
-488799677edadbfb1f3d6e33ee26d634 *R/pwr.f2.test.R
-260ae685483621ea6c92732a37cdc861 *R/pwr.norm.test.R
-854521043f3a9d86d7f85fc1d34c6825 *R/pwr.p.test.R
-4b2c4b4f78d8fa545c284e368ef6acd1 *R/pwr.r.test.R
-5772ade02e99b562451fd470319b01e2 *R/pwr.t.test.R
-ae5c866df701cff5da5d4357c3d2d1fa *R/pwr.t2n.test.R
-304cca75676c0c5d7bbdcd384e699b8a *build/vignette.rds
-ad7a38d96cd3a8c238cf4ab57a0a6589 *inst/doc/pwr-vignette.R
-b516cc1084cfde79508ec53c2b61aded *inst/doc/pwr-vignette.Rmd
-d9418368d021e83b55028cc491b1205a *inst/doc/pwr-vignette.html
-eca9274a0fb0feba8000a076e5796800 *man/ES.h.Rd
-800c5e5691e698138998a86b4c410dee *man/ES.w1.Rd
-16994846d5cf682688fd5617d6193185 *man/ES.w2.Rd
-c060199d3c12481ab4bf243844a09068 *man/cohen.ES.Rd
-dd3f9870cce4892502312d7063b56034 *man/plot.power.htest.Rd
-41150f50d68ee5de7a5473455422d5ac *man/pwr-package.Rd
-6573055b854cd28d915583603bd38f65 *man/pwr.2p.test.Rd
-a09c9418a99083ace9224c8dbea7e6d6 *man/pwr.2p2n.test.Rd
-96d5df94bdb949e8a225da03771be265 *man/pwr.anova.test.Rd
-e7a9b99a266050e243c112a49e5ea80c *man/pwr.chisq.test.Rd
-ae37d123a9ab27983256c64ffa36f018 *man/pwr.f2.test.Rd
-b60c87f94df02422fd38b524a94ffa88 *man/pwr.norm.test.Rd
-3b1079dbdc8100942f4a09e45f668ccf *man/pwr.p.test.Rd
-dd3845762017fcc04860eee76aae7c8c *man/pwr.r.test.Rd
-892acb23edb6da8b1f9193e762e03548 *man/pwr.t.test.Rd
-b13d9039aa43414595657cf2611a6bac *man/pwr.t2n.test.Rd
-b516cc1084cfde79508ec53c2b61aded *vignettes/pwr-vignette.Rmd
diff --git a/R/pwr.2p.test.R b/R/pwr.2p.test.R
index a31c4fd..0da8512 100644
--- a/R/pwr.2p.test.R
+++ b/R/pwr.2p.test.R
@@ -21,21 +21,21 @@ function (h = NULL, n = NULL, sig.level = 0.05, power = NULL,
         h <- abs(h)
     if (tside == 3) {
         p.body <- quote({
-            pnorm(qnorm(sig.level, lower = FALSE) - h * sqrt(n/2),
-                lower = FALSE)
+            pnorm(qnorm(sig.level, lower.tail = FALSE) - h * sqrt(n/2),
+                lower.tail = FALSE)
         })
     }
     if (tside == 2) {
         p.body <- quote({
-            pnorm(qnorm(sig.level/2, lower = FALSE) - h * sqrt(n/2),
-                lower = FALSE) + pnorm(qnorm(sig.level/2, lower = TRUE) -
-                h * sqrt(n/2), lower = TRUE)
+            pnorm(qnorm(sig.level/2, lower.tail = FALSE) - h * sqrt(n/2),
+                lower.tail = FALSE) + pnorm(qnorm(sig.level/2, lower.tail = TRUE) -
+                h * sqrt(n/2), lower.tail = TRUE)
         })
     }
     if (tside ==1) {
         p.body <- quote({
-            pnorm(qnorm(sig.level, lower = TRUE) - h * sqrt(n/2),
-                lower = TRUE)
+            pnorm(qnorm(sig.level, lower.tail = TRUE) - h * sqrt(n/2),
+                lower.tail = TRUE)
         })
     }
 
diff --git a/R/pwr.2p2n.test.R b/R/pwr.2p2n.test.R
index 5efa35b..021aa7a 100644
--- a/R/pwr.2p2n.test.R
+++ b/R/pwr.2p2n.test.R
@@ -23,23 +23,23 @@ function (h = NULL, n1 = NULL, n2 = NULL, sig.level = 0.05, power = NULL,
         h <- abs(h)
     if (tside == 3) {
         p.body <- quote({
-            pnorm(qnorm(sig.level, lower = FALSE) - h * sqrt((n1 *
-                n2)/(n1 + n2)), lower = FALSE)
+            pnorm(qnorm(sig.level, lower.tail = FALSE) - h * sqrt((n1 *
+                n2)/(n1 + n2)), lower.tail = FALSE)
         })
     }
     if (tside == 1) {
         p.body <- quote({
-            pnorm(qnorm(sig.level, lower = TRUE) - h * sqrt((n1 *
-                n2)/(n1 + n2)), lower = TRUE)
+            pnorm(qnorm(sig.level, lower.tail = TRUE) - h * sqrt((n1 *
+                n2)/(n1 + n2)), lower.tail = TRUE)
         })
     }
 
      if (tside == 2)  {
         p.body <- quote({
-            pnorm(qnorm(sig.level/2, lower = FALSE) - h * sqrt((n1 *
-                n2)/(n1 + n2)), lower = FALSE) + pnorm(qnorm(sig.level/2,
-                lower = TRUE) - h * sqrt((n1 * n2)/(n1 + n2)),
-                lower = TRUE)
+            pnorm(qnorm(sig.level/2, lower.tail = FALSE) - h * sqrt((n1 *
+                n2)/(n1 + n2)), lower.tail = FALSE) + pnorm(qnorm(sig.level/2,
+                lower.tail = TRUE) - h * sqrt((n1 * n2)/(n1 + n2)),
+                lower.tail = TRUE)
         })
     }
     if (is.null(power))
diff --git a/R/pwr.anova.test.R b/R/pwr.anova.test.R
index 4a1436a..ee3ba99 100644
--- a/R/pwr.anova.test.R
+++ b/R/pwr.anova.test.R
@@ -22,8 +22,8 @@ function (k = NULL, n = NULL, f = NULL, sig.level = 0.05, power = NULL)
         stop(sQuote("power"), " must be numeric in [0, 1]")
     p.body <- quote({
         lambda <- k * n * f^2
-        pf(qf(sig.level, k - 1, (n - 1) * k, lower = FALSE),
-            k - 1, (n - 1) * k, lambda, lower = FALSE)
+        pf(qf(sig.level, k - 1, (n - 1) * k, lower.tail = FALSE),
+            k - 1, (n - 1) * k, lambda, lower.tail = FALSE)
     })
     if (is.null(power))
         power <- eval(p.body)
diff --git a/R/pwr.chisq.test.R b/R/pwr.chisq.test.R
index 1855980..ef084e2 100644
--- a/R/pwr.chisq.test.R
+++ b/R/pwr.chisq.test.R
@@ -19,8 +19,8 @@ function (w = NULL, N = NULL, df = NULL, sig.level = 0.05, power = NULL)
         power > 1))
         stop(sQuote("power"), " must be numeric in [0, 1]")
     p.body <- quote({
-        k <- qchisq(sig.level, df = df, lower = FALSE)
-        pchisq(k, df = df, ncp = N * w^2, lower = FALSE)
+        k <- qchisq(sig.level, df = df, lower.tail = FALSE)
+        pchisq(k, df = df, ncp = N * w^2, lower.tail = FALSE)
     })
     if (is.null(power))
         power <- eval(p.body)
diff --git a/R/pwr.f2.test.R b/R/pwr.f2.test.R
index 5a07f80..91a89c7 100644
--- a/R/pwr.f2.test.R
+++ b/R/pwr.f2.test.R
@@ -22,8 +22,8 @@ function (u = NULL, v = NULL, f2 = NULL, sig.level = 0.05, power = NULL)
         stop(sQuote("power"), " must be numeric in [0, 1]")
     p.body <- quote({
         lambda <- f2*(u+v+1)
-        pf(qf(sig.level, u, v, lower = FALSE),
-            u, v, lambda, lower = FALSE)
+        pf(qf(sig.level, u, v, lower.tail = FALSE),
+            u, v, lambda, lower.tail = FALSE)
     })
     if (is.null(power))
         power <- eval(p.body)
diff --git a/R/pwr.norm.test.R b/R/pwr.norm.test.R
index 6b95d00..7e44740 100644
--- a/R/pwr.norm.test.R
+++ b/R/pwr.norm.test.R
@@ -21,22 +21,22 @@ function (d = NULL, n = NULL, sig.level = 0.05, power = NULL,
         d <- abs(d)
     if (tside == 2) {
         p.body <- quote({
-            pnorm(qnorm(sig.level/2, lower = FALSE) - d * sqrt(n),
-                lower = FALSE) + pnorm(qnorm(sig.level/2, lower = TRUE) -
-                d * sqrt(n), lower = TRUE)
+            pnorm(qnorm(sig.level/2, lower.tail = FALSE) - d * sqrt(n),
+                lower.tail = FALSE) + pnorm(qnorm(sig.level/2, lower.tail = TRUE) -
+                d * sqrt(n), lower.tail = TRUE)
         })
     }
     if (tside==1) {
         p.body <- quote({
-            pnorm(qnorm(sig.level, lower = TRUE) - d * sqrt(n),
-                lower = TRUE)
+            pnorm(qnorm(sig.level, lower.tail = TRUE) - d * sqrt(n),
+                lower.tail = TRUE)
         })
     }
 
     if (tside==3) {
         p.body <- quote({
-            pnorm(qnorm(sig.level, lower = FALSE) - d * sqrt(n),
-                lower = FALSE)
+            pnorm(qnorm(sig.level, lower.tail = FALSE) - d * sqrt(n),
+                lower.tail = FALSE)
         })
     }
 
diff --git a/R/pwr.p.test.R b/R/pwr.p.test.R
index f5132a8..7719781 100644
--- a/R/pwr.p.test.R
+++ b/R/pwr.p.test.R
@@ -21,21 +21,21 @@ function (h = NULL, n = NULL, sig.level = 0.05, power = NULL,
         h <- abs(h)
     if (tside == 2) {
         p.body <- quote({
-            pnorm(qnorm(sig.level/2, lower = FALSE) - h * sqrt(n),
-                lower = FALSE) + pnorm(qnorm(sig.level/2, lower = TRUE) -
-                h * sqrt(n), lower = TRUE)
+            pnorm(qnorm(sig.level/2, lower.tail = FALSE) - h * sqrt(n),
+                lower.tail = FALSE) + pnorm(qnorm(sig.level/2, lower.tail = TRUE) -
+                h * sqrt(n), lower.tail = TRUE)
         })
     }
     if (tside == 3) {
         p.body <- quote({
-            pnorm(qnorm(sig.level, lower = FALSE) - h * sqrt(n),
-                lower = FALSE)
+            pnorm(qnorm(sig.level, lower.tail = FALSE) - h * sqrt(n),
+                lower.tail = FALSE)
         })
     }
     if (tside == 1) {
         p.body <- quote({
-            pnorm(qnorm(sig.level, lower = TRUE) - h * sqrt(n),
-                lower = TRUE)
+            pnorm(qnorm(sig.level, lower.tail = TRUE) - h * sqrt(n),
+                lower.tail = TRUE)
         })
     }
     if (is.null(power))
diff --git a/R/pwr.r.test.R b/R/pwr.r.test.R
index c086c6a..a857a24 100644
--- a/R/pwr.r.test.R
+++ b/R/pwr.r.test.R
@@ -21,7 +21,7 @@ function (n = NULL, r = NULL, sig.level = 0.05, power = NULL,
         r <- abs(r)
     if (tside == 3) {
         p.body <- quote({
-            ttt <- qt(sig.level, df = n - 2, lower = FALSE)
+            ttt <- qt(sig.level, df = n - 2, lower.tail = FALSE)
             rc <- sqrt(ttt^2/(ttt^2 + n - 2))
             zr <- atanh(r) + r/(2 * (n - 1))
             zrc <- atanh(rc) # + rc/(2 * (n - 1))
@@ -31,7 +31,7 @@ function (n = NULL, r = NULL, sig.level = 0.05, power = NULL,
     if (tside == 1) {
         p.body <- quote({
             r<--r
-            ttt <- qt(sig.level, df = n - 2, lower = FALSE)
+            ttt <- qt(sig.level, df = n - 2, lower.tail = FALSE)
             rc <- sqrt(ttt^2/(ttt^2 + n - 2))
             zr <- atanh(r) + r/(2 * (n - 1))
             zrc <- atanh(rc) # + rc/(2 * (n - 1))
@@ -41,7 +41,7 @@ function (n = NULL, r = NULL, sig.level = 0.05, power = NULL,
 
     if (tside == 2) {
         p.body <- quote({
-            ttt <- qt(sig.level/2, df = n - 2, lower = FALSE)
+            ttt <- qt(sig.level/2, df = n - 2, lower.tail = FALSE)
             rc <- sqrt(ttt^2/(ttt^2 + n - 2))
             zr <- atanh(r) + r/(2 * (n - 1))
             zrc <- atanh(rc) # + rc/(2 * (n - 1))
diff --git a/R/pwr.t.test.R b/R/pwr.t.test.R
index fed01c0..3f2465f 100644
--- a/R/pwr.t.test.R
+++ b/R/pwr.t.test.R
@@ -24,23 +24,23 @@ function (n = NULL, d = NULL, sig.level = 0.05, power = NULL,
     if (ttside == 1) {
         p.body <- quote({
             nu <- (n - 1) * tsample
-            pt(qt(sig.level/tside, nu, lower = TRUE), nu,
-                ncp = sqrt(n/tsample) * d, lower = TRUE)
+            pt(qt(sig.level/tside, nu, lower.tail = TRUE), nu,
+                ncp = sqrt(n/tsample) * d, lower.tail = TRUE)
         })
     }
     if (ttside == 2)  {
         p.body <- quote({
             nu <- (n - 1) * tsample
-            qu <- qt(sig.level/tside, nu, lower = FALSE)
-            pt(qu, nu, ncp = sqrt(n/tsample) * d, lower = FALSE) +
-                pt(-qu, nu, ncp = sqrt(n/tsample) * d, lower = TRUE)
+            qu <- qt(sig.level/tside, nu, lower.tail = FALSE)
+            pt(qu, nu, ncp = sqrt(n/tsample) * d, lower.tail = FALSE) +
+                pt(-qu, nu, ncp = sqrt(n/tsample) * d, lower.tail = TRUE)
         })
     }
 	if (ttside == 3) {
         p.body <- quote({
             nu <- (n - 1) * tsample
-            pt(qt(sig.level/tside, nu, lower = FALSE), nu,
-                ncp = sqrt(n/tsample) * d, lower = FALSE)
+            pt(qt(sig.level/tside, nu, lower.tail = FALSE), nu,
+                ncp = sqrt(n/tsample) * d, lower.tail = FALSE)
         })
     }
 
diff --git a/R/pwr.t2n.test.R b/R/pwr.t2n.test.R
index e178337..99c7dc9 100644
--- a/R/pwr.t2n.test.R
+++ b/R/pwr.t2n.test.R
@@ -28,23 +28,23 @@ function (n1 = NULL, n2= NULL, d = NULL, sig.level = 0.05, power = NULL,
     if (ttside == 1) {
         p.body <- quote({
             nu <- n1+n2-2
-            pt(qt(sig.level/tside, nu, lower = TRUE), nu,
-                ncp = d*(1/sqrt(1/n1+1/n2)), lower = TRUE)
+            pt(qt(sig.level/tside, nu, lower.tail = TRUE), nu,
+                ncp = d*(1/sqrt(1/n1+1/n2)), lower.tail = TRUE)
         })
     }
     if (ttside == 2)  {
         p.body <- quote({
            nu <- n1+n2-2
-            qu <- qt(sig.level/tside, nu, lower = FALSE)
-            pt(qu, nu, ncp = d*(1/sqrt(1/n1+1/n2)), lower = FALSE) +
-                pt(-qu, nu,ncp = d*(1/sqrt(1/n1+1/n2)), lower = TRUE)
+            qu <- qt(sig.level/tside, nu, lower.tail = FALSE)
+            pt(qu, nu, ncp = d*(1/sqrt(1/n1+1/n2)), lower.tail = FALSE) +
+                pt(-qu, nu,ncp = d*(1/sqrt(1/n1+1/n2)), lower.tail = TRUE)
         })
     }
 	if (ttside == 3) {
         p.body <- quote({
            nu <- n1+n2-2
-            pt(qt(sig.level/tside, nu, lower = FALSE), nu,
-                ncp = d*(1/sqrt(1/n1+1/n2)), lower = FALSE)
+            pt(qt(sig.level/tside, nu, lower.tail = FALSE), nu,
+                ncp = d*(1/sqrt(1/n1+1/n2)), lower.tail = FALSE)
         })
     }
 
diff --git a/build/vignette.rds b/build/vignette.rds
index ba57740..68db86e 100644
Binary files a/build/vignette.rds and b/build/vignette.rds differ
diff --git a/debian/changelog b/debian/changelog
index 550ed82..8700027 100644
--- a/debian/changelog
+++ b/debian/changelog
@@ -1,3 +1,10 @@
+r-cran-pwr (1.3-0+git20200520.2.2f64c78+dfsg-1) UNRELEASED; urgency=low
+
+  * New upstream snapshot.
+  * New upstream snapshot.
+
+ -- Debian Janitor <janitor@jelmer.uk>  Thu, 19 Jan 2023 12:24:25 -0000
+
 r-cran-pwr (1.3-0+dfsg-1) unstable; urgency=medium
 
   * Set upstream metadata fields: Archive, Bug-Database, Bug-Submit,
diff --git a/inst/doc/pwr-vignette.html b/inst/doc/pwr-vignette.html
new file mode 100644
index 0000000..0689c4a
--- /dev/null
+++ b/inst/doc/pwr-vignette.html
@@ -0,0 +1,1371 @@
+<!DOCTYPE html>
+
+<html>
+
+<head>
+
+<meta charset="utf-8" />
+<meta name="generator" content="pandoc" />
+<meta http-equiv="X-UA-Compatible" content="IE=EDGE" />
+
+<meta name="viewport" content="width=device-width, initial-scale=1" />
+
+<meta name="author" content="Clay Ford" />
+
+<meta name="date" content="2023-01-19" />
+
+<title>Getting started with the pwr package</title>
+
+<script>// Pandoc 2.9 adds attributes on both header and div. We remove the former (to
+// be compatible with the behavior of Pandoc < 2.8).
+document.addEventListener('DOMContentLoaded', function(e) {
+  var hs = document.querySelectorAll("div.section[class*='level'] > :first-child");
+  var i, h, a;
+  for (i = 0; i < hs.length; i++) {
+    h = hs[i];
+    if (!/^h[1-6]$/i.test(h.tagName)) continue;  // it should be a header h1-h6
+    a = h.attributes;
+    while (a.length > 0) h.removeAttribute(a[0].name);
+  }
+});
+</script>
+
+<style type="text/css">
+  code{white-space: pre-wrap;}
+  span.smallcaps{font-variant: small-caps;}
+  span.underline{text-decoration: underline;}
+  div.column{display: inline-block; vertical-align: top; width: 50%;}
+  div.hanging-indent{margin-left: 1.5em; text-indent: -1.5em;}
+  ul.task-list{list-style: none;}
+    </style>
+
+
+
+<style type="text/css">
+  code {
+    white-space: pre;
+  }
+  .sourceCode {
+    overflow: visible;
+  }
+</style>
+<style type="text/css" data-origin="pandoc">
+pre > code.sourceCode { white-space: pre; position: relative; }
+pre > code.sourceCode > span { display: inline-block; line-height: 1.25; }
+pre > code.sourceCode > span:empty { height: 1.2em; }
+.sourceCode { overflow: visible; }
+code.sourceCode > span { color: inherit; text-decoration: inherit; }
+div.sourceCode { margin: 1em 0; }
+pre.sourceCode { margin: 0; }
+@media screen {
+div.sourceCode { overflow: auto; }
+}
+@media print {
+pre > code.sourceCode { white-space: pre-wrap; }
+pre > code.sourceCode > span { text-indent: -5em; padding-left: 5em; }
+}
+pre.numberSource code
+  { counter-reset: source-line 0; }
+pre.numberSource code > span
+  { position: relative; left: -4em; counter-increment: source-line; }
+pre.numberSource code > span > a:first-child::before
+  { content: counter(source-line);
+    position: relative; left: -1em; text-align: right; vertical-align: baseline;
+    border: none; display: inline-block;
+    -webkit-touch-callout: none; -webkit-user-select: none;
+    -khtml-user-select: none; -moz-user-select: none;
+    -ms-user-select: none; user-select: none;
+    padding: 0 4px; width: 4em;
+    color: #aaaaaa;
+  }
+pre.numberSource { margin-left: 3em; border-left: 1px solid #aaaaaa;  padding-left: 4px; }
+div.sourceCode
+  {   }
+@media screen {
+pre > code.sourceCode > span > a:first-child::before { text-decoration: underline; }
+}
+code span.al { color: #ff0000; font-weight: bold; } /* Alert */
+code span.an { color: #60a0b0; font-weight: bold; font-style: italic; } /* Annotation */
+code span.at { color: #7d9029; } /* Attribute */
+code span.bn { color: #40a070; } /* BaseN */
+code span.bu { color: #008000; } /* BuiltIn */
+code span.cf { color: #007020; font-weight: bold; } /* ControlFlow */
+code span.ch { color: #4070a0; } /* Char */
+code span.cn { color: #880000; } /* Constant */
+code span.co { color: #60a0b0; font-style: italic; } /* Comment */
+code span.cv { color: #60a0b0; font-weight: bold; font-style: italic; } /* CommentVar */
+code span.do { color: #ba2121; font-style: italic; } /* Documentation */
+code span.dt { color: #902000; } /* DataType */
+code span.dv { color: #40a070; } /* DecVal */
+code span.er { color: #ff0000; font-weight: bold; } /* Error */
+code span.ex { } /* Extension */
+code span.fl { color: #40a070; } /* Float */
+code span.fu { color: #06287e; } /* Function */
+code span.im { color: #008000; font-weight: bold; } /* Import */
+code span.in { color: #60a0b0; font-weight: bold; font-style: italic; } /* Information */
+code span.kw { color: #007020; font-weight: bold; } /* Keyword */
+code span.op { color: #666666; } /* Operator */
+code span.ot { color: #007020; } /* Other */
+code span.pp { color: #bc7a00; } /* Preprocessor */
+code span.sc { color: #4070a0; } /* SpecialChar */
+code span.ss { color: #bb6688; } /* SpecialString */
+code span.st { color: #4070a0; } /* String */
+code span.va { color: #19177c; } /* Variable */
+code span.vs { color: #4070a0; } /* VerbatimString */
+code span.wa { color: #60a0b0; font-weight: bold; font-style: italic; } /* Warning */
+
+</style>
+<script>
+// apply pandoc div.sourceCode style to pre.sourceCode instead
+(function() {
+  var sheets = document.styleSheets;
+  for (var i = 0; i < sheets.length; i++) {
+    if (sheets[i].ownerNode.dataset["origin"] !== "pandoc") continue;
+    try { var rules = sheets[i].cssRules; } catch (e) { continue; }
+    var j = 0;
+    while (j < rules.length) {
+      var rule = rules[j];
+      // check if there is a div.sourceCode rule
+      if (rule.type !== rule.STYLE_RULE || rule.selectorText !== "div.sourceCode") {
+        j++;
+        continue;
+      }
+      var style = rule.style.cssText;
+      // check if color or background-color is set
+      if (rule.style.color === '' && rule.style.backgroundColor === '') {
+        j++;
+        continue;
+      }
+      // replace div.sourceCode by a pre.sourceCode rule
+      sheets[i].deleteRule(j);
+      sheets[i].insertRule('pre.sourceCode{' + style + '}', j);
+    }
+  }
+})();
+</script>
+
+
+
+
+<style type="text/css">body {
+background-color: #fff;
+margin: 1em auto;
+max-width: 700px;
+overflow: visible;
+padding-left: 2em;
+padding-right: 2em;
+font-family: "Open Sans", "Helvetica Neue", Helvetica, Arial, sans-serif;
+font-size: 14px;
+line-height: 1.35;
+}
+#TOC {
+clear: both;
+margin: 0 0 10px 10px;
+padding: 4px;
+width: 400px;
+border: 1px solid #CCCCCC;
+border-radius: 5px;
+background-color: #f6f6f6;
+font-size: 13px;
+line-height: 1.3;
+}
+#TOC .toctitle {
+font-weight: bold;
+font-size: 15px;
+margin-left: 5px;
+}
+#TOC ul {
+padding-left: 40px;
+margin-left: -1.5em;
+margin-top: 5px;
+margin-bottom: 5px;
+}
+#TOC ul ul {
+margin-left: -2em;
+}
+#TOC li {
+line-height: 16px;
+}
+table {
+margin: 1em auto;
+border-width: 1px;
+border-color: #DDDDDD;
+border-style: outset;
+border-collapse: collapse;
+}
+table th {
+border-width: 2px;
+padding: 5px;
+border-style: inset;
+}
+table td {
+border-width: 1px;
+border-style: inset;
+line-height: 18px;
+padding: 5px 5px;
+}
+table, table th, table td {
+border-left-style: none;
+border-right-style: none;
+}
+table thead, table tr.even {
+background-color: #f7f7f7;
+}
+p {
+margin: 0.5em 0;
+}
+blockquote {
+background-color: #f6f6f6;
+padding: 0.25em 0.75em;
+}
+hr {
+border-style: solid;
+border: none;
+border-top: 1px solid #777;
+margin: 28px 0;
+}
+dl {
+margin-left: 0;
+}
+dl dd {
+margin-bottom: 13px;
+margin-left: 13px;
+}
+dl dt {
+font-weight: bold;
+}
+ul {
+margin-top: 0;
+}
+ul li {
+list-style: circle outside;
+}
+ul ul {
+margin-bottom: 0;
+}
+pre, code {
+background-color: #f7f7f7;
+border-radius: 3px;
+color: #333;
+white-space: pre-wrap; 
+}
+pre {
+border-radius: 3px;
+margin: 5px 0px 10px 0px;
+padding: 10px;
+}
+pre:not([class]) {
+background-color: #f7f7f7;
+}
+code {
+font-family: Consolas, Monaco, 'Courier New', monospace;
+font-size: 85%;
+}
+p > code, li > code {
+padding: 2px 0px;
+}
+div.figure {
+text-align: center;
+}
+img {
+background-color: #FFFFFF;
+padding: 2px;
+border: 1px solid #DDDDDD;
+border-radius: 3px;
+border: 1px solid #CCCCCC;
+margin: 0 5px;
+}
+h1 {
+margin-top: 0;
+font-size: 35px;
+line-height: 40px;
+}
+h2 {
+border-bottom: 4px solid #f7f7f7;
+padding-top: 10px;
+padding-bottom: 2px;
+font-size: 145%;
+}
+h3 {
+border-bottom: 2px solid #f7f7f7;
+padding-top: 10px;
+font-size: 120%;
+}
+h4 {
+border-bottom: 1px solid #f7f7f7;
+margin-left: 8px;
+font-size: 105%;
+}
+h5, h6 {
+border-bottom: 1px solid #ccc;
+font-size: 105%;
+}
+a {
+color: #0033dd;
+text-decoration: none;
+}
+a:hover {
+color: #6666ff; }
+a:visited {
+color: #800080; }
+a:visited:hover {
+color: #BB00BB; }
+a[href^="http:"] {
+text-decoration: underline; }
+a[href^="https:"] {
+text-decoration: underline; }
+
+code > span.kw { color: #555; font-weight: bold; } 
+code > span.dt { color: #902000; } 
+code > span.dv { color: #40a070; } 
+code > span.bn { color: #d14; } 
+code > span.fl { color: #d14; } 
+code > span.ch { color: #d14; } 
+code > span.st { color: #d14; } 
+code > span.co { color: #888888; font-style: italic; } 
+code > span.ot { color: #007020; } 
+code > span.al { color: #ff0000; font-weight: bold; } 
+code > span.fu { color: #900; font-weight: bold; } 
+code > span.er { color: #a61717; background-color: #e3d2d2; } 
+</style>
+
+
+
+
+</head>
+
+<body>
+
+
+
+
+<h1 class="title toc-ignore">Getting started with the pwr package</h1>
+<h4 class="author">Clay Ford</h4>
+<h4 class="date">2023-01-19</h4>
+
+
+
+<p>The basic idea of calculating power or sample size with functions in
+the pwr package is to <em>leave out</em> the argument that you want to
+calculate. If you want to calculate power, then leave the
+<code>power</code> argument out of the function. If you want to
+calculate sample size, leave <code>n</code> out of the function.
+Whatever parameter you want to calculate is determined from the
+others.</p>
+<p>You select a function based on the statistical test you plan to use
+to analyze your data. If you plan to use a two-sample t-test to compare
+two means, you would use the <code>pwr.t.test</code> function for
+estimating sample size or power. All functions for power and sample size
+analysis in the pwr package begin with <code>pwr</code>. Functions are
+available for the following statistical tests:</p>
+<ul>
+<li><code>pwr.p.test</code>: one-sample proportion test</li>
+<li><code>pwr.2p.test</code>: two-sample proportion test</li>
+<li><code>pwr.2p2n.test</code>: two-sample proportion test (unequal
+sample sizes)</li>
+<li><code>pwr.t.test</code>: two-sample, one-sample and paired
+t-tests</li>
+<li><code>pwr.t2n.test</code>: two-sample t-tests (unequal sample
+sizes)</li>
+<li><code>pwr.anova.test</code>: one-way balanced ANOVA</li>
+<li><code>pwr.r.test</code>: correlation test</li>
+<li><code>pwr.chisq.test</code>: chi-squared test (goodness of fit and
+association)</li>
+<li><code>pwr.f2.test</code>: test for the general linear model</li>
+</ul>
+<p>There are also a few convenience functions for calculating effect
+size as well as a generic <code>plot</code> function for plotting power
+versus sample size. All of these are demonstrated in the examples
+below.</p>
+<div id="a-simple-example" class="section level2">
+<h2>A simple example</h2>
+<p>Let’s say we suspect we have a loaded coin that lands heads 75% of
+the time instead of the expected 50%. We wish to create an experiment to
+test this. We will flip the coin a certain number of times and observe
+the proportion of heads. We will then conduct a one-sample proportion
+test to see if the proportion of heads is significantly different from
+what we would expect with a fair coin. We will judge significance by our
+p-value. If our p-value falls below a certain threshold, say 0.05, we
+will conclude our coin’s behavior is inconsistent with that of a fair
+coin.</p>
+<ul>
+<li>Our null hypothesis is that the coin is fair and lands heads 50% of
+the time (<span class="math inline">\(\pi\)</span> = 0.50).</li>
+<li>Our alternative hypothesis is that the coin is loaded to land heads
+more then 50% of the time (<span class="math inline">\(\pi\)</span> &gt;
+0.50).</li>
+</ul>
+<p>How many times should we flip the coin to have a high probability (or
+<em>power</em>), say 0.80, of correctly rejecting the null of <span class="math inline">\(\pi\)</span> = 0.5 if our coin is indeed loaded to
+land heads 75% of the time?</p>
+<p>Here is how we can determine this using the <code>pwr.p.test</code>
+function.</p>
+<div class="sourceCode" id="cb1"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb1-1"><a href="#cb1-1" aria-hidden="true" tabindex="-1"></a><span class="fu">library</span>(pwr)</span>
+<span id="cb1-2"><a href="#cb1-2" aria-hidden="true" tabindex="-1"></a><span class="fu">pwr.p.test</span>(<span class="at">h =</span> <span class="fu">ES.h</span>(<span class="at">p1 =</span> <span class="fl">0.75</span>, <span class="at">p2 =</span> <span class="fl">0.50</span>),</span>
+<span id="cb1-3"><a href="#cb1-3" aria-hidden="true" tabindex="-1"></a>           <span class="at">sig.level =</span> <span class="fl">0.05</span>,</span>
+<span id="cb1-4"><a href="#cb1-4" aria-hidden="true" tabindex="-1"></a>           <span class="at">power =</span> <span class="fl">0.80</span>,</span>
+<span id="cb1-5"><a href="#cb1-5" aria-hidden="true" tabindex="-1"></a>           <span class="at">alternative =</span> <span class="st">&quot;greater&quot;</span>)</span></code></pre></div>
+<pre><code>## 
+##      proportion power calculation for binomial distribution (arcsine transformation) 
+## 
+##               h = 0.5235988
+##               n = 22.55126
+##       sig.level = 0.05
+##           power = 0.8
+##     alternative = greater</code></pre>
+<p>The function tells us we should flip the coin 22.55127 times, which
+we round up to 23. Always round sample size estimates up. If we’re
+correct that our coin lands heads 75% of the time, we need to flip it at
+least 23 times to have an 80% chance of correctly rejecting the null
+hypothesis at the 0.05 significance level.</p>
+<p>Notice that since we wanted to determine sample size
+(<code>n</code>), we left it out of the function. Our <em>effect
+size</em> is entered in the <code>h</code> argument. The label
+<code>h</code> is due to Cohen (1988). The function <code>ES.h</code> is
+used to calculate a unitless effect size using the arcsine
+transformation. (More on effect size below.) <code>sig.level</code> is
+the argument for our desired significance level. This is also sometimes
+referred to as our tolerance for a Type I error (<span class="math inline">\(\alpha\)</span>). <code>power</code> is our
+desired power. It is sometimes referred to as 1 - <span class="math inline">\(\beta\)</span>, where <span class="math inline">\(\beta\)</span> is Type II error. The
+<code>alternative</code> argument says we think the alternative is
+“greater” than the null, not just different.</p>
+<p>Type I error, <span class="math inline">\(\alpha\)</span>, is the
+probability of rejecting the null hypothesis when it is true. This is
+thinking we have found an effect where none exist. This is considered
+the more serious error. Our tolerance for Type I error is usually 0.05
+or lower.</p>
+<p>Type II error, <span class="math inline">\(\beta\)</span>, is the
+probability of failing to reject the null hypothesis when it is false.
+This is thinking there is no effect when in fact there is. Our tolerance
+for Type II error is usually 0.20 or lower. Type II error is 1 - Power.
+If we desire a power of 0.90, then we implicitly specify a Type II error
+tolerance of 0.10.</p>
+<p>The pwr package provides a generic <code>plot</code> function that
+allows us to see how power changes as we change our sample size. If you
+have the ggplot2 package installed, it will create a plot using
+<code>ggplot</code>. Otherwise base R graphics are used.</p>
+<div class="sourceCode" id="cb3"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb3-1"><a href="#cb3-1" aria-hidden="true" tabindex="-1"></a>p.out <span class="ot">&lt;-</span> <span class="fu">pwr.p.test</span>(<span class="at">h =</span> <span class="fu">ES.h</span>(<span class="at">p1 =</span> <span class="fl">0.75</span>, <span class="at">p2 =</span> <span class="fl">0.50</span>),</span>
+<span id="cb3-2"><a href="#cb3-2" aria-hidden="true" tabindex="-1"></a>                    <span class="at">sig.level =</span> <span class="fl">0.05</span>,</span>
+<span id="cb3-3"><a href="#cb3-3" aria-hidden="true" tabindex="-1"></a>                    <span class="at">power =</span> <span class="fl">0.80</span>,</span>
+<span id="cb3-4"><a href="#cb3-4" aria-hidden="true" tabindex="-1"></a>                    <span class="at">alternative =</span> <span class="st">&quot;greater&quot;</span>)</span>
+<span id="cb3-5"><a href="#cb3-5" aria-hidden="true" tabindex="-1"></a><span class="fu">plot</span>(p.out)</span></code></pre></div>
+<p><img src="" /><!-- --></p>
+<p>What is the power of our test if we flip the coin 40 times and lower
+our Type I error tolerance to 0.01? Notice we leave out the
+<code>power</code> argument, add <code>n = 40</code>, and change
+<code>sig.level = 0.01</code>:</p>
+<div class="sourceCode" id="cb4"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb4-1"><a href="#cb4-1" aria-hidden="true" tabindex="-1"></a><span class="fu">pwr.p.test</span>(<span class="at">h =</span> <span class="fu">ES.h</span>(<span class="at">p1 =</span> <span class="fl">0.75</span>, <span class="at">p2 =</span> <span class="fl">0.50</span>),</span>
+<span id="cb4-2"><a href="#cb4-2" aria-hidden="true" tabindex="-1"></a>           <span class="at">sig.level =</span> <span class="fl">0.01</span>,</span>
+<span id="cb4-3"><a href="#cb4-3" aria-hidden="true" tabindex="-1"></a>           <span class="at">n =</span> <span class="dv">40</span>,</span>
+<span id="cb4-4"><a href="#cb4-4" aria-hidden="true" tabindex="-1"></a>           <span class="at">alternative =</span> <span class="st">&quot;greater&quot;</span>)</span></code></pre></div>
+<pre><code>## 
+##      proportion power calculation for binomial distribution (arcsine transformation) 
+## 
+##               h = 0.5235988
+##               n = 40
+##       sig.level = 0.01
+##           power = 0.8377325
+##     alternative = greater</code></pre>
+<p>The power of our test is about 84%.</p>
+<p>We specified <code>alternative = &quot;greater&quot;</code> since we assumed
+the coin was loaded for more heads (not less). This is a stronger
+assumption than assuming that the coin is simply unfair in one way or
+another. In practice, sample size and power calculations will usually
+make the more conservative “two-sided” assumption. In fact this is the
+default for pwr functions with an <code>alternative</code> argument. If
+we wish to assume a “two-sided” alternative, we can simply leave it out
+of the function. Notice how our power estimate drops below 80% when we
+do this.</p>
+<div class="sourceCode" id="cb6"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb6-1"><a href="#cb6-1" aria-hidden="true" tabindex="-1"></a><span class="fu">pwr.p.test</span>(<span class="at">h =</span> <span class="fu">ES.h</span>(<span class="at">p1 =</span> <span class="fl">0.75</span>, <span class="at">p2 =</span> <span class="fl">0.50</span>),</span>
+<span id="cb6-2"><a href="#cb6-2" aria-hidden="true" tabindex="-1"></a>           <span class="at">sig.level =</span> <span class="fl">0.01</span>,</span>
+<span id="cb6-3"><a href="#cb6-3" aria-hidden="true" tabindex="-1"></a>           <span class="at">n =</span> <span class="dv">40</span>)</span></code></pre></div>
+<pre><code>## 
+##      proportion power calculation for binomial distribution (arcsine transformation) 
+## 
+##               h = 0.5235988
+##               n = 40
+##       sig.level = 0.01
+##           power = 0.7690434
+##     alternative = two.sided</code></pre>
+<p>What if we assume the “loaded” effect is smaller? Maybe the coin
+lands heads 65% of the time. How many flips do we need to perform to
+detect this smaller effect at the 0.05 level with 80% power and the more
+conservative two-sided alternative?</p>
+<div class="sourceCode" id="cb8"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb8-1"><a href="#cb8-1" aria-hidden="true" tabindex="-1"></a><span class="fu">pwr.p.test</span>(<span class="at">h =</span> <span class="fu">ES.h</span>(<span class="at">p1 =</span> <span class="fl">0.65</span>, <span class="at">p2 =</span> <span class="fl">0.50</span>),</span>
+<span id="cb8-2"><a href="#cb8-2" aria-hidden="true" tabindex="-1"></a>           <span class="at">sig.level =</span> <span class="fl">0.05</span>,</span>
+<span id="cb8-3"><a href="#cb8-3" aria-hidden="true" tabindex="-1"></a>           <span class="at">power =</span> <span class="fl">0.80</span>)</span></code></pre></div>
+<pre><code>## 
+##      proportion power calculation for binomial distribution (arcsine transformation) 
+## 
+##               h = 0.3046927
+##               n = 84.54397
+##       sig.level = 0.05
+##           power = 0.8
+##     alternative = two.sided</code></pre>
+<p>About 85 coin flips. Detecting smaller effects require larger sample
+sizes.</p>
+</div>
+<div id="more-on-effect-size" class="section level2">
+<h2>More on effect size</h2>
+<p>Cohen describes effect size as “the degree to which the null
+hypothesis is false.” In our coin flipping example, this is the
+difference between 75% and 50%. We could say the effect was 25% but
+recall we had to transform the absolute difference in proportions to
+another quantity using the <code>ES.h</code> function. This is a crucial
+part of using the pwr package correctly: <em>You must provide an effect
+size on the expected scale.</em> Doing otherwise will produce wrong
+sample size and power calculations.</p>
+<p>When in doubt, we can use <em>Conventional Effect Sizes</em>. These
+are pre-determined effect sizes for “small”, “medium”, and “large”
+effects. The <code>cohen.ES</code> function returns a conventional
+effect size for a given test and size. For example, the medium effect
+size for the correlation test is 0.3:</p>
+<div class="sourceCode" id="cb10"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb10-1"><a href="#cb10-1" aria-hidden="true" tabindex="-1"></a><span class="fu">cohen.ES</span>(<span class="at">test =</span> <span class="st">&quot;r&quot;</span>, <span class="at">size =</span> <span class="st">&quot;medium&quot;</span>)</span></code></pre></div>
+<pre><code>## 
+##      Conventional effect size from Cohen (1982) 
+## 
+##            test = r
+##            size = medium
+##     effect.size = 0.3</code></pre>
+<p>As a shortcut, the effect size can be passed to power test functions
+as a string with the alias of a conventional effect size:</p>
+<div class="sourceCode" id="cb12"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb12-1"><a href="#cb12-1" aria-hidden="true" tabindex="-1"></a><span class="fu">pwr.r.test</span>(<span class="at">r=</span><span class="st">&quot;medium&quot;</span>, <span class="at">power=</span><span class="fl">0.8</span>)</span></code></pre></div>
+<pre><code>## 
+##      approximate correlation power calculation (arctangh transformation) 
+## 
+##               n = 84.07364
+##               r = 0.3
+##       sig.level = 0.05
+##           power = 0.8
+##     alternative = two.sided</code></pre>
+<p>For convenience, here are all conventional effect sizes for all tests
+in the pwr package:</p>
+<table>
+<thead>
+<tr class="header">
+<th>Test</th>
+<th><code>small</code></th>
+<th><code>medium</code></th>
+<th><code>large</code></th>
+</tr>
+</thead>
+<tbody>
+<tr class="odd">
+<td>tests for proportions (<code>p</code>)</td>
+<td>0.2</td>
+<td>0.5</td>
+<td>0.8</td>
+</tr>
+<tr class="even">
+<td>tests for means (<code>t</code>)</td>
+<td>0.2</td>
+<td>0.5</td>
+<td>0.8</td>
+</tr>
+<tr class="odd">
+<td>chi-square tests (<code>chisq</code>)</td>
+<td>0.1</td>
+<td>0.3</td>
+<td>0.5</td>
+</tr>
+<tr class="even">
+<td>correlation test (<code>r</code>)</td>
+<td>0.1</td>
+<td>0.3</td>
+<td>0.5</td>
+</tr>
+<tr class="odd">
+<td>anova (<code>anov</code>)</td>
+<td>0.1</td>
+<td>0.25</td>
+<td>0.4</td>
+</tr>
+<tr class="even">
+<td>general linear model (<code>f2</code>)</td>
+<td>0.02</td>
+<td>0.15</td>
+<td>0.35</td>
+</tr>
+</tbody>
+</table>
+<p>It is worth noting that pwr functions can take vectors for numeric
+effect size and n arguments. This allows us to make many power
+calculations at once, either for multiple effect sizes or multiple
+sample sizes. For example, let’s see how power changes for our coin
+flipping experiment for the three conventional effect sizes of 0.2, 0.5,
+and 0.8, assuming a sample size of 20.</p>
+<div class="sourceCode" id="cb14"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb14-1"><a href="#cb14-1" aria-hidden="true" tabindex="-1"></a><span class="fu">pwr.p.test</span>(<span class="at">h =</span> <span class="fu">c</span>(<span class="fl">0.2</span>,<span class="fl">0.5</span>,<span class="fl">0.8</span>),</span>
+<span id="cb14-2"><a href="#cb14-2" aria-hidden="true" tabindex="-1"></a>           <span class="at">n =</span> <span class="dv">20</span>,</span>
+<span id="cb14-3"><a href="#cb14-3" aria-hidden="true" tabindex="-1"></a>           <span class="at">sig.level =</span> <span class="fl">0.05</span>)</span></code></pre></div>
+<pre><code>## 
+##      proportion power calculation for binomial distribution (arcsine transformation) 
+## 
+##               h = 0.2, 0.5, 0.8
+##               n = 20
+##       sig.level = 0.05
+##           power = 0.1454725, 0.6087795, 0.9471412
+##     alternative = two.sided</code></pre>
+<p>As we demonstrated with the <code>plot</code> function above, we can
+save our results. This produces a list object from which we can extract
+quantities for further manipulation. For example, we can calculate power
+for sample sizes ranging from 10 to 100 in steps of 10, with an assumed
+“medium” effect of 0.5, and output to a data frame with some
+formatting:</p>
+<div class="sourceCode" id="cb16"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb16-1"><a href="#cb16-1" aria-hidden="true" tabindex="-1"></a>n <span class="ot">&lt;-</span> <span class="fu">seq</span>(<span class="dv">10</span>,<span class="dv">100</span>,<span class="dv">10</span>)</span>
+<span id="cb16-2"><a href="#cb16-2" aria-hidden="true" tabindex="-1"></a>p.out <span class="ot">&lt;-</span> <span class="fu">pwr.p.test</span>(<span class="at">h =</span> <span class="fl">0.5</span>,</span>
+<span id="cb16-3"><a href="#cb16-3" aria-hidden="true" tabindex="-1"></a>                    <span class="at">n =</span> n,</span>
+<span id="cb16-4"><a href="#cb16-4" aria-hidden="true" tabindex="-1"></a>                    <span class="at">sig.level =</span> <span class="fl">0.05</span>)</span>
+<span id="cb16-5"><a href="#cb16-5" aria-hidden="true" tabindex="-1"></a><span class="fu">data.frame</span>(n, <span class="at">power =</span> <span class="fu">sprintf</span>(<span class="st">&quot;%.2f%%&quot;</span>, p.out<span class="sc">$</span>power <span class="sc">*</span> <span class="dv">100</span>))</span></code></pre></div>
+<pre><code>##      n  power
+## 1   10 35.26%
+## 2   20 60.88%
+## 3   30 78.19%
+## 4   40 88.54%
+## 5   50 94.24%
+## 6   60 97.21%
+## 7   70 98.69%
+## 8   80 99.40%
+## 9   90 99.73%
+## 10 100 99.88%</code></pre>
+<p>We can also directly extract quantities with the <code>$</code>
+function appended to the end of a pwr function. For example,</p>
+<div class="sourceCode" id="cb18"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb18-1"><a href="#cb18-1" aria-hidden="true" tabindex="-1"></a><span class="fu">pwr.p.test</span>(<span class="at">h =</span> <span class="fl">0.5</span>, <span class="at">n =</span> n, <span class="at">sig.level =</span> <span class="fl">0.05</span>)<span class="sc">$</span>power</span></code></pre></div>
+<pre><code>##  [1] 0.3526081 0.6087795 0.7819080 0.8853791 0.9424375 0.9721272 0.9869034
+##  [8] 0.9940005 0.9973108 0.9988173</code></pre>
+</div>
+<div id="more-examples" class="section level2">
+<h2>More examples</h2>
+<div id="pwr.2p.test---two-sample-test-for-proportions" class="section level3">
+<h3>pwr.2p.test - two-sample test for proportions</h3>
+<p>Let’s say we want to randomly sample male and female college
+undergraduate students and ask them if they consume alcohol at least
+once a week. Our null hypothesis is no difference in the proportion that
+answer yes. Our alternative hypothesis is that there is a difference.
+This is a two-sided alternative; one gender has higher proportion but we
+don’t know which. We would like to detect a difference as small as 5%.
+How many students do we need to sample in each group if we want 80%
+power and a significance level of 0.05?</p>
+<p>If we think one group proportion is 55% and the other 50%:</p>
+<div class="sourceCode" id="cb20"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb20-1"><a href="#cb20-1" aria-hidden="true" tabindex="-1"></a><span class="fu">pwr.2p.test</span>(<span class="at">h =</span> <span class="fu">ES.h</span>(<span class="at">p1 =</span> <span class="fl">0.55</span>, <span class="at">p2 =</span> <span class="fl">0.50</span>), <span class="at">sig.level =</span> <span class="fl">0.05</span>, <span class="at">power =</span> .<span class="dv">80</span>)</span></code></pre></div>
+<pre><code>## 
+##      Difference of proportion power calculation for binomial distribution (arcsine transformation) 
+## 
+##               h = 0.1001674
+##               n = 1564.529
+##       sig.level = 0.05
+##           power = 0.8
+##     alternative = two.sided
+## 
+## NOTE: same sample sizes</code></pre>
+<p>Notice the sample size is <em>per group</em>. We need to sample 1,565
+males and 1,565 females to detect the 5% difference with 80% power.</p>
+<p>If we think one group proportion is 10% and the other 5%:</p>
+<div class="sourceCode" id="cb22"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb22-1"><a href="#cb22-1" aria-hidden="true" tabindex="-1"></a><span class="fu">pwr.2p.test</span>(<span class="at">h =</span> <span class="fu">ES.h</span>(<span class="at">p1 =</span> <span class="fl">0.10</span>, <span class="at">p2 =</span> <span class="fl">0.05</span>), <span class="at">sig.level =</span> <span class="fl">0.05</span>, <span class="at">power =</span> .<span class="dv">80</span>)</span></code></pre></div>
+<pre><code>## 
+##      Difference of proportion power calculation for binomial distribution (arcsine transformation) 
+## 
+##               h = 0.1924743
+##               n = 423.7319
+##       sig.level = 0.05
+##           power = 0.8
+##     alternative = two.sided
+## 
+## NOTE: same sample sizes</code></pre>
+<p>Even though the absolute difference between proportions is the same
+(5%), the optimum sample size is now 424 per group. 10% vs 5% is
+actually a bigger difference than 55% vs 50%. A heuristic approach for
+understanding why is to compare the ratios: 55/50 = 1.1 while 10/5 =
+2.</p>
+<p>The <code>ES.h</code> function performs an arcsine transformation on
+both proportions and returns the difference. By setting <code>p2</code>
+to 0, we can see the transformed value for <code>p1</code>. We can
+exploit this to help us visualize how the transformation creates larger
+effects for two proportions closer to 0 or 1. Below we plot transformed
+proportions versus untransformed proportions and then compare the
+distance between pairs of proportions on each axis.</p>
+<div class="sourceCode" id="cb24"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb24-1"><a href="#cb24-1" aria-hidden="true" tabindex="-1"></a>addSegs <span class="ot">&lt;-</span> <span class="cf">function</span>(p1, p2){</span>
+<span id="cb24-2"><a href="#cb24-2" aria-hidden="true" tabindex="-1"></a>  tp1 <span class="ot">&lt;-</span> <span class="fu">ES.h</span>(p1, <span class="dv">0</span>); tp2 <span class="ot">&lt;-</span> <span class="fu">ES.h</span>(p2, <span class="dv">0</span>)</span>
+<span id="cb24-3"><a href="#cb24-3" aria-hidden="true" tabindex="-1"></a>  <span class="fu">segments</span>(p1,<span class="dv">0</span>,p1,tp1, <span class="at">col=</span><span class="st">&quot;blue&quot;</span>); <span class="fu">segments</span>(p2,<span class="dv">0</span>,p2,tp2,<span class="at">col=</span><span class="st">&quot;blue&quot;</span>)</span>
+<span id="cb24-4"><a href="#cb24-4" aria-hidden="true" tabindex="-1"></a>  <span class="fu">segments</span>(<span class="dv">0</span>, tp1, p1, tp1, <span class="at">col=</span><span class="st">&quot;red&quot;</span>); <span class="fu">segments</span>(<span class="dv">0</span>, tp2, p2, tp2, <span class="at">col=</span><span class="st">&quot;red&quot;</span>)</span>
+<span id="cb24-5"><a href="#cb24-5" aria-hidden="true" tabindex="-1"></a>}</span>
+<span id="cb24-6"><a href="#cb24-6" aria-hidden="true" tabindex="-1"></a></span>
+<span id="cb24-7"><a href="#cb24-7" aria-hidden="true" tabindex="-1"></a><span class="fu">curve</span>(<span class="at">expr =</span> <span class="fu">ES.h</span>(<span class="at">p1 =</span> x, <span class="at">p2 =</span> <span class="dv">0</span>), <span class="at">xlim =</span> <span class="fu">c</span>(<span class="dv">0</span>,<span class="dv">1</span>),</span>
+<span id="cb24-8"><a href="#cb24-8" aria-hidden="true" tabindex="-1"></a>      <span class="at">xlab =</span> <span class="st">&quot;proportion&quot;</span>, <span class="at">ylab =</span> <span class="st">&quot;transformed proportion&quot;</span>)</span>
+<span id="cb24-9"><a href="#cb24-9" aria-hidden="true" tabindex="-1"></a><span class="fu">addSegs</span>(<span class="at">p1 =</span> <span class="fl">0.50</span>, <span class="at">p2 =</span> <span class="fl">0.55</span>) <span class="co"># 50% vs 55%</span></span>
+<span id="cb24-10"><a href="#cb24-10" aria-hidden="true" tabindex="-1"></a><span class="fu">addSegs</span>(<span class="at">p1 =</span> <span class="fl">0.05</span>, <span class="at">p2 =</span> <span class="fl">0.10</span>) <span class="co"># 5% vs 10%</span></span></code></pre></div>
+<p><img src="" /><!-- --></p>
+<p>The differences on the x-axis between the two pairs of proportions is
+the same (0.05), but the difference is larger for 5% vs 10% on the
+y-axis. The <code>ES.h</code> function returns the distance between the
+red lines.</p>
+<p>Base R has a function called <code>power.prop.test</code> that allows
+us to use the raw proportions in the function without a need for a
+separate effect size function.</p>
+<div class="sourceCode" id="cb25"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb25-1"><a href="#cb25-1" aria-hidden="true" tabindex="-1"></a><span class="fu">power.prop.test</span>(<span class="at">p1 =</span> <span class="fl">0.55</span>, <span class="at">p2 =</span> <span class="fl">0.50</span>, <span class="at">sig.level =</span> <span class="fl">0.05</span>, <span class="at">power =</span> .<span class="dv">80</span>)</span></code></pre></div>
+<pre><code>## 
+##      Two-sample comparison of proportions power calculation 
+## 
+##               n = 1564.672
+##              p1 = 0.55
+##              p2 = 0.5
+##       sig.level = 0.05
+##           power = 0.8
+##     alternative = two.sided
+## 
+## NOTE: n is number in *each* group</code></pre>
+<p>Notice the results are slightly different. It calculates effect size
+differently.</p>
+<p>If we don’t have any preconceived estimates of proportions or don’t
+feel comfortable making estimates, we can use conventional effect sizes
+of 0.2 (small), 0.5 (medium), or 0.8 (large). The sample size per group
+needed to detect a “small” effect with 80% power and 0.05 significance
+is about 393:</p>
+<div class="sourceCode" id="cb27"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb27-1"><a href="#cb27-1" aria-hidden="true" tabindex="-1"></a><span class="fu">pwr.2p.test</span>(<span class="at">h =</span> <span class="fl">0.2</span>, <span class="at">sig.level =</span> <span class="fl">0.05</span>, <span class="at">power =</span> .<span class="dv">80</span>)</span></code></pre></div>
+<pre><code>## 
+##      Difference of proportion power calculation for binomial distribution (arcsine transformation) 
+## 
+##               h = 0.2
+##               n = 392.443
+##       sig.level = 0.05
+##           power = 0.8
+##     alternative = two.sided
+## 
+## NOTE: same sample sizes</code></pre>
+</div>
+<div id="pwr.2p2n.test---two-sample-test-for-proportions-unequal-sample-sizes" class="section level3">
+<h3>pwr.2p2n.test - two-sample test for proportions, unequal sample
+sizes</h3>
+<p>Let’s return to our undergraduate survey of alcohol consumption. It
+turns out we were able to survey 543 males and 675 females. The power of
+our test if we’re interested in being able to detect a “small” effect
+size with 0.05 significance is about 93%.</p>
+<div class="sourceCode" id="cb29"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb29-1"><a href="#cb29-1" aria-hidden="true" tabindex="-1"></a><span class="fu">cohen.ES</span>(<span class="at">test =</span> <span class="st">&quot;p&quot;</span>, <span class="at">size =</span> <span class="st">&quot;small&quot;</span>)</span></code></pre></div>
+<pre><code>## 
+##      Conventional effect size from Cohen (1982) 
+## 
+##            test = p
+##            size = small
+##     effect.size = 0.2</code></pre>
+<div class="sourceCode" id="cb31"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb31-1"><a href="#cb31-1" aria-hidden="true" tabindex="-1"></a><span class="fu">pwr.2p2n.test</span>(<span class="at">h =</span> <span class="fl">0.2</span>, <span class="at">n1 =</span> <span class="dv">543</span>, <span class="at">n2 =</span> <span class="dv">675</span>, <span class="at">sig.level =</span> <span class="fl">0.05</span>)</span></code></pre></div>
+<pre><code>## 
+##      difference of proportion power calculation for binomial distribution (arcsine transformation) 
+## 
+##               h = 0.2
+##              n1 = 543
+##              n2 = 675
+##       sig.level = 0.05
+##           power = 0.9344102
+##     alternative = two.sided
+## 
+## NOTE: different sample sizes</code></pre>
+<p>Let’s say we previously surveyed 763 female undergraduates and found
+that <em>p</em>% said they consumed alcohol once a week. We would like
+to survey some males and see if a significantly different proportion
+respond yes. How many do I need to sample to detect a small effect size
+(0.2) in either direction with 80% power and a significance level of
+0.05?</p>
+<div class="sourceCode" id="cb33"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb33-1"><a href="#cb33-1" aria-hidden="true" tabindex="-1"></a><span class="fu">pwr.2p2n.test</span>(<span class="at">h =</span> <span class="fl">0.2</span>, <span class="at">n1 =</span> <span class="dv">763</span>, <span class="at">power =</span> <span class="fl">0.8</span>, <span class="at">sig.level =</span> <span class="fl">0.05</span>)</span></code></pre></div>
+<pre><code>## 
+##      difference of proportion power calculation for binomial distribution (arcsine transformation) 
+## 
+##               h = 0.2
+##              n1 = 763
+##              n2 = 264.1544
+##       sig.level = 0.05
+##           power = 0.8
+##     alternative = two.sided
+## 
+## NOTE: different sample sizes</code></pre>
+<p>About 265.</p>
+</div>
+<div id="pwr.t.test---one-sample-and-two-sample-t-tests-for-means" class="section level3">
+<h3>pwr.t.test - one-sample and two-sample t tests for means</h3>
+<p>We’re interested to know if there is a difference in the mean price
+of what male and female students pay at a library coffee shop. Let’s say
+we randomly observe 30 male and 30 female students check out from the
+coffee shop and calculate the mean purchase price for each gender. We’ll
+test for a difference in means using a two-sample t-test. How powerful
+is this experiment if we want to detect a “medium” effect in either
+direction with a significance level of 0.05?</p>
+<div class="sourceCode" id="cb35"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb35-1"><a href="#cb35-1" aria-hidden="true" tabindex="-1"></a><span class="fu">cohen.ES</span>(<span class="at">test =</span> <span class="st">&quot;t&quot;</span>, <span class="at">size =</span> <span class="st">&quot;medium&quot;</span>)</span></code></pre></div>
+<pre><code>## 
+##      Conventional effect size from Cohen (1982) 
+## 
+##            test = t
+##            size = medium
+##     effect.size = 0.5</code></pre>
+<div class="sourceCode" id="cb37"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb37-1"><a href="#cb37-1" aria-hidden="true" tabindex="-1"></a><span class="fu">pwr.t.test</span>(<span class="at">n =</span> <span class="dv">30</span>, <span class="at">d =</span> <span class="fl">0.5</span>, <span class="at">sig.level =</span> <span class="fl">0.05</span>)</span></code></pre></div>
+<pre><code>## 
+##      Two-sample t test power calculation 
+## 
+##               n = 30
+##               d = 0.5
+##       sig.level = 0.05
+##           power = 0.4778965
+##     alternative = two.sided
+## 
+## NOTE: n is number in *each* group</code></pre>
+<p>Only 48%. Not very powerful. How many students should we observe for
+a test with 80% power?</p>
+<div class="sourceCode" id="cb39"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb39-1"><a href="#cb39-1" aria-hidden="true" tabindex="-1"></a><span class="fu">pwr.t.test</span>(<span class="at">d =</span> <span class="fl">0.5</span>, <span class="at">power =</span> <span class="fl">0.80</span>, <span class="at">sig.level =</span> <span class="fl">0.05</span>)</span></code></pre></div>
+<pre><code>## 
+##      Two-sample t test power calculation 
+## 
+##               n = 63.76561
+##               d = 0.5
+##       sig.level = 0.05
+##           power = 0.8
+##     alternative = two.sided
+## 
+## NOTE: n is number in *each* group</code></pre>
+<p>About 64 per group.</p>
+<p>Let’s say we want to be able to detect a difference of at least 75
+cents in the mean purchase price. We need to convert that to an effect
+size using the following formula:</p>
+<p><span class="math display">\[d = \frac{m_{1} - m_{2}}{\sigma}
+\]</span></p>
+<p>where <span class="math inline">\(m_{1}\)</span> and <span class="math inline">\(m_{2}\)</span> are the means of each group,
+respectively, and <span class="math inline">\(\sigma\)</span> is the
+common standard deviation of the two groups. Again, the label <em>d</em>
+is due to Cohen (1988).</p>
+<p>We have <span class="math inline">\(m_{1} - m_{2} =\)</span> 0.75. We
+need to make a guess at the population standard deviation. If we have
+absolutely no idea, one rule of thumb is to take the difference between
+the maximum and minimum values and divide by 4. Let’s say the maximum
+purchase is $10 and the minimum purchase is $1. Our estimated standard
+deviation is (10 - 1)/4 = 2.25. Therefore our effect size is 0.75/2.25
+<span class="math inline">\(\approx\)</span> 0.333.</p>
+<div class="sourceCode" id="cb41"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb41-1"><a href="#cb41-1" aria-hidden="true" tabindex="-1"></a>d <span class="ot">&lt;-</span> <span class="fl">0.75</span><span class="sc">/</span><span class="fl">2.25</span></span>
+<span id="cb41-2"><a href="#cb41-2" aria-hidden="true" tabindex="-1"></a><span class="fu">pwr.t.test</span>(<span class="at">d =</span> d, <span class="at">power =</span> <span class="fl">0.80</span>, <span class="at">sig.level =</span> <span class="fl">0.05</span>)</span></code></pre></div>
+<pre><code>## 
+##      Two-sample t test power calculation 
+## 
+##               n = 142.2462
+##               d = 0.3333333
+##       sig.level = 0.05
+##           power = 0.8
+##     alternative = two.sided
+## 
+## NOTE: n is number in *each* group</code></pre>
+<p>For a desired power of 80%, Type I error tolerance of 0.05, and a
+hypothesized effect size of 0.333, we should sample at least 143 per
+group.</p>
+<p>Performing the same analysis with the base R function
+<code>power.t.test</code> is a little easier. The difference <span class="math inline">\(m_{1} - m_{2} =\)</span> 0.75 is entered in the
+<code>delta</code> argument and the estimated <span class="math inline">\(\sigma\)</span> = 2.25 is entered in the
+<code>sd</code> argument:</p>
+<div class="sourceCode" id="cb43"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb43-1"><a href="#cb43-1" aria-hidden="true" tabindex="-1"></a><span class="fu">power.t.test</span>(<span class="at">delta =</span> <span class="fl">0.75</span>, <span class="at">sd =</span> <span class="fl">2.25</span>, <span class="at">sig.level =</span> <span class="fl">0.05</span>, <span class="at">power =</span> <span class="fl">0.8</span>)</span></code></pre></div>
+<pre><code>## 
+##      Two-sample t test power calculation 
+## 
+##               n = 142.2466
+##           delta = 0.75
+##              sd = 2.25
+##       sig.level = 0.05
+##           power = 0.8
+##     alternative = two.sided
+## 
+## NOTE: n is number in *each* group</code></pre>
+<p>To calculate power and sample size for one-sample t-tests, we need to
+set the <code>type</code> argument to <code>&quot;one.sample&quot;</code>. By
+default it is set to <code>&quot;two.sample&quot;</code>.</p>
+<p>For example, we think the average purchase price at the Library
+coffee shop is over $3 per student. Our null is $3 or less; our
+alternative is greater than $3. We can use a one-sample t-test to
+investigate this hunch. If the true average purchase price is $3.50, we
+would like to have 90% power to declare the estimated average purchase
+price is greater than $3. How many transactions do we need to observe
+assuming a significance level of 0.05? Let’s say the maximum purchase
+price is $10 and the minimum is $1. So our guess at a standard deviation
+is 9/4 = 2.25.</p>
+<div class="sourceCode" id="cb45"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb45-1"><a href="#cb45-1" aria-hidden="true" tabindex="-1"></a>d <span class="ot">&lt;-</span> <span class="fl">0.50</span><span class="sc">/</span><span class="fl">2.25</span></span>
+<span id="cb45-2"><a href="#cb45-2" aria-hidden="true" tabindex="-1"></a><span class="fu">pwr.t.test</span>(<span class="at">d =</span> d, <span class="at">sig.level =</span> <span class="fl">0.05</span>, <span class="at">power =</span> <span class="fl">0.90</span>, <span class="at">alternative =</span> <span class="st">&quot;greater&quot;</span>,</span>
+<span id="cb45-3"><a href="#cb45-3" aria-hidden="true" tabindex="-1"></a>           <span class="at">type =</span> <span class="st">&quot;one.sample&quot;</span>)</span></code></pre></div>
+<pre><code>## 
+##      One-sample t test power calculation 
+## 
+##               n = 174.7796
+##               d = 0.2222222
+##       sig.level = 0.05
+##           power = 0.9
+##     alternative = greater</code></pre>
+<p>We should plan on observing at least 175 transactions.</p>
+<p>To use the <code>power.t.test</code> function, set
+<code>type = &quot;one.sample&quot;</code> and
+<code>alternative = &quot;one.sided&quot;</code>:</p>
+<div class="sourceCode" id="cb47"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb47-1"><a href="#cb47-1" aria-hidden="true" tabindex="-1"></a><span class="fu">power.t.test</span>(<span class="at">delta =</span> <span class="fl">0.50</span>, <span class="at">sd =</span> <span class="fl">2.25</span>, <span class="at">power =</span> <span class="fl">0.90</span>, <span class="at">sig.level =</span> <span class="fl">0.05</span>,</span>
+<span id="cb47-2"><a href="#cb47-2" aria-hidden="true" tabindex="-1"></a>             <span class="at">alternative =</span> <span class="st">&quot;one.sided&quot;</span>, <span class="at">type =</span> <span class="st">&quot;one.sample&quot;</span>)</span></code></pre></div>
+<pre><code>## 
+##      One-sample t test power calculation 
+## 
+##               n = 174.7796
+##           delta = 0.5
+##              sd = 2.25
+##       sig.level = 0.05
+##           power = 0.9
+##     alternative = one.sided</code></pre>
+<p>“Paired” t-tests are basically the same as one-sample t-tests, except
+our one sample is usually differences in pairs. The following example
+should make this clear.</p>
+<p>(<em>From Hogg &amp; Tanis, exercise 6.5-12</em>) 24 high school boys
+are put on a ultra-heavy rope-jumping program. Does this decrease their
+40-yard dash time (i.e., make them faster)? We’ll measure their 40 time
+in seconds before the program and after. We’ll use a paired t-test to
+see if the difference in times is greater than 0 (before - after).
+Assume the standard deviation of the differences will be about 0.25
+seconds. How powerful is the test to detect a difference of about 0.08
+seconds with 0.05 significance?</p>
+<p>Notice we set <code>type = &quot;paired&quot;</code>:</p>
+<div class="sourceCode" id="cb49"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb49-1"><a href="#cb49-1" aria-hidden="true" tabindex="-1"></a><span class="fu">pwr.t.test</span>(<span class="at">n =</span> <span class="dv">24</span>, <span class="at">d =</span> <span class="fl">0.08</span> <span class="sc">/</span> <span class="fl">0.25</span>,</span>
+<span id="cb49-2"><a href="#cb49-2" aria-hidden="true" tabindex="-1"></a>           <span class="at">type =</span> <span class="st">&quot;paired&quot;</span>, <span class="at">alternative =</span> <span class="st">&quot;greater&quot;</span>)</span></code></pre></div>
+<pre><code>## 
+##      Paired t test power calculation 
+## 
+##               n = 24
+##               d = 0.32
+##       sig.level = 0.05
+##           power = 0.4508691
+##     alternative = greater
+## 
+## NOTE: n is number of *pairs*</code></pre>
+<p>Only 45%. Not all that powerful. How many high school boys should we
+sample for 80% power?</p>
+<div class="sourceCode" id="cb51"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb51-1"><a href="#cb51-1" aria-hidden="true" tabindex="-1"></a><span class="fu">pwr.t.test</span>(<span class="at">d =</span> <span class="fl">0.08</span> <span class="sc">/</span> <span class="fl">0.25</span>, <span class="at">power =</span> <span class="fl">0.8</span>,</span>
+<span id="cb51-2"><a href="#cb51-2" aria-hidden="true" tabindex="-1"></a>           <span class="at">type =</span> <span class="st">&quot;paired&quot;</span>, <span class="at">alternative =</span> <span class="st">&quot;greater&quot;</span>)</span></code></pre></div>
+<pre><code>## 
+##      Paired t test power calculation 
+## 
+##               n = 61.75209
+##               d = 0.32
+##       sig.level = 0.05
+##           power = 0.8
+##     alternative = greater
+## 
+## NOTE: n is number of *pairs*</code></pre>
+<p>About 62.</p>
+<p>For paired t-tests we sometimes estimate a standard deviation for
+<em>within</em> pairs instead of for the difference in pairs. In our
+example, this would mean an estimated standard deviation for each boy’s
+40-yard dash times. When dealing with this type of estimated standard
+deviation we need to multiply it by <span class="math inline">\(\sqrt{2}\)</span> in the <code>pwr.t.test</code>
+function. Let’s say we estimate the standard deviation of each boy’s
+40-yard dash time to be about 0.10 seconds. The sample size needed to
+detect a difference of 0.08 seconds is now calculated as follows:</p>
+<div class="sourceCode" id="cb53"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb53-1"><a href="#cb53-1" aria-hidden="true" tabindex="-1"></a><span class="fu">pwr.t.test</span>(<span class="at">d =</span> <span class="fl">0.08</span> <span class="sc">/</span> (<span class="fl">0.1</span> <span class="sc">*</span> <span class="fu">sqrt</span>(<span class="dv">2</span>)), <span class="at">power =</span> <span class="fl">0.8</span>,</span>
+<span id="cb53-2"><a href="#cb53-2" aria-hidden="true" tabindex="-1"></a>           <span class="at">type =</span> <span class="st">&quot;paired&quot;</span>, <span class="at">alternative =</span> <span class="st">&quot;greater&quot;</span>)</span></code></pre></div>
+<pre><code>## 
+##      Paired t test power calculation 
+## 
+##               n = 20.74232
+##               d = 0.5656854
+##       sig.level = 0.05
+##           power = 0.8
+##     alternative = greater
+## 
+## NOTE: n is number of *pairs*</code></pre>
+<p>We need to sample at least 21 students.</p>
+</div>
+<div id="pwr.t2n.test---two-sample-t-test-for-means-unequal-sample-sizes" class="section level3">
+<h3>pwr.t2n.test - two-sample t test for means, unequal sample
+sizes</h3>
+<p>Find power for a two-sample t-test with 28 in one group and 35 in the
+other group and a medium effect size. (sig.level defaults to 0.05.)</p>
+<div class="sourceCode" id="cb55"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb55-1"><a href="#cb55-1" aria-hidden="true" tabindex="-1"></a><span class="fu">pwr.t2n.test</span>(<span class="at">n1 =</span> <span class="dv">28</span>, <span class="at">n2 =</span> <span class="dv">35</span>, <span class="at">d =</span> <span class="fl">0.5</span>)</span></code></pre></div>
+<pre><code>## 
+##      t test power calculation 
+## 
+##              n1 = 28
+##              n2 = 35
+##               d = 0.5
+##       sig.level = 0.05
+##           power = 0.4924588
+##     alternative = two.sided</code></pre>
+</div>
+<div id="pwr.chisq.test---goodness-of-fit-test" class="section level3">
+<h3>pwr.chisq.test - Goodness of fit test</h3>
+<p>(<em>From Cohen, example 7.1</em>) A market researcher is seeking to
+determine preference among 4 package designs. He arranges to have a
+panel of 100 consumers rate their favorite package design. He wants to
+perform a chi-square goodness of fit test against the null of equal
+preference (25% for each design) with a significance level of 0.05.
+What’s the power of the test if 3/8 of the population actually prefers
+one of the designs and the remaining 5/8 are split over the other 3
+designs?</p>
+<p>We use the <code>ES.w1</code> function to calculate effect size. To
+do so, we need to create vectors of null and alternative
+proportions:</p>
+<div class="sourceCode" id="cb57"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb57-1"><a href="#cb57-1" aria-hidden="true" tabindex="-1"></a>null <span class="ot">&lt;-</span> <span class="fu">rep</span>(<span class="fl">0.25</span>, <span class="dv">4</span>)</span>
+<span id="cb57-2"><a href="#cb57-2" aria-hidden="true" tabindex="-1"></a>alt <span class="ot">&lt;-</span> <span class="fu">c</span>(<span class="dv">3</span><span class="sc">/</span><span class="dv">8</span>, <span class="fu">rep</span>((<span class="dv">5</span><span class="sc">/</span><span class="dv">8</span>)<span class="sc">/</span><span class="dv">3</span>, <span class="dv">3</span>))</span>
+<span id="cb57-3"><a href="#cb57-3" aria-hidden="true" tabindex="-1"></a><span class="fu">ES.w1</span>(null,alt)</span></code></pre></div>
+<pre><code>## [1] 0.2886751</code></pre>
+<p>To calculate power, specify effect size (<code>w</code>), sample size
+(<code>N</code>), and degrees of freedom, which is the number of
+categories minus 1 (<code>df</code> = 4 - 1).</p>
+<div class="sourceCode" id="cb59"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb59-1"><a href="#cb59-1" aria-hidden="true" tabindex="-1"></a><span class="fu">pwr.chisq.test</span>(<span class="at">w=</span><span class="fu">ES.w1</span>(null,alt), <span class="at">N=</span><span class="dv">100</span>, <span class="at">df=</span>(<span class="dv">4-1</span>), <span class="at">sig.level=</span><span class="fl">0.05</span>)</span></code></pre></div>
+<pre><code>## 
+##      Chi squared power calculation 
+## 
+##               w = 0.2886751
+##               N = 100
+##              df = 3
+##       sig.level = 0.05
+##           power = 0.6739834
+## 
+## NOTE: N is the number of observations</code></pre>
+<p>If our estimated effect size is correct, we only have about a 67%
+chance of finding it (i.e., rejecting the null hypothesis of equal
+preference).</p>
+<p>How many subjects do we need to achieve 80% power?</p>
+<div class="sourceCode" id="cb61"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb61-1"><a href="#cb61-1" aria-hidden="true" tabindex="-1"></a><span class="fu">pwr.chisq.test</span>(<span class="at">w=</span><span class="fu">ES.w1</span>(null,alt), <span class="at">df=</span>(<span class="dv">4-1</span>), <span class="at">power=</span><span class="fl">0.8</span>, <span class="at">sig.level =</span> <span class="fl">0.05</span>)</span></code></pre></div>
+<pre><code>## 
+##      Chi squared power calculation 
+## 
+##               w = 0.2886751
+##               N = 130.8308
+##              df = 3
+##       sig.level = 0.05
+##           power = 0.8
+## 
+## NOTE: N is the number of observations</code></pre>
+<p>If our alternative hypothesis is correct then we need to survey at
+least 131 people to detect it with 80% power.</p>
+</div>
+<div id="pwr.chisq.test---test-of-association" class="section level3">
+<h3>pwr.chisq.test - test of association</h3>
+<p>We want to see if there’s an association between gender and flossing
+teeth among college students. We randomly sample 100 students (male and
+female) and ask whether or not they floss daily. We want to carry out a
+chi-square test of association to determine if there’s an association
+between these two variables. We set our significance level to 0.01. To
+determine effect size we need to propose an alternative hypothesis,
+which in this case is a table of proportions. We propose the
+following:</p>
+<table>
+<thead>
+<tr class="header">
+<th>gender</th>
+<th>Floss</th>
+<th>No Floss</th>
+</tr>
+</thead>
+<tbody>
+<tr class="odd">
+<td>Male</td>
+<td>0.1</td>
+<td>0.4</td>
+</tr>
+<tr class="even">
+<td>Female</td>
+<td>0.2</td>
+<td>0.3</td>
+</tr>
+</tbody>
+</table>
+<p>We use the <code>ES.w2</code> function to calculate effect size for
+chi-square tests of association</p>
+<div class="sourceCode" id="cb63"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb63-1"><a href="#cb63-1" aria-hidden="true" tabindex="-1"></a>prob <span class="ot">&lt;-</span> <span class="fu">matrix</span>(<span class="fu">c</span>(<span class="fl">0.1</span>,<span class="fl">0.2</span>,<span class="fl">0.4</span>,<span class="fl">0.3</span>), <span class="at">ncol=</span><span class="dv">2</span>,</span>
+<span id="cb63-2"><a href="#cb63-2" aria-hidden="true" tabindex="-1"></a>               <span class="at">dimnames =</span> <span class="fu">list</span>(<span class="fu">c</span>(<span class="st">&quot;M&quot;</span>,<span class="st">&quot;F&quot;</span>),<span class="fu">c</span>(<span class="st">&quot;Floss&quot;</span>,<span class="st">&quot;No Floss&quot;</span>)))</span>
+<span id="cb63-3"><a href="#cb63-3" aria-hidden="true" tabindex="-1"></a>prob</span></code></pre></div>
+<pre><code>##   Floss No Floss
+## M   0.1      0.4
+## F   0.2      0.3</code></pre>
+<p>This says we sample even proportions of male and females, but believe
+10% more females floss.</p>
+<p>Now use the matrix to calculate effect size:</p>
+<div class="sourceCode" id="cb65"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb65-1"><a href="#cb65-1" aria-hidden="true" tabindex="-1"></a><span class="fu">ES.w2</span>(prob)</span></code></pre></div>
+<pre><code>## [1] 0.2182179</code></pre>
+<p>We also need degrees of freedom. <code>df</code> = (2 - 1) * (2 - 1)
+= 1</p>
+<p>And now to calculate power:</p>
+<div class="sourceCode" id="cb67"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb67-1"><a href="#cb67-1" aria-hidden="true" tabindex="-1"></a><span class="fu">pwr.chisq.test</span>(<span class="at">w =</span> <span class="fu">ES.w2</span>(prob), <span class="at">N =</span> <span class="dv">100</span>, <span class="at">df =</span> <span class="dv">1</span>, <span class="at">sig.level =</span> <span class="fl">0.01</span>)</span></code></pre></div>
+<pre><code>## 
+##      Chi squared power calculation 
+## 
+##               w = 0.2182179
+##               N = 100
+##              df = 1
+##       sig.level = 0.01
+##           power = 0.3469206
+## 
+## NOTE: N is the number of observations</code></pre>
+<p>At only 35% this is not a very powerful experiment. How many students
+should I survey if I wish to achieve 90% power?</p>
+<div class="sourceCode" id="cb69"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb69-1"><a href="#cb69-1" aria-hidden="true" tabindex="-1"></a><span class="fu">pwr.chisq.test</span>(<span class="at">w =</span> <span class="fu">ES.w2</span>(prob), <span class="at">power =</span> <span class="fl">0.9</span>, <span class="at">df =</span> <span class="dv">1</span>, <span class="at">sig.level =</span> <span class="fl">0.01</span>)</span></code></pre></div>
+<pre><code>## 
+##      Chi squared power calculation 
+## 
+##               w = 0.2182179
+##               N = 312.4671
+##              df = 1
+##       sig.level = 0.01
+##           power = 0.9
+## 
+## NOTE: N is the number of observations</code></pre>
+<p>About 313.</p>
+<p>If you don’t suspect association in either direction, or you don’t
+feel like building a matrix in R, you can try a conventional effect
+size. For example, how many students should we sample to detect a small
+effect?</p>
+<div class="sourceCode" id="cb71"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb71-1"><a href="#cb71-1" aria-hidden="true" tabindex="-1"></a><span class="fu">cohen.ES</span>(<span class="at">test =</span> <span class="st">&quot;chisq&quot;</span>, <span class="at">size =</span> <span class="st">&quot;small&quot;</span>)</span></code></pre></div>
+<pre><code>## 
+##      Conventional effect size from Cohen (1982) 
+## 
+##            test = chisq
+##            size = small
+##     effect.size = 0.1</code></pre>
+<div class="sourceCode" id="cb73"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb73-1"><a href="#cb73-1" aria-hidden="true" tabindex="-1"></a><span class="fu">pwr.chisq.test</span>(<span class="at">w =</span> <span class="fl">0.1</span>, <span class="at">power =</span> <span class="fl">0.9</span>, <span class="at">df =</span> <span class="dv">1</span>, <span class="at">sig.level =</span> <span class="fl">0.01</span>)</span></code></pre></div>
+<pre><code>## 
+##      Chi squared power calculation 
+## 
+##               w = 0.1
+##               N = 1487.939
+##              df = 1
+##       sig.level = 0.01
+##           power = 0.9
+## 
+## NOTE: N is the number of observations</code></pre>
+<p>1,488 students. Perhaps more than we thought we might need.</p>
+<p>We could consider reframing the question as a two-sample proportion
+test. What sample size do we need to detect a “small” effect in gender
+on the proportion of students who floss with 90% power and a
+significance level of 0.01?</p>
+<div class="sourceCode" id="cb75"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb75-1"><a href="#cb75-1" aria-hidden="true" tabindex="-1"></a><span class="fu">pwr.2p.test</span>(<span class="at">h =</span> <span class="fl">0.2</span>, <span class="at">sig.level =</span> <span class="fl">0.01</span>, <span class="at">power =</span> <span class="fl">0.9</span>)</span></code></pre></div>
+<pre><code>## 
+##      Difference of proportion power calculation for binomial distribution (arcsine transformation) 
+## 
+##               h = 0.2
+##               n = 743.9694
+##       sig.level = 0.01
+##           power = 0.9
+##     alternative = two.sided
+## 
+## NOTE: same sample sizes</code></pre>
+<p>About 744 per group. Notice that 744 <span class="math inline">\(\times\)</span> 2 = 1,488, the sample size
+returned previously by <code>pwr.chisq.test</code>. In fact the test
+statistic for a two-sample proportion test and chi-square test of
+association are one and the same.</p>
+</div>
+<div id="pwr.r.test---correlation-test" class="section level3">
+<h3>pwr.r.test - correlation test</h3>
+<p>(<em>From Hogg &amp; Tanis, exercise 8.9-12</em>) A graduate student
+is investigating the effectiveness of a fitness program. She wants to
+see if there is a correlation between the weight of a participant at the
+beginning of the program and the participant’s weight change after 6
+months. She suspects there is a “small” positive linear relationship
+between these two quantities. She will measure this relationship with
+correlation, <em>r</em>, and conduct a correlation test to determine if
+the estimated correlation is statistically greater than 0. How many
+subjects does she need to sample to detect this small positive (i.e.,
+<em>r</em> &gt; 0) relationship with 80% power and 0.01 significance
+level?</p>
+<p>There is nothing tricky about the effect size argument,
+<code>r</code>. It is simply the hypothesized correlation. It can take
+values ranging from -1 to 1.</p>
+<div class="sourceCode" id="cb77"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb77-1"><a href="#cb77-1" aria-hidden="true" tabindex="-1"></a><span class="fu">cohen.ES</span>(<span class="at">test =</span> <span class="st">&quot;r&quot;</span>, <span class="at">size =</span> <span class="st">&quot;small&quot;</span>)</span></code></pre></div>
+<pre><code>## 
+##      Conventional effect size from Cohen (1982) 
+## 
+##            test = r
+##            size = small
+##     effect.size = 0.1</code></pre>
+<div class="sourceCode" id="cb79"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb79-1"><a href="#cb79-1" aria-hidden="true" tabindex="-1"></a><span class="fu">pwr.r.test</span>(<span class="at">r =</span> <span class="fl">0.1</span>, <span class="at">sig.level =</span> <span class="fl">0.01</span>, <span class="at">power =</span> <span class="fl">0.8</span>, <span class="at">alternative =</span> <span class="st">&quot;greater&quot;</span>)</span></code></pre></div>
+<pre><code>## 
+##      approximate correlation power calculation (arctangh transformation) 
+## 
+##               n = 999.2054
+##               r = 0.1
+##       sig.level = 0.01
+##           power = 0.8
+##     alternative = greater</code></pre>
+<p>She needs to observe about a 1000 students.</p>
+<p>The default is a two-sided test. We specify
+<code>alternative = &quot;greater&quot;</code> since we believe there is small
+positive effect.</p>
+<p>If she just wants to detect a small effect in either direction
+(positive or negative correlation), use the default settings of
+“two.sided”, which we can do by removing the <code>alternative</code>
+argument from the function.</p>
+<div class="sourceCode" id="cb81"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb81-1"><a href="#cb81-1" aria-hidden="true" tabindex="-1"></a><span class="fu">pwr.r.test</span>(<span class="at">r =</span> <span class="fl">0.1</span>, <span class="at">sig.level =</span> <span class="fl">0.01</span>, <span class="at">power =</span> <span class="fl">0.8</span>)</span></code></pre></div>
+<pre><code>## 
+##      approximate correlation power calculation (arctangh transformation) 
+## 
+##               n = 1162.564
+##               r = 0.1
+##       sig.level = 0.01
+##           power = 0.8
+##     alternative = two.sided</code></pre>
+<p>Now she needs to observe 1163 students. Detecting small effects
+requires large sample sizes.</p>
+</div>
+<div id="pwr.anova.test---balanced-one-way-analysis-of-variance-tests" class="section level3">
+<h3>pwr.anova.test - balanced one-way analysis of variance tests</h3>
+<p>(<em>From Hogg &amp; Tanis, exercise 8.7-11</em>) The driver of a
+diesel-powered car decides to test the quality of three types of fuel
+sold in his area based on the miles per gallon (mpg) his car gets on
+each fuel. He will use a balanced one-way ANOVA to test the null that
+the mean mpg is the same for each fuel versus the alternative that the
+means are different. (“balanced” means equal sample size in each group;
+“one-way” means one grouping variable.) How many times does he need to
+try each fuel to have 90% power to detect a “medium” effect with a
+significance of 0.01?</p>
+<p>We use <code>cohen.ES</code> to get learn the “medium” effect value
+is 0.25. We put that in the <code>f</code> argument of
+<code>pwr.anova.test</code>. We also need to specify the number of
+groups using the <code>k</code> argument.</p>
+<div class="sourceCode" id="cb83"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb83-1"><a href="#cb83-1" aria-hidden="true" tabindex="-1"></a><span class="fu">cohen.ES</span>(<span class="at">test =</span> <span class="st">&quot;anov&quot;</span>, <span class="at">size =</span> <span class="st">&quot;medium&quot;</span>)</span></code></pre></div>
+<pre><code>## 
+##      Conventional effect size from Cohen (1982) 
+## 
+##            test = anov
+##            size = medium
+##     effect.size = 0.25</code></pre>
+<div class="sourceCode" id="cb85"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb85-1"><a href="#cb85-1" aria-hidden="true" tabindex="-1"></a><span class="fu">pwr.anova.test</span>(<span class="at">k =</span> <span class="dv">3</span>, <span class="at">f =</span> <span class="fl">0.25</span>, <span class="at">sig.level =</span> <span class="fl">0.01</span>, <span class="at">power =</span> <span class="fl">0.9</span>)</span></code></pre></div>
+<pre><code>## 
+##      Balanced one-way analysis of variance power calculation 
+## 
+##               k = 3
+##               n = 94.48714
+##               f = 0.25
+##       sig.level = 0.01
+##           power = 0.9
+## 
+## NOTE: n is number in each group</code></pre>
+<p>He would need to measure mpg 95 times for each type of fuel. His
+experiment may take a while to complete.</p>
+<p>The effect size <code>f</code> is calculated as follows:</p>
+<p><span class="math display">\[f =
+\frac{\sigma_{means}}{\sigma_{pop&#39;n}}\]</span></p>
+<p>where <span class="math inline">\(\sigma_{means}\)</span> is the
+standard deviation of the <em>k</em> means and <span class="math inline">\(\sigma_{pop&#39;n}\)</span> is the common standard
+deviation of the <em>k</em> groups. These two quantities are also known
+as the <em>between-group</em> and <em>within-group</em> standard
+deviations. If our driver suspects the between-group standard deviation
+is 5 mpg and the within-group standard deviation is 3 mpg,
+<code>f</code> = 5/3.</p>
+<div class="sourceCode" id="cb87"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb87-1"><a href="#cb87-1" aria-hidden="true" tabindex="-1"></a><span class="fu">pwr.anova.test</span>(<span class="at">k =</span> <span class="dv">3</span>, <span class="at">f =</span> <span class="dv">5</span><span class="sc">/</span><span class="dv">3</span>, <span class="at">sig.level =</span> <span class="fl">0.01</span>, <span class="at">power =</span> <span class="fl">0.9</span>)</span></code></pre></div>
+<pre><code>## 
+##      Balanced one-way analysis of variance power calculation 
+## 
+##               k = 3
+##               n = 3.842228
+##               f = 1.666667
+##       sig.level = 0.01
+##           power = 0.9
+## 
+## NOTE: n is number in each group</code></pre>
+<p>In this case he only needs to try each fuel 4 times. Clearly the
+hypothesized effect has important consequences in estimating an optimum
+effect size.</p>
+<p>We can also use the <code>power.anova.test</code> function that comes
+with base R. It requires between-group and within-group
+<em>variances</em>. To get the same result as
+<code>pwr.anova.test</code> we need to square the standard deviations to
+get variances and multiply the between-group variance by <span class="math inline">\(\frac{k}{k-1}\)</span>. This is because the effect
+size formula for the ANOVA test assumes the between-group variance has a
+denominator of <em>k</em> instead of <em>k - 1</em>.</p>
+<div class="sourceCode" id="cb89"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb89-1"><a href="#cb89-1" aria-hidden="true" tabindex="-1"></a><span class="fu">power.anova.test</span>(<span class="at">groups =</span> <span class="dv">3</span>,</span>
+<span id="cb89-2"><a href="#cb89-2" aria-hidden="true" tabindex="-1"></a>                 <span class="at">within.var =</span> <span class="dv">3</span><span class="sc">^</span><span class="dv">2</span>,</span>
+<span id="cb89-3"><a href="#cb89-3" aria-hidden="true" tabindex="-1"></a>                 <span class="at">between.var =</span> <span class="dv">5</span><span class="sc">^</span><span class="dv">2</span> <span class="sc">*</span> (<span class="dv">3</span><span class="sc">/</span><span class="dv">2</span>),</span>
+<span id="cb89-4"><a href="#cb89-4" aria-hidden="true" tabindex="-1"></a>                 <span class="at">sig.level =</span> <span class="fl">0.01</span>, <span class="at">power =</span> <span class="fl">0.90</span>)</span></code></pre></div>
+<pre><code>## 
+##      Balanced one-way analysis of variance power calculation 
+## 
+##          groups = 3
+##               n = 3.842225
+##     between.var = 37.5
+##      within.var = 9
+##       sig.level = 0.01
+##           power = 0.9
+## 
+## NOTE: n is number in each group</code></pre>
+</div>
+<div id="pwr.f2.test---test-for-the-general-linear-model" class="section level3">
+<h3>pwr.f2.test - test for the general linear model</h3>
+<p>(<em>From Kutner, et al, exercise 8.43</em>) A director of admissions
+at a university wants to determine how accurately students’ grade-point
+averages (gpa) at the end of their first year can be predicted or
+explained by SAT scores and high school class rank. A common approach to
+answering this kind of question is to model gpa as a function of SAT
+score and class rank. Or to put another way, we can perform a multiple
+regression with gpa as the dependent variable and SAT and class rank as
+independent variables.</p>
+<p>The null hypothesis is that none of the independent variables explain
+any of the variability in gpa. This would mean their regression
+coefficients are statistically indistinguishable from 0. The alternative
+is that at least one of the coefficients is not 0. This is tested with
+an F test. We can estimate power and sample size for this test using the
+<code>pwr.f2.test</code> function.</p>
+<p>The F test has numerator and denominator degrees of freedom. The
+numerator degrees of freedom, <code>u</code>, is the number of
+coefficients you’ll have in your model (minus the intercept). In our
+example, <code>u = 2</code>. The denominator degrees of freedom,
+<code>v</code>, is the number of error degrees of freedom: <span class="math inline">\(v = n - u - 1\)</span>. This implies <span class="math inline">\(n = v + u + 1\)</span>.</p>
+<p>The effect size, <code>f2</code>, is <span class="math inline">\(R^{2}/(1 - R^{2})\)</span>, where <span class="math inline">\(R^{2}\)</span> is the coefficient of
+determination, aka the “proportion of variance explained”. To determine
+effect size you hypothesize the proportion of variance your model
+explains, or the <span class="math inline">\(R^{2}\)</span>. For
+example, if I think my model explains 45% of the variance in my
+dependent variable, the effect size is 0.45/(1 - 0.45) <span class="math inline">\(\approx\)</span> 0.81.</p>
+<p>Returning to our example, let’s say the director of admissions
+hypothesizes his model explains about 30% of the variability in gpa. How
+large of a sample does he need to take to detect this effect with 80%
+power at a 0.001 significance level?</p>
+<div class="sourceCode" id="cb91"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb91-1"><a href="#cb91-1" aria-hidden="true" tabindex="-1"></a><span class="fu">pwr.f2.test</span>(<span class="at">u =</span> <span class="dv">2</span>, <span class="at">f2 =</span> <span class="fl">0.3</span><span class="sc">/</span>(<span class="dv">1</span> <span class="sc">-</span> <span class="fl">0.3</span>), <span class="at">sig.level =</span> <span class="fl">0.001</span>, <span class="at">power =</span> <span class="fl">0.8</span>)</span></code></pre></div>
+<pre><code>## 
+##      Multiple regression power calculation 
+## 
+##               u = 2
+##               v = 49.88971
+##              f2 = 0.4285714
+##       sig.level = 0.001
+##           power = 0.8</code></pre>
+<p>Recall <span class="math inline">\(n = v + u + 1\)</span>. Therefore
+he needs 50 + 2 + 1 = 53 student records.</p>
+<p>What is the power of the test with 40 subjects and a significance
+level of 0.01? Recall <span class="math inline">\(v = n - u -
+1\)</span>.</p>
+<div class="sourceCode" id="cb93"><pre class="sourceCode r"><code class="sourceCode r"><span id="cb93-1"><a href="#cb93-1" aria-hidden="true" tabindex="-1"></a><span class="fu">pwr.f2.test</span>(<span class="at">u =</span> <span class="dv">2</span>, <span class="at">v =</span> <span class="dv">40</span> <span class="sc">-</span> <span class="dv">2</span> <span class="sc">-</span> <span class="dv">1</span>, <span class="at">f2 =</span> <span class="fl">0.3</span><span class="sc">/</span>(<span class="dv">1</span> <span class="sc">-</span> <span class="fl">0.3</span>), <span class="at">sig.level =</span> <span class="fl">0.01</span>)</span></code></pre></div>
+<pre><code>## 
+##      Multiple regression power calculation 
+## 
+##               u = 2
+##               v = 37
+##              f2 = 0.4285714
+##       sig.level = 0.01
+##           power = 0.8406124</code></pre>
+<p>Power is about 84%.</p>
+</div>
+</div>
+<div id="references-and-further-reading" class="section level2">
+<h2>References and Further Reading</h2>
+<p>Cohen, J. (1988). <em>Statistical Power Analysis for the Behavioral
+Sciences (2nd ed.)</em>. LEA. Dalgaard, P. (2002). <em>Introductory
+Statistics with R</em>. Springer. (Ch. 2) Hogg, R and Tanis, E. (2006).
+<em>Probability and Statistical Inference (7th ed.)</em>. Pearson. (Ch.
+9) Kabacoff, R. (2011). <em>R in Action</em>. Manning. (Ch. 10) Kutner,
+et al. (2005). <em>Applied Linear Statistical Models</em>. McGraw-Hill.
+(Ch. 16) Ryan, T. (2013). <em>Sample Size Determination and Power</em>.
+Wiley.</p>
+<p>The <a href="https://CRAN.R-project.org/view=ClinicalTrials">CRAN
+Task View for Clinical Trial Design, Monitoring, and Analysis</a> lists
+various R packages that also perform sample size and power
+calculations.</p>
+</div>
+
+
+
+<!-- code folding -->
+
+
+<!-- dynamically load mathjax for compatibility with self-contained -->
+<script>
+  (function () {
+    var script = document.createElement("script");
+    script.type = "text/javascript";
+    script.src  = "https://mathjax.rstudio.com/latest/MathJax.js?config=TeX-AMS-MML_HTMLorMML";
+    document.getElementsByTagName("head")[0].appendChild(script);
+  })();
+</script>
+
+</body>
+</html>

Debdiff

[The following lists of changes regard files as different if they have different names, permissions or owners.]

Files in second set of .debs but not in first

-rw-r--r--  root/root   /usr/lib/R/site-library/pwr/doc/pwr-vignette.html

Control files: lines which differ (wdiff format)

  • Depends: r-base-core (>= 4.1.3.20220413-2~jan+lint1), 4.2.0-1~jan+unchanged1), r-api-4.0

More details

Full run details