This script just generates some basic summary statistics that are
used as input for power calculations using the Aranda et al. data
set
devtools::source_url("https://raw.githubusercontent.com/mjkeough/mjkeough.github.io/refs/heads/main/R/libraries.R")
aranda <- read.csv("../data/aranda.csv")
#Plot to check that linear relationship is reasonable as a model
plot(richness~precip, data=aranda)
# fit model in case residuals are wanted
reg<-lm(richness~precip, data=aranda)
For power, we want estimates of σx and
σy. The best estimates are the standard deviations
of precipitation and species richness. In the worked example, we’ve
decided that a 50% change in overall richness is an important effect to
detect. We need to translate this into an actual change in the response
variable, and there are several ways we could do it. We will calculate
the overall mean richness, and then hypothesise that the lowest
precipitation has richness 25% below this value, and the highest
precipitation sites have an increase of 25%. To get the effect, we just
need the mean(richness)
summarise(aranda,mean=mean(richness), sd=sd(richness))
summarise(aranda,mean=mean(precip), sd=sd(precip))
The values we want are:
To calculate a slope of interest, we’ll assume that the range in
precipitation is represented by the range in the existing data
(113-1492). We could have also obtained this information from other
sources.
LS0tCnRpdGxlOiAiUUsgQm94IDYuMTEiCm91dHB1dDoKICBodG1sX25vdGVib29rOgogICAgdGhlbWU6IGZsYXRseQotLS0KCmBgYHtyIHNldHVwLCBpbmNsdWRlPUZBTFNFfQprbml0cjo6b3B0c19jaHVuayRzZXQoZWNobyA9IFRSVUUpCmBgYAoKVGhpcyBzY3JpcHQganVzdCBnZW5lcmF0ZXMgc29tZSBiYXNpYyBzdW1tYXJ5IHN0YXRpc3RpY3MgdGhhdCBhcmUgdXNlZCBhcyBpbnB1dCBmb3IgcG93ZXIgY2FsY3VsYXRpb25zIHVzaW5nIHRoZSBBcmFuZGEgZXQgYWwuIGRhdGEgc2V0CgpgYGB7ciByZXN1bHRzPSdoaWRlJ30KZGV2dG9vbHM6OnNvdXJjZV91cmwoImh0dHBzOi8vcmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbS9tamtlb3VnaC9tamtlb3VnaC5naXRodWIuaW8vcmVmcy9oZWFkcy9tYWluL1IvbGlicmFyaWVzLlIiKQpgYGAKCmBgYHtyfQphcmFuZGEgPC0gcmVhZC5jc3YoIi4uL2RhdGEvYXJhbmRhLmNzdiIpCiNQbG90IHRvIGNoZWNrIHRoYXQgbGluZWFyIHJlbGF0aW9uc2hpcCBpcyByZWFzb25hYmxlIGFzIGEgbW9kZWwKcGxvdChyaWNobmVzc35wcmVjaXAsIGRhdGE9YXJhbmRhKQojIGZpdCBtb2RlbCBpbiBjYXNlIHJlc2lkdWFscyBhcmUgd2FudGVkCnJlZzwtbG0ocmljaG5lc3N+cHJlY2lwLCBkYXRhPWFyYW5kYSkKYGBgCgpGb3IgcG93ZXIsIHdlIHdhbnQgZXN0aW1hdGVzIG9mICrPgyp+eH4gYW5kICrPgyp+eX4uIFRoZSBiZXN0IGVzdGltYXRlcyBhcmUgdGhlIHN0YW5kYXJkIGRldmlhdGlvbnMgb2YgcHJlY2lwaXRhdGlvbiBhbmQgc3BlY2llcyByaWNobmVzcy4gSW4gdGhlIHdvcmtlZCBleGFtcGxlLCB3ZSd2ZSBkZWNpZGVkIHRoYXQgYSA1MCUgY2hhbmdlIGluIG92ZXJhbGwgcmljaG5lc3MgaXMgYW4gaW1wb3J0YW50IGVmZmVjdCB0byBkZXRlY3QuIFdlIG5lZWQgdG8gdHJhbnNsYXRlIHRoaXMgaW50byBhbiBhY3R1YWwgY2hhbmdlIGluIHRoZSByZXNwb25zZSB2YXJpYWJsZSwgYW5kIHRoZXJlIGFyZSBzZXZlcmFsIHdheXMgd2UgY291bGQgZG8gaXQuIFdlIHdpbGwgY2FsY3VsYXRlIHRoZSBvdmVyYWxsIG1lYW4gcmljaG5lc3MsIGFuZCB0aGVuIGh5cG90aGVzaXNlIHRoYXQgdGhlIGxvd2VzdCBwcmVjaXBpdGF0aW9uIGhhcyByaWNobmVzcyAyNSUgYmVsb3cgdGhpcyB2YWx1ZSwgYW5kIHRoZSBoaWdoZXN0IHByZWNpcGl0YXRpb24gc2l0ZXMgaGF2ZSBhbiBpbmNyZWFzZSBvZiAyNSUuIFRvIGdldCB0aGUgZWZmZWN0LCB3ZSBqdXN0IG5lZWQgdGhlIG1lYW4ocmljaG5lc3MpCgpgYGB7cn0Kc3VtbWFyaXNlKGFyYW5kYSxtZWFuPW1lYW4ocmljaG5lc3MpLCBzZD1zZChyaWNobmVzcykpCnN1bW1hcmlzZShhcmFuZGEsbWVhbj1tZWFuKHByZWNpcCksIHNkPXNkKHByZWNpcCkpCmBgYAoKVGhlIHZhbHVlcyB3ZSB3YW50IGFyZToKCi0gICAxMDggZm9yIHRoZSBjaGFuZ2UgaW4gc3BlY2llcyByaWNobmVzcyAoMjE2LzIpCgotICAgMTMyIGZvciBzfnl+CgotICAgNDMyIGZvciBzfnh+CgpUbyBjYWxjdWxhdGUgYSBzbG9wZSBvZiBpbnRlcmVzdCwgd2UnbGwgYXNzdW1lIHRoYXQgdGhlIHJhbmdlIGluIHByZWNpcGl0YXRpb24gaXMgcmVwcmVzZW50ZWQgYnkgdGhlIHJhbmdlIGluIHRoZSBleGlzdGluZyBkYXRhICgxMTMtMTQ5MikuIFdlIGNvdWxkIGhhdmUgYWxzbyBvYnRhaW5lZCB0aGlzIGluZm9ybWF0aW9uIGZyb20gb3RoZXIgc291cmNlcy4gICAK