====== GNU R ====== The [[https://www.r-project.org/|GNU R programming language]] is often paired with [[https://posit.co/download/rstudio-desktop/|posit's RStudio Desktop IDE]] and a suit of libraries (language packages) known as [[:tools:tidyverse|tidyverse]] (includes ''dplyr'' and ''ggplot2''). You can also find a web interface to [[http://rhea.wpic.upmc.edu:8787/|Rstudio on rhea]] (also [[:admin:remoteaccess]]). [[:tools:tutorials|Tutorials]] contains additional resources. See [[:tools:r:issues]] for log of debugged problems. ===== Notes ===== ==== na.action ==== When adding module residuals back to a dataframe, you need ''residuals()'' to return the same length as the input data.frame. use ''lm(na.action=na.exclude)''. For example, d <- data.frame(x=c(1:4,NA),y=1:5); m <- lm(x~y,d,na.action=na.exclude); nrow(d); # 5 length(m$residuals); # 4 length(residuals(m)) # 5 This avoids the error Error in `$<-.data.frame`(`*tmp*`, ... replacement has 237 rows, data has 348 ==== MASS::select vs dplyr::select ==== If you load MASS after dplyr, ''select'' will be ''MASS::select'' not ''dplyr::select'' and you're likely to encounter hard-to-debug errors about unused arguments > Error in select ... : unused arguments **solutions** include - load MASS first - force select to be ''dplyr'''s version, or - unload MASS if you don't need it # load mass before dplyr to have 'select' be from dplyr library(MASS) library(dplyr) # force which select (if MASS was already loaded after dplyr and overwrite the function) select <- dplyr::select # or unload MASS detach("package:MASS", unload=TRUE) # check to see environment(select) # if "MASS", you're in for a bad time ===== Backlinks ===== {{backlinks>.}}