Christensen et al. (1996) studied the relationships between coarse woody debris (CWD) and shoreline vegetation and lake development in a sample of 16 lakes in North America. The main variables of interest are the density of cabins (no. km−1), density of riparian trees (trees km−1), the basal area of riparian trees (m2 km−1), density of coarse woody debris (no. km−1), basal area of coarse woody debris (m2 km−1).

Coarse woody debris provides important habitat structure. Not quite a lake in Wisconsin, but World Heritage rainforest in northern Australia! Photo M. Keough
Coarse woody debris provides important habitat structure. Not quite a lake in Wisconsin, but World Heritage rainforest in northern Australia! Photo M. Keough

Coarse woody debris provides important habitat structure. Not quite a lake in Wisconsin, but World Heritage rainforest in northern Australia! Photo M. Keough

Christensen, D. L., Herwig, B. R., Schindler, D. E. & Carpenter, S. R. (1996). Impacts of lakeshore residential development on coarse woody debris in north temperate lakes. Ecological Applications, 6, 1143-49.

The original paper: https://doi.org/10.2307/2269598

This data set was used for the first edition, and is available here christ.csv

Preliminaries

First, load the required packages (car, lm.beta).

Import Christensen data (christ.csv)

christ <- read.csv("../data/christ.csv")
head(christ,10)
NA

CWD versus riparian density first

scatterplot(cwdbasal~ripdens, data=christ)

christ.lm <- lm(cwdbasal ~ ripdens, data=christ)

Check diagnostics

plot(christ.lm)

augment(christ.lm)

Examine model output

glance(christ.lm)
tidy(christ.lm, conf.int = TRUE)
anova(christ.lm)
Analysis of Variance Table

Response: cwdbasal
          Df Sum Sq Mean Sq F value    Pr(>F)    
ripdens    1  32054   32054  24.303 0.0002216 ***
Residuals 14  18466    1319                      
---
Signif. codes:  0 ‘***’ 0.001 ‘**’ 0.01 ‘*’ 0.05 ‘.’ 0.1 ‘ ’ 1

Get standardized coefficients

lm.beta(christ.lm)

Call:
lm(formula = cwdbasal ~ ripdens, data = christ)

Standardized Coefficients::
(Intercept)     ripdens 
         NA   0.7965489 

Predict new CWD values for riparian densities of 1000 and 2000 trees per km

predict(christ.lm, data.frame(ripdens=c(1500)), interval="prediction", se=T)
$fit
       fit      lwr     upr
1 96.17503 14.88709 177.463

$se.fit
[1] 10.83789

$df
[1] 14

$residual.scale
[1] 36.31761

Now CWD versus cabin density

scatterplot(cwdbasal~cabin, data=christ)

christ1.lm <- lm(cwdbasal ~ cabin, data=christ)

Check diagnostics

plot(christ1.lm)

augment(christ1.lm)
anova(christ1.lm)
Analysis of Variance Table

Response: cwdbasal
          Df Sum Sq Mean Sq F value   Pr(>F)   
cabin      1  25440 25440.1  14.201 0.002076 **
Residuals 14  25080  1791.4                    
---
Signif. codes:  0 ‘***’ 0.001 ‘**’ 0.01 ‘*’ 0.05 ‘.’ 0.1 ‘ ’ 1

Examine model output

Transform cabin density to log10 (cabin density + 1) and refit model

christ$lcabin <- log10(christ$cabin+1)
christ2.lm <- lm(cwdbasal ~ lcabin, data=christ)

Get diagnostics

plot(christ2.lm)

augment(christ2.lm)

Examine model output

glance(christ2.lm)
tidy(christ2.lm, conf.int = TRUE)
anova(christ2.lm)
Analysis of Variance Table

Response: cwdbasal
          Df Sum Sq Mean Sq F value    Pr(>F)    
lcabin     1  32840   32840  26.004 0.0001619 ***
Residuals 14  17680    1263                      
---
Signif. codes:  0 ‘***’ 0.001 ‘**’ 0.01 ‘*’ 0.05 ‘.’ 0.1 ‘ ’ 1

Get standardized coefficients

lm.beta(christ2.lm)

Call:
lm(formula = cwdbasal ~ lcabin, data = christ)

Standardized Coefficients::
(Intercept)      lcabin 
         NA  -0.8062482 

Fit log cwd vs log cabin model to get residual plots, etc. for figure used in book

christ$lcwd<-log10(christ$cwdbasal)
christ3.lm<-lm(christ$lcwd~christ$lcabin)
glance(christ3.lm)
tidy(christ3.lm)
anova(christ3.lm)
Analysis of Variance Table

Response: christ$lcwd
              Df Sum Sq Mean Sq F value    Pr(>F)    
christ$lcabin  1 5.7336  5.7336  26.141 0.0001579 ***
Residuals     14 3.0707  0.2193                      
---
Signif. codes:  0 ‘***’ 0.001 ‘**’ 0.01 ‘*’ 0.05 ‘.’ 0.1 ‘ ’ 1
LS0tCnRpdGxlOiAiUUsgQm94IDYuMiIKCm91dHB1dDogCiAgaHRtbF9ub3RlYm9vazoKICAgIHRoZW1lOiBmbGF0bHkKLS0tCgpgYGB7ciBzZXR1cCwgaW5jbHVkZT1GQUxTRX0Ka25pdHI6Om9wdHNfY2h1bmskc2V0KGVjaG8gPSBUUlVFKQpgYGAKCkNocmlzdGVuc2VuIGV0IGFsLiAoMTk5Nikgc3R1ZGllZCB0aGUgcmVsYXRpb25zaGlwcyBiZXR3ZWVuIGNvYXJzZSB3b29keSBkZWJyaXMgKENXRCkgYW5kIHNob3JlbGluZSB2ZWdldGF0aW9uIGFuZCBsYWtlIGRldmVsb3BtZW50IGluIGEgc2FtcGxlIG9mIDE2IGxha2VzIGluIE5vcnRoIEFtZXJpY2EuIFRoZSBtYWluIHZhcmlhYmxlcyBvZiBpbnRlcmVzdCBhcmUgdGhlIGRlbnNpdHkgb2YgY2FiaW5zIChuby4ga21e4oiSMV4pLCBkZW5zaXR5IG9mIHJpcGFyaWFuIHRyZWVzICh0cmVlcyBrbV7iiJIxXiksIHRoZSBiYXNhbCBhcmVhIG9mIHJpcGFyaWFuIHRyZWVzIChtXjJeIGttXuKIkjFeKSwgZGVuc2l0eSBvZiBjb2Fyc2Ugd29vZHkgZGVicmlzIChuby4ga21e4oiSMV4pLCBiYXNhbCBhcmVhIG9mIGNvYXJzZSB3b29keSBkZWJyaXMgKG1eMl4ga21e4oiSMV4pLgoKIVtDb2Fyc2Ugd29vZHkgZGVicmlzIHByb3ZpZGVzIGltcG9ydGFudCBoYWJpdGF0IHN0cnVjdHVyZS4gTm90IHF1aXRlIGEgbGFrZSBpbiBXaXNjb25zaW4sIGJ1dCBXb3JsZCBIZXJpdGFnZSByYWluZm9yZXN0IGluIG5vcnRoZXJuIEF1c3RyYWxpYSEgUGhvdG8gTS4gS2VvdWdoXSguLi9tZWRpYS9jd2QlMjBxbGQuanBnKXt3aWR0aD0iODAwIn0KCkNvYXJzZSB3b29keSBkZWJyaXMgcHJvdmlkZXMgaW1wb3J0YW50IGhhYml0YXQgc3RydWN0dXJlLiBOb3QgcXVpdGUgYSBsYWtlIGluIFdpc2NvbnNpbiwgYnV0IFdvcmxkIEhlcml0YWdlIHJhaW5mb3Jlc3QgaW4gbm9ydGhlcm4gQXVzdHJhbGlhISBQaG90byBNLiBLZW91Z2ggIVtdKGltYWdlcy9ieS0wMi5wbmcpe3dpZHRoPSI0MyJ9CgpDaHJpc3RlbnNlbiwgRC4gTC4sIEhlcndpZywgQi4gUi4sIFNjaGluZGxlciwgRC4gRS4gJiBDYXJwZW50ZXIsIFMuIFIuICgxOTk2KS4gSW1wYWN0cyBvZiBsYWtlc2hvcmUgcmVzaWRlbnRpYWwgZGV2ZWxvcG1lbnQgb24gY29hcnNlIHdvb2R5IGRlYnJpcyBpbiBub3J0aCB0ZW1wZXJhdGUgbGFrZXMuICpFY29sb2dpY2FsIEFwcGxpY2F0aW9ucyosIDYsIDExNDMtNDkuCgpUaGUgb3JpZ2luYWwgcGFwZXI6IDxodHRwczovL2RvaS5vcmcvMTAuMjMwNy8yMjY5NTk4PgoKVGhpcyBkYXRhIHNldCB3YXMgdXNlZCBmb3IgdGhlIGZpcnN0IGVkaXRpb24sIGFuZCBpcyBhdmFpbGFibGUgaGVyZSBbY2hyaXN0LmNzdl0oLi4vZGF0YS9jaHJpc3QuY3N2KQoKIyMjIFByZWxpbWluYXJpZXMKCkZpcnN0LCBsb2FkIHRoZSByZXF1aXJlZCBwYWNrYWdlcyAoY2FyLCBsbS5iZXRhKS4KCmBgYHtyIGluY2x1ZGU9RkFMU0UsIHJlc3VsdHM9J2hpZGUnfQpkZXZ0b29sczo6c291cmNlX3VybCgiaHR0cHM6Ly9yYXcuZ2l0aHVidXNlcmNvbnRlbnQuY29tL21qa2VvdWdoL21qa2VvdWdoLmdpdGh1Yi5pby9yZWZzL2hlYWRzL21haW4vUi9saWJyYXJpZXMuUiIpICAgI1RoaXMgaXMgdGhlIGNvbW1vbiBsaWJyYXJ5CgpsaWJyYXJ5KGxtLmJldGEpCmBgYAoKSW1wb3J0IENocmlzdGVuc2VuIGRhdGEgKGNocmlzdC5jc3YpCgpgYGB7cn0KY2hyaXN0IDwtIHJlYWQuY3N2KCIuLi9kYXRhL2NocmlzdC5jc3YiKQpoZWFkKGNocmlzdCwxMCkKCmBgYAoKIyMjIENXRCB2ZXJzdXMgcmlwYXJpYW4gZGVuc2l0eSBmaXJzdAoKYGBge3IgfQpzY2F0dGVycGxvdChjd2RiYXNhbH5yaXBkZW5zLCBkYXRhPWNocmlzdCkKY2hyaXN0LmxtIDwtIGxtKGN3ZGJhc2FsIH4gcmlwZGVucywgZGF0YT1jaHJpc3QpCmBgYAoKQ2hlY2sgZGlhZ25vc3RpY3MKCmBgYHtyIH0KcGxvdChjaHJpc3QubG0pCmF1Z21lbnQoY2hyaXN0LmxtKQpgYGAKCkV4YW1pbmUgbW9kZWwgb3V0cHV0CgpgYGB7ciB9CmdsYW5jZShjaHJpc3QubG0pCnRpZHkoY2hyaXN0LmxtLCBjb25mLmludCA9IFRSVUUpCmFub3ZhKGNocmlzdC5sbSkKYGBgCgpHZXQgc3RhbmRhcmRpemVkIGNvZWZmaWNpZW50cwoKYGBge3IgfQpsbS5iZXRhKGNocmlzdC5sbSkKYGBgCgpQcmVkaWN0IG5ldyBDV0QgdmFsdWVzIGZvciByaXBhcmlhbiBkZW5zaXRpZXMgb2YgMTAwMCBhbmQgMjAwMCB0cmVlcyBwZXIga20KCmBgYHtyIH0KcHJlZGljdChjaHJpc3QubG0sIGRhdGEuZnJhbWUocmlwZGVucz1jKDE1MDApKSwgaW50ZXJ2YWw9InByZWRpY3Rpb24iLCBzZT1UKQpgYGAKCiMjIyBOb3cgQ1dEIHZlcnN1cyBjYWJpbiBkZW5zaXR5CgpgYGB7ciB9CnNjYXR0ZXJwbG90KGN3ZGJhc2FsfmNhYmluLCBkYXRhPWNocmlzdCkKY2hyaXN0MS5sbSA8LSBsbShjd2RiYXNhbCB+IGNhYmluLCBkYXRhPWNocmlzdCkKYGBgCgpDaGVjayBkaWFnbm9zdGljcwoKYGBge3IgfQpwbG90KGNocmlzdDEubG0pCmF1Z21lbnQoY2hyaXN0MS5sbSkKYW5vdmEoY2hyaXN0MS5sbSkKCmBgYAoKRXhhbWluZSBtb2RlbCBvdXRwdXQKClRyYW5zZm9ybSBjYWJpbiBkZW5zaXR5IHRvIGxvZzEwIChjYWJpbiBkZW5zaXR5ICsgMSkgYW5kIHJlZml0IG1vZGVsCgpgYGB7ciB9CmNocmlzdCRsY2FiaW4gPC0gbG9nMTAoY2hyaXN0JGNhYmluKzEpCmNocmlzdDIubG0gPC0gbG0oY3dkYmFzYWwgfiBsY2FiaW4sIGRhdGE9Y2hyaXN0KQpgYGAKCkdldCBkaWFnbm9zdGljcwoKYGBge3IgfQpwbG90KGNocmlzdDIubG0pCmF1Z21lbnQoY2hyaXN0Mi5sbSkKYGBgCgpFeGFtaW5lIG1vZGVsIG91dHB1dAoKYGBge3IgfQpnbGFuY2UoY2hyaXN0Mi5sbSkKdGlkeShjaHJpc3QyLmxtLCBjb25mLmludCA9IFRSVUUpCmFub3ZhKGNocmlzdDIubG0pCgpgYGAKCkdldCBzdGFuZGFyZGl6ZWQgY29lZmZpY2llbnRzCgpgYGB7ciB9CmxtLmJldGEoY2hyaXN0Mi5sbSkKYGBgCgojIyMgRml0IGxvZyBjd2QgdnMgbG9nIGNhYmluIG1vZGVsIHRvIGdldCByZXNpZHVhbCBwbG90cywgZXRjLiBmb3IgZmlndXJlIHVzZWQgaW4gYm9vawoKYGBge3J9CmNocmlzdCRsY3dkPC1sb2cxMChjaHJpc3QkY3dkYmFzYWwpCmNocmlzdDMubG08LWxtKGNocmlzdCRsY3dkfmNocmlzdCRsY2FiaW4pCmdsYW5jZShjaHJpc3QzLmxtKQp0aWR5KGNocmlzdDMubG0pCmFub3ZhKGNocmlzdDMubG0pCgpgYGAK