R packages: Difference between revisions

From 太極
Jump to navigation Jump to search
 
(371 intermediate revisions by the same user not shown)
Line 1: Line 1:
= R package management =
= R package management =
== Challenges in Package Management ==
[https://www.rstudio.com/blog/challenges-in-package-management/ Challenges in Package Management]
== Packages loaded at startup ==
== Packages loaded at startup ==
''getOption("defaultPackages")''
''getOption("defaultPackages")''


== How to install a new package ==
== How to install a new package ==
* [https://thomasadventure.blog/posts/install-r-packages/ The Comprehensive Guide to Installing R Packages from CRAN, Bioconductor, GitHub and Co.]
* An example from [https://bvieth.github.io/powsimR/articles/powsimR.html powsimR] package
=== utils::install.packages() ===
=== utils::install.packages() ===
* By default, install.packages() will check versions and install uninstalled packages shown in ''' 'Depends', 'Imports' ''', and ''' 'LinkingTo' ''' fields. See [http://cran.r-project.org/doc/manuals/r-release/R-exts.html R-exts] manual.
* By default, install.packages() will check versions and install uninstalled packages shown in ''' 'Depends', 'Imports' ''', and ''' 'LinkingTo' ''' (<span style="color: red">DIL</span>) fields. See [http://cran.r-project.org/doc/manuals/r-release/R-exts.html R-exts] manual.
* Take advantage of '''Ncpus''' parameter in [https://www.rdocumentation.org/packages/utils/versions/3.6.2/topics/install.packages install.packages()]
* If we want to install packages listed in 'Suggests' field, we should specify it explicitly by using ''dependencies'' argument:
* If we want to install packages listed in 'Suggests' field, we should specify it explicitly by using ''dependencies'' argument:
: <syntaxhighlight lang='rsplus'>
: <syntaxhighlight lang='rsplus'>
Line 38: Line 45:
: Look at CRAN, we see the latest version (1.7-0) of [https://cran.r-project.org/web/packages/gridSVG/index.html gridSVG] depends on the latest version of R (3.6.0). But '''why even the source is removed from the old version of R?'''
: Look at CRAN, we see the latest version (1.7-0) of [https://cran.r-project.org/web/packages/gridSVG/index.html gridSVG] depends on the latest version of R (3.6.0). But '''why even the source is removed from the old version of R?'''
* The '''install.packages''' function source code can be found in R -> src -> library -> utils -> R -> [https://github.com/wch/r-source/blob/trunk/src/library/utils/R/packages2.R packages2.R] file from [https://github.com/wch/r-source Github] repository (put 'install.packages' in the search box).
* The '''install.packages''' function source code can be found in R -> src -> library -> utils -> R -> [https://github.com/wch/r-source/blob/trunk/src/library/utils/R/packages2.R packages2.R] file from [https://github.com/wch/r-source Github] repository (put 'install.packages' in the search box).
=== mirror ===
<pre>
local({r <- getOption("repos")
      r["CRAN"] <- "http://cran.r-project.org"
      options(repos=r)
})
options("repos")
</pre>
=== RStudio ===
On my mac,
* install.packages() will install the packages to User Library '/Users/USERNAME/Library/R/3.6/library'
* RStudio GUI method will install the packages to System Library '/Library/Frameworks/R.framework/Versions/3.6/Resources/library'. So if we want to remove a package, we need to specify the '''lib''' parameter in remove.packages() or clicking on the adjacent X icon to remove it.
=== utils:::menuInstallLocal() (Windows OS only) ===
Packages -> Install package(s) from local files...
It works on tarball file.


=== pacman: Install and load the package at the same time, installing temporarily ===
=== pacman: Install and load the package at the same time, installing temporarily ===
Line 47: Line 73:


Also used by [https://hpc.nih.gov/apps/R.html#install Biowulf/NIH]
Also used by [https://hpc.nih.gov/apps/R.html#install Biowulf/NIH]
For bioconductor, use, [https://github.com/trinker/pacman/issues/127 for example],
<pre>
pacman::p_load("BioManager")
pacman::p_load("DESeq2",try.bioconductor=TRUE,update.bioconductor=TRUE)
</pre>
PS. Brute force method
<pre>
mypackages<-c("ggplot2", "dplyr")
for (p in mypackages){
  cond <- suppressWarnings(!require(p, character.only = TRUE))
  if(cond){
    try(install.packages(p), silent = TRUE)
    library(p, character.only = TRUE)
  }
}
</pre>


=== remotes ===
=== remotes ===
devtools depends on 92 (non-base) packages and remotes depends on none.
Download and install R packages stored in 'GitHub', 'BitBucket', or plain 'subversion' or 'git' repositories. This package is a lightweight replacement of the 'install_*' functions in 'devtools'.
Download and install R packages stored in 'GitHub', 'BitBucket', or plain 'subversion' or 'git' repositories. This package is a lightweight replacement of the 'install_*' functions in 'devtools'.


* https://cran.r-project.org/web/packages/remotes/index.html
* https://cran.r-project.org/web/packages/remotes/index.html
* https://www.rdocumentation.org/packages/remotes/versions/2.0.2
* https://www.rdocumentation.org/packages/remotes/versions/2.0.2
* remotes::install("USERNAME/REPOSITORY"). [https://twitter.com/strnr/status/1781419059948462394 Install all my packages with just a github repository and a DESCRIPTION file]


To install a package from a local machines with all dependency, run '''remotes::install_local(path = "MyPackage.tar.gz", dependencies=TRUE)''' or '''devtools::install()''' though the later requires to untar the source first.
To install a package from a local machines with all dependency, run '''remotes::install_local(path = "MyPackage.tar.gz", dependencies=TRUE)''' or '''devtools::install()''' though the later requires to untar the source first.
==== remotes::install_github() vs devtools::install_github() ====
See [https://twitter.com/JohnHelveston/status/1417798263344930819 the answers]. '''remotes''' is a lighter weight package for those who don't need/want all the other functionality in devtools. The remotes package says it copied most of its functionality from devtools, so the functions are likely the same.


=== devtools ===
=== devtools ===
[https://www.rdocumentation.org/packages/devtools/versions/2.0.1/topics/install devtools::install()]
* [https://www.rdocumentation.org/packages/devtools/versions/2.0.1/topics/install devtools::install()]
* devtools::install(".", ...) assumes the current location contains the package content; eg [https://github.com/seandavi/BuildABiocWorkshop2020/blob/master/Dockerfile Dockerfile] from [https://github.com/seandavi/BuildABiocWorkshop2020 Bioc2020 template].


=== pak ===
=== pak ===
https://cran.r-project.org/web/packages/pak/index.html
* https://cran.r-project.org/web/packages/pak/index.html. 'pak' supports CRAN, 'Bioconductor' and 'GitHub' packages. An example about the [https://tidymodels.github.io/censored/index.html censored] package.
* When I use rsconnect::deployApp() to deploy a shiny app to shinyapps.io, the terminal emits the message ''The following package(s) were installed from sources, but may be available from the following remotes: - pak  [r-lib/pak]''. So it seems shinyapps.io uses the [https://github.com/r-lib/pak pak] to install packages.
* [https://www.r-bloggers.com/2023/08/three-four-r-functions-i-enjoyed-this-week/ How does this package depend on this other package?]


=== BiocManager ===
=== BiocManager ===
Line 68: Line 122:
[https://resources.rstudio.com/rstudio-conf-2019/pkgman-a-fresh-approach-to-package-installation pkgman: A fresh approach to package installation - Gábor Csárdi]
[https://resources.rstudio.com/rstudio-conf-2019/pkgman-a-fresh-approach-to-package-installation pkgman: A fresh approach to package installation - Gábor Csárdi]


== Check installed Bioconductor version ==
=== ccache: Faster R package installation ===
Following [https://www.biostars.org/p/150920/ this post], use '''tools:::.BioC_version_associated_with_R_version()'''.
[https://www.jumpingrivers.com/blog/faster-r-package-installation-rstudio/ Faster R package installation]
 
=== Ubuntu ===
<ul>
<li>[http://dirk.eddelbuettel.com/blog/2017/12/22/ Finding Binary .deb Files for CRAN Packages]
<li>Add an additional binary source to your source.lists file, see for example, the line in [https://github.com/rocker-org/rocker/blob/master/r-ubuntu/Dockerfile#L27 rocker]. This is mentioned in [https://www.jumpingrivers.com/blog/faster-r-package-installation-rstudio/ Faster R package installation].
<li>[http://dirk.eddelbuettel.com/blog/2020/06/22/#027_ubuntu_binaries R and CRAN Binaries for Ubuntu] by Dirk Eddelbuettel
* [https://eddelbuettel.github.io/r2u/ r2u: R Binaries for Ubuntu]; see [https://twitter.com/eddelbuettel/status/1523376755548979201 The new #CRANapt repo has 19000 .deb binaries  (and 200+ from BioConductor) for each with full dependencies and `apt` integration.]
** [https://www.brodrigues.co/blog/2022-10-29-mkusb_minp/ A Linux Live USB as a statistical programming dev environment]
** [https://yegrug.github.io/meetups/2022-10-27/ October 27, 2022: r2u, binary packages on Ubuntu]
* [https://enchufa2.github.io/rspm/ rspm]. [https://www.enchufa2.es/archives/rspm-easy-access-to-rspm-binary-packages-with-automatic-management-of-system-requirements.html {rspm}: easy access to RSPM binary packages with automatic management of system requirements]
* [https://cloud.r-project.org/web/packages/bspm/index.html bspm] R package (cf '''rocker/r-rspm''' docker image which is not an R package). 5 lines. After that, "install.packages()" will trigger "sudo apt-get install". Note: it seems the ''apt-add-repository'' commands will break the ''apt update'' command on '''Debian 11'''. After a successful installation on Ubuntu OS, I'll see the following messages every time I started R,
<pre>
Loading required package: utils
Tracing function "install.packages" in package "utils"
</pre>
Also [https://github.com/Enchufa2/bspm/issues/43 for some reason], I cannot remove packages that were just installed. Not sure if the same problem happened if I use '''rig''' (based on rspm).
<pre>
> install.packages("fgsea") # Works fine
> remove.packages("fgsea")
Removing package from ‘/home/brb/R/x86_64-pc-linux-gnu-library/4.2’
(as ‘lib’ is unspecified)
Error in find.package(pkgs, lib) : there is no package called ‘fgsea’
> packageVersion("fgsea")
[1] ‘1.22.0’
</pre>
Since the ''bspm::enable()'' function enables the integration of '''install_sys()''' into '''install.packages()''', we have to use '''remove_sys(pkgs)''' to uninstall a package. See [https://rdrr.io/cran/bspm/api/ API].
</li>
</ul>


''Mind the '.' in front of the 'BioC'. It may be possible for some installed packages to have been sourced from a different BioC version.''  
=== Posit Package Manager/RStudio Package Manager/PPM ===
<ul>
<li>https://packagemanager.posit.co/client/#/ -> Repository:Bioconductor -> Setup.
* On Ubuntu (Linux), there is no binary format of Bioconductor packages. P3M only has binary format of CRAN packages.
* On Windows, I have to install '''Rtools'''. After Rtools has been installed, R will recognize it. Go to https://packagemanager.posit.co/client/#/. Select Bioconductor and click "SETUP". Pick Bioconductor version. Copy/paste options() statements into R or put it in the '''~/.Rprofile'''.
* On macOS, similar to Windows.
<li>[https://packagemanager.rstudio.com/__docs__/admin/getting-started/installation/installing-ppm/ PPM Admin Guide]. <s>It only supports Ubuntu (no Debian), RedHat, OpenSUSE.</s>
<li>[https://docs.posit.co/rspm/admin/serving-binaries/#installing-binary-packages R Configuration Steps (Linux) -> Using Linux Binary Packages -> Configuring the R User Agent Header] from Admin Guide. <span style="color: red">The step of configuring http user agent header should not be skipped</span>.
<li>[https://tshafer.com/blog/2023/07/posit-package-manager-linux Posit Package Manager for Linux R Binaries]. Put the following in the <.Rprofile> file. If inside the RStudio, we need to quit the current R session first.
<syntaxhighlight lang='r'>
options(HTTPUserAgent = sprintf(
  "R/%s R (%s)",
  getRversion(),
  paste(
    getRversion(),
    R.version["platform"],
    R.version["arch"],
    R.version["os"]
  )
))


<syntaxhighlight lang='rsplus'>
# adjust this for your Linux distribution
tools:::.BioC_version_associated_with_R_version() # `3.6'
.ppm <- "https://packagemanager.posit.co/cran/__linux__/noble/latest"
tools:::.BioC_version_associated_with_R_version() == '3.6'  # TRUE
options(repos = c(CRAN = .ppm))
# verify
getOption("repos")
options()$repos
</syntaxhighlight>
</syntaxhighlight>
<li>It provides '''pre-compiled binary packages''' for Linux and Windows OS, but not macOS. When enabled, RStudio Package Manager will serve the appropriate CRAN binaries to R users instead of the source packages, saving R users significant installation time.
* <strike>It does not include binary packages from bioconductor</strike>. However, Package Manager allows you to supplement local and git sources with your own precompiled binaries.
* [https://support.posit.co/hc/en-us/articles/360016400354-Using-Bioconductor-with-RStudio-Package-Manager Using Bioconductor with RStudio Package Manager] 7/12/2021
* See [https://docs.posit.co/rspm/admin/serving-binaries/ Serving Package Binaries]
<li>It is similar to MRAN as it allows users to use particular a '''snapshot''' of CRAN as their active repositories within their R session
* [https://community.rstudio.com/t/programmatically-retrieve-frozen-urls-for-cran-from-packagemanager-rstudio-com/119326 programmatically retrieve frozen urls for CRAN from packagemanager.rstudio.com]
* See [https://packagemanager.rstudio.com/client/#/repos/2/overview Setup]. We can change the distribution (Source, CentOS7, Rocky Linux 9, OpenSUSE, Red Hat, SLES, Ubuntu, Windows, macOS) for the Repository URL.
* See [https://packagemanager.rstudio.com/__docs__/user/ User Guide]
<li> Once configured, users can access RStudio Package Manager through all their familiar tools including base R’s install.packages(), packrat, and devtools.
<li>[https://blog.rstudio.com/2020/07/01/announcing-public-package-manager/ Announcing Public Package Manager and v1.1.6]
<li>Package Manager allows linux users to install '''pre-built binaries''' of the packages which will make install quicker. See an example [https://blog.sellorm.com/2021/04/25/shiny-app-in-docker/?s=09 here].
<pre>
# Freeze to Apr 29, 2021 8:00 PM
options(repos = c(REPO_NAME = "https://packagemanager.posit.co/all/2639103"))


== CRAN Package Depends on Bioconductor Package ==
# Using Linux Binary Packages
For example, if I run ''install.packages("NanoStringNorm")'' to install the [https://cran.r-project.org/web/packages/NanoStringNorm/index.html package] from CRAN, I may get
https://r-pkgs.example.com/our-cran/__linux__/xenial/latest
<pre>
https://packagemanager.posit.co/cran/__linux__/focal/2021-04-23
ERROR: dependency ‘vsn’ is not available for package ‘NanoStringNorm’
</pre>
</pre>
This is because the NanoStringNorm package depends on the vsn package which is on Bioconductor.
<li>[https://www.rstudio.com/blog/publishing-your-own-binary-packages-with-rspm-2022-07/ Bring Your Own Binary Packages with RSPM]


Another instance is CRAN's 'biospear' (actually 'plsRcox') depends on Bioc's 'survcomp' & 'mixOmics'.
<li>'''Docker images'''
* r-base, rocker/r-base don't use PPM (as of R 4.3.3).
* rocker/r-ver (eg. rocker/r-ver:4.3.3) uses PPM. See the table of images on [https://rocker-project.org/images/ The versioned stack].
* [https://bioconductor.org/help/docker/ Bioconductor] (source on [https://github.com/Bioconductor/bioconductor_docker github]) does take advantage of PPM. In Bioc 3.17/R 4.3.1, Posit's PPM hosts the binaries. As of Bioc 3.18/R 4.3.3, Bioconductor hosts the binaries.</br>
:RStudio will be available on your web browser at http://localhost:8787. The username is "rstudio".
:<syntaxhighlight lang='r'>docker run \
-e PASSWORD=bioc \
-p 8787:8787 \
bioconductor/bioconductor_docker:devel
</syntaxhighlight>
:R will be available on the terminal
:<syntaxhighlight lang='r'>
docker run -it --rm \
    --user rstudio \
    bioconductor/bioconductor_docker:RELEASE_3_18 R
</syntaxhighlight>
{{Pre}}
system.time(BiocManager::install("DESeq2", ask = FALSE))
# Replacement repositories:
#    CRAN: https://p3m.dev/cran/__linux__/jammy/latest
# ...
# trying URL 'https://bioconductor.org/packages/3.18/container-binaries/bioconductor_docker/src/contrib/bitops_1.0-7_R_x86_64-pc-linux-gnu.tar.gz'
Content type 'application/gzip' length 24831 bytes (24 KB)
# ...
# 52 seconds
</pre>
</ul>


One solution is to run a line '''setRepositories(ind=1:2)'''. See [http://stackoverflow.com/questions/14343817/cran-package-depends-on-bioconductor-package-installing-error this post] or [https://stackoverflow.com/questions/34617306/r-package-with-cran-and-bioconductor-dependencies this one]. Note that the default repository list can be found at (Ubuntu) '''/usr/lib/R/etc/repositories''' file.
=== install a package as it existed on a specific date/snapshot: mran repository ===
<syntaxhighlight lang='rsplus'>
* [https://blog.revolutionanalytics.com/2023/01/mran-time-machine-retired.html MRAN Time Machine will be retired on July 1 2023]
options("repos") # display the available repositories (only CRAN)
** [https://www.brodrigues.co/blog/2023-01-12-repro_r/ MRAN is getting shutdown] - what else is there for reproducibility with R, or why reproducibility is on a continuum?
setRepositories(ind=1:2)
* [https://www.r-bloggers.com/mran-snapshots-and-you-2/ MRAN snapshots, and you] May 22, 2019.
options("repos") # CRAN and bioc are included
#                                        CRAN
#                "https://cloud.r-project.org"
# "https://bioconductor.org/packages/3.6/bioc"


install.packages("biospear") # it will prompt to select CRAN
Look at https://cran.microsoft.com/snapshot/, it seems the snapshot went back 2014 for R 3.1.1.


install.packages("biospear", repos = "http://cran.rstudio.com") # NOT work since bioc repos is erased
For example,
</syntaxhighlight>
<pre>
options(repos = c(CRAN = "https://mran.microsoft.com/snapshot/2022-10-01"))


This will also install the '''BiocInstaller''' package if it has not been installed before. See also [https://www.bioconductor.org/install/ Install Bioconductor Packages].
install.packages("xgboost", repos="https://mran.microsoft.com/snapshot/2022-10-01/")
</pre>


== Install a tar.gz (e.g. an archived package) from a local directory ==
This trick works great when I try to install an R package (glmnet 3.0-2) on an old version of R. The current glmnet requires R 3.6.0. ''So even the source package is not available for older versions of R.'' If I install a package that does not require a very new version of R, that it works. The same problem happens on Windows OS. (today is 2020-05-05)
<syntaxhighlight lang='bash'>
<pre>
R CMD INSTALL <package-name>.tar.gz
$ docker run --rm -it r-base:3.5.3
</syntaxhighlight>
...
Or in R:
> install.packages("glmnet")
<syntaxhighlight lang='rsplus'>
Installing package into ‘/usr/local/lib/R/site-library’
# Method 1: cannot install dependencies
(as ‘lib’ is unspecified)
install.packages(<pathtopackage>, repos = NULL)
Warning message:
# These paths can be source directories or archives or binary package
package ‘glmnet’ is not available (for R version 3.5.3)
# archive files  (as created by ‘R CMD build --binary’).
> install.packages("glmnet", repos="https://mran.microsoft.com/snapshot/2019-09-20/")
# (‘http://’ and ‘file://’ URLs are also accepted and the files
...
# will be downloaded and installed from local copies.)
* DONE (glmnet)
 
The downloaded source packages are in
‘/tmp/RtmpoWVWFQ/downloaded_packages’
> packageVersion("glmnet")
[1] ‘2.0.18’
> options()$repos
                        CRAN
"https://cloud.r-project.org"
> install.packages('knitr') # OK.
</pre>


# Method 2: take care of dependencies from CRAN
=== install a package on an old version of R ===
devtools::install(<directory to package>, dependencies = TRUE)
<ul>
                        # this will use 'R CMD INSTALL' to install the package.
<li>Currently R is 4.2.2
                        # It will try to install dependencies of the package from CRAN,
<li>I have build R 4.1.3 and R 4.0.5 from source on Ubuntu 22.04. P.S. We need to include/enable "Source code" URIs  [https://askubuntu.com/a/857433 Error :: You must put some 'source' URIs in your sources.list].
                        # if they're not already installed.
<pre>
</syntaxhighlight>
sudo apt update
sudo apt-get build-dep r-base


The installation process can be nasty due to the dependency issue. Consider the 'biospear' package
tar -xzvf R-4.1.3.tar.gz
cd R-4.1.3
./configure
time make -j2
bin/R
</pre>
<li>I'm trying to install DESEq2 on R 4.1.3 and R 4.0.5
<li>On R 4.1.3, the installation is successful.
<pre>
<pre>
biospear - plsRcox (archived) - plsRglm (archived) - bipartite
install.packages("BiocManager")
                              - lars
BiocManager::install("DESeq2")  
                              - pls
packageVersion("DESeq2")  # 1.34.0
                              - kernlab
</pre>
                              - mixOmics (CRAN->Bioconductor)
<li>On R 4.0.5, the installation of "locfit" (current version 1.5-9.7) requires R >= 4.1.0. Check on CRAN, we see the locfit version is 1.5-6 for R 4.0.5 (2021-3-31). So I try this version first.
                              - risksetROC
<pre>
                              - survcomp (Bioconductor)
install.packages("BiocManager")
                              - rms
install.packages("remotes")
remotes::install_version("locfit", "1.5-6")
# Error: a 'NAMESPACE' file is required
 
# Try the next version 1.5-7
remotes::install_version("locfit", "1.5-7") # Works
BiocManager::install("DESeq2")   # Works too
packageVersion("DESeq2")  # 1.30.1
</pre>
</pre>
So in order to install the 'plsRcox' package, we need to do the following steps. Note: plsRcox package is back on 6/2/2018.
<li>Now it is a good opportunity to try '''renv'''. So I create a new folder 'testProject' and create a new file 'test.R'. This R file contains only one line: library(DESeq2).  
<syntaxhighlight lang='bash'>
<pre>
# For curl
> setwd("testProj")
system("apt update")
> install.packages("renv")
system("apt install curl libcurl4-openssl-dev libssl-dev")
> renv::init()
* Initializing project ...
* Discovering package dependencies ... Done!
* Copying packages into the cache ... [79/79] Done!
One or more Bioconductor packages are used in your project,
but the BiocManager package is not available.
 
Consider installing BiocManager before snapshot.


# For X11
The following package(s) will be updated in the lockfile:
system("apt install libcgal-dev libglu1-mesa-dev libglu1-mesa-dev")
...
system("apt install libfreetype6-dev") # https://stackoverflow.com/questions/31820865/error-in-installing-rgl-package
The version of R recorded in the lockfile will be updated:
</syntaxhighlight>
- R                      [*] -> [4.0.5]


<syntaxhighlight lang='rsplus'>
* Lockfile written to '~/Downloads/testProject/renv.lock'.
source("https://bioconductor.org/biocLite.R")
* Project '~/Downloads/testProject' loaded. [renv 0.16.0]
biocLite("survcomp") # this has to be run before the next command of installing a bunch of packages from CRAN
* renv activated -- please restart the R session.
> renv::install("BiocManager")  # NOT SURE IF THIS IS NECESSARY
Retrieving 'https://cloud.r-project.org/src/contrib/BiocManager_1.30.19.tar.gz' ...
OK [file is up to date]
Installing BiocManager [1.30.19] ...
OK [built from source]
Moving BiocManager [1.30.19] into the cache ...
OK [moved to cache in 20 milliseconds]
> q()
</pre>
Now DESeq2 is in "renv.lock" file!


install.packages("https://cran.r-project.org/src/contrib/Archive/biospear/biospear_1.0.1.tar.gz",
Note if we accidentally start a different version of R on an renv-ed project based on an older version of R, we shall see some ''special'' message informing us '''The project library is out of sync with the lockfile'''. At this time, the "renv.lock" is not touched yet.
                repos = NULL, type="source")
<pre>
# ERROR: dependencies ‘pkgconfig’, ‘cobs’, ‘corpcor’, ‘devtools’, ‘glmnet’, ‘grplasso’, ‘mboost’, ‘plsRcox’,
# Bootstrapping renv 0.16.0 --------------------------------------------------
# ‘pROC’, ‘PRROC’, ‘RCurl’, ‘survAUC’ are not available for package ‘biospear’
* Downloading renv 0.16.0 ... OK (downloaded source)
install.packages(c("pkgconfig", "cobs", "corpcor", "devtools", "glmnet", "grplasso", "mboost",
* Installing renv 0.16.0 ... Done!
                  "plsRcox", "pROC", "PRROC", "RCurl", "survAUC"))
* Successfully installed and loaded renv 0.16.0.
# optional: install.packages(c("doRNG", "mvnfast"))
! Using R 4.2.2 (lockfile was generated with R 4.0.5)
install.packages("https://cran.r-project.org/src/contrib/Archive/biospear/biospear_1.0.1.tar.gz",
* Project '~/Downloads/testProject' loaded. [renv 0.16.0]
                repos = NULL, type="source")
* The project library is out of sync with the lockfile.
# OR
* Use `renv::restore()` to install packages recorded in the lockfile.
# devtools::install_github("cran/biospear")
</pre>
library(biospear) # verify
<li>What happened if we start with the same version of R but have a different version of renv in the global environment (vs renv.lock)?
</syntaxhighlight>
<pre>
install.packages("remotes")
remotes::install_version("renv", "0.15.5")
renv::init()
q()
 
# Start the same R from another directory and update renv to the latest version 0.16.0
# Now go back to the project directory and start R to see what will happen?
# Nothing....  This is because the same project has the old & same version of "renv" library
# in the "$PROJECT/renv" directory
</pre>
If we delete the "renv" subdirectory, ".Rprofile" file but keep "renv.lock" file, and start R (remember the 'renv' package version in the global R is different from the version in "renv.lock".
<pre>
> renv::restore()
This project has not yet been activated.
Activating this project will ensure the project library is used during restore.
Please see `?renv::activate` for more details.
 
Would you like to activate this project before restore? [Y/n]: y
Retrieving 'https://cloud.r-project.org/src/contrib/BiocManager_1.30.19.tar.gz' ...
OK [file is up to date]
Installing BiocManager [1.30.19] ...
OK [built from source]
Moving BiocManager [1.30.19] into the cache ...
OK [moved to cache in 27 milliseconds]
* Project '~/Downloads/testProject' loaded. [renv 0.16.0]
* The project may be out of sync -- use `renv::status()` for more details.
The following package(s) will be updated:
 
# Bioconductor =======================
- AnnotationDbi          [* -> 1.56.2]
...
# CRAN ===============================
- renv                  [0.16.0 -> 0.15.5]
...
Do you want to proceed? [y/N]: y
Retrieving 'https://cloud.r-project.org/src/contrib/Archive/renv/renv_0.15.5.tar.gz' ...
OK [downloaded 961.3 Kb in 0.2 secs]
Installing renv [0.15.5] ...
OK [built from source]
Moving renv [0.15.5] into the cache ...
OK [moved to cache in 6.8 milliseconds]
...
The following package(s) have been updated:


To install the (deprecated, bioc) packages 'inSilicoMerging',
renv [installed version 0.15.5 != loaded version 0.16.0]
<syntaxhighlight lang='bash'>
biocLite(c('rjson', 'Biobase', 'RCurl'))


# destination directory is required
Consider restarting the R session and loading the newly-installed packages.
# download.file("http://www.bioconductor.org/packages/3.3/bioc/src/contrib/inSilicoDb_2.7.0.tar.gz",
</pre>
#              "~/Downloads/inSilicoDb_2.7.0.tar.gz")
All the R packages are restored in the $PROJECT/renv directory.
# download.file("http://www.bioconductor.org/packages/3.3/bioc/src/contrib/inSilicoMerging_1.15.0.tar.gz",
</li>
#              "~/Downloads/inSilicoMerging_1.15.0.tar.gz")
</ul>
# ~/Downloads or $HOME/Downloads won't work in untar()
 
# untar("~/Downloads/inSilicoDb_2.7.0.tar.gz", exdir="/home/brb/Downloads")
== Check installed Bioconductor version ==
# untar("~/Downloads/inSilicoMerging_1.15.0.tar.gz", exdir="/home/brb/Downloads")
Following [https://www.biostars.org/p/150920/ this post], use '''tools:::.BioC_version_associated_with_R_version()'''.
# install.packages("~/Downloads/inSilicoDb", repos = NULL)
 
# install.packages("~/Downloads/inSilicoMerging", repos = NULL)
''Mind the '.' in front of the 'BioC'. It may be possible for some installed packages to have been sourced from a different BioC version.''
install.packages("http://www.bioconductor.org/packages/3.3/bioc/src/contrib/inSilicoDb_2.7.0.tar.gz",
 
                repos = NULL, type = "source")
<syntaxhighlight lang='rsplus'>
install.packages("http://www.bioconductor.org/packages/3.3/bioc/src/contrib/inSilicoMerging_1.15.0.tar.gz",
tools:::.BioC_version_associated_with_R_version() # `3.6'
                repos = NULL, type = "source")
tools:::.BioC_version_associated_with_R_version() == '3.6'  # TRUE
</syntaxhighlight>
</syntaxhighlight>


=== R CMD INSTALL -l LIB/--library=LIB option ===
== CRAN Package Depends on Bioconductor Package ==
Install a package to a custom location
For example, if I run ''install.packages("NanoStringNorm")'' to install the [https://cran.r-project.org/web/packages/NanoStringNorm/index.html package] from CRAN, I may get
<pre>
<pre>
$ R CMD INSTALL -l /usr/me/localR/library myRPackage.tar.gz
ERROR: dependency ‘vsn’ is not available for package ‘NanoStringNorm’
</pre>
</pre>
This is because the NanoStringNorm package depends on the vsn package which is on Bioconductor.


Use a package installed in a custom location
Another example is CRAN's ''tidyHeatmap'' that imports ''ComplexHeatmap'' in Bioconductor.
<pre>
R> library("myRPackage", lib.loc="/usr/me/local/R/library")


# OR include below in .bashrc file
Another instance is CRAN's ''biospear'' (actually [https://cran.r-project.org/web/packages/plsRcox/index.html plsRcox]) that depends on Bioc's 'survcomp' & 'mixOmics'.
$ export R_LIBS=/usr/me/local/R/library
R> .libPaths() # check
R> library("myRPackage")
</pre>


== Install multiple versions of the same R package ==
One solution is to run a line '''setRepositories(ind=1:2)'''. See [http://stackoverflow.com/questions/14343817/cran-package-depends-on-bioconductor-package-installing-error this post] or [https://stackoverflow.com/questions/34617306/r-package-with-cran-and-bioconductor-dependencies this one]. Note that the default repository list can be found at (Ubuntu) '''/usr/lib/R/etc/repositories''' file.
https://stackoverflow.com/a/2989369
{{Pre}}
<pre>
options("repos") # display the available repositories (only CRAN)
library(foo, lib.loc="~/dev/foo/v1")   ## loads v1
setRepositories(ind=1:2)
# and
options("repos") # CRAN and bioc are included
library(foo, lib.loc="~/dev/foo/v2")    ## loads v2
#                                       CRAN
</pre>
#                "https://cloud.r-project.org"
# "https://bioconductor.org/packages/3.6/bioc"


The same works for install.packages(). help(install.packages)
install.packages("biospear") # it will prompt to select CRAN


The install_version() from devtools and remotes will overwrite the existing installation.
install.packages("biospear", repos = "http://cran.rstudio.com") # NOT work since bioc repos is erased
</pre>


== Query an R package installed locally ==
This will also install the '''BiocInstaller''' package if it has not been installed before. See also [https://www.bioconductor.org/install/ Install Bioconductor Packages].
<pre>
packageDescription("MASS")
packageVersion("MASS")
</pre>


== Query an R package (from CRAN) basic information ==
=== Bioconductor packages depend on CRAN ===
<syntaxhighlight lang='rsplus'>
For example [https://cran.r-project.org/web/packages/cowplot/index.html cowplot] shows ''breakpointR'' from Bioconductor depends on it.
packageStatus() # Summarize information about installed packages
 
== update.packages() ==
update.packages(ask="graphics") can open a graphical window to select packages.
 
== only upgrade to binary package versions ==
Try setting options(pkgType = "binary") before running update.packages(). To make this always be the default behavior, you can add that line to your .Rprofile file.


available.packages() # List Available Packages at CRAN-like Repositories
How about options(install.packages.check.source = "no"), options(install.packages.compile.from.source = "never")?
</syntaxhighlight>
The '''available.packages()''' command is useful for understanding package dependency. Use '''setRepositories()''' or 'RGUI -> Packages -> select repositories' to select repositories and '''options()$repos''' to check or change the repositories.


Also the '''packageStatus()''' is another useful function for query how many packages are in the repositories, how many have been installed, and individual package status (installed or not, needs to be upgraded or not).
== Binary packages only for two versions of R ==
<syntaxhighlight lang='rsplus'>
[https://www.r-bloggers.com/r-tip-check-what-repos-you-are-using/ Check What Repos You are Using].
> options()$repos
                      CRAN
"https://cran.rstudio.com/"


> packageStatus()
'''CRAN only provides binaries for one version of R prior to the current one. So when CRAN moves to post-3.6.* R most non version-stuck mirrors will not have 3.5.* binary versions of packages.'''
Number of installed packages:
                                   
                                      ok upgrade unavailable
  C:/Program Files/R/R-3.0.1/library 110      0          1


Number of available packages (each package counted only once):
== Install a tar.gz (e.g. an archived package) from a local directory ==
                                                                                 
<syntaxhighlight lang='bash'>
                                                                                    installed not installed
R CMD INSTALL <package-name>.tar.gz
  http://watson.nci.nih.gov/cran_mirror/bin/windows/contrib/3.0                            76          4563
</syntaxhighlight>
  http://www.stats.ox.ac.uk/pub/RWin/bin/windows/contrib/3.0                                0            5
Or in R:
  http://www.bioconductor.org/packages/2.12/bioc/bin/windows/contrib/3.0                  16          625
<syntaxhighlight lang='rsplus'>
  http://www.bioconductor.org/packages/2.12/data/annotation/bin/windows/contrib/3.0        4          686
# Method 1: cannot install dependencies
> tmp <- available.packages()
install.packages(<pathtopackage>, repos = NULL)
> str(tmp)
# These paths can be source directories or archives or binary package
chr [1:5975, 1:17] "A3" "ABCExtremes" "ABCp2" "ACCLMA" "ACD" "ACNE" "ADGofTest" "ADM3" "AER" ...
# archive files  (as created by ‘R CMD build --binary’).
- attr(*, "dimnames")=List of 2
# (‘http://’ and ‘file://’ URLs are also accepted and the files
  ..$ : chr [1:5975] "A3" "ABCExtremes" "ABCp2" "ACCLMA" ...
# will be downloaded and installed from local copies.)
  ..$ : chr [1:17] "Package" "Version" "Priority" "Depends" ...
 
> tmp[1:3,]
# Method 2: take care of dependencies from CRAN
            Package      Version Priority Depends                    Imports LinkingTo Suggests           
devtools::install(<directory to package>, dependencies = TRUE)  
A3          "A3"          "0.9.2" NA      "xtable, pbapply"          NA      NA        "randomForest, e1071"
                        # this will use 'R CMD INSTALL' to install the package.
ABCExtremes "ABCExtremes" "1.0"  NA      "SpatialExtremes, combinat" NA      NA        NA                 
                        # It will try to install dependencies of the package from CRAN,
ABCp2      "ABCp2"      "1.1"  NA      "MASS"                      NA      NA        NA                 
                        # if they're not already installed.
            Enhances License      License_is_FOSS License_restricts_use OS_type Archs MD5sum NeedsCompilation File
</syntaxhighlight>
A3          NA      "GPL (>= 2)" NA              NA                    NA      NA    NA    NA              NA 
 
ABCExtremes NA      "GPL-2"      NA              NA                    NA      NA    NA    NA              NA 
The installation process can be nasty due to the dependency issue. Consider the 'biospear' package
ABCp2      NA      "GPL-2"      NA              NA                    NA      NA    NA    NA              NA 
<pre>
            Repository                                                   
biospear - plsRcox (archived) - plsRglm (archived) - bipartite
A3          "http://watson.nci.nih.gov/cran_mirror/bin/windows/contrib/3.0"
                              - lars
ABCExtremes "http://watson.nci.nih.gov/cran_mirror/bin/windows/contrib/3.0"
                              - pls
ABCp2      "http://watson.nci.nih.gov/cran_mirror/bin/windows/contrib/3.0"
                              - kernlab
</syntaxhighlight>
                              - mixOmics (CRAN->Bioconductor)
And the following commands find which package depends on Rcpp and also which are from bioconductor repository.
                              - risksetROC
<syntaxhighlight lang='rsplus'>
                              - survcomp (Bioconductor)
> pkgName <- "Rcpp"
                              - rms
> rownames(tmp)[grep(pkgName, tmp[,"Depends"])]
</pre>
> tmp[grep("Rcpp", tmp[,"Depends"]), "Depends"]
So in order to install the 'plsRcox' package, we need to do the following steps. Note: plsRcox package is back on 6/2/2018.
{{Pre}}
# For curl
system("apt update")
system("apt install curl libcurl4-openssl-dev libssl-dev")


> ind <- intersect(grep(pkgName, tmp[,"Depends"]), grep("bioconductor", tmp[, "Repository"]))
# For X11
> rownames(grep)[ind]
system("apt install libcgal-dev libglu1-mesa-dev libglu1-mesa-dev")
NULL
system("apt install libfreetype6-dev") # https://stackoverflow.com/questions/31820865/error-in-installing-rgl-package
> rownames(tmp)[ind]
</pre>
[1] "ddgraph"            "DESeq2"            "GeneNetworkBuilder" "GOSemSim"          "GRENITS"         
[6] "mosaics"            "mzR"                "pcaMethods"        "Rdisop"            "Risa"             
[11] "rTANDEM"   
</syntaxhighlight>


== CRAN vs Bioconductor packages ==
{{Pre}}
<syntaxhighlight lang='rsplus'>
source("https://bioconductor.org/biocLite.R")
> R.version # 3.4.3
biocLite("survcomp") # this has to be run before the next command of installing a bunch of packages from CRAN
# CRAN
> x <- available.packages()
> dim(x)
[1] 12581    17


# Bioconductor Soft
install.packages("https://cran.r-project.org/src/contrib/Archive/biospear/biospear_1.0.1.tar.gz",
> biocinstallRepos()
                repos = NULL, type="source")
                                              BioCsoft
# ERROR: dependencies ‘pkgconfig’, ‘cobs’, ‘corpcor’, ‘devtools’, ‘glmnet’, ‘grplasso’, ‘mboost’, ‘plsRcox’,
          "https://bioconductor.org/packages/3.6/bioc"
# ‘pROC’, ‘PRROC’, ‘RCurl’, ‘survAUC’ are not available for package ‘biospear’
                                                BioCann
install.packages(c("pkgconfig", "cobs", "corpcor", "devtools", "glmnet", "grplasso", "mboost",
"https://bioconductor.org/packages/3.6/data/annotation"  
                  "plsRcox", "pROC", "PRROC", "RCurl", "survAUC"))
                                                BioCexp
# optional: install.packages(c("doRNG", "mvnfast"))
"https://bioconductor.org/packages/3.6/data/experiment"  
install.packages("https://cran.r-project.org/src/contrib/Archive/biospear/biospear_1.0.1.tar.gz",
                                                  CRAN
                repos = NULL, type="source")
                            "https://cran.rstudio.com/"
# OR
> y <- available.packages(repos = biocinstallRepos()[1])
# devtools::install_github("cran/biospear")
> dim(y)
library(biospear) # verify
[1] 1477  17
</pre>
> intersect(x[, "Package"], y[, "Package"])
character(0)
# Bioconductor Annotation
> dim(available.packages(repos = biocinstallRepos()[2]))
[1] 909  17
# Bioconductor Experiment
> dim(available.packages(repos = biocinstallRepos()[3]))
[1] 326  17


# CRAN + All Bioconductor
To install the (deprecated, bioc) packages 'inSilicoMerging',
> z <- available.packages(repos = biocinstallRepos())
{{Pre}}
> dim(z)
biocLite(c('rjson', 'Biobase', 'RCurl'))
[1] 15292    17
</syntaxhighlight>


== Downloading Bioconductor package with an old R ==
# destination directory is required
When I try to download the [https://bioconductor.org/packages/release/bioc/html/GenomicDataCommons.html GenomicDataCommons] package using R 3.4.4 with Bioc 3.6 (the current R version is 3.5.0), it was found it can only install version 1.2.0 instead the latest version 1.4.1.
# download.file("http://www.bioconductor.org/packages/3.3/bioc/src/contrib/inSilicoDb_2.7.0.tar.gz",
#              "~/Downloads/inSilicoDb_2.7.0.tar.gz")
# download.file("http://www.bioconductor.org/packages/3.3/bioc/src/contrib/inSilicoMerging_1.15.0.tar.gz",
#              "~/Downloads/inSilicoMerging_1.15.0.tar.gz")
# ~/Downloads or $HOME/Downloads won't work in untar()
# untar("~/Downloads/inSilicoDb_2.7.0.tar.gz", exdir="/home/brb/Downloads")
# untar("~/Downloads/inSilicoMerging_1.15.0.tar.gz", exdir="/home/brb/Downloads")
# install.packages("~/Downloads/inSilicoDb", repos = NULL)
# install.packages("~/Downloads/inSilicoMerging", repos = NULL)
install.packages("http://www.bioconductor.org/packages/3.3/bioc/src/contrib/inSilicoDb_2.7.0.tar.gz",
                repos = NULL, type = "source")
install.packages("http://www.bioconductor.org/packages/3.3/bioc/src/contrib/inSilicoMerging_1.15.0.tar.gz",
                repos = NULL, type = "source")
</pre>


It does not work by running biocLite("BiocUpgrade") to upgrade Bioc from 3.6 to 3.7.
=== R CMD INSTALL -l LIB/--library=LIB option ===
<syntaxhighlight lang='rsplus'>
Install a package to a custom location
source("https://bioconductor.org/biocLite.R")
<pre>
biocLite("BiocUpgrade")
$ R CMD INSTALL -l /usr/me/localR/library myRPackage.tar.gz
# Error: Bioconductor version 3.6 cannot be upgraded with R version 3.4.4
</pre>
</syntaxhighlight>


== Analyzing data on CRAN packages ==
Use a package installed in a custom location
New undocumented function in R 3.4.0: '''tools::CRAN_package_db()'''
<pre>
R> library("myRPackage", lib.loc="/usr/me/local/R/library")


http://blog.revolutionanalytics.com/2017/05/analyzing-data-on-cran-packages.html
# OR include below in .bashrc file
$ export R_LIBS=/usr/me/local/R/library
R> .libPaths() # check
R> library("myRPackage")
</pre>


== R package location when they are installed by root ==
== Install a specific version of R/Bioconductor package ==
''/usr/local/lib/R/site-library''
For packages from CRAN, use something like '''remotes::install_version'''("dplyr", "1.0.2")


== R_LIBS_USER is empty in R 3.4.1 ==
For packages from Bioconductor, see the two solutions [https://stackoverflow.com/questions/49487171/r-how-to-install-a-specified-version-of-a-bioconductor-package R how to install a specified version of a bioconductor package?]  
See  [[R#install.package.28.29_error.2C_R_LIBS_USER_is_empty_in_R_3.4.1|install.package() error, R_LIBS_USER is empty in R 3.4.1]].


== Add a personal directory to .libPaths() ==
== Install multiple/different versions of the same R package ==
<syntaxhighlight lang='rsplus'>
https://stackoverflow.com/a/2989369
.libPaths( c( .libPaths(), "~/userLibrary") )
<pre>
</syntaxhighlight>
install.packages("~/Downloads/foo_0.1.1.tar.gz", lib = "/tmp", repos = NULL)
No need to use the assignment operator.
# a new folder "/tmp/foo" will be created
library(foo, lib.loc="/tmp") # Or use 'lib' to be consistent with install.packages()     


== Install personal R packages after upgrade R, .libPaths(), Rprofile.site, R_LIBS_USER ==
library(foo, lib.loc="~/dev/foo/v1")    ## loads v1
Scenario: We already have installed many R packages under R 3.1.X in the user's directory. Now we upgrade R to a new version (3.2.X). We like to have these packages available in R 3.2.X.
# and
library(foo, lib.loc="~/dev/foo/v2")   ## loads v2


<span style="color:#0000FF">For Windows OS, refer to [http://cran.r-project.org/bin/windows/base/rw-FAQ.html#What_0027s-the-best-way-to-upgrade_003f R for Windows FAQ]</span>
packageVersion("foo", lib.loc = "/tmp")
sessionInfo()
help(package = "foo", lib.loc = "/tmp")


The follow method works on Linux and Windows.
remove.packages("foo", lib = "/tmp")
</pre>


<span style="color:#FF0000">Make sure only one instance of R is running</span>
The same works for install.packages(). help(install.packages)
<pre>
# Step 1. update R's built-in packages and install them on my personal directory
update.packages(ask=FALSE, checkBuilt = TRUE, repos="http://cran.rstudio.com")


# Step 2. update Bioconductor packages
The install_version() from devtools and remotes will overwrite the existing installation.
.libPaths() # The first one is my personal directory
# [1] "/home/brb/R/x86_64-pc-linux-gnu-library/3.2"
# [2] "/usr/local/lib/R/site-library"
# [3] "/usr/lib/R/site-library"
# [4] "/usr/lib/R/library"


Sys.getenv("R_LIBS_USER") # may or may not equivalent to .libPaths()[1]
== Query an R package installed locally ==
ul <- unlist(strsplit(Sys.getenv("R_LIBS_USER"), "/"))
<pre>
src <- file.path(paste(ul[1:(length(ul)-1)], collapse="/"), "3.1")
packageDescription("MASS")
des <- file.path(paste(ul[1:(length(ul)-1)], collapse="/"), "3.2")
packageVersion("MASS")
pkg <- dir(src, full.names = TRUE)
if (!file.exists(des)) dir.create(des)  # If 3.2 subdirectory does not exist yet!
file.copy(pkg, des, overwrite=FALSE, recursive = TRUE)
source("http://www.bioconductor.org/biocLite.R")
biocLite(ask = FALSE)
</pre>
</pre>


<span style="color:#0000FF">From Robert Kabacoff ([https://www.statmethods.net/interface/customizing.html R in Action])</span>
== Query an R package (from CRAN) basic information: available.packages() ==
* If you have a customized '''Rprofile.site file''' (see appendix B), save a copy outside of R.
<syntaxhighlight lang='rsplus'>
* Launch your current version of R and issue the following statements
packageStatus() # Summarize information about installed packages
<pre>
 
oldip <- installed.packages()[,1]
available.packages() # List Available Packages at CRAN-like Repositories
save(oldip, file="path/installedPackages.Rdata")
                    # Even I use an old version of R, it still return the latest version of the packages
</pre>
                    # The 'problem' happens on install.packages() too.
where ''path'' is a directory outside of R.
</syntaxhighlight>
* Download and install the newer version of R.
The '''available.packages()''' command is useful for understanding package dependency. Use '''setRepositories()''' or 'RGUI -> Packages -> select repositories' to select repositories and '''options()$repos''' to check or change the repositories.
* If you saved a customized version of the Rprofile.site file in step 1, copy it into the new installation.
* Launch the new version of R, and issue the following statements
<pre>
load("path/installedPackages.Rdata")
newip <- installed.packages()[,1]
for(i in setdiff(oldip, newip))
  install.packages(i)
</pre>
where path is the location specified in step 2.
*  Delete the old installation (optional).


This approach will install only packages that are available from the CRAN. It won’t find packages obtained from other locations. In fact, the process will display a list of packages that can’t be installed For example for packages obtained from Bioconductor, use the following method to update packages
<span style="color: red">The return result of available.packages() depends on the R version. </span>
<pre>
source(http://bioconductor.org/biocLite.R)
biocLite(PKGNAME)
</pre>


== Would you like to use a personal library instead? ==
The number of packages returned from available.packages() is smaller than the number of packages obtained from '''rsync''' [https://cran.r-project.org/mirror-howto.html CRAN Mirror HOWTO/FAQ]. For example, 19473 < 25000. Some archived packages are still available via rsync.
Some posts from internet
* [https://stackoverflow.com/questions/29969838/setting-r-libs-avoiding-would-you-like-to-use-a-personal-library-instead Setting R_LIBS & avoiding “Would you like to use a personal library instead?”]. Note: I try to create ~/.Renviron to add my personal folder in it. But update.packages() still asks me if I like to use a personal library instead (tested on Ubuntu + R 3.4).
* [https://stackoverflow.com/questions/39879424/automatically-create-personal-library-in-r automatically create personal library in R]. Using suppressUpdates + specify '''lib''' in biocLite() or update.packages(Sys.getenv("R_LIBS_USER"), ask = F) <syntaxhighlight lang='rsplus'>
# create local user library path (not present by default)
dir.create(path = Sys.getenv("R_LIBS_USER"), showWarnings = FALSE, recursive = TRUE)
# install to local user library path
install.packages(p, lib = Sys.getenv("R_LIBS_USER"), repos = "https://cran.rstudio.com/")
# Bioconductor version
biocLite(p, suppressUpdates = TRUE, lib = Sys.getenv("R_LIBS_USER"))
</syntaxhighlight>


The problem can happen if the R was installed to the C:\Program Files\R folder by ''users'' but then some main packages want to be upgraded. R will always pops a message 'Would you like to use a personal library instead?'.  
Also the '''packageStatus()''' is another useful function for query how many packages are in the repositories, how many have been installed, and individual package status (installed or not, needs to be upgraded or not).
{{Pre}}
> options()$repos
                      CRAN
"https://cran.rstudio.com/"


To suppress the message and use the personal library always,
> packageStatus()
* Run R as administrator. If you do that, main packages can be upgraded from C:\Program Files\R\R-X.Y.Z\library folder.
Number of installed packages:
* [[Arraytools#Writable_R_package_directory_cannot_be_found|Writable R package directory cannot be found]] and a [[Arraytools#Download_required_R.2FBioconductor_.28software.29_packages|this]]. A solution here is to change the security of the R library folder so the user has a full control on the folder.
                                   
* [https://cran.r-project.org/bin/windows/base/rw-FAQ.html#Does-R-run-under-Windows-Vista_003f Does R run under Windows Vista/7/8/Server 2008?] There are 3 ways to get around the issue.
                                      ok upgrade unavailable
* [https://cran.r-project.org/bin/windows/base/rw-FAQ.html#I-don_0027t-have-permission-to-write-to-the-R_002d3_002e3_002e2_005clibrary-directory I don’t have permission to write to the R-3.3.2\library directory]
  C:/Program Files/R/R-3.0.1/library 110      0          1


Actually the following hints will help us to create a convenient function UpdateMainLibrary() which will install updated main packages in the user's ''Documents'' directory without a warning dialog.
Number of available packages (each package counted only once):
* '''.libPaths()''' only returns 1 string "C:/Program Files/R/R-x.y.z/library" on the machines that does not have this problem
                                                                                 
* '''.libPaths()''' returns two strings "C:/Users/USERNAME/Documents/R/win-library/x.y" & "C:/Program Files/R/R-x.y.z/library" on machines with the problem.
                                                                                    installed not installed
<syntaxhighlight lang='rsplus'>
  http://watson.nci.nih.gov/cran_mirror/bin/windows/contrib/3.0                            76          4563
UpdateMainLibrary <- function() {
  http://www.stats.ox.ac.uk/pub/RWin/bin/windows/contrib/3.0                                0            5
  # Update main/site packages
  http://www.bioconductor.org/packages/2.12/bioc/bin/windows/contrib/3.0                  16          625
  # The function is used to fix the problem 'Would you like to use a personal library instead?'  
  http://www.bioconductor.org/packages/2.12/data/annotation/bin/windows/contrib/3.0        4          686
  if (length(.libPaths()) == 1) return()
> tmp <- available.packages()
    
> str(tmp)
   ind_mloc <- grep("Program", .libPaths()) # main library e.g. 2
  chr [1:5975, 1:17] "A3" "ABCExtremes" "ABCp2" "ACCLMA" "ACD" "ACNE" "ADGofTest" "ADM3" "AER" ...
   ind_ploc <- grep("Documents", .libPaths()) # personal library e.g. 1
- attr(*, "dimnames")=List of 2
  if (length(ind_mloc) > 0L && length(ind_ploc) > 0L)
   ..$ : chr [1:5975] "A3" "ABCExtremes" "ABCp2" "ACCLMA" ...
     # search outdated main packages
   ..$ : chr [1:17] "Package" "Version" "Priority" "Depends" ...
old_mloc <- ! old.packages(.libPaths()[ind_mloc])[, "Package"] %in%
> tmp[1:3,]
              installed.packages(.libPaths()[ind_ploc])[, "Package"]
            Package      Version Priority Depends                    Imports LinkingTo Suggests           
    oldpac <- old.packages(.libPaths()[ind_mloc])[old_mloc, "Package"]
A3          "A3"          "0.9.2" NA      "xtable, pbapply"          NA      NA        "randomForest, e1071"
if (length(oldpac) > 0L)
ABCExtremes "ABCExtremes" "1.0"   NA      "SpatialExtremes, combinat" NA      NA        NA                 
        install.packages(oldpac, .libPaths()[ind_ploc])
ABCp2      "ABCp2"       "1.1"  NA      "MASS"                      NA      NA        NA                 
}
            Enhances License      License_is_FOSS License_restricts_use OS_type Archs MD5sum NeedsCompilation File
</syntaxhighlight>
A3          NA      "GPL (>= 2)" NA              NA                    NA      NA    NA    NA              NA 
ABCExtremes NA      "GPL-2"      NA              NA                    NA     NA    NA    NA              NA 
ABCp2      NA      "GPL-2"      NA              NA                    NA      NA    NA    NA              NA 
            Repository                                                   
A3          "http://watson.nci.nih.gov/cran_mirror/bin/windows/contrib/3.0"
ABCExtremes "http://watson.nci.nih.gov/cran_mirror/bin/windows/contrib/3.0"
ABCp2      "http://watson.nci.nih.gov/cran_mirror/bin/windows/contrib/3.0"
</pre>
And the following commands find which package depends on Rcpp and also which are from bioconductor repository.
<syntaxhighlight lang='rsplus'>
> pkgName <- "Rcpp"
> rownames(tmp)[grep(pkgName, tmp[,"Depends"])]
> tmp[grep("Rcpp", tmp[,"Depends"]), "Depends"]


On Linux,
> ind <- intersect(grep(pkgName, tmp[,"Depends"]), grep("bioconductor", tmp[, "Repository"]))
<syntaxhighlight lang='rsplus'>
> rownames(grep)[ind]
> update.packages()
NULL
...
> rownames(tmp)[ind]
The downloaded source packages are in
  [1] "ddgraph"            "DESeq2"            "GeneNetworkBuilder" "GOSemSim"          "GRENITS"         
‘/tmp/RtmpBrYccd/downloaded_packages’
  [6] "mosaics"            "mzR"                "pcaMethods"        "Rdisop"            "Risa"             
Warning in install.packages(update[instlib == l, "Package"], l, contriburl = contriburl, :
[11] "rTANDEM"   
                              'lib = "/opt/R/3.5.0/lib/R/library"' is not writable
Would you like to use a personal library instead? (yes/No/cancel) yes
...
> system("ls -lt /home/brb/R/x86_64-pc-linux-gnu-library/3.5 | head")
total 224
drwxrwxr-x 9 brb brb 4096 Oct  3 09:30 survival
drwxrwxr-x 9 brb brb 4096 Oct  3 09:29 mgcv
drwxrwxr-x 10 brb brb 4096 Oct  3 09:29 MASS
drwxrwxr-x  9 brb brb 4096 Oct  3 09:29 foreign
 
# So new versions of survival, mgc, MASS, foreign are installed in the personal directory
# The update.packages() will issue warnings if we try to run it again.
# It's OK to ignore these warnings.
> update.packages()
Warning: package 'foreign' in library '/opt/R/3.5.0/lib/R/library' will not be updated
Warning: package 'MASS' in library '/opt/R/3.5.0/lib/R/library' will not be updated
Warning: package 'mgcv' in library '/opt/R/3.5.0/lib/R/library' will not be updated
Warning: package 'survival' in library '/opt/R/3.5.0/lib/R/library' will not be updated
</syntaxhighlight>
</syntaxhighlight>


== List vignettes from a package ==
== CRAN vs Bioconductor packages ==
<syntaxhighlight lang='rsplus'>
<syntaxhighlight lang='rsplus'>
vignette(package=PACKAGENAME)
> R.version # 3.4.3
</syntaxhighlight>
# CRAN
> x <- available.packages()
> dim(x)
[1] 12581    17


== List data from a package ==
# Bioconductor Soft
<syntaxhighlight lang='rsplus'>
> biocinstallRepos()
data(package=PACKAGENAME)
                                              BioCsoft
</syntaxhighlight>
          "https://bioconductor.org/packages/3.6/bioc"
 
                                                BioCann
=== sysdata.rda ===
"https://bioconductor.org/packages/3.6/data/annotation"
* [https://stackoverflow.com/a/24363504 Load data object when package is loaded]
                                                BioCexp
* https://r-pkgs.org/data.html
"https://bioconductor.org/packages/3.6/data/experiment"
 
                                                  CRAN
== List installed packages and versions ==
                            "https://cran.rstudio.com/"
* http://heuristicandrew.blogspot.com/2015/06/list-of-user-installed-r-packages-and.html
> y <- available.packages(repos = biocinstallRepos()[1])
* [http://cran.r-project.org/web/packages/checkpoint/index.html checkpoint] package
> dim(y)
[1] 1477  17
> intersect(x[, "Package"], y[, "Package"])
character(0)
# Bioconductor Annotation
> dim(available.packages(repos = biocinstallRepos()[2]))
[1] 909  17
# Bioconductor Experiment
> dim(available.packages(repos = biocinstallRepos()[3]))
[1] 326  17


<syntaxhighlight lang='rsplus'>
# CRAN + All Bioconductor
ip <- as.data.frame(installed.packages()[,c(1,3:4)])
> z <- available.packages(repos = biocinstallRepos())
rownames(ip) <- NULL
> dim(z)
unique(ip$Priority)
[1] 15292    17
# [1] <NA>        base        recommended
# Levels: base recommended
ip <- ip[is.na(ip$Priority),1:2,drop=FALSE]
print(ip, row.names=FALSE)
</syntaxhighlight>
</syntaxhighlight>


== Query the names of outdated packages ==
== Downloading Bioconductor package with an old R ==
<pre>
When I try to download the [https://bioconductor.org/packages/release/bioc/html/GenomicDataCommons.html GenomicDataCommons] package using R 3.4.4 with Bioc 3.6 (the current R version is 3.5.0), it was found it can only install version 1.2.0 instead the latest version 1.4.1.
psi <- packageStatus()$inst
 
subset(psi, Status == "upgrade", drop = FALSE)
It does not work by running biocLite("BiocUpgrade") to upgrade Bioc from 3.6 to 3.7.
#                    Package                                  LibPath    Version    Priority                Depends
<syntaxhighlight lang='rsplus'>
# RcppArmadillo RcppArmadillo C:/Users/brb/Documents/R/win-library/3.2 0.5.100.1.0       <NA>                  <NA>
source("https://bioconductor.org/biocLite.R")
# Matrix              Matrix      C:/Program Files/R/R-3.2.0/library      1.2-0 recommended R (>= 2.15.2), methods
biocLite("BiocUpgrade")  
#                                            Imports LinkingTo                Suggests
# Error: Bioconductor version 3.6 cannot be upgraded with R version 3.4.4
# RcppArmadillo                      Rcpp (>= 0.11.0)      Rcpp RUnit, Matrix, pkgKitten
</syntaxhighlight>
# Matrix        graphics, grid, stats, utils, lattice      <NA>               expm, MASS
#                                            Enhances    License License_is_FOSS License_restricts_use OS_type MD5sum
# RcppArmadillo                                  <NA> GPL (>= 2)           <NA>                  <NA>    <NA>  <NA>
# Matrix        MatrixModels, graph, SparseM, sfsmisc GPL (>= 2)           <NA>                  <NA>    <NA>  <NA>
#               NeedsCompilation Built  Status
# RcppArmadillo              yes 3.2.0 upgrade
# Matrix                    yes 3.2.0 upgrade
</pre>


The above output does not show the package version from the latest packages on CRAN. So the following snippet does that.
See some instruction on [https://packagemanager.rstudio.com/client/#/repos/3/overview RStudio package manager] website.
<pre>
 
psi <- packageStatus()$inst
== Analyzing data on CRAN packages ==
pl <- unname(psi$Package[psi$Status == "upgrade"])  # List package names
* New undocumented function in R 3.4.0: '''tools::CRAN_package_db()'''
ap <- as.data.frame(available.packages()[, c(1,2,3)], stringsAsFactors = FALSE)
* http://blog.revolutionanalytics.com/2017/05/analyzing-data-on-cran-packages.html
out <- cbind(subset(psi, Status == "upgrade")[, c("Package", "Version")], ap[match(pl, ap$Package), "Version"])
* [http://blog.schochastics.net/posts/2024-01-17_six-degrees-of-hadley-wickham/ Six degrees of Hadley Wickham: The CRAN co-authorship network]
colnames(out)[2:3] <- c("OldVersion", "NewVersion")
rownames(out) <- NULL
out
#        Package  OldVersion  NewVersion
# 1 RcppArmadillo 0.5.100.1.0 0.5.200.1.0
# 2        Matrix      1.2-0      1.2-1
</pre>


To consider also the packages from Bioconductor, we have the following code. Note that "3.1" means the Bioconductor version and "3.2" is the R version. See [http://bioconductor.org/about/release-announcements/#release-versions Bioconductor release versions] page.
== R package location when they are installed by root ==
<pre>
''/usr/local/lib/R/site-library''
psic <- packageStatus(repos = c(contrib.url(getOption("repos")),
                                "http://bioconductor.org/packages/3.1/bioc/bin/windows/contrib/3.2",
                                "http://www.bioconductor.org/packages/3.1/data/annotation/bin/windows/contrib/3.2"))$inst
subset(psic, Status == "upgrade", drop = FALSE)
pl <- unname(psic$Package[psic$Status == "upgrade"])


ap  <- as.data.frame(available.packages(c(contrib.url(getOption("repos")),
== Customizing your package/library location ==
                                "http://bioconductor.org/packages/3.1/bioc/bin/windows/contrib/3.2",
                                "http://www.bioconductor.org/packages/3.1/data/annotation/bin/windows/contrib/3.2"))[, c(1:3)],
                      stringAsFactors = FALSE)


out <- cbind(subset(psic, Status == "upgrade")[, c("Package", "Version")], ap[match(pl, ap$Package), "Version"])
=== Add a personal directory to .libPaths() ===
colnames(out)[2:3] <- c("OldVersion", "NewVersion")
<syntaxhighlight lang='rsplus'>
rownames(out) <- NULL
.libPaths( c( .libPaths(), "~/userLibrary") )
out
</syntaxhighlight>
#        Package  OldVersion  NewVersion
No need to use the assignment operator.
# 1        limma      3.24.5      3.24.9
# 2 RcppArmadillo 0.5.100.1.0 0.5.200.1.0
# 3        Matrix      1.2-0      1.2-1
</pre>


== Searching for packages in CRAN ==
=== Install personal R packages after upgrade R, .libPaths(), Rprofile.site, R_LIBS_USER ===
* [https://github.com/metacran/pkgsearch#readme pkgsearch] package - Search R packages on CRAN
{| class="wikitable"
** [https://rviews.rstudio.com/2019/03/01/some-r-packages-for-roc-curves/ Some R Packages for ROC Curves]
|-
* [http://blog.revolutionanalytics.com/2015/06/fishing-for-packages-in-cran.html Fishing for packages in CRAN]
! File
* [http://blog.revolutionanalytics.com/2017/01/cran-10000.html CRAN now has 10,000 R packages. Here's how to find the ones you need]
! Example
* [https://rviews.rstudio.com/2018/10/22/searching-for-r-packages/ Searching for R packages], [https://cran.r-project.org/web/packages/packagefinder/index.html packagefinder] package <syntaxhighlight lang='rsplus'>
|-
library(packagefinder)
| Rprofile.site/.Rprofile
findPackage("survival")  
| .libPaths(c("/usr/lib/R/site-library",<br /> &emsp;&emsp;&emsp;&emsp;&emsp; "/usr/lib/R/library"))
# 272 out of 13256 CRAN packages found in 5 seconds
|-
findPackage("follic")
| Renviron.site/.Renviron
# No results found.
| R_LIB_SITE="/usr/lib/R/site-library:/usr/lib/R/library"
# Actually 'follic' comes from randomForestSRC package
|}
# https://www.rdocumentation.org/packages/randomForestSRC/versions/2.7.0
</syntaxhighlight> The result is shown in an html format with columns of SCORE, NAME, DESC_SHORT, DOWNL_TOTAL & GO.


== [http://www.r-pkg.org/ METACRAN (www.r-pkg.org)] - Search and browse all CRAN/R packages ==
Scenario: We already have installed many R packages under R 3.1.X in the user's directory. Now we upgrade R to a new version (3.2.X). We like to have these packages available in R 3.2.X.
* Source code on https://github.com/metacran. The 'PACKAGES' file is updated regularly to Github.
* [https://stat.ethz.ch/pipermail/r-devel/2015-May/thread.html Announcement] on R/mailing list
* Author's homepage on http://gaborcsardi.org/.


== [https://cran.r-project.org/web/packages/cranly/ cranly] visualisations and summaries for R packages ==
<span style="color:#0000FF">For Windows OS, refer to [http://cran.r-project.org/bin/windows/base/rw-FAQ.html#What_0027s-the-best-way-to-upgrade_003f R for Windows FAQ]</span>
[https://rviews.rstudio.com/2018/05/31/exploring-r-packages/ Exploring R packages with cranly]


== Query top downloaded packages, download statistics ==
The follow method works on Linux and Windows.
* Daily download statistics http://cran-logs.rstudio.com/. Note the page is split into 'package' download and 'R' download. It tracks
** Package: date, time, size, r_version, r_arch, r_os, package, version, country, ip_id.
** R: date, time, size, R version, os (win/src/osx), county, ip_id (reset daily).
* Original methods
** https://strengejacke.wordpress.com/2015/03/07/cran-download-statistics-of-any-packages-rstats/
** http://blog.revolutionanalytics.com/2015/06/working-with-the-rstudio-cran-logs.html
* https://www.r-bloggers.com/finally-tracking-cran-packages-downloads/. The code still works.
** [https://gist.github.com/arraytools/f037a4fd90ae8fe8e2896db6fe5b7fad My modified code] for showing the top download R packages. The original code suffers from memory issue (tested on my 64GB Linux box) when it is calling rbindlist() from data.table package with large data. Still 64GB is required since the  matrix is 369M by 4 (12GB).
** [http://www.bnosac.be/index.php/blog/12-popularity-bigdata-large-data-packages-in-r-and-ffbase-user-presentation Popularity bigdata / large data packages in R and ffbase useR presentation]
* [https://github.com/metacran/cranlogs cranlogs] package - Download Logs from the RStudio CRAN Mirror
** [https://colinfay.me/12-months-cranlogs/ 2018 through {cranlogs}]
** [https://hadley.shinyapps.io/cran-downloads/ Shiny app] by Hadley (works for packages on CRAN only)
** [https://blog.r-hub.io/2019/05/02/cranlogs-2-1-1/ cranlogs 2.1.1 is on CRAN!] 5/2/2019
* [https://github.com/lindbrook/packageRank packageRank] package: Computing and Visualizing CRAN Downloads
* [https://blog.rsquaredacademy.com/introducing-pkginfo/ pkginfo]: Tools for Retrieving R Package Information
* For Bioconductor packages, try [http://bioconductor.org/packages/release/bioc/html/BiocPkgTools.html BiocPkgTools]. See the [https://f1000research.com/articles/8-752 paper].


== installation path not writeable from running biocLite() ==
<span style="color:#FF0000">Make sure only one instance of R is running</span>
When I ran biocLite() to install a new package, I got a message (the Bioc packages are installed successfully anyway)
<pre>
<pre>
...
# Step 1. update R's built-in packages and install them on my personal directory
* DONE (curatedOvarianData)
update.packages(ask=FALSE, checkBuilt = TRUE, repos="http://cran.rstudio.com")


The downloaded source packages are in
# Step 2. update Bioconductor packages
/tmp/RtmpHxnH2K/downloaded_packages’
.libPaths() # The first one is my personal directory
installation path not writeable, unable to update packages: rgl, rJava,
# [1] "/home/brb/R/x86_64-pc-linux-gnu-library/3.2"
  codetools, foreign, lattice, MASS, spatial, survival
# [2] "/usr/local/lib/R/site-library"
# [3] "/usr/lib/R/site-library"
# [4] "/usr/lib/R/library"
 
Sys.getenv("R_LIBS_USER") # may or may not equivalent to .libPaths()[1]
ul <- unlist(strsplit(Sys.getenv("R_LIBS_USER"), "/"))
src <- file.path(paste(ul[1:(length(ul)-1)], collapse="/"), "3.1")
des <- file.path(paste(ul[1:(length(ul)-1)], collapse="/"), "3.2")
pkg <- dir(src, full.names = TRUE)
if (!file.exists(des)) dir.create(des)  # If 3.2 subdirectory does not exist yet!
file.copy(pkg, des, overwrite=FALSE, recursive = TRUE)
source("http://www.bioconductor.org/biocLite.R")
biocLite(ask = FALSE)
</pre>
</pre>
However, if I uses install.package() it can update the package
<syntaxhighlight lang='rsplus'>
> packageVersion("survival")
[1] ‘2.42.3’
> update.packages("survival")  # Not working though no error message
> packageVersion("survival")
[1] ‘2.42.3’
> install.packages("survival")
Installing package into ‘/home/brb/R/x86_64-pc-linux-gnu-library/3.4’
...
* DONE (survival)


The downloaded source packages are in
<span style="color:#0000FF">From Robert Kabacoff ([https://www.statmethods.net/interface/customizing.html R in Action])</span>
‘/tmp/RtmpHxnH2K/downloaded_packages’
* If you have a customized '''Rprofile.site file''' (see appendix B), save a copy outside of R.
> packageVersion("survival")
* Launch your current version of R and issue the following statements
[1] ‘2.42.6’
> library(survival)
> sessionInfo() # show survival package 2.42-6 was attached
</syntaxhighlight>
 
It makes sense to always use personal directory when we install packages. See .libPaths().
 
== Warning: cannot remove prior installation of package ==
http://stackoverflow.com/questions/15932152/unloading-and-removing-a-loaded-package-withouth-restarting-r
 
Instance 1.
<pre>
<pre>
# Install the latest hgu133plus2cdf package
oldip <- installed.packages()[,1]
# Remove/Uninstall hgu133plus2.db package
save(oldip, file="path/installedPackages.Rdata")
# Put/Install an old version of IRanges (eg version 1.18.2 while currently it is version 1.18.3)
# Test on R 3.0.1
library(hgu133plus2cdf) # hgu133pluscdf does not depend or import IRanges
source("http://bioconductor.org/biocLite.R")
biocLite("hgu133plus2.db", ask=FALSE) # hgu133plus2.db imports IRanges
# Warning:cannot remove prior installation of package 'IRanges'
# Open Windows Explorer and check IRanges folder. Only see libs subfolder.
</pre>
</pre>
where ''path'' is a directory outside of R.
* Download and install the newer version of R.
* If you saved a customized version of the Rprofile.site file in step 1, copy it into the new installation.
* Launch the new version of R, and issue the following statements
<pre>
load("path/installedPackages.Rdata")
newip <- installed.packages()[,1]
for(i in setdiff(oldip, newip))
  install.packages(i)
</pre>
where path is the location specified in step 2.
*  Delete the old installation (optional).


Note:
This approach will install only packages that are available from the CRAN. It won’t find packages obtained from other locations. In fact, the process will display a list of packages that can’t be installed For example for packages obtained from Bioconductor, use the following method to update packages
* In the above example, all packages were installed under C:\Program Files\R\R-3.0.1\library\.
* In another instance where I cannot reproduce the problem, new R packages were installed under C:\Users\xxx\Documents\R\win-library\3.0\. The different thing is IRanges package CAN be updated but if I use packageVersion("IRanges") command in R, it still shows the old version.
* The above were tested on a desktop.
 
Instance 2.
<pre>
<pre>
# On a fresh R 3.2.0, I install Bioconductor's depPkgTools & lumi packages. Then I close R, re-open it,
source(http://bioconductor.org/biocLite.R)
# and install depPkgTools package again.
biocLite(PKGNAME)
> source("http://bioconductor.org/biocLite.R")
</pre>
Bioconductor version 3.1 (BiocInstaller 1.18.2), ?biocLite for help
> biocLite("pkgDepTools")
BioC_mirror: http://bioconductor.org
Using Bioconductor version 3.1 (BiocInstaller 1.18.2), R version 3.2.0.
Installing package(s) ‘pkgDepTools’
trying URL 'http://bioconductor.org/packages/3.1/bioc/bin/windows/contrib/3.2/pkgDepTools_1.34.0.zip'
Content type 'application/zip' length 390579 bytes (381 KB)
downloaded 381 KB


package ‘pkgDepTools’ successfully unpacked and MD5 sums checked
=== Persistent config and data for R packages with .Rprofile and .Renviron ===
Warning: cannot remove prior installation of package ‘pkgDepTools’
[https://blog.r-hub.io/2020/03/12/user-preferences/ Persistent config and data for R packages]. startup, rappdirs, hoardr, keyring.


The downloaded binary packages are in
=== Would you like to use a personal library instead? ===
        C:\Users\brb\AppData\Local\Temp\RtmpYd2l7i\downloaded_packages
Some posts from internet
> library(pkgDepTools)
* [https://stackoverflow.com/questions/29969838/setting-r-libs-avoiding-would-you-like-to-use-a-personal-library-instead Setting R_LIBS & avoiding “Would you like to use a personal library instead?”]. Note: I try to create ~/.Renviron to add my personal folder in it. But update.packages() still asks me if I like to use a personal library instead (tested on Ubuntu + R 3.4).
Error in library(pkgDepTools) : there is no package called ‘pkgDepTools’
* [https://stackoverflow.com/questions/39879424/automatically-create-personal-library-in-r automatically create personal library in R]. Using suppressUpdates + specify '''lib''' in biocLite() or update.packages(Sys.getenv("R_LIBS_USER"), ask = F) <syntaxhighlight lang='rsplus'>
</pre>
# create local user library path (not present by default)
The pkgDepTools library folder appears in C:\Users\brb\Documents\R\win-library\3.2, but it is empty. The weird thing is if I try the above steps again, I cannot reproduce the problem.
dir.create(path = Sys.getenv("R_LIBS_USER"), showWarnings = FALSE, recursive = TRUE)
# install to local user library path
install.packages(p, lib = Sys.getenv("R_LIBS_USER"), repos = "https://cran.rstudio.com/")
# Bioconductor version
biocLite(p, suppressUpdates = TRUE, lib = Sys.getenv("R_LIBS_USER"))
</syntaxhighlight>


== Warning: dependency ‘XXX’ is not available ==
The problem can happen if the R was installed to the C:\Program Files\R folder by ''users'' but then some main packages want to be upgraded. R will always pops a message 'Would you like to use a personal library instead?'.  
[https://stackoverflow.com/a/25721890 How should I deal with “package 'xxx' is not available (for R version x.y.z)” warning?]


== Error: there is no package called XXX ==
To suppress the message and use the personal library always,
The error happened when I try to run library() command on a package that was just installed. R 3.6.0. 'biospear' version is 1.0.2. macOS.
* Run R as administrator. If you do that, main packages can be upgraded from C:\Program Files\R\R-X.Y.Z\library folder.
<syntaxhighlight lang='rsplus'>
* [[Arraytools#Writable_R_package_directory_cannot_be_found|Writable R package directory cannot be found]] and a [[Arraytools#Download_required_R.2FBioconductor_.28software.29_packages|this]]. A solution here is to change the security of the R library folder so the user has a full control on the folder.
> library(biospear)
* [https://cran.r-project.org/bin/windows/base/rw-FAQ.html#Does-R-run-under-Windows-Vista_003f Does R run under Windows Vista/7/8/Server 2008?] There are 3 ways to get around the issue.
Loading required package: pkgconfig
* [https://cran.r-project.org/bin/windows/base/rw-FAQ.html#I-don_0027t-have-permission-to-write-to-the-R_002d3_002e3_002e2_005clibrary-directory I don’t have permission to write to the R-3.3.2\library directory]
Error: package or namespace load failed for ‘biospear’ in loadNamespace(i, c(lib.loc, .libPaths()), versionCheck = vI[[i]]):
 
  there is no package called ‘mixOmics’
Actually the following hints will help us to create a convenient function UpdateMainLibrary() which will install updated main packages in the user's ''Documents'' directory without a warning dialog.
* '''.libPaths()''' only returns 1 string "C:/Program Files/R/R-x.y.z/library" on the machines that does not have this problem
* '''.libPaths()''' returns two strings "C:/Users/USERNAME/Documents/R/win-library/x.y" & "C:/Program Files/R/R-x.y.z/library" on machines with the problem.
<syntaxhighlight lang='rsplus'>
UpdateMainLibrary <- function() {
  # Update main/site packages
  # The function is used to fix the problem 'Would you like to use a personal library instead?' 
  if (length(.libPaths()) == 1) return()
 
  ind_mloc <- grep("Program", .libPaths()) # main library e.g. 2
  ind_ploc <- grep("Documents", .libPaths()) # personal library e.g. 1
  if (length(ind_mloc) > 0L && length(ind_ploc) > 0L)
    # search outdated main packages
old_mloc <- ! old.packages(.libPaths()[ind_mloc])[, "Package"] %in%
              installed.packages(.libPaths()[ind_ploc])[, "Package"]
    oldpac <- old.packages(.libPaths()[ind_mloc])[old_mloc, "Package"]
if (length(oldpac) > 0L)
        install.packages(oldpac, .libPaths()[ind_ploc])  
}
</syntaxhighlight>
</syntaxhighlight>


Note
On Linux,
<syntaxhighlight lang='rsplus'>
> update.packages()
...
The downloaded source packages are in
‘/tmp/RtmpBrYccd/downloaded_packages’
Warning in install.packages(update[instlib == l, "Package"], l, contriburl = contriburl,  :
                              'lib = "/opt/R/3.5.0/lib/R/library"' is not writable
Would you like to use a personal library instead? (yes/No/cancel) yes
...
> system("ls -lt /home/brb/R/x86_64-pc-linux-gnu-library/3.5 | head")
total 224
drwxrwxr-x  9 brb brb 4096 Oct  3 09:30 survival
drwxrwxr-x  9 brb brb 4096 Oct  3 09:29 mgcv
drwxrwxr-x 10 brb brb 4096 Oct  3 09:29 MASS
drwxrwxr-x  9 brb brb 4096 Oct  3 09:29 foreign


* The package [https://cran.r-project.org/web/packages/mixOmics/index.html mixOmics] was removed from CRAN. It is now available on Bioconductor.
# So new versions of survival, mgc, MASS, foreign are installed in the personal directory
* Tested to install on a docker container: '''docker run --net=host -it --rm r-base''' <syntaxhighlight lang='rsplus'>
# The update.packages() will issue warnings if we try to run it again.  
ERROR: dependency ‘car’ is not available for package ‘plsRglm’
# It's OK to ignore these warnings.
* removing ‘/usr/local/lib/R/site-library/plsRglm’
> update.packages()
ERROR: dependencies ‘plsRglm’, ‘mixOmics’, ‘survcomp’ are not available for package ‘plsRcox’
Warning: package 'foreign' in library '/opt/R/3.5.0/lib/R/library' will not be updated
* removing ‘/usr/local/lib/R/site-library/plsRcox’
Warning: package 'MASS' in library '/opt/R/3.5.0/lib/R/library' will not be updated
ERROR: dependencies ‘devtools’, ‘plsRcox’, ‘RCurl’ are not available for package ‘biospear’
Warning: package 'mgcv' in library '/opt/R/3.5.0/lib/R/library' will not be updated
* removing ‘/usr/local/lib/R/site-library/biospear’
Warning: package 'survival' in library '/opt/R/3.5.0/lib/R/library' will not be updated
</syntaxhighlight>The car package looks OK on CRAN. [https://cran.r-project.org/web/packages/survcomp/index.html survcomp] was moved from CRAN to Bioconductor too.
* As we can see above, the official r-base image does not contain libraries enough to install RCurl/devtools packages. Consider the [https://hub.docker.com/r/rocker/tidyverse tidyverse] image (based on [https://github.com/rocker-org/rocker-versioned/blob/master/rstudio/Dockerfile RStudio image]) from the rocker project. <syntaxhighlight lang='bash'>
docker pull rocker/tidyverse:3.6.0
docker run --net=host -it --rm -e PASSWORD=password -p 8787:8787 rocker/tidyverse:3.6.0
# the default username is 'rstudio'
# Open a browser, log in. Run 'install.packages("RCurl")'. It works.
</syntaxhighlight>
</syntaxhighlight>
* Testing on Mint linux also shows errors about dependencies of mixOmics and survcomp.
* '''The best practice to install a package that may depend on packages located/moved to Bioconductor''': Run '''setRepositories(ind=1:2)''' before calling install.packages(). However, it does not '''remedy''' the situation that the 1st level imports package (eg plsRcox) was installed before but the 2nd level imports package (eg mixOmics) was not installed.
* [https://stat.ethz.ch/R-manual/R-devel/library/tools/html/dependsOnPkgs.html dependsOnPkgs()]: Find Reverse Dependencies


== Warning: Unable to move temporary installation ==
=== R_LIBS_USER is empty in R 3.4.1 ===
The problem seems to happen only on virtual machines (Virtualbox).
See [[R#install.package.28.29_error.2C_R_LIBS_USER_is_empty_in_R_3.4.1|install.package() error, R_LIBS_USER is empty in R 3.4.1]].
* '''Warning: unable to move temporary installation `C:\Users\brb\Documents\R\win-library\3.0\fileed8270978f5\quadprog` to `C:\Users\brb\Documents\R\win-library\3.0\quadprog`''' when I try to run 'install.packages("forecast").
 
* '''Warning: unable to move temporary installation ‘C:\Users\brb\Documents\R\win-library\3.2\file5e0104b5b49\plyr’ to ‘C:\Users\brb\Documents\R\win-library\3.2\plyr’ ''' when I try to run 'biocLite("lumi")'. The other dependency packages look fine although I am not sure if any unknown problem can happen (it does, see below).
== List vignettes from a package ==
<syntaxhighlight lang='rsplus'>
vignette(package=PACKAGENAME)
</syntaxhighlight>


Here is a note of my trouble shooting.
== List data from a package ==
# If I try to ignore the warning and load the lumi package. I will get an error.
<syntaxhighlight lang='rsplus'>
# If I try to run biocLite("lumi") again, it will only download & install lumi without checking missing 'plyr' package. Therefore, when I try to load the lumi package, it will give me an error again.
data(package=PACKAGENAME)
# Even I install the plyr package manually, library(lumi) gives another error - missing mclust package.
</syntaxhighlight>
<pre>
 
> biocLite("lumi")
=== sysdata.rda ===
trying URL 'http://bioconductor.org/packages/3.1/bioc/bin/windows/contrib/3.2/BiocInstaller_1.18.2.zip'
* [https://stackoverflow.com/a/24363504 Load data object when package is loaded]
Content type 'application/zip' length 114097 bytes (111 KB)
* https://r-pkgs.org/data.html
downloaded 111 KB
 
...
== List all functions of a package ==
package ‘lumi’ successfully unpacked and MD5 sums checked
Assume a package is already loaded. Then
<pre>
ls("package:cowplot")
</pre>


The downloaded binary packages are in
[http://www.cookbook-r.com/Scripts_and_functions/Getting_a_list_of_functions_and_objects_in_a_package/ Getting a list of functions and objects in a package]. This also assumes the package in loaded. In addition to functions (separated by primitive and non-primitive), it can show constants and objects.
        C:\Users\brb\AppData\Local\Temp\RtmpyUjsJD\downloaded_packages
Old packages: 'BiocParallel', 'Biostrings', 'caret', 'DESeq2', 'gdata', 'GenomicFeatures', 'gplots', 'Hmisc', 'Rcpp', 'RcppArmadillo', 'rgl',
  'stringr'
Update all/some/none? [a/s/n]: a
also installing the dependencies ‘Rsamtools’, ‘GenomicAlignments’, ‘plyr’, ‘rtracklayer’, ‘gridExtra’, ‘stringi’, ‘magrittr’


trying URL 'http://bioconductor.org/packages/3.1/bioc/bin/windows/contrib/3.2/Rsamtools_1.20.1.zip'
== List installed packages and versions ==
Content type 'application/zip' length 8138197 bytes (7.8 MB)
* http://heuristicandrew.blogspot.com/2015/06/list-of-user-installed-r-packages-and.html
downloaded 7.8 MB
* [http://cran.r-project.org/web/packages/checkpoint/index.html checkpoint] package
...
package ‘Rsamtools’ successfully unpacked and MD5 sums checked
package ‘GenomicAlignments’ successfully unpacked and MD5 sums checked
package ‘plyr’ successfully unpacked and MD5 sums checked
Warning: unable to move temporary installation ‘C:\Users\brb\Documents\R\win-library\3.2\file5e0104b5b49\plyr’
        to ‘C:\Users\brb\Documents\R\win-library\3.2\plyr’
package ‘rtracklayer’ successfully unpacked and MD5 sums checked
package ‘gridExtra’ successfully unpacked and MD5 sums checked
package ‘stringi’ successfully unpacked and MD5 sums checked
package ‘magrittr’ successfully unpacked and MD5 sums checked
package ‘BiocParallel’ successfully unpacked and MD5 sums checked
package ‘Biostrings’ successfully unpacked and MD5 sums checked
Warning: cannot remove prior installation of package ‘Biostrings’
package ‘caret’ successfully unpacked and MD5 sums checked
package ‘DESeq2’ successfully unpacked and MD5 sums checked
package ‘gdata’ successfully unpacked and MD5 sums checked
package ‘GenomicFeatures’ successfully unpacked and MD5 sums checked
package ‘gplots’ successfully unpacked and MD5 sums checked
package ‘Hmisc’ successfully unpacked and MD5 sums checked
package ‘Rcpp’ successfully unpacked and MD5 sums checked
package ‘RcppArmadillo’ successfully unpacked and MD5 sums checked
package ‘rgl’ successfully unpacked and MD5 sums checked
package ‘stringr’ successfully unpacked and MD5 sums checked


The downloaded binary packages are in
<syntaxhighlight lang='rsplus'>
        C:\Users\brb\AppData\Local\Temp\RtmpyUjsJD\downloaded_packages
ip <- as.data.frame(installed.packages()[,c(1,3:4)])
> library(lumi)
rownames(ip) <- NULL
Error in loadNamespace(i, c(lib.loc, .libPaths()), versionCheck = vI[[i]]) :
unique(ip$Priority)
  there is no package called ‘plyr’
# [1] <NA>        base       recommended
Error: package or namespace load failed for ‘lumi’
# Levels: base recommended
> search()
ip <- ip[is.na(ip$Priority),1:2,drop=FALSE]
[1] ".GlobalEnv"            "package:BiocInstaller" "package:Biobase"      "package:BiocGenerics"  "package:parallel"      "package:stats"        
print(ip, row.names=FALSE)
[7] "package:graphics"      "package:grDevices"    "package:utils"        "package:datasets"      "package:methods"      "Autoloads"           
</syntaxhighlight>
[13] "package:base"       
> biocLite("lumi")
BioC_mirror: http://bioconductor.org
Using Bioconductor version 3.1 (BiocInstaller 1.18.2), R version 3.2.0.
Installing package(s) ‘lumi’
trying URL 'http://bioconductor.org/packages/3.1/bioc/bin/windows/contrib/3.2/lumi_2.20.1.zip'
Content type 'application/zip' length 18185326 bytes (17.3 MB)
downloaded 17.3 MB


package ‘lumi’ successfully unpacked and MD5 sums checked
== Query the names of outdated packages ==
 
{{Pre}}
The downloaded binary packages are in
psi <- packageStatus()$inst
        C:\Users\brb\AppData\Local\Temp\RtmpyUjsJD\downloaded_packages
subset(psi, Status == "upgrade", drop = FALSE)
> search()
#                    Package                                  LibPath     Version    Priority                Depends
[1] ".GlobalEnv"           "package:BiocInstaller" "package:Biobase"      "package:BiocGenerics"  "package:parallel"      "package:stats"       
# RcppArmadillo RcppArmadillo C:/Users/brb/Documents/R/win-library/3.2 0.5.100.1.0        <NA>                  <NA>
[7] "package:graphics"      "package:grDevices"     "package:utils"        "package:datasets"      "package:methods"      "Autoloads"           
# Matrix              Matrix      C:/Program Files/R/R-3.2.0/library      1.2-0 recommended R (>= 2.15.2), methods
[13] "package:base"       
#                                            Imports LinkingTo                Suggests
> library(lumi)
# RcppArmadillo                      Rcpp (>= 0.11.0)      Rcpp RUnit, Matrix, pkgKitten
Error in loadNamespace(i, c(lib.loc, .libPaths()), versionCheck = vI[[i]]) :
# Matrix        graphics, grid, stats, utils, lattice      <NA>              expm, MASS
  there is no package called ‘plyr’
#                                            Enhances    License License_is_FOSS License_restricts_use OS_type MD5sum
Error: package or namespace load failed for ‘lumi’
# RcppArmadillo                                  <NA> GPL (>= 2)            <NA>                  <NA>    <NA>  <NA>
> biocLite("plyr")
# Matrix        MatrixModels, graph, SparseM, sfsmisc GPL (>= 2)           <NA>                  <NA>    <NA>  <NA>
BioC_mirror: http://bioconductor.org
#              NeedsCompilation Built  Status
Using Bioconductor version 3.1 (BiocInstaller 1.18.2), R version 3.2.0.
# RcppArmadillo              yes 3.2.0 upgrade
Installing package(s) ‘plyr’
# Matrix                    yes 3.2.0 upgrade
trying URL 'http://cran.rstudio.com/bin/windows/contrib/3.2/plyr_1.8.2.zip'
</pre>
Content type 'application/zip' length 1128621 bytes (1.1 MB)
downloaded 1.1 MB


package ‘plyr’ successfully unpacked and MD5 sums checked
The above output does not show the package version from the latest packages on CRAN. So the following snippet does that.
{{Pre}}
psi <- packageStatus()$inst
pl <- unname(psi$Package[psi$Status == "upgrade"])  # List package names
ap <- as.data.frame(available.packages()[, c(1,2,3)], stringsAsFactors = FALSE)
out <- cbind(subset(psi, Status == "upgrade")[, c("Package", "Version")], ap[match(pl, ap$Package), "Version"])
colnames(out)[2:3] <- c("OldVersion", "NewVersion")
rownames(out) <- NULL
out
#        Package  OldVersion  NewVersion
# 1 RcppArmadillo 0.5.100.1.0 0.5.200.1.0
# 2        Matrix      1.2-0      1.2-1
</pre>


The downloaded binary packages are in
To consider also the packages from Bioconductor, we have the following code. Note that "3.1" means the Bioconductor version and "3.2" is the R version. See [http://bioconductor.org/about/release-announcements/#release-versions Bioconductor release versions] page.
        C:\Users\brb\AppData\Local\Temp\RtmpyUjsJD\downloaded_packages
{{Pre}}
psic <- packageStatus(repos = c(contrib.url(getOption("repos")),
                                "http://bioconductor.org/packages/3.1/bioc/bin/windows/contrib/3.2",
                                "http://www.bioconductor.org/packages/3.1/data/annotation/bin/windows/contrib/3.2"))$inst
subset(psic, Status == "upgrade", drop = FALSE)
pl <- unname(psic$Package[psic$Status == "upgrade"])


> library(lumi)
ap  <- as.data.frame(available.packages(c(contrib.url(getOption("repos")),
Error in loadNamespace(j <- i[[1L]], c(lib.loc, .libPaths()), versionCheck = vI[[j]]) :
                                "http://bioconductor.org/packages/3.1/bioc/bin/windows/contrib/3.2",
  there is no package called ‘mclust’
                                "http://www.bioconductor.org/packages/3.1/data/annotation/bin/windows/contrib/3.2"))[, c(1:3)],  
Error: package or namespace load failed for ‘lumi’
                      stringAsFactors = FALSE)


> ?biocLite
out <- cbind(subset(psic, Status == "upgrade")[, c("Package", "Version")], ap[match(pl, ap$Package), "Version"])
Warning messages:
colnames(out)[2:3] <- c("OldVersion", "NewVersion")
1: In read.dcf(file.path(p, "DESCRIPTION"), c("Package", "Version")) :
rownames(out) <- NULL
  cannot open compressed file 'C:/Users/brb/Documents/R/win-library/3.2/Biostrings/DESCRIPTION', probable reason 'No such file or directory'
out
2: In find.package(if (is.null(package)) loadedNamespaces() else package,  :
#        Package  OldVersion  NewVersion
  there is no package called ‘Biostrings’
# 1        limma      3.24.5      3.24.9
> library(lumi)
# 2 RcppArmadillo 0.5.100.1.0 0.5.200.1.0
Error in loadNamespace(j <- i[[1L]], c(lib.loc, .libPaths()), versionCheck = vI[[j]]) :
# 3        Matrix      1.2-0      1.2-1
  there is no package called ‘mclust’
In addition: Warning messages:
1: In read.dcf(file.path(p, "DESCRIPTION"), c("Package", "Version")) :
  cannot open compressed file 'C:/Users/brb/Documents/R/win-library/3.2/Biostrings/DESCRIPTION', probable reason 'No such file or directory'
2: In find.package(if (is.null(package)) loadedNamespaces() else package,  :
  there is no package called ‘Biostrings’
Error: package or namespace load failed for ‘lumi’
</pre>
</pre>


[http://r.789695.n4.nabble.com/unable-to-move-temporary-installation-td4521714.html Other people also have the similar problem]. The possible cause is the virus scanner locks the file and R cannot move them.
== Searching for packages in CRAN ==
 
* [https://github.com/metacran/pkgsearch#readme pkgsearch] package - Search R packages on CRAN
Some possible solutions:
** [https://rviews.rstudio.com/2019/03/01/some-r-packages-for-roc-curves/ Some R Packages for ROC Curves]
# Delete ALL folders under R/library (e.g. C:/Progra~1/R/R-3.2.0/library) folder and install the main package again using install.packages() or biocLite().
* [http://blog.revolutionanalytics.com/2015/06/fishing-for-packages-in-cran.html Fishing for packages in CRAN]
# For specific package like 'lumi' from Bioconductor, we can [[R#Bioconductor.27s_pkgDepTools_package|find out all dependency packages]] and then install them one by one.
* [http://blog.revolutionanalytics.com/2017/01/cran-10000.html CRAN now has 10,000 R packages. Here's how to find the ones you need]
# Find out and install the top level package which misses dependency packages.  
* [https://rviews.rstudio.com/2018/10/22/searching-for-r-packages/ Searching for R packages], [https://cran.r-project.org/web/packages/packagefinder/index.html packagefinder] package <syntaxhighlight lang='rsplus'>
## This is based on the fact that install.packages() or biocLite() '''sometimes''' just checks & installs the 'Depends' and 'Imports' packages and '''won't install all packages recursively'''
library(packagefinder)
## we can do a small experiment by removing a package which is not directly dependent/imported by another package; e.g. 'iterators' is not dependent/imported by 'glment' directly but indirectly. So if we run '''remove.packages("iterators"); install.packages("glmnet")''', then the 'iterator' package is still missing.
findPackage("survival")  
## A real example is if the missing packages are 'Biostrings', 'limma', 'mclust' (these are packages that 'minfi' directly depends/imports although they should be installed when I run biocLite("lumi") command), then I should just run the command '''remove.packages("minfi"); biocLite("minfi")'''. If we just run biocLite("lumi") or biocLite("methylumi"), the missing packages won't be installed.
# 272 out of 13256 CRAN packages found in 5 seconds
findPackage("follic")
# No results found.
# Actually 'follic' comes from randomForestSRC package
# https://www.rdocumentation.org/packages/randomForestSRC/versions/2.7.0
</syntaxhighlight> The result is shown in an html format with columns of SCORE, NAME, DESC_SHORT, DOWNL_TOTAL & GO.
 
== [http://www.r-pkg.org/ METACRAN (www.r-pkg.org)] - Search and browse all CRAN/R packages ==
* Source code on https://github.com/metacran. The 'PACKAGES' file is updated regularly to Github.
* [https://stat.ethz.ch/pipermail/r-devel/2015-May/thread.html Announcement] on R/mailing list
* Author's homepage on http://gaborcsardi.org/.


== Error in download.file(url, destfile, method, mode = "wb", ...) ==
== [https://cran.r-project.org/web/packages/cranly/ cranly] visualisations and summaries for R packages ==
HTTP status was '404 Not Found'
[https://rviews.rstudio.com/2018/05/31/exploring-r-packages/ Exploring R packages with cranly]


Tested on an existing R-3.2.0 session. Note that VariantAnnotation 1.14.4 was just uploaded to Bioc.
== Query top downloaded packages, download statistics ==
<pre>
* Daily download statistics http://cran-logs.rstudio.com/. Note the page is split into 'package' download and 'R' download. It tracks
> biocLite("COSMIC.67")
** Package: date, time, size, r_version, r_arch, r_os, package, version, country, ip_id.
BioC_mirror: http://bioconductor.org
** R: date, time, size, R version, os (win/src/osx), county, ip_id (reset daily).
Using Bioconductor version 3.1 (BiocInstaller 1.18.3), R version 3.2.0.
* Original methods
Installing package(s) ‘COSMIC.67’
** https://strengejacke.wordpress.com/2015/03/07/cran-download-statistics-of-any-packages-rstats/
also installing the dependency ‘VariantAnnotation’
** http://blog.revolutionanalytics.com/2015/06/working-with-the-rstudio-cran-logs.html
* https://www.r-bloggers.com/finally-tracking-cran-packages-downloads/. The code still works.
** [https://gist.github.com/arraytools/f037a4fd90ae8fe8e2896db6fe5b7fad My modified code] for showing the top download R packages. The original code suffers from memory issue (tested on my 64GB Linux box) when it is calling rbindlist() from data.table package with large data. Still 64GB is required since the  matrix is 369M by 4 (12GB).
** [http://www.bnosac.be/index.php/blog/12-popularity-bigdata-large-data-packages-in-r-and-ffbase-user-presentation Popularity bigdata / large data packages in R and ffbase useR presentation]
* [https://blog.rsquaredacademy.com/introducing-pkginfo/ pkginfo]: Tools for Retrieving R Package Information. It's only in github. Shiny interface.
* [https://www.r-pkg.org/downloaded Top 100 downloaded packages] from METACRAN


trying URL 'http://bioconductor.org/packages/3.1/bioc/bin/windows/contrib/3.2/VariantAnnotation_1.14.3.zip'
=== cranlogs ===
Error in download.file(url, destfile, method, mode = "wb", ...) :
[https://github.com/metacran/cranlogs cranlogs] package - Download Logs from the RStudio CRAN Mirror. Suitable on R console.
  cannot open URL 'http://bioconductor.org/packages/3.1/bioc/bin/windows/contrib/3.2/VariantAnnotation_1.14.3.zip'
* [https://colinfay.me/12-months-cranlogs/ 2018 through {cranlogs}]
In addition: Warning message:
* [https://hadley.shinyapps.io/cran-downloads/ Shiny app] by Hadley (works for packages on CRAN only). It's like the Google Trend app. An example of collection: '''survC1, survAUC, TreatmentSelection, biospear , (glmnet)'''
In download.file(url, destfile, method, mode = "wb", ...) :
* [https://blog.r-hub.io/2019/05/02/cranlogs-2-1-1/ cranlogs 2.1.1 is on CRAN!] 5/2/2019
  cannot open: HTTP status was '404 Not Found'
* [https://github.com/r-hub/cranlogs/issues/56 limit on number of packages as argument to cran_downloads]
Warning in download.packages(pkgs, destdir = tmpd, available = available,  :
<pre>
  download of package ‘VariantAnnotation’ failed
library(cranlogs)
installing the source package ‘COSMIC.67’
out <- cran_top_downloads("last-week", 100) # 100 is the maximum limit
out$package
</pre>


trying URL 'http://bioconductor.org/packages/3.1/data/experiment/src/contrib/COSMIC.67_1.4.0.tar.gz'
=== packageRank ===
Content type 'application/x-gzip' length 40999037 bytes (39.1 MB)
[https://github.com/lindbrook/packageRank packageRank] package: Computing and Visualizing CRAN Downloads. Suitable to run on RStudio cloud. Include both CRAN and Bioconductor.
{{Pre}}
> plot(cranDownloads(packages = c("packageRank", "limma"), when = "last-month"))
> plot(cranDownloads(packages = c("shiny", "glmnet"), when = "last-month"))
> plot(cranDownloads(packages = c("shiny", "glmnet"), from = "2019", to ="2019"))
> plot(cranDownloads(packages = c("shiny", "glmnet"), from = "2019-12", to ="2019-12"))
> plot(bioconductorDownloads(packages = c("edgeR", "DESeq2", "Rsubread", "limma"), when = "last-year"))
</pre>
</pre>


However, when I tested on a new R-3.2.0 (just installed in VM), the COSMIC package installation is successful. That VariantAnnotation version 1.14.4 was installed (this version was just updated today from Bioconductor).
=== BiocPkgTools ===
For Bioconductor packages, try [http://bioconductor.org/packages/release/bioc/html/BiocPkgTools.html BiocPkgTools]. See the [https://f1000research.com/articles/8-752 paper].
 
=== dlstats ===
[https://cran.r-project.org/web/packages/dlstats/ dlstats]. Monthly download stats of 'CRAN' and 'Bioconductor' packages.


The cause of the error is the '''[https://github.com/wch/r-source/blob/trunk/src/library/utils/R/packages.R available.package()]''' function will read the rds file first from cache in a tempdir (C:\Users\XXXX\AppData\Local\Temp\RtmpYYYYYY). See lines 51-55 of <packages.R>.
== installation path not writeable from running biocLite() ==
When I ran biocLite() to install a new package, I got a message (the Bioc packages are installed successfully anyway)
<pre>
<pre>
dest <- file.path(tempdir(),
...
                  paste0("repos_", URLencode(repos, TRUE), ".rds"))
* DONE (curatedOvarianData)
if(file.exists(dest)) {
    res0 <- readRDS(dest)
} else {
    ...
</pre>
Since my R was opened 1 week ago, the rds file it reads today contains old information. Note that Bioconductor does not hold the source code or binary code for the old version of packages. This explains why biocLite() function broke. When I restart R, the original problem is gone.


If we look at the source code of available.packages(), we will see we could use '''cacheOK''' option in download.file() function.
The downloaded source packages are in
<pre>
‘/tmp/RtmpHxnH2K/downloaded_packages’
download.file(url, destfile, method, cacheOK = FALSE, quiet = TRUE, mode ="wb")
installation path not writeable, unable to update packages: rgl, rJava,
  codetools, foreign, lattice, MASS, spatial, survival
</pre>
</pre>
However, if I uses install.package() it can update the package
<syntaxhighlight lang='rsplus'>
> packageVersion("survival")
[1] ‘2.42.3’
> update.packages("survival")  # Not working though no error message
> packageVersion("survival")
[1] ‘2.42.3’
> install.packages("survival")
Installing package into ‘/home/brb/R/x86_64-pc-linux-gnu-library/3.4’
...
* DONE (survival)


== Another case: Error in download.file(url, destfile, method, mode = "wb", ...) ==
The downloaded source packages are in
<pre>
‘/tmp/RtmpHxnH2K/downloaded_packages’
> install.packages("quantreg")
> packageVersion("survival")
 
[1] ‘2.42.6’
  There is a binary version available but the source version is later:
> library(survival)
        binary source needs_compilation
> sessionInfo() # show survival package 2.42-6 was attached
quantreg  5.33  5.34              TRUE
</syntaxhighlight>
 
 
Do you want to install from sources the package which needs compilation?
It makes sense to always use personal directory when we install packages. See .libPaths().
y/n: n
trying URL 'https://cran.rstudio.com/bin/macosx/el-capitan/contrib/3.4/quantreg_5.33.tgz'
Warning in install.packages :
  cannot open URL 'https://cran.rstudio.com/bin/macosx/el-capitan/contrib/3.4/quantreg_5.33.tgz': HTTP status was '404 Not Found'
Error in download.file(url, destfile, method, mode = "wb", ...) :
  cannot open URL 'https://cran.rstudio.com/bin/macosx/el-capitan/contrib/3.4/quantreg_5.33.tgz'
Warning in install.packages :
  download of package ‘quantreg’ failed
</pre>


It seems the binary package cannot be found on the mirror. So the solution here is to download the package from the R main server. Note that after I have successfully installed the binary package from the main R server, I remove the package in R and try to install the binary package from rstudio.com server agin and it works this time.
== Warning: cannot remove prior installation of package ==
http://stackoverflow.com/questions/15932152/unloading-and-removing-a-loaded-package-withouth-restarting-r


Instance 1.
<pre>
<pre>
> install.packages("quantreg", repos = "https://cran.r-project.org")
# Install the latest hgu133plus2cdf package
trying URL 'https://cran.r-project.org/bin/macosx/el-capitan/contrib/3.4/quantreg_5.34.tgz'
# Remove/Uninstall hgu133plus2.db package
Content type 'application/x-gzip' length 1863561 bytes (1.8 MB)
# Put/Install an old version of IRanges (eg version 1.18.2 while currently it is version 1.18.3)
==================================================
# Test on R 3.0.1
downloaded 1.8 MB
library(hgu133plus2cdf) # hgu133pluscdf does not depend or import IRanges
source("http://bioconductor.org/biocLite.R")
biocLite("hgu133plus2.db", ask=FALSE) # hgu133plus2.db imports IRanges
# Warning:cannot remove prior installation of package 'IRanges'
# Open Windows Explorer and check IRanges folder. Only see libs subfolder.
</pre>
</pre>


==== Another case: Error in download.file() on Windows 7 ====
Note:
For some reason, IE 8 cannot interpret https://ftp.ncbi.nlm.nih.gov though it understands ftp://ftp.ncbi.nlm.nih.gov.
* In the above example, all packages were installed under C:\Program Files\R\R-3.0.1\library\.
* In another instance where I cannot reproduce the problem, new R packages were installed under C:\Users\xxx\Documents\R\win-library\3.0\. The different thing is IRanges package CAN be updated but if I use packageVersion("IRanges") command in R, it still shows the old version.
* The above were tested on a desktop.


This is tested using R 3.4.3.
Instance 2.
<pre>
{{Pre}}
> download.file("https://ftp.ncbi.nlm.nih.gov/geo/series/GSE7nnn/GSE7848/soft/GSE7848_family.soft.gz", "test.soft.gz")
# On a fresh R 3.2.0, I install Bioconductor's depPkgTools & lumi packages. Then I close R, re-open it,
trying URL 'https://ftp.ncbi.nlm.nih.gov/geo/series/GSE7nnn/GSE7848/soft/GSE7848_family.soft.gz'
# and install depPkgTools package again.
Error in download.file("https://ftp.ncbi.nlm.nih.gov/geo/series/GSE7nnn/GSE7848/soft/GSE7848_family.soft.gz",  :
> source("http://bioconductor.org/biocLite.R")
  cannot open URL 'https://ftp.ncbi.nlm.nih.gov/geo/series/GSE7nnn/GSE7848/soft/GSE7848_family.soft.gz'
Bioconductor version 3.1 (BiocInstaller 1.18.2), ?biocLite for help
In addition: Warning message:
> biocLite("pkgDepTools")
In download.file("https://ftp.ncbi.nlm.nih.gov/geo/series/GSE7nnn/GSE7848/soft/GSE7848_family.soft.gz",  :
BioC_mirror: http://bioconductor.org
  InternetOpenUrl failed: 'An error occurred in the secure channel support'
Using Bioconductor version 3.1 (BiocInstaller 1.18.2), R version 3.2.0.
Installing package(s) ‘pkgDepTools’
trying URL 'http://bioconductor.org/packages/3.1/bioc/bin/windows/contrib/3.2/pkgDepTools_1.34.0.zip'
Content type 'application/zip' length 390579 bytes (381 KB)
downloaded 381 KB


> download.file("ftp://ftp.ncbi.nlm.nih.gov/geo/series/GSE7nnn/GSE7848/soft/GSE7848_family.soft.gz", "test.soft.gz")
package ‘pkgDepTools’ successfully unpacked and MD5 sums checked
trying URL 'ftp://ftp.ncbi.nlm.nih.gov/geo/series/GSE7nnn/GSE7848/soft/GSE7848_family.soft.gz'
Warning: cannot remove prior installation of package ‘pkgDepTools’
downloaded 9.1 MB
</pre>


== ERROR: failed to lock directory ==
The downloaded binary packages are in
Follow the suggestion to remove the LOCK file. See the [https://stackoverflow.com/questions/23483303/error-failed-to-lock-directory-c-program-files-r-r-3-0-2-library-for-modifyi post].
        C:\Users\brb\AppData\Local\Temp\RtmpYd2l7i\downloaded_packages
> library(pkgDepTools)
Error in library(pkgDepTools) : there is no package called ‘pkgDepTools’
</pre>
The pkgDepTools library folder appears in C:\Users\brb\Documents\R\win-library\3.2, but it is empty. The weird thing is if I try the above steps again, I cannot reproduce the problem.
 
== Warning: dependency ‘XXX’ is not available ==
[https://stackoverflow.com/a/25721890 How should I deal with “package 'xxx' is not available (for R version x.y.z)” warning?]


It could happened in calling install.packages(), biocLite() or devtools::install_github(), and so on.
== Error: there is no package called XXX ==
The error happened when I try to run library() command on a package that was just installed. R 3.6.0. 'biospear' version is 1.0.2. macOS.
{{Pre}}
> library(biospear)
Loading required package: pkgconfig
Error: package or namespace load failed for ‘biospear’ in loadNamespace(i, c(lib.loc, .libPaths()), versionCheck = vI[[i]]):
there is no package called ‘mixOmics’
</pre>


== Error in unloadNamespace(package) ==
Note
<pre>
> d3heatmap(mtcars, scale = "column", colors = "Blues")
Error: 'col_numeric' is not an exported object from 'namespace:scales'
> packageVersion("scales")
[1] ‘0.2.5’
> library(scales)
Error in unloadNamespace(package) :
  namespace ‘scales’ is imported by ‘ggplot2’ so cannot be unloaded
In addition: Warning message:
package ‘scales’ was built under R version 3.2.1
Error in library(scales) :
  Package ‘scales’ version 0.2.4 cannot be unloaded
> search()
[1] ".GlobalEnv"            "package:d3heatmap"      "package:ggplot2"     
[4] "package:microbenchmark" "package:COSMIC.67"      "package:BiocInstaller"
[7] "package:stats"          "package:graphics"      "package:grDevices"   
[10] "package:utils"          "package:datasets"      "package:methods"     
[13] "Autoloads"              "package:base"
</pre>
If I open a new R session, the above error will not happen!


The problem occurred because the 'scales' package version required by the d3heatmap package/function is old. See [https://github.com/rstudio/d3heatmap/issues/16 this post]. And when I upgraded the 'scales' package, it was ''locked'' by the package was ''imported'' by the ''ggplot2'' package.
* The package [https://cran.r-project.org/web/packages/mixOmics/index.html mixOmics] was removed from CRAN. It is now available on Bioconductor.
 
* Tested to install on a docker container: '''docker run --net=host -it --rm r-base''' <syntaxhighlight lang='rsplus'>
== Unload a package ==
ERROR: dependency ‘car’ is not available for package ‘plsRglm’
See an example below.
* removing ‘/usr/local/lib/R/site-library/plsRglm’
<pre>
ERROR: dependencies ‘plsRglm’, ‘mixOmics’, ‘survcomp’ are not available for package ‘plsRcox’
require(splines)
* removing ‘/usr/local/lib/R/site-library/plsRcox’
detach(package:splines, unload=TRUE)
ERROR: dependencies ‘devtools’, ‘plsRcox’, ‘RCurl’ are not available for package ‘biospear’
</pre>
* removing ‘/usr/local/lib/R/site-library/biospear’
</syntaxhighlight>The car package looks OK on CRAN. [https://cran.r-project.org/web/packages/survcomp/index.html survcomp] was moved from CRAN to Bioconductor too.
* As we can see above, the official r-base image does not contain libraries enough to install RCurl/devtools packages. Consider the [https://hub.docker.com/r/rocker/tidyverse tidyverse] image (based on [https://github.com/rocker-org/rocker-versioned/blob/master/rstudio/Dockerfile RStudio image]) from the rocker project. <syntaxhighlight lang='bash'>
docker pull rocker/tidyverse:3.6.0
docker run --net=host -it --rm -e PASSWORD=password -p 8787:8787 rocker/tidyverse:3.6.0
# the default username is 'rstudio'
# Open a browser, log in. Run 'install.packages("RCurl")'. It works.
</syntaxhighlight>
* Testing on Mint linux also shows errors about dependencies of mixOmics and survcomp.
* '''The best practice to install a package that may depend on packages located/moved to Bioconductor''': Run '''setRepositories(ind=1:2)''' before calling install.packages(). However, it does not '''remedy''' the situation that the 1st level imports package (eg plsRcox) was installed before but the 2nd level imports package (eg mixOmics) was not installed.
* [https://stat.ethz.ch/R-manual/R-devel/library/tools/html/dependsOnPkgs.html dependsOnPkgs()]: Find Reverse Dependencies. It seems it only return packages that have been installed locally. For example, tools::dependsOnPkgs("RcppEigen", "LinkingTo")


== New R packages as reported by [http://dirk.eddelbuettel.com/cranberries/ CRANberries] ==
== Warning: Unable to move temporary installation ==
http://blog.revolutionanalytics.com/2015/07/mranspackages-spotlight.html
The problem seems to happen only on virtual machines (Virtualbox).
* '''Warning: unable to move temporary installation `C:\Users\brb\Documents\R\win-library\3.0\fileed8270978f5\quadprog`  to `C:\Users\brb\Documents\R\win-library\3.0\quadprog`''' when I try to run 'install.packages("forecast").
* '''Warning: unable to move temporary installation ‘C:\Users\brb\Documents\R\win-library\3.2\file5e0104b5b49\plyr’ to ‘C:\Users\brb\Documents\R\win-library\3.2\plyr’ ''' when I try to run 'biocLite("lumi")'. The other dependency packages look fine although I am not sure if any unknown problem can happen (it does, see below).


<pre>
Here is a note of my trouble shooting.
#----------------------------
# If I try to ignore the warning and load the lumi package. I will get an error.
# SCRAPE CRANBERRIES FILES TO COUNT NEW PACKAGES AND PLOT
# If I try to run biocLite("lumi") again, it will only download & install lumi without checking missing 'plyr' package. Therefore, when I try to load the lumi package, it will give me an error again.
#
# Even I install the plyr package manually, library(lumi) gives another error - missing mclust package.
library(ggplot2)
{{Pre}}
# Build a vextor of the directories of interest
> biocLite("lumi")
year <- c("2013","2014","2015")
trying URL 'http://bioconductor.org/packages/3.1/bioc/bin/windows/contrib/3.2/BiocInstaller_1.18.2.zip'
month <- c("01","02","03","04","05","06","07","08","09","10","11","12")
Content type 'application/zip' length 114097 bytes (111 KB)
span <-c(rep(month,2),month[1:7])
downloaded 111 KB
dir <- "http://dirk.eddelbuettel.com/cranberries"
...
package ‘lumi’ successfully unpacked and MD5 sums checked


url2013 <- file.path(dir,"2013",month)
The downloaded binary packages are in
url2014 <- file.path(dir,"2014",month)
        C:\Users\brb\AppData\Local\Temp\RtmpyUjsJD\downloaded_packages
url2015 <- file.path(dir,"2015",month[1:7])
Old packages: 'BiocParallel', 'Biostrings', 'caret', 'DESeq2', 'gdata', 'GenomicFeatures', 'gplots', 'Hmisc', 'Rcpp', 'RcppArmadillo', 'rgl',
url <- c(url2013,url2014,url2015)
  'stringr'
Update all/some/none? [a/s/n]: a
also installing the dependencies ‘Rsamtools’, ‘GenomicAlignments’, ‘plyr’, ‘rtracklayer’, ‘gridExtra’, ‘stringi’, ‘magrittr’


# Read each directory and count the new packages
trying URL 'http://bioconductor.org/packages/3.1/bioc/bin/windows/contrib/3.2/Rsamtools_1.20.1.zip'
new_p <- vector()
Content type 'application/zip' length 8138197 bytes (7.8 MB)
for(i in url){
downloaded 7.8 MB
  raw.data <- readLines(i)
...
  new_p[i] <- length(grep("New package",raw.data,value=TRUE))
package ‘Rsamtools’ successfully unpacked and MD5 sums checked
}
package ‘GenomicAlignments’ successfully unpacked and MD5 sums checked
package ‘plyr’ successfully unpacked and MD5 sums checked
Warning: unable to move temporary installation ‘C:\Users\brb\Documents\R\win-library\3.2\file5e0104b5b49\plyr’
        to ‘C:\Users\brb\Documents\R\win-library\3.2\plyr’
package ‘rtracklayer’ successfully unpacked and MD5 sums checked
package ‘gridExtra’ successfully unpacked and MD5 sums checked
package ‘stringi’ successfully unpacked and MD5 sums checked
package ‘magrittr’ successfully unpacked and MD5 sums checked
package ‘BiocParallel’ successfully unpacked and MD5 sums checked
package ‘Biostrings’ successfully unpacked and MD5 sums checked
Warning: cannot remove prior installation of package ‘Biostrings’
package ‘caret’ successfully unpacked and MD5 sums checked
package ‘DESeq2’ successfully unpacked and MD5 sums checked
package ‘gdata’ successfully unpacked and MD5 sums checked
package ‘GenomicFeatures’ successfully unpacked and MD5 sums checked
package ‘gplots’ successfully unpacked and MD5 sums checked
package ‘Hmisc’ successfully unpacked and MD5 sums checked
package ‘Rcpp’ successfully unpacked and MD5 sums checked
package ‘RcppArmadillo’ successfully unpacked and MD5 sums checked
package ‘rgl’ successfully unpacked and MD5 sums checked
package ‘stringr’ successfully unpacked and MD5 sums checked


# Plot
The downloaded binary packages are in
time <- seq(as.Date("2013-01-01"), as.Date("2015-07-01"), by="months")
        C:\Users\brb\AppData\Local\Temp\RtmpyUjsJD\downloaded_packages
new_pkgs <- data.frame(time,new_p)
> library(lumi)
Error in loadNamespace(i, c(lib.loc, .libPaths()), versionCheck = vI[[i]]) :
  there is no package called ‘plyr’
Error: package or namespace load failed for ‘lumi’
> search()
[1] ".GlobalEnv"            "package:BiocInstaller" "package:Biobase"      "package:BiocGenerics"  "package:parallel"      "package:stats"       
[7] "package:graphics"      "package:grDevices"    "package:utils"        "package:datasets"      "package:methods"      "Autoloads"           
[13] "package:base"       
> biocLite("lumi")
BioC_mirror: http://bioconductor.org
Using Bioconductor version 3.1 (BiocInstaller 1.18.2), R version 3.2.0.
Installing package(s) ‘lumi’
trying URL 'http://bioconductor.org/packages/3.1/bioc/bin/windows/contrib/3.2/lumi_2.20.1.zip'
Content type 'application/zip' length 18185326 bytes (17.3 MB)
downloaded 17.3 MB


ggplot(new_pkgs, aes(time,y=new_p)) +
package ‘lumi’ successfully unpacked and MD5 sums checked
  geom_line() + xlab("") + ylab("Number of new packages") +
  geom_smooth(method='lm') + ggtitle("New R packages as reported by CRANberries")
</pre>


== Top new packages in 2015 ==
The downloaded binary packages are in
* [http://opiateforthemass.es/articles/R-packages-in-2015/ 2015 R packages roundup] by CHRISTOPH SAFFERLING
        C:\Users\brb\AppData\Local\Temp\RtmpyUjsJD\downloaded_packages
* [http://gforge.se/2016/01/r-trends-in-2015/ R trends in 2015] by MAX GORDON
> search()
 
[1] ".GlobalEnv"            "package:BiocInstaller" "package:Biobase"      "package:BiocGenerics"  "package:parallel"      "package:stats"       
== Speeding up package installation ==
[7] "package:graphics"      "package:grDevices"    "package:utils"        "package:datasets"      "package:methods"      "Autoloads"           
* http://blog.jumpingrivers.com/posts/2017/speed_package_installation/
[13] "package:base"       
* [http://dirk.eddelbuettel.com/blog/2017/11/27/#011_faster_package_installation_one (Much) Faster Package (Re-)Installation via Caching]
> library(lumi)
* [http://dirk.eddelbuettel.com/blog/2017/12/13/#013_faster_package_installation_two (Much) Faster Package (Re-)Installation via Caching, part 2]
Error in loadNamespace(i, c(lib.loc, .libPaths()), versionCheck = vI[[i]]) :
  there is no package called ‘plyr’
Error: package or namespace load failed for ‘lumi’
> biocLite("plyr")
BioC_mirror: http://bioconductor.org
Using Bioconductor version 3.1 (BiocInstaller 1.18.2), R version 3.2.0.
Installing package(s) ‘plyr’
trying URL 'http://cran.rstudio.com/bin/windows/contrib/3.2/plyr_1.8.2.zip'
Content type 'application/zip' length 1128621 bytes (1.1 MB)
downloaded 1.1 MB


== package ‘XXX’ was installed by an R version with different internals ==
package ‘plyr’ successfully unpacked and MD5 sums checked
it needs to be reinstalled for use with this R version. The problem seems to be specific to R 3.5.1 in Ubuntu 16.04. I got this message when I try to install the '''keras''' and '''tidyverse''' packages. The 'XXX' package includes ''nlme'' for installing "tidyverse" and ''Matrix'' for installing "reticulate". I have already logged in as root. I need to manually install these packages again though it seems I did not see a version change for these packages.


Same error [https://stackoverflow.com/q/50992032 Error: package was installed by an R version with different internals; it needs to be reinstalled for use with this R version].
The downloaded binary packages are in
        C:\Users\brb\AppData\Local\Temp\RtmpyUjsJD\downloaded_packages


Today it also happened when I tried to install "pec" which broke when it was installing "Hmisc". The error message is "Error : package ‘rpart’ was installed by an R version with different internals; it needs to be reinstalled for use with this R version". I am using R 3.5.2. rpart version is ‘4.1.13’. The solution is I install rpart again (under my account is enough) though rpart does not have a new version. Then I can install "Hmisc".
> library(lumi)
Error in loadNamespace(j <- i[[1L]], c(lib.loc, .libPaths()), versionCheck = vI[[j]]) :
  there is no package called ‘mclust’
Error: package or namespace load failed for ‘lumi’


= packrat (reproducible search): project specific package managment =
> ?biocLite
* [https://cran.r-project.org/web/packages/packrat/ CRAN] & [https://rstudio.github.io/packrat/ Github]
Warning messages:
* Videos:
1: In read.dcf(file.path(p, "DESCRIPTION"), c("Package", "Version")) :
** https://www.rstudio.com/resources/webinars/managing-package-dependencies-in-r-with-packrat/
  cannot open compressed file 'C:/Users/brb/Documents/R/win-library/3.2/Biostrings/DESCRIPTION', probable reason 'No such file or directory'
** https://www.rstudio.com/resources/webinars/rstudio-essentials-webinar-series-managing-part-3/
2: In find.package(if (is.null(package)) loadedNamespaces() else package, :
* Packrat will not only store all packages, but also all project files.
  there is no package called ‘Biostrings’
* Packrat is integrated in RStudio’s user interface. It allows you to share projects along co-workers easily. See [https://rstudio.github.io/packrat/rstudio.html Using Packrat with RStudio].
> library(lumi)
* [https://rstudio.github.io/packrat/limitations.html limitations].
Error in loadNamespace(j <- i[[1L]], c(lib.loc, .libPaths()), versionCheck = vI[[j]]) :  
* [https://stackoverflow.com/questions/36187543/using-r-with-git-and-packrat Git and packrat]. The ''packrat/src'' directory can be very large. ''If you don't want them available in your git-repo, you simply add packrat/src/ to the .gitignore. But, this will mean that anyone accessing the git-repo will not have access to the package source code, and the files will be downloaded from CRAN, or from wherever the source line dictates within the packrat.lock file.''
  there is no package called ‘mclust’
** [https://www.joelnitta.com/post/packrat/ Using packrat with git for (better) version control] Jun 2018
In addition: Warning messages:
* A scenario that we need packrat: suppose we are developing a package in the current R-3.5.X. Our package requires the 'doRNG' package. That package depends the 'rngtools' package. A few months later a new R (3.6.0) was released and a new release (1.3.1.1) of 'rngtools' also requires R-3.6.0. So if we want to install 'doRNG' in R-3.5.x, it will fail with an error: ''dependency 'rngtools' is not available for package 'doRNG' ''.
1: In read.dcf(file.path(p, "DESCRIPTION"), c("Package", "Version")) :
 
  cannot open compressed file 'C:/Users/brb/Documents/R/win-library/3.2/Biostrings/DESCRIPTION', probable reason 'No such file or directory'
== Create a snapshot ==
2: In find.package(if (is.null(package)) loadedNamespaces() else package,  :
* Do we really need to call packrat::snapshot()? The [https://rstudio.github.io/packrat/walkthrough.html walk through] page says it is not needed but the lock file is not updated from my testing.
  there is no package called ‘Biostrings’
* I got an error when it is trying to fetch the source code from bioconductor and local repositories: packrat is trying to fetch the source from CRAN in these two packages.  
Error: package or namespace load failed for ‘lumi’
** On normal case, the packrat/packrat.lock file contains two entries in 'Repos' field (line 4).
</pre>
** The cause of the error is I ran snapshot() after I quitted R and entered again. So the solution is to add bioc and local repositories to options(repos).
** So what is important of running snapshot()?
** Check out the [https://groups.google.com/forum/#!forum/packrat-discuss forum].
<syntaxhighlight lang='rsplus'>
> dir.create("~/projects/babynames", recu=T)
> packrat::init("~/projects/babynames")
Initializing packrat project in directory:
- "~/projects/babynames"


Adding these packages to packrat:
[http://r.789695.n4.nabble.com/unable-to-move-temporary-installation-td4521714.html Other people also have the similar problem]. The possible cause is the virus scanner locks the file and R cannot move them.
            _
    packrat  0.4.9-3


Fetching sources for packrat (0.4.9-3) ... OK (CRAN current)
Some possible solutions:
Snapshot written to '/home/brb/projects/babynames/packrat/packrat.lock'
# Delete ALL folders under R/library (e.g. C:/Progra~1/R/R-3.2.0/library) folder and install the main package again using install.packages() or biocLite().
Installing packrat (0.4.9-3) ...
# For specific package like 'lumi' from Bioconductor, we can [[R#Bioconductor.27s_pkgDepTools_package|find out all dependency packages]] and then install them one by one.
OK (built source)
# Find out and install the top level package which misses dependency packages.  
Initialization complete!
## This is based on the fact that install.packages() or biocLite() '''sometimes''' just checks & installs the 'Depends' and 'Imports' packages and '''won't install all packages recursively'''
Unloading packages in user library:
## we can do a small experiment by removing a package which is not directly dependent/imported by another package; e.g. 'iterators' is not dependent/imported by 'glment' directly but indirectly. So if we run '''remove.packages("iterators"); install.packages("glmnet")''', then the 'iterator' package is still missing.
- packrat
## A real example is if the missing packages are 'Biostrings', 'limma', 'mclust' (these are packages that 'minfi' directly depends/imports although they should be installed when I run biocLite("lumi") command), then I should just run the command '''remove.packages("minfi"); biocLite("minfi")'''. If we just run biocLite("lumi") or biocLite("methylumi"), the missing packages won't be installed.
Packrat mode on. Using library in directory:
- "~/projects/babynames/packrat/lib"


> install.packages("reshape2")
== Error in download.file(url, destfile, method, mode = "wb", ...) ==
> packrat::snapshot()
HTTP status was '404 Not Found'


> system("tree -L 2 ~/projects/babynames/packrat/")
Tested on an existing R-3.2.0 session. Note that VariantAnnotation 1.14.4 was just uploaded to Bioc.
/home/brb/projects/babynames/packrat/
{{pre}}
├── init.R
> biocLite("COSMIC.67")
├── lib
BioC_mirror: http://bioconductor.org
│   └── x86_64-pc-linux-gnu
Using Bioconductor version 3.1 (BiocInstaller 1.18.3), R version 3.2.0.
├── lib-ext
Installing package(s) ‘COSMIC.67’
│   └── x86_64-pc-linux-gnu
also installing the dependency ‘VariantAnnotation’
├── lib-R            # base packages
│   └── x86_64-pc-linux-gnu
├── packrat.lock
├── packrat.opts
└── src
    ├── bitops
    ├── glue
    ├── magrittr
    ├── packrat
    ├── plyr
    ├── Rcpp
    ├── reshape2
    ├── stringi
    └── stringr
</syntaxhighlight>


== Restoring snapshots ==
trying URL 'http://bioconductor.org/packages/3.1/bioc/bin/windows/contrib/3.2/VariantAnnotation_1.14.3.zip'
Error in download.file(url, destfile, method, mode = "wb", ...) :
  cannot open URL 'http://bioconductor.org/packages/3.1/bioc/bin/windows/contrib/3.2/VariantAnnotation_1.14.3.zip'
In addition: Warning message:
In download.file(url, destfile, method, mode = "wb", ...) :
  cannot open: HTTP status was '404 Not Found'
Warning in download.packages(pkgs, destdir = tmpd, available = available,  :
  download of package ‘VariantAnnotation’ failed
installing the source package ‘COSMIC.67’


Suppose a packrat project was created on Ubuntu 16.04 and we now want to repeat the analysis on Ubuntu 18.04. We first copy the whole project directory ('babynames') to Ubuntu 18.04. Then we should delete the library subdirectory ('packrat/lib') which contains binary files (*.so) that do not work on the new OS. After we delete the library subdirectory, start R from the project directory. Now if we run '''packrat::restore()''' command, it will re-install all missing libraries. Bingo! NOTE: Maybe I should use '''packrat::bundle()''' instead of manually copy the whole project folder.
trying URL 'http://bioconductor.org/packages/3.1/data/experiment/src/contrib/COSMIC.67_1.4.0.tar.gz'
Content type 'application/x-gzip' length 40999037 bytes (39.1 MB)
</pre>


Note: some OS level libraries (e.g. libXXX-dev) need to be installed manually beforehand in order for the magic to work.
However, when I tested on a new R-3.2.0 (just installed in VM), the COSMIC package installation is successful. That VariantAnnotation version 1.14.4 was installed (this version was just updated today from Bioconductor).
<syntaxhighlight lang='rsplus'>
$ rm -rf ~/projects/babynames/packrat/lib
$ cd ~/projects/babynames/
$ R
>
> packrat::status()
> remove.packages("plyr")
> packrat::status()
> packrat::restore()
</syntaxhighlight>


== Set Up a Custom CRAN-like Repository ==
The cause of the error is the '''[https://github.com/wch/r-source/blob/trunk/src/library/utils/R/packages.R available.package()]''' function will read the rds file first from cache in a tempdir (C:\Users\XXXX\AppData\Local\Temp\RtmpYYYYYY). See lines 51-55 of <packages.R>.
 
<pre>
See https://rstudio.github.io/packrat/custom-repos.html. Note the personal repository name ('sushi' in this example) used in "Repository" field of the personal package will be used in <packrat/packrat.lock> file. So as long as we work on the same computer, it is easy to restore a packrat project containing packages coming from personal repository.
dest <- file.path(tempdir(),
 
                  paste0("repos_", URLencode(repos, TRUE), ".rds"))
'''[https://rstudio.github.io/packrat/commands.html Common functions]''':
if(file.exists(dest)) {
* packrat::init()
    res0 <- readRDS(dest)
* packrat::snapshot(), packrat::restore()
} else {
* packrat::clean()
    ...
* packrat::status()
* packrat::install_local() # http://rstudio.github.io/packrat/limitations.html
</pre>
* packrat::bundle() # see @28:44 of the [https://www.rstudio.com/resources/webinars/managing-package-dependencies-in-r-with-packrat/ video], packrat::unbundle() # see @29:17 of the same video. This will rebuild all packages
Since my R was opened 1 week ago, the rds file it reads today contains old information. Note that Bioconductor does not hold the source code or binary code for the old version of packages. This explains why biocLite() function broke. When I restart R, the original problem is gone.
* packrat::on(), packrat::off()
* packrat::get_opts()
* packrat::set_opts() # http://rstudio.github.io/packrat/limitations.html
* packrat::opts$local.repos("~/local-cran")
* packrat::opts$external.packages(c("devtools")) # break the isolation
* packrat::extlib()
* packrat::with_extlib()
* packrat::project_dir(), .libPaths()
 
== Warning ==
* If we download and modify some function definition from a package in CRAN without changing DESCRIPTION file or the package name, the snapshot created using packrat::snapshot() will contain the package source from CRAN instead of local repository. This is because (I guess) the DESCRIPTION file contains a field 'Repository' with the value 'CRAN'.


== Docker ==
If we look at the source code of available.packages(), we will see we could use '''cacheOK''' option in download.file() function.
[https://www.joelnitta.com/post/docker-and-packrat/ Docker and Packrat]. The first part of generating packrat.lock is not quite right since the file was generated in the container only. We should use '''-v''' in the ''docker run'' command. The github repository at https://github.com/joelnitta/docker-packrat-example has fixed the problem.
<pre>
<syntaxhighlight lang='rsplus'>
download.file(url, destfile, method, cacheOK = FALSE, quiet = TRUE, mode ="wb")
$ git clone https://github.com/joelnitta/docker-packrat-example.git
</pre>
$ cd docker-packrat-example


# Step 1: create the 'packrat.lock' file
== Another case: Error in download.file(url, destfile, method, mode = "wb", ...) ==
$ nano install_packages.R    # note: nano is not available in the rstudio container
{{Pre}}
                              # need to install additional OS level packages like libcurl
> install.packages("quantreg")
                              # in rocker/rstudio. Probably rocker/tidyverse is better than rstudio
                              #
$ docker run -it -e DISABLE_AUTH=true -v $(pwd):/home/rstudio/project rocker/tidyverse:3.6.0 bash
# Inside the container now
$ cd home/rstudio/project
$ time Rscript install_packages.R  # generate 'packrat/packrat.lock'
$ exit                        # It took 43 minutes.
                              # Question: is there an easier way to generate packrat.lock without
                              # wasting time to install lots of packages?
# Step 2: build the image
# Open another terminal/tab
$ nano Dockerfile            # change rocker image and R version. Make sure these two are the same as
                              # we have used when we created the 'packrat.lock' file
$ time docker build . -t mycontainer # It took 45 minutes.
$ docker run -it mycontainer R


# Step 3: check the packages defined in 'install_packages.R' are installed
  There is a binary version available but the source version is later:
packageVersion("minimal")
        binary source needs_compilation
packageVersion("biospear")
quantreg  5.33  5.34              TRUE
</syntaxhighlight>
Questions:
* After running the statement packrat::init(), it will leave a footprint of a hidden file ".Rprofile" in the current directory. <syntaxhighlight lang='rsplus'>
#### -- Packrat Autoloader (version 0.5.0) -- ####
source("packrat/init.R")
#### -- End Packrat Autoloader -- ####
</syntaxhighlight>
: If the 'packrat' directory was accidentally deleted, next time when you launch R it will show an error message because it cannot find the file.  
* The ownership of the 'packrat' directory will be root now. See this [https://rviews.rstudio.com/2018/01/18/package-management-for-reproducible-r-code/ Package Management for Reproducible R Code].
* This sophisticated approach does not save the package source code. If a package has been updated and the version we used has been moved to archive in CRAN, what will happen when we try to restore it?


== renv: successor to the packrat package ==
Do you want to install from sources the package which needs compilation?
https://rstudio.github.io/renv/index.html
y/n: n
 
trying URL 'https://cran.rstudio.com/bin/macosx/el-capitan/contrib/3.4/quantreg_5.33.tgz'
= R package dependencies =
Warning in install.packages :
 
  cannot open URL 'https://cran.rstudio.com/bin/macosx/el-capitan/contrib/3.4/quantreg_5.33.tgz': HTTP status was '404 Not Found'
== Depends, Imports, Suggests, Enhances, LinkingTo ==
Error in download.file(url, destfile, method, mode = "wb", ...) :
See [https://cran.r-project.org/doc/manuals/r-release/R-exts.html#Package-Dependencies Writing R Extensions] and [[#install.packages.28.29|install.packages()]].
  cannot open URL 'https://cran.rstudio.com/bin/macosx/el-capitan/contrib/3.4/quantreg_5.33.tgz'
Warning in install.packages :
  download of package ‘quantreg’ failed
</pre>
 
It seems the binary package cannot be found on the mirror. So the solution here is to download the package from the R main server. Note that after I have successfully installed the binary package from the main R server, I remove the package in R and try to install the binary package from rstudio.com server agin and it works this time.  


* Depends: list of package names which this package depends on. Those packages will be attached (so it is better to use ''Imports'' instead of ''Depends'' as much as you can) before the current package when library or require is called. The ‘Depends’ field can also specify a dependence on a certain version of R.
<pre>
* Imports: lists packages whose '''namespaces''' are imported from (as specified in the NAMESPACE file) but which do not need to be attached.
> install.packages("quantreg", repos = "https://cran.r-project.org")
* Suggests: lists packages that are not necessarily needed. This includes packages used only in examples, tests or vignettes, and packages loaded in the body of functions.
trying URL 'https://cran.r-project.org/bin/macosx/el-capitan/contrib/3.4/quantreg_5.34.tgz'
* Enhances: lists packages “enhanced” by the package at hand, e.g., by providing methods for classes from these packages, or ways to handle objects from these packages.
Content type 'application/x-gzip' length 1863561 bytes (1.8 MB)
* LinkingTo: A package that wishes to make use of '''header''' files in other packages needs to declare them as a comma-separated list in the field ‘LinkingTo’ in the DESCRIPTION file.
==================================================
downloaded 1.8 MB
</pre>


== Package related functions from package 'utils' ==
==== Another case: Error in download.file() on Windows 7 ====
* [http://stat.ethz.ch/R-manual/R-devel/library/utils/html/available.packages.html available.packages()]; see packageStatus().
For some reason, IE 8 cannot interpret https://ftp.ncbi.nlm.nih.gov though it understands ftp://ftp.ncbi.nlm.nih.gov.
* [http://stat.ethz.ch/R-manual/R-devel/library/utils/html/download.packages.html download.packages()]
 
* [http://stat.ethz.ch/R-manual/R-devel/library/utils/html/packageStatus.html packageStatus(), update(), upgrade()]. packageStatus() will return a list with two components:
This is tested using R 3.4.3.
# inst - a data frame with columns as the matrix returned by '''installed.packages''' plus "Status", a factor with levels c("ok", "upgrade"). Note: the manual does not mention "unavailable" case (but I do get it) in R 3.2.0?
{{Pre}}
# avail - a data frame with columns as the matrix returned by '''available.packages''' plus "Status", a factor with levels c("installed", "not installed", "unavailable"). Note: I don't get the "unavailable" case in R 3.2.0?
> download.file("https://ftp.ncbi.nlm.nih.gov/geo/series/GSE7nnn/GSE7848/soft/GSE7848_family.soft.gz", "test.soft.gz")
<syntaxhighlight lang='rsplus'>
trying URL 'https://ftp.ncbi.nlm.nih.gov/geo/series/GSE7nnn/GSE7848/soft/GSE7848_family.soft.gz'
> x <- packageStatus()
Error in download.file("https://ftp.ncbi.nlm.nih.gov/geo/series/GSE7nnn/GSE7848/soft/GSE7848_family.soft.gz",  :
> names(x)
   cannot open URL 'https://ftp.ncbi.nlm.nih.gov/geo/series/GSE7nnn/GSE7848/soft/GSE7848_family.soft.gz'
[1] "inst"  "avail"
In addition: Warning message:
> dim(x[['inst']])
In download.file("https://ftp.ncbi.nlm.nih.gov/geo/series/GSE7nnn/GSE7848/soft/GSE7848_family.soft.gz", :
[1] 225  17
  InternetOpenUrl failed: 'An error occurred in the secure channel support'
> x[['inst']][1:3, ]
 
              Package                            LibPath Version Priority              Depends Imports
> download.file("ftp://ftp.ncbi.nlm.nih.gov/geo/series/GSE7nnn/GSE7848/soft/GSE7848_family.soft.gz", "test.soft.gz")
acepack      acepack C:/Program Files/R/R-3.1.2/library 1.3-3.3    <NA>                  <NA>    <NA>
trying URL 'ftp://ftp.ncbi.nlm.nih.gov/geo/series/GSE7nnn/GSE7848/soft/GSE7848_family.soft.gz'
adabag        adabag C:/Program Files/R/R-3.1.2/library    4.0    <NA> rpart, mlbench, caret    <NA>
downloaded 9.1 MB
affxparser affxparser C:/Program Files/R/R-3.1.2/library  1.38.0    <NA>          R (>= 2.6.0)    <NA>
</pre>
          LinkingTo                                                        Suggests Enhances
 
acepack        <NA>                                                            <NA>    <NA>
== ERROR: failed to lock directory ==
adabag          <NA>                                                            <NA>    <NA>
Follow the suggestion to remove the LOCK file. See the [https://stackoverflow.com/questions/23483303/error-failed-to-lock-directory-c-program-files-r-r-3-0-2-library-for-modifyi post].
affxparser      <NA> R.oo (>= 1.18.0), R.utils (>= 1.32.4),\nAffymetrixDataTestFiles    <NA>
 
                      License License_is_FOSS License_restricts_use OS_type MD5sum NeedsCompilation Built
It could happened in calling install.packages(), biocLite() or devtools::install_github(), and so on.
acepack    MIT + file LICENSE            <NA>                  <NA>    <NA>  <NA>              yes 3.1.2
 
adabag            GPL (>= 2)            <NA>                  <NA>    <NA>  <NA>              no 3.1.2
== Error in unloadNamespace(package) ==
affxparser        LGPL (>= 2)            <NA>                  <NA>    <NA>  <NA>            <NA> 3.1.1
<pre>
                Status
> d3heatmap(mtcars, scale = "column", colors = "Blues")
acepack            ok
Error: 'col_numeric' is not an exported object from 'namespace:scales'
adabag              ok
> packageVersion("scales")
affxparser unavailable
[1] ‘0.2.5’
> dim(x[['avail']])
> library(scales)
[1] 6538  18
Error in unloadNamespace(package) :
> x[['avail']][1:3, ]
  namespace ‘scales’ is imported by ‘ggplot2’ so cannot be unloaded
                Package Version Priority                        Depends        Imports LinkingTo
In addition: Warning message:
A3                  A3  0.9.2    <NA> R (>= 2.15.0), xtable, pbapply          <NA>      <NA>
package ‘scales’ was built under R version 3.2.1
ABCExtremes ABCExtremes    1.0    <NA>      SpatialExtremes, combinat          <NA>      <NA>
Error in library(scales) :
ABCanalysis ABCanalysis  1.0.1    <NA>                    R (>= 2.10) Hmisc, plotrix      <NA>
  Package ‘scales’ version 0.2.4 cannot be unloaded
                      Suggests Enhances    License License_is_FOSS License_restricts_use OS_type Archs
> search()
A3          randomForest, e1071    <NA> GPL (>= 2)            <NA>                  <NA>    <NA>  <NA>
[1] ".GlobalEnv"            "package:d3heatmap"      "package:ggplot2"     
ABCExtremes                <NA>    <NA>      GPL-2            <NA>                  <NA>    <NA>  <NA>
[4] "package:microbenchmark" "package:COSMIC.67"      "package:BiocInstaller"
ABCanalysis                <NA>    <NA>      GPL-3            <NA>                  <NA>    <NA>  <NA>
[7] "package:stats"          "package:graphics"      "package:grDevices"   
            MD5sum NeedsCompilation File                                      Repository        Status
[10] "package:utils"          "package:datasets"      "package:methods"     
A3            <NA>            <NA> <NA> http://cran.rstudio.com/bin/windows/contrib/3.1 not installed
[13] "Autoloads"              "package:base"
ABCExtremes   <NA>            <NA> <NA> http://cran.rstudio.com/bin/windows/contrib/3.1 not installed
</pre>
ABCanalysis  <NA>            <NA> <NA> http://cran.rstudio.com/bin/windows/contrib/3.1 not installed
If I open a new R session, the above error will not happen!
</syntaxhighlight>
* [http://stat.ethz.ch/R-manual/R-devel/library/utils/html/packageDescription.html packageVersion(), packageDescription()]
* [http://stat.ethz.ch/R-manual/R-devel/library/utils/html/install.packages.html install.packages()], [http://stat.ethz.ch/R-manual/R-devel/library/utils/html/remove.packages.html remove.packages()].
* [http://stat.ethz.ch/R-manual/R-devel/library/utils/html/installed.packages.html installed.packages()]; see packageStatus().
* [http://stat.ethz.ch/R-manual/R-devel/library/utils/html/update.packages.html update.packages(), old.packages(), new.packages()]
* [http://stat.ethz.ch/R-manual/R-devel/library/utils/html/setRepositories.html setRepositories()]
* [http://stat.ethz.ch/R-manual/R-devel/library/utils/html/contrib.url.html contrib.url()]
* [http://stat.ethz.ch/R-manual/R-devel/library/utils/html/chooseCRANmirror.html chooseCRANmirror()], [http://stat.ethz.ch/R-manual/R-devel/library/utils/html/chooseBioCmirror.html chooseBioCmirror()]
* [http://stat.ethz.ch/R-manual/R-devel/library/utils/html/globalVariables.html suppressForeignCheck()]


== tools package ==
The problem occurred because the 'scales' package version required by the d3heatmap package/function is old. See [https://github.com/rstudio/d3heatmap/issues/16 this post]. And when I upgraded the 'scales' package, it was ''locked'' by the package was ''imported'' by the ''ggplot2'' package.
* https://www.rdocumentation.org/packages/tools/versions/3.6.1
* CRAN_package_db() from [https://www.rdocumentation.org/packages/tools/versions/3.6.1/topics/CRANtools ?CRANtools]
* [https://www.rdocumentation.org/packages/tools/versions/3.6.1/topics/dependsOnPkgs dependsOnPkgs()]
* package.dependencies(), pkgDepends(), etc are deprecated now, mostly in favor of package_dependencies() which is both more flexible and efficient. See [https://cran.rstudio.com/doc/manuals/r-release/NEWS.html R 3.3.0 News].


== Bioconductor's [http://www.bioconductor.org/packages/release/bioc/html/pkgDepTools.html pkgDepTools] package ==
== Unload a package ==
The is an example of querying the dependencies of the notorious 'lumi' package which often broke the installation script. I am using R 3.2.0 and Bioconductor 3.1.
Add '''unload = TRUE''' option to unload the namespace. See [https://www.rdocumentation.org/packages/base/versions/3.6.2/topics/detach detach()].
<pre>
require(splines)
detach(package:splines, unload=TRUE)
</pre>


The '''getInstallOrder''' function is useful to get a list of all (recursive) dependency packages.
== crantastic ==
<pre>
https://crantastic.org/. A community site for R packages where you can search for, review and tag CRAN packages.
source("http://bioconductor.org/biocLite.R")
if (!require(pkgDepTools)) {
  biocLite("pkgDepTools", ask = FALSE)
  library(pkgDepTools)
}
MkPlot <- FALSE


library(BiocInstaller)
https://github.com/hadley/crantastic
biocUrl <- biocinstallRepos()["BioCsoft"]
biocDeps <- makeDepGraph(biocUrl, type="source", dosize=FALSE) # pkgDepTools defines its makeDepGraph()


PKG <- "lumi"
== New R packages as reported by [http://dirk.eddelbuettel.com/cranberries/ CRANberries] ==
if (MkPlot) {
http://blog.revolutionanalytics.com/2015/07/mranspackages-spotlight.html
  if (!require(Biobase))  {
    biocLite("Biobase", ask = FALSE)
    library(Biobase)
  }
  if (!require(Rgraphviz))  {
    biocLite("Rgraphviz", ask = FALSE)
    library(Rgraphviz)
  }
  categoryNodes <- c(PKG, names(acc(biocDeps, PKG)[[1]])) 
  categoryGraph <- subGraph(categoryNodes, biocDeps)
  nn <- makeNodeAttrs(categoryGraph, shape="ellipse")
  plot(categoryGraph, nodeAttrs=nn)  # Complete but plot is too complicated & font is too small.
}


system.time(allDeps <- makeDepGraph(biocinstallRepos(), type="source",
<pre>
                          keep.builtin=TRUE, dosize=FALSE)) # takes a little while
#----------------------------
#    user  system elapsed
# SCRAPE CRANBERRIES FILES TO COUNT NEW PACKAGES AND PLOT
# 175.737  10.994 186.875
#
# Warning messages:
library(ggplot2)
# 1: In .local(from, to, graph) : edges replaced: ‘SNPRelate|gdsfmt’
# Build a vextor of the directories of interest
# 2: In .local(from, to, graph) :
year <- c("2013","2014","2015")
edges replaced: ‘RCurl|methods’, ‘NA|bitops’
month <- c("01","02","03","04","05","06","07","08","09","10","11","12")
span <-c(rep(month,2),month[1:7])
dir <- "http://dirk.eddelbuettel.com/cranberries"
 
url2013 <- file.path(dir,"2013",month)
url2014 <- file.path(dir,"2014",month)
url2015 <- file.path(dir,"2015",month[1:7])
url <- c(url2013,url2014,url2015)
 
# Read each directory and count the new packages
new_p <- vector()
for(i in url){
   raw.data <- readLines(i)
  new_p[i] <- length(grep("New package",raw.data,value=TRUE))
}


# When needed.only=TRUE, only those dependencies not currently installed are included in the list.
# Plot
x1 <- sort(getInstallOrder(PKG, allDeps, needed.only=TRUE)$packages); x1
time <- seq(as.Date("2013-01-01"), as.Date("2015-07-01"), by="months")
[1] "affy"                             "affyio"                          
new_pkgs <- data.frame(time,new_p)
[3] "annotate"                         "AnnotationDbi"                   
 
[5] "base64"                            "beanplot"                       
ggplot(new_pkgs, aes(time,y=new_p)) +
[7] "Biobase"                          "BiocParallel"                   
  geom_line() + xlab("") + ylab("Number of new packages") +
[9] "biomaRt"                          "Biostrings"                     
  geom_smooth(method='lm') + ggtitle("New R packages as reported by CRANberries")
[11] "bitops"                            "bumphunter"                     
</pre>
[13] "colorspace"                        "DBI"                             
 
[15] "dichromat"                        "digest"                         
== R packages being removed ==
[17] "doRNG"                            "FDb.InfiniumMethylation.hg19"   
* https://dirk.eddelbuettel.com/cranberries/cran/removed/
[19] "foreach"                          "futile.logger"                   
* https://web.archive.org/ to find out the package website before it's removed
[21] "futile.options"                    "genefilter"                     
 
[23] "GenomeInfoDb"                      "GenomicAlignments"               
== Top new packages in 2015 ==
[25] "GenomicFeatures"                  "GenomicRanges"                   
* [http://opiateforthemass.es/articles/R-packages-in-2015/ 2015 R packages roundup] by CHRISTOPH SAFFERLING
[27] "GEOquery"                          "ggplot2"                         
* [http://gforge.se/2016/01/r-trends-in-2015/ R trends in 2015] by MAX GORDON
[29] "gtable"                            "illuminaio"                     
 
[31] "IRanges"                          "iterators"                       
== keep.source.pkgs option ==
[33] "labeling"                          "lambda.r"                       
[https://blog.r-hub.io/2020/09/03/keep.source/ State of R packages in your library]. The original code formatting and commenting being removed by default, unless one changes some options for installing packages.
[35] "limma"                            "locfit"                         
 
[37] "lumi"                              "magrittr"                       
* options(keep.source.pkgs = TRUE)
[39] "matrixStats"                      "mclust"                         
* install.packages("rhub", INSTALL_opts = "--with-keep.source", type = "source")
[41] "methylumi"                        "minfi"                           
* R CMD install --with-keep.source
[43] "multtest"                          "munsell"                         
 
[45] "nleqslv"                          "nor1mix"                         
[https://bugs.r-project.org/show_bug.cgi?id=18236 Package installation speed for packages installed with ‘keep.source’ has been improved.] 2021-12-2.
[47] "org.Hs.eg.db"                      "pkgmaker"                       
 
[49] "plyr"                              "preprocessCore"                 
== Speeding up package installation ==
[51] "proto"                            "quadprog"                       
* http://blog.jumpingrivers.com/posts/2017/speed_package_installation/
[53] "RColorBrewer"                      "Rcpp"                           
* [http://dirk.eddelbuettel.com/blog/2017/11/27/#011_faster_package_installation_one (Much) Faster Package (Re-)Installation via Caching]
[55] "RCurl"                             "registry"                        
* [http://dirk.eddelbuettel.com/blog/2017/12/13/#013_faster_package_installation_two (Much) Faster Package (Re-)Installation via Caching, part 2]
[57] "reshape"                           "reshape2"                       
[59] "rngtools"                          "Rsamtools"                       
[61] "RSQLite"                          "rtracklayer"                     
[63] "S4Vectors"                        "scales"                         
[65] "siggenes"                          "snow"                           
[67] "stringi"                          "stringr"                         
[69] "TxDb.Hsapiens.UCSC.hg19.knownGene" "XML"                             
[71] "xtable"                            "XVector"                         
[73] "zlibbioc"                       


# When needed.only=FALSE the complete list of dependencies is given regardless of the set of currently installed packages.
== An efficient way to install and load R packages ==
x2 <- sort(getInstallOrder(PKG, allDeps, needed.only=FALSE)$packages); x2
[https://www.statsandr.com/blog/an-efficient-way-to-install-and-load-r-packages/ An efficient way to install and load R packages]
[1] "affy"                              "affyio"                            "annotate"                       
{{Pre}}
[4] "AnnotationDbi"                    "base64"                            "beanplot"                       
# Package names
[7] "Biobase"                          "BiocGenerics"                      "BiocInstaller"                   
packages <- c("ggplot2", "readxl", "dplyr", "tidyr", "ggfortify", "DT", "reshape2", "knitr", "lubridate", "pwr", "psy", "car", "doBy", "imputeMissings", "RcmdrMisc", "questionr", "vcd", "multcomp", "KappaGUI", "rcompanion", "FactoMineR", "factoextra", "corrplot", "ltm", "goeveg", "corrplot", "FSA", "MASS", "scales", "nlme", "psych", "ordinal", "lmtest", "ggpubr", "dslabs", "stringr", "assist", "ggstatsplot", "forcats", "styler", "remedy", "snakecaser", "addinslist", "esquisse", "here", "summarytools", "magrittr", "tidyverse", "funModeling", "pander", "cluster", "abind")
[10] "BiocParallel"                      "biomaRt"                          "Biostrings"                     
[13] "bitops"                            "bumphunter"                        "codetools"                       
[16] "colorspace"                        "DBI"                              "dichromat"                       
[19] "digest"                            "doRNG"                            "FDb.InfiniumMethylation.hg19"   
[22] "foreach"                          "futile.logger"                    "futile.options"                 
[25] "genefilter"                        "GenomeInfoDb"                      "GenomicAlignments"               
[28] "GenomicFeatures"                  "GenomicRanges"                    "GEOquery"                       
[31] "ggplot2"                           "graphics"                         "grDevices"                      
[34] "grid"                             "gtable"                           "illuminaio"                      
[37] "IRanges"                           "iterators"                         "KernSmooth"                      
[40] "labeling"                         "lambda.r"                         "lattice"                        
[43] "limma"                             "locfit"                           "lumi"                            
[46] "magrittr"                         "MASS"                             "Matrix"                          
[49] "matrixStats"                       "mclust"                           "methods"                        
[52] "methylumi"                         "mgcv"                             "minfi"                          
[55] "multtest"                         "munsell"                           "nleqslv"                        
[58] "nlme"                             "nor1mix"                           "org.Hs.eg.db"                    
[61] "parallel"                         "pkgmaker"                         "plyr"                            
[64] "preprocessCore"                   "proto"                             "quadprog"                        
[67] "RColorBrewer"                     "Rcpp"                             "RCurl"                          
[70] "registry"                         "reshape"                           "reshape2"                        
[73] "rngtools"                         "Rsamtools"                         "RSQLite"                        
[76] "rtracklayer"                       "S4Vectors"                         "scales"                          
[79] "siggenes"                         "snow"                             "splines"                        
[82] "stats"                            "stats4"                            "stringi"                         
[85] "stringr"                          "survival"                          "tools"                           
[88] "TxDb.Hsapiens.UCSC.hg19.knownGene" "utils"                            "XML"                             
[91] "xtable"                            "XVector"                          "zlibbioc"  


> sort(setdiff(x2, x1)) # Not all R's base packages are included; e.g. 'base', 'boot', ...
# Install packages not yet installed
[1] "BiocGenerics"  "BiocInstaller" "codetools"    "graphics"      "grDevices"   
installed_packages <- packages %in% rownames(installed.packages())
[6] "grid"          "KernSmooth"    "lattice"      "MASS"          "Matrix"     
if (any(installed_packages == FALSE)) {
[11] "methods"      "mgcv"          "nlme"          "parallel"      "splines"     
  install.packages(packages[!installed_packages])
[16] "stats"        "stats4"        "survival"      "tools"        "utils" 
}
 
# Packages loading
invisible(lapply(packages, library, character.only = TRUE))
</pre>
</pre>
[[File:Lumi rgraphviz.svg|200px]]
Alternatively use the '''pacman''' package.


== Bioconductor [https://bioconductor.org/packages/devel/bioc/html/BiocPkgTools.html BiocPkgTools] ==
== library( , '''exclude, include.only''') ==
Collection of simple tools for learning about Bioc Packages. Functionality includes access to :
See [https://www.rdocumentation.org/packages/base/versions/3.6.2/topics/library ?library]
* Download statistics
<pre>
* General package listing
library(tidyverse)
* Build reports
library(MASS, exclude='select')
* Package dependency graphs
library(thepackage, include.only="thefunction")
* Vignettes
</pre>


[https://seandavi.github.io/BiocPkgTools/articles/BiocPkgTools.html#dependency-graphs Overview of BiocPkgTools & Dependency graphs]
== package ‘XXX’ was installed by an R version with different internals ==
it needs to be reinstalled for use with this R version. The problem seems to be specific to R 3.5.1 in Ubuntu 16.04. I got this message when I try to install the '''keras''' and '''tidyverse''' packages. The 'XXX' package includes ''nlme'' for installing "tidyverse" and ''Matrix'' for installing "reticulate". I have already logged in as root. I need to manually install these packages again though it seems I did not see a version change for these packages.


[https://www.biorxiv.org/content/10.1101/642132v1 BiocPkgTools: Toolkit for Mining the Bioconductor Package Ecosystem] in biorxiv.org.
Same error [https://stackoverflow.com/q/50992032 Error: package was installed by an R version with different internals; it needs to be reinstalled for use with this R version].


== [http://cran.r-project.org/web/packages/miniCRAN/ miniCRAN package]  ==
Today it also happened when I tried to install "pec" which broke when it was installing "Hmisc". The error message is "Error : package ‘rpart’ was installed by an R version with different internals; it needs to be reinstalled for use with this R version". I am using R 3.5.2. rpart version is ‘4.1.13’. The solution is I install rpart again (under my account is enough) though rpart does not have a new version. Then I can install "Hmisc".
'''miniCRAN''' package can be used to identify package dependencies or create a local CRAN repository. It can be used on repositories other than CRAN, such as Bioconductor.


* http://blog.revolutionanalytics.com/2014/07/dependencies-of-popular-r-packages.html
= packrat and renv =
* http://www.r-bloggers.com/introducing-minicran-an-r-package-to-create-a-private-cran-repository/
See [[Reproducible#renv:_successor_to_the_packrat_package| Reproducible &rarr; packrat/renv]]
* http://www.magesblog.com/2014/09/managing-r-package-dependencies.html
* [http://blog.revolutionanalytics.com/2015/10/using-minicran-in-azure-ml.html Using miniCRAN in Azure ML]
* [http://www.mango-solutions.com/wp/2016/01/minicran-developing-internal-cran-repositories/ developing internal CRAN Repositories]


Before we go into R, we need to install some packages from Ubuntu terminal. See [[R#Ubuntu.2FDebian_2|here]].
= R package dependencies =
<syntaxhighlight lang='rsplus'>
# Consider glmnet package (today is 4/29/2015)
# Version: 2.0-2
# Depends: Matrix (≥ 1.0-6), utils, foreach
# Suggests: survival, knitr, lars
if (!require("miniCRAN"))  {
  install.packages("miniCRAN", dependencies = TRUE, repos="http://cran.rstudio.com") # include 'igraph' in Suggests.
  library(miniCRAN)
}
if (!"igraph" %in% installed.packages()[,1]) install.packages("igraph")


tags <- "glmnet"
== Depends, Imports, Suggests, Enhances, LinkingTo ==
pkgDep(tags, suggests=TRUE, enhances=TRUE) # same as pkgDep(tags)
See [https://cran.r-project.org/doc/manuals/r-release/R-exts.html#Package-Dependencies Writing R Extensions] and [[#install.packages.28.29|install.packages()]].
# [1] "glmnet"    "Matrix"    "foreach"  "codetools" "iterators" "lattice"  "evaluate"  "digest" 
# [9] "formatR"  "highr"    "markdown"  "stringr"  "yaml"      "mime"      "survival"  "knitr"   
# [17] "lars" 


dg <- makeDepGraph(tags, suggests=TRUE, enhances=TRUE) # miniCRAN defines its makeDepGraph()
* Depends: list of package names which this package depends on. Those packages will be attached (so it is better to use ''Imports'' instead of ''Depends'' as much as you can) before the current package when library or require is called. The ‘Depends’ field can also specify a dependence on a certain version of R.
plot(dg, legendPosition = c(-1, 1), vertex.size=20)
* Imports: lists packages whose '''namespaces''' are imported from (as specified in the NAMESPACE file) but which do not need to be attached.
</syntaxhighlight>
* Suggests: lists packages that are not necessarily needed. This includes packages used only in examples, tests or vignettes, and packages loaded in the body of functions.
* Enhances: lists packages “enhanced” by the package at hand, e.g., by providing methods for classes from these packages, or ways to handle objects from these packages.
* LinkingTo: A package that wishes to make use of '''header''' files in other packages needs to declare them as a comma-separated list in the field ‘LinkingTo’ in the DESCRIPTION file.
** An example is [https://www.bioconductor.org/packages/release/bioc/html/SingleR.html SingleR] that links to the ''beachmat'' package in its [https://github.com/LTLA/SingleR/blob/master/src/recompute_scores.cpp cpp source code].


[[File:MiniCRAN dep.svg|300px]] [[File:pkgDepTools dep.svg|300px]]
== Package related functions from package 'utils' ==
[[File:Glmnet dep.svg|300px]]
* [http://stat.ethz.ch/R-manual/R-devel/library/utils/html/available.packages.html available.packages()]; see packageStatus().
 
* [http://stat.ethz.ch/R-manual/R-devel/library/utils/html/download.packages.html download.packages()]
We can also display the dependence for a package from the [http://cran.r-project.org/web/packages/miniCRAN/vignettes/miniCRAN-non-CRAN-repos.html Bioconductor] repository.
* [http://stat.ethz.ch/R-manual/R-devel/library/utils/html/packageStatus.html packageStatus(), update(), upgrade()]. packageStatus() will return a list with two components:
<syntaxhighlight lang='rsplus'>
# inst - a data frame with columns as the matrix returned by '''installed.packages''' plus "Status", a factor with levels c("ok", "upgrade"). Note: the manual does not mention "unavailable" case (but I do get it) in R 3.2.0?
tags <- "DESeq2"
# avail - a data frame with columns as the matrix returned by '''available.packages''' plus "Status", a factor with levels c("installed", "not installed", "unavailable"). Note: I don't get the "unavailable" case in R 3.2.0?
# Depends S4Vectors, IRanges, GenomicRanges, Rcpp (>= 0.10.1), RcppArmadillo (>= 0.3.4.4)
{{Pre}}
# Imports BiocGenerics(>= 0.7.5), Biobase, BiocParallel, genefilter, methods, locfit, geneplotter, ggplot2, Hmisc
> x <- packageStatus()
# Suggests RUnit, gplots, knitr, RColorBrewer, BiocStyle, airway,\npasilla (>= 0.2.10), DESeq, vsn
> names(x)
# LinkingTo    Rcpp, RcppArmadillo
[1] "inst"  "avail"
index <- function(url, type="source", filters=NULL, head=5, cols=c("Package", "Version")){
> dim(x[['inst']])
   contribUrl <- contrib.url(url, type=type)
[1] 225  17
   available.packages(contribUrl, type=type, filters=filters)
> x[['inst']][1:3, ]
}
              Package                            LibPath Version Priority              Depends Imports
 
acepack      acepack C:/Program Files/R/R-3.1.2/library 1.3-3.3    <NA>                  <NA>    <NA>
bioc <- local({
adabag        adabag C:/Program Files/R/R-3.1.2/library    4.0    <NA> rpart, mlbench, caret    <NA>
   env <- new.env()
affxparser affxparser C:/Program Files/R/R-3.1.2/library  1.38.0    <NA>          R (>= 2.6.0)   <NA>
  on.exit(rm(env))
          LinkingTo                                                       Suggests Enhances
   evalq(source("http://bioconductor.org/biocLite.R", local=TRUE), env)
acepack        <NA>                                                            <NA>    <NA>
  biocinstallRepos() # return URLs
adabag          <NA>                                                            <NA>     <NA>
})
affxparser      <NA> R.oo (>= 1.18.0), R.utils (>= 1.32.4),\nAffymetrixDataTestFiles    <NA>
 
                      License License_is_FOSS License_restricts_use OS_type MD5sum NeedsCompilation Built
bioc
acepack    MIT + file LICENSE            <NA>                  <NA>    <NA>   <NA>              yes 3.1.2
#                                              BioCsoft
adabag            GPL (>= 2)           <NA>                  <NA>    <NA>   <NA>              no 3.1.2
#           "http://bioconductor.org/packages/3.0/bioc"
affxparser        LGPL (>= 2)           <NA>                  <NA>    <NA>  <NA>            <NA> 3.1.1
#                                                BioCann
                Status
# "http://bioconductor.org/packages/3.0/data/annotation"
acepack            ok
#                                                BioCexp
adabag              ok
# "http://bioconductor.org/packages/3.0/data/experiment"
affxparser unavailable
#                                              BioCextra
> dim(x[['avail']])
#          "http://bioconductor.org/packages/3.0/extra"
[1] 6538  18
#                                                  CRAN
> x[['avail']][1:3, ]
#                                "http://cran.fhcrc.org"
                Package Version Priority                        Depends        Imports LinkingTo
#                                              CRANextra
A3                  A3   0.9.2    <NA> R (>= 2.15.0), xtable, pbapply          <NA>      <NA>
#                  "http://www.stats.ox.ac.uk/pub/RWin"
ABCExtremes ABCExtremes    1.0    <NA>      SpatialExtremes, combinat          <NA>      <NA>
str(index(bioc["BioCsoft"])) # similar to cranJuly2014 object
ABCanalysis ABCanalysis   1.0.1    <NA>                    R (>= 2.10) Hmisc, plotrix      <NA>
 
                      Suggests Enhances    License License_is_FOSS License_restricts_use OS_type Archs
system.time(dg <- makeDepGraph(tags, suggests=TRUE, enhances=TRUE, availPkgs = index(bioc["BioCsoft"]))) # Very quick!
A3          randomForest, e1071    <NA> GPL (>= 2)           <NA>                  <NA>    <NA>  <NA>
plot(dg, legendPosition = c(-1, 1), vertex.size=20)
ABCExtremes                <NA>    <NA>      GPL-2            <NA>                  <NA>    <NA>  <NA>
</syntaxhighlight>
ABCanalysis                <NA>    <NA>      GPL-3            <NA>                  <NA>    <NA>  <NA>
[[File:deseq2 dep.svg|300px]] [[File:Lumi dep.svg|300px]]
            MD5sum NeedsCompilation File                                      Repository        Status
 
A3           <NA>            <NA> <NA> http://cran.rstudio.com/bin/windows/contrib/3.1 not installed
The dependencies of [http://www.bioconductor.org/packages/release/bioc/html/GenomicFeatures.html GenomicFeature] and [http://www.bioconductor.org/packages/release/bioc/html/GenomicAlignments.html GenomicAlignments] are more complicated. So we turn the 'suggests' option to FALSE.
ABCExtremes  <NA>            <NA> <NA> http://cran.rstudio.com/bin/windows/contrib/3.1 not installed
<syntaxhighlight lang='rsplus'>
ABCanalysis  <NA>            <NA> <NA> http://cran.rstudio.com/bin/windows/contrib/3.1 not installed
tags <- "GenomicAlignments"
</pre>
dg <- makeDepGraph(tags, suggests=FALSE, enhances=FALSE, availPkgs = index(bioc["BioCsoft"]))
* [http://stat.ethz.ch/R-manual/R-devel/library/utils/html/packageDescription.html packageVersion(), packageDescription()]
plot(dg, legendPosition = c(-1, 1), vertex.size=20)
* [http://stat.ethz.ch/R-manual/R-devel/library/utils/html/install.packages.html install.packages()], [http://stat.ethz.ch/R-manual/R-devel/library/utils/html/remove.packages.html remove.packages()].
* [http://stat.ethz.ch/R-manual/R-devel/library/utils/html/installed.packages.html installed.packages()]; see packageStatus().
* [http://stat.ethz.ch/R-manual/R-devel/library/utils/html/update.packages.html update.packages(), old.packages(), new.packages()]
* [http://stat.ethz.ch/R-manual/R-devel/library/utils/html/setRepositories.html setRepositories()]
* [http://stat.ethz.ch/R-manual/R-devel/library/utils/html/contrib.url.html contrib.url()]
* [http://stat.ethz.ch/R-manual/R-devel/library/utils/html/chooseCRANmirror.html chooseCRANmirror()], [http://stat.ethz.ch/R-manual/R-devel/library/utils/html/chooseBioCmirror.html chooseBioCmirror()]
* [http://stat.ethz.ch/R-manual/R-devel/library/utils/html/globalVariables.html suppressForeignCheck()]
 
=== download.packages() for source package ===
Consider the [https://bioinformatics.mdanderson.org/estimate/rpackage.html esimate] package hosted on [https://r-forge.r-project.org/projects/estimate/ r-forge].
<pre>
download.packages("estimate", destdir = "~/Downloads",
  repos = "https://R-Forge.R-project.org")
</pre>
 
== tools package ==
* https://www.rdocumentation.org/packages/tools/versions/3.6.1
* CRAN_package_db() from [https://www.rdocumentation.org/packages/tools/versions/3.6.1/topics/CRANtools ?CRANtools]. Especially, it gives the Description and Maintainer information not provided by utils::available.packages()
* [https://www.rdocumentation.org/packages/tools/versions/3.6.1/topics/dependsOnPkgs dependsOnPkgs()]
:<syntaxhighlight lang='rsplus'>
db <- tools::CRAN_package_db()
nRcpp <- length(tools::dependsOnPkgs("Rcpp", recursive=FALSE, installed=db) )
nCompiled <- table(db[, "NeedsCompilation"])[["yes"]]
propRcpp <- nRcpp / nCompiled * 100
</syntaxhighlight>
</syntaxhighlight>
[[File:Genomicfeature dep dep.svg|300px]] [[File:Genomicalignments dep.svg|300px]]
* package.dependencies(), pkgDepends(), etc are deprecated now, mostly in favor of [https://www.rdocumentation.org/packages/tools/versions/3.6.2/topics/package_dependencies package_dependencies()] which is both more flexible and efficient. See [https://cran.rstudio.com/doc/manuals/r-release/NEWS.html R 3.3.0 News]. For example, tools::package_dependencies(c("remotes", "devtools"), recursive=TRUE) shows ''remotes'' has only a few dependencies while ''devtools'' has a lot.


== [http://mran.revolutionanalytics.com/ MRAN] (CRAN only) ==
== crandep package ==
* http://blog.revolutionanalytics.com/2014/10/explore-r-package-connections-at-mran.html
https://cran.r-project.org/web/packages/crandep/index.html. Useful to find reverse dependencies. [https://rdrr.io/cran/crandep/man/get_dep.html ?get_dep]. Consider the [https://cran.r-project.org/web/packages/abc/index.html abc] package:
<pre>
get_dep("abc", "depends") # abc depends on these packages
                          # note my computer does not have 'abc' installed
#  from      to    type reverse
# 1  abc abc.data depends  FALSE
# 2  abc    nnet depends  FALSE
# 3  abc quantreg depends  FALSE
# 4  abc    MASS depends  FALSE
# 5  abc  locfit depends  FALSE


== [https://cran.r-project.org/web/packages/cranly/ cranly] ==
get_dep("abc", "reverse_depends")
[https://cran.r-project.org/web/packages/cranly/vignettes/dependence_trees.html R package dependence trees]
#    from      to    type reverse
# 1  abc abctools depends    TRUE
# 2  abc  EasyABC depends    TRUE


== Reverse dependence ==
x <- get_dep("RcppEigen", c("reverse linking to"))
* http://romainfrancois.blog.free.fr/index.php?post/2011/10/30/Rcpp-reverse-dependency-graph
dim(x)
* [http://www.markvanderloo.eu/yaRb/2019/04/26/checking-reverse-dependencies-the-tiny-way/ Checking reverse dependencies: the tiny way]
# [1] 331  4
head(x, 3)
#        from      to      type reverse
# 1 RcppEigen  abess linking to    TRUE
# 2 RcppEigen    acrt linking to    TRUE
# 3 RcppEigen ADMMnet linking to    TRUE
</pre>


== Install packages offline ==
== How does this package depend on this other package ==
http://www.mango-solutions.com/wp/2017/05/installing-packages-without-internet/
[https://www.r-bloggers.com/2023/08/three-four-r-functions-i-enjoyed-this-week/ How does this package depend on this other package?],  [https://pak.r-lib.org/reference/pkg_deps_explain.html pak::pkg_deps_explain()]


== Install a packages locally and its dependencies ==
== pkgndep ==
It's impossible to install the dependencies if you want to install a package locally. See [http://r.789695.n4.nabble.com/Windows-GUI-quot-Install-Packages-from-local-zip-files-quot-and-dependencies-td848173.html Windows-GUI: "Install Packages from local zip files" and dependencies]
* [https://cran.r-project.org/web/packages/pkgndep/index.html CRAN] & the paper [https://academic.oup.com/bioinformatics/advance-article/doi/10.1093/bioinformatics/btac449/6633919?login=false pkgndep: a tool for analyzing dependency heaviness of R packages]
* [https://jokergoo.github.io/2023/11/16/package-dependencies-in-your-session/ Package dependencies in your session]. DESeq2 was used.


== A minimal R package (for testing purpose) ==
== remotes ==
https://github.com/joelnitta/minimal. Question: is there a one from CRAN?
[https://www.rdocumentation.org/packages/remotes/versions/2.2.0/topics/package_deps  remotes::local_package_deps(dependencies=TRUE)] will find and return all dependent packages based on the "DESCRIPTION" file. See an example [https://github.com/Bioconductor/OrchestratingSingleCellAnalysis here].


== An R package that does not require others during install.packages() ==
== Bioconductor's [http://www.bioconductor.org/packages/release/bioc/html/pkgDepTools.html pkgDepTools] package ==
* [https://cran.r-project.org/web/packages/crayon/index.html crayon]
The is an example of querying the dependencies of the notorious 'lumi' package which often broke the installation script. I am using R 3.2.0 and Bioconductor 3.1.  
* [https://cran.rstudio.com/web/packages/testit/index.html testit]
* [https://cran.rstudio.com/web/packages/docopt/index.html docopt] and [https://cran.rstudio.com/web/packages/littler/index.html littler]. See also [https://hadley.shinyapps.io/cran-downloads/ cran-downloads] shiny.
* [https://cran.r-project.org/web/packages/Rcpp/index.html Rcpp]


= Create a new R package, namespace, documentation =
The '''getInstallOrder''' function is useful to get a list of all (recursive) dependency packages.  
* http://cran.r-project.org/doc/contrib/Leisch-CreatingPackages.pdf (highly recommend)
{{Pre}}
* https://stat.ethz.ch/pipermail/r-devel/2013-July/066975.html
source("http://bioconductor.org/biocLite.R")
* [http://stackoverflow.com/questions/7283134/what-is-the-benefit-of-import-in-a-namespace-in-r/7283511#7283511 Benefit of import in a namespace]
if (!require(pkgDepTools)) {
* This youtube [http://www.youtube.com/watch?v=jGeCCxdZsDQ video] from Tyler Rinker teaches how to use RStudio to develop an R package and also use Git to do version control. Very useful!
  biocLite("pkgDepTools", ask = FALSE)
* [https://github.com/jtleek/rpackages Developing R packages] by Jeff Leek in Johns Hopkins University.
  library(pkgDepTools)
* [http://r-pkgs.had.co.nz/ R packages] book by Hadley Wickham.
}
* [http://kbroman.org/pkg_primer/ R package primer] a minimal tutorial from Karl Broman.
MkPlot <- FALSE
* [https://datascienceplus.com/how-to-make-and-share-an-r-package-in-3-steps/ How to make and share an R package in 3 steps] (6/14/2017)
* [https://github.com/jennybc/pkg-dev-tutorial Package Development tutorial for useR! 2019 Toulouse]


== Package structure ==
library(BiocInstaller)
http://r-pkgs.had.co.nz/package.html
biocUrl <- biocinstallRepos()["BioCsoft"]
biocDeps <- makeDepGraph(biocUrl, type="source", dosize=FALSE) # pkgDepTools defines its makeDepGraph()


* ChangeLog
PKG <- "lumi"
* DESCRIPTION
if (MkPlot) {
* MD5
  if (!require(Biobase))  {
* NAMESPACE
    biocLite("Biobase", ask = FALSE)
* R/
    library(Biobase)
** zzz.R
  }
* build/
  if (!require(Rgraphviz))  {
** Package.pdf (eg [https://github.com/cran/dplyr/tree/master/build dplyr])
    biocLite("Rgraphviz", ask = FALSE)  
** vignette.rds
    library(Rgraphviz)
* data/
  }
* demo/
  categoryNodes <- c(PKG, names(acc(biocDeps, PKG)[[1]])) 
* inst/
  categoryGraph <- subGraph(categoryNodes, biocDeps)
** extdata/
  nn <- makeNodeAttrs(categoryGraph, shape="ellipse")
** doc/
  plot(categoryGraph, nodeAttrs=nn)  # Complete but plot is too complicated & font is too small.
*** FileName.R
}
*** FileName.Rmd
*** FileName.html
** include/
** othersYouInclude/
** tinytest/
** CITATION
* man/
** figures/
* src/
* tests/
** testthat
* vignettes/


== Install software for PDF output ==
system.time(allDeps <- makeDepGraph(biocinstallRepos(), type="source",
* Windows: [http://miktex.org/download Miktex] and [https://pandoc.org/installing.html pandoc] ([http://rprogramming.net/create-html-or-pdf-files-with-r-knitr-miktex-and-pandoc/ Create HTML or PDF Files with R, Knitr, MiKTeX, and Pandoc])
                          keep.builtin=TRUE, dosize=FALSE)) # takes a little while
* Unix: [https://tug.org/texlive/ TeX Live] ('''sudo apt-get install texlive-full''') and [https://pandoc.org/installing.html pandoc]
#    user  system elapsed
* Mac: [https://tug.org/mactex/ MacTex]
# 175.737  10.994 186.875
# Warning messages:
# 1: In .local(from, to, graph) : edges replaced: ‘SNPRelate|gdsfmt’
# 2: In .local(from, to, graph) :
#  edges replaced: ‘RCurl|methods’, ‘NA|bitops’


== Windows: Rtools ==
# When needed.only=TRUE, only those dependencies not currently installed are included in the list.
[https://thecoatlessprofessor.com/programming/installing-rtools-for-compiled-code-via-rcpp/ Installing RTools for Compiled Code via Rcpp]. Just remember to check the option to include some paths in the '''PATH''' environment variable.
x1 <- sort(getInstallOrder(PKG, allDeps, needed.only=TRUE)$packages); x1
 
[1] "affy"                              "affyio"                         
== R CMD ==
[3] "annotate"                          "AnnotationDbi"                   
[https://cran.r-project.org/doc/manuals/R-admin.html R Installation and Administration]
[5] "base64"                            "beanplot"                       
 
[7] "Biobase"                          "BiocParallel"                   
* R CMD build XXX. Note this will not create pdf files for vignettes. The output is a tarball.
[9] "biomaRt"                          "Biostrings"                     
* R CMD INSTALL
[11] "bitops"                            "bumphunter"                     
* R CMD REMOVE
[13] "colorspace"                        "DBI"                             
* R CMD SHLIB files. For example, "Rcmd shlib *.f *.c -o surv.dll" on Windows.
[15] "dichromat"                        "digest"                         
* R CMD make
[17] "doRNG"                            "FDb.InfiniumMethylation.hg19"   
* R CMD check XXX. Useful if we want to create reference manual (PDF file). See [https://stackoverflow.com/a/16987795 R create reference manual with R CMD check].
[19] "foreach"                          "futile.logger"                   
* R CMD javareconf
[21] "futile.options"                    "genefilter"                     
[23] "GenomeInfoDb"                      "GenomicAlignments"               
[25] "GenomicFeatures"                  "GenomicRanges"                   
[27] "GEOquery"                          "ggplot2"                         
[29] "gtable"                            "illuminaio"                     
[31] "IRanges"                          "iterators"                       
[33] "labeling"                          "lambda.r"                       
[35] "limma"                            "locfit"                         
[37] "lumi"                              "magrittr"                       
[39] "matrixStats"                      "mclust"                         
[41] "methylumi"                        "minfi"                           
[43] "multtest"                          "munsell"                         
[45] "nleqslv"                          "nor1mix"                         
[47] "org.Hs.eg.db"                      "pkgmaker"                       
[49] "plyr"                              "preprocessCore"                 
[51] "proto"                            "quadprog"                       
[53] "RColorBrewer"                      "Rcpp"                           
[55] "RCurl"                            "registry"                       
[57] "reshape"                          "reshape2"                       
[59] "rngtools"                          "Rsamtools"                       
[61] "RSQLite"                          "rtracklayer"                     
[63] "S4Vectors"                        "scales"                         
[65] "siggenes"                          "snow"                           
[67] "stringi"                          "stringr"                         
[69] "TxDb.Hsapiens.UCSC.hg19.knownGene" "XML"                             
[71] "xtable"                            "XVector"                         
[73] "zlibbioc"                       


== usethis package ==
# When needed.only=FALSE the complete list of dependencies is given regardless of the set of currently installed packages.
* https://usethis.r-lib.org/. '''usethis''' is a workflow package: it automates repetitive tasks that arise during project setup and development, both for R packages and non-package projects.
x2 <- sort(getInstallOrder(PKG, allDeps, needed.only=FALSE)$packages); x2
* [https://www.tidyverse.org/articles/2019/04/usethis-1.5.0/ usethis 1.5.0]
[1] "affy"                              "affyio"                            "annotate"                       
 
[4] "AnnotationDbi"                    "base64"                            "beanplot"                       
== R package depends vs imports ==
[7] "Biobase"                          "BiocGenerics"                      "BiocInstaller"                   
* http://stackoverflow.com/questions/8637993/better-explanation-of-when-to-use-imports-depends
[10] "BiocParallel"                      "biomaRt"                          "Biostrings"                     
* http://stackoverflow.com/questions/9893791/imports-and-depends
[13] "bitops"                            "bumphunter"                        "codetools"                       
* https://stat.ethz.ch/pipermail/r-devel/2013-August/067082.html
[16] "colorspace"                        "DBI"                              "dichromat"                       
 
[19] "digest"                            "doRNG"                            "FDb.InfiniumMethylation.hg19"   
In the namespace era Depends is never really needed. All modern packages have no technical need for Depends anymore. Loosely speaking the only purpose of Depends today is to expose other package's functions to the user without re-exporting them.
[22] "foreach"                          "futile.logger"                    "futile.options"                 
 
[25] "genefilter"                        "GenomeInfoDb"                      "GenomicAlignments"               
load = functions exported in myPkg are available to interested parties as myPkg::foo or via direct imports - essentially this means the package can now be used
[28] "GenomicFeatures"                  "GenomicRanges"                    "GEOquery"                       
 
[31] "ggplot2"                          "graphics"                          "grDevices"                       
attach = the namespace (and thus all exported functions) is attached to the search path - the only effect is that you have now added the exported functions to the global pool of functions - sort of like dumping them in the workspace (for all practical purposes, not technically)
[34] "grid"                              "gtable"                            "illuminaio"                     
[37] "IRanges"                          "iterators"                        "KernSmooth"                     
[40] "labeling"                          "lambda.r"                          "lattice"                         
[43] "limma"                            "locfit"                            "lumi"                           
[46] "magrittr"                          "MASS"                              "Matrix"                         
[49] "matrixStats"                      "mclust"                            "methods"                         
[52] "methylumi"                        "mgcv"                              "minfi"                           
[55] "multtest"                          "munsell"                          "nleqslv"                         
[58] "nlme"                              "nor1mix"                          "org.Hs.eg.db"                   
[61] "parallel"                          "pkgmaker"                          "plyr"                           
[64] "preprocessCore"                    "proto"                            "quadprog"                       
[67] "RColorBrewer"                      "Rcpp"                              "RCurl"                           
[70] "registry"                          "reshape"                          "reshape2"                       
[73] "rngtools"                          "Rsamtools"                        "RSQLite"                         
[76] "rtracklayer"                      "S4Vectors"                        "scales"                         
[79] "siggenes"                          "snow"                              "splines"                         
[82] "stats"                            "stats4"                            "stringi"                         
[85] "stringr"                          "survival"                          "tools"                           
[88] "TxDb.Hsapiens.UCSC.hg19.knownGene" "utils"                            "XML"                             
[91] "xtable"                            "XVector"                          "zlibbioc"


import a function into a package = make sure that this function works in my package regardless of the search path (so I can write fn1 instead of pkg1::fn1 and still know it will come from pkg1 and not someone's workspace or other package that chose the same name)
> sort(setdiff(x2, x1)) # Not all R's base packages are included; e.g. 'base', 'boot', ...
[1] "BiocGenerics"  "BiocInstaller" "codetools"    "graphics"      "grDevices"   
[6] "grid"          "KernSmooth"    "lattice"      "MASS"          "Matrix"     
[11] "methods"      "mgcv"          "nlme"          "parallel"      "splines"     
[16] "stats"        "stats4"        "survival"      "tools"        "utils" 
</pre>
[[File:Lumi rgraphviz.svg|200px]]


------------------------------------------------------------------------
== Bioconductor [https://bioconductor.org/packages/devel/bioc/html/BiocPkgTools.html BiocPkgTools] ==
* https://stat.ethz.ch/pipermail/r-devel/2013-September/067451.html
Collection of simple tools for learning about Bioc Packages. Functionality includes access to :
* Download statistics
* General package listing
* Build reports
* Package dependency graphs
* Vignettes


The distinction is between "loading" and "attaching" a package. Loading
[https://seandavi.github.io/BiocPkgTools/articles/BiocPkgTools.html#dependency-graphs Overview of BiocPkgTools & Dependency graphs]
it (which would be done if you had MASS::loglm, or imported it)
guarantees that the package is initialized and in memory, but doesn't
make it visible to the user without the explicit MASS:: prefix.
Attaching it first loads it, then modifies the user's search list so the
user can see it.


Loading is less intrusive, so it's preferred over attaching. Both
[https://www.biorxiv.org/content/10.1101/642132v1 BiocPkgTools: Toolkit for Mining the Bioconductor Package Ecosystem] in biorxiv.org.
library() and require() would attach it.


== R package suggests ==
== [http://cran.r-project.org/web/packages/miniCRAN/ miniCRAN package] ==
[https://cran.r-project.org/web/packages/stringr/index.html stringr] has suggested '''htmlwidgets'''. An error will come out if the suggested packages are not available.
'''miniCRAN''' package can be used to identify package dependencies or create a local CRAN repository. It can be used on repositories other than CRAN, such as Bioconductor.
<syntaxhighlight lang='rsplus'>
> library(stringr)
> str_view(c("abc", "a.c", "bef"), "a\\.c")
Error in loadNamespace(name) : there is no package called ‘htmlwidgets’
</syntaxhighlight>


== Useful functions for accessing files in packages ==
* http://blog.revolutionanalytics.com/2014/07/dependencies-of-popular-r-packages.html
* [https://stat.ethz.ch/R-manual/R-devel/library/base/html/system.file.html system.file()]
* http://www.r-bloggers.com/introducing-minicran-an-r-package-to-create-a-private-cran-repository/
* [https://stat.ethz.ch/R-manual/R-devel/library/base/html/find.package.html path.package()] and normalizePath().
* http://www.magesblog.com/2014/09/managing-r-package-dependencies.html
<syntaxhighlight lang='rsplus'>
* [http://blog.revolutionanalytics.com/2015/10/using-minicran-in-azure-ml.html Using miniCRAN in Azure ML]
> system.file(package = "batr")
* [http://www.mango-solutions.com/wp/2016/01/minicran-developing-internal-cran-repositories/ developing internal CRAN Repositories]
[1] "f:/batr"
> system.file("extdata", package = "batr")


> path.package("batr")
Before we go into R, we need to install some packages from Ubuntu terminal. See [[R#Ubuntu.2FDebian_2|here]].
[1] "f:\\batr"
{{Pre}}
# Consider glmnet package (today is 4/29/2015)
# Version: 2.0-2
# Depends: Matrix (≥ 1.0-6), utils, foreach
# Suggests: survival, knitr, lars
if (!require("miniCRAN"))  {
  install.packages("miniCRAN", dependencies = TRUE, repos="http://cran.rstudio.com") # include 'igraph' in Suggests.
  library(miniCRAN)
}
if (!"igraph" %in% installed.packages()[,1]) install.packages("igraph")


# sometimes it returns the forward slash format for some reason; C:/Program Files/R/R-3.4.0/library/batr
tags <- "glmnet"
# so it is best to add normalizePath().
pkgDep(tags, suggests=TRUE, enhances=TRUE) # same as pkgDep(tags)
> normalizePath(path.package("batr"))
#  [1] "glmnet"    "Matrix"    "foreach"  "codetools" "iterators" "lattice"  "evaluate"  "digest" 
</syntaxhighlight>
#  [9] "formatR"  "highr"    "markdown"  "stringr"  "yaml"      "mime"      "survival"  "knitr"  
# [17] "lars" 


== RStudio shortcuts ==
dg <- makeDepGraph(tags, suggests=TRUE, enhances=TRUE) # miniCRAN defines its makeDepGraph()
[[File:RStudio Build.png|200px]]
plot(dg, legendPosition = c(-1, 1), vertex.size=20)
</pre>


== Create R package with [https://github.com/hadley/devtools devtools] and [http://cran.r-project.org/web/packages/roxygen2/index.html roxygen2] ==
[[File:MiniCRAN dep.svg|300px]] [[File:pkgDepTools dep.svg|300px]]
[[File:Glmnet dep.svg|300px]]


* A useful [http://thepoliticalmethodologist.com/2014/08/14/building-and-maintaining-r-packages-with-devtools-and-roxygen2/ post] by Jacob Montgomery. Watch the [https://www.youtube.com/watch?v=9PyQlbAEujY#t=19 youtube video] there. The process requires 3 components: RStudio software, devtools and roxygen2 (creating documentation from R code) packages.
We can also display the dependence for a package from the [http://cran.r-project.org/web/packages/miniCRAN/vignettes/miniCRAN-non-CRAN-repos.html Bioconductor] repository.
* [https://uoftcoders.github.io/studyGroup/lessons/r/packages/lesson/ MAKING PACKAGES IN R USING DEVTOOLS]
{{Pre}}
* [http://r-pkgs.had.co.nz/r.html R code workflow] from Hadley Wickham.
tags <- "DESeq2"
* [https://jozefhajnala.gitlab.io/r/r102-addin-roxytags/ RStudio:addins part 2 - roxygen documentation formatting made easy]
# Depends S4Vectors, IRanges, GenomicRanges, Rcpp (>= 0.10.1), RcppArmadillo (>= 0.3.4.4)
* [http://web.mit.edu/insong/www/pdf/rpackage_instructions.pdf Instructions for Creating Your Own R Package]. It includes creating a R package with functions written in C++ via Rcpp helper function.
# Imports BiocGenerics(>= 0.7.5), Biobase, BiocParallel, genefilter, methods, locfit, geneplotter, ggplot2, Hmisc
* [https://www.rstudio.com/wp-content/uploads/2015/06/devtools-cheatsheet.pdf devtools cheatsheet] (2 pages)
# Suggests RUnit, gplots, knitr, RColorBrewer, BiocStyle, airway,\npasilla (>= 0.2.10), DESeq, vsn
* My first R package [https://qualityandinnovation.com/2019/10/13/my-first-r-package-part-1/ Part 1], [https://qualityandinnovation.com/2019/10/13/my-first-r-package-part-2/ Part 2], [https://qualityandinnovation.com/2019/10/13/my-first-r-package-part-3/ Part 3]. It uses 3 packages: usethis, roxygen2 and devtools.
# LinkingTo    Rcpp, RcppArmadillo
index <- function(url, type="source", filters=NULL, head=5, cols=c("Package", "Version")){
  contribUrl <- contrib.url(url, type=type)
  available.packages(contribUrl, type=type, filters=filters)
}


How to use [http://rstudio-pubs-static.s3.amazonaws.com/2556_4e9f1c2af93b4683a19e2303a52bb2d5.html devtools::load_all("FolderName")]. load_all() loads any modified R files, and recompile and reload any modified C or Fortran files.
bioc <- local({
<syntaxhighlight lang='rsplus'>
  env <- new.env()
# Step 1
  on.exit(rm(env))
library(devtools)
  evalq(source("http://bioconductor.org/biocLite.R", local=TRUE), env)
  biocinstallRepos() # return URLs
})


# Step 2
bioc
dir.create(file.path("MyCode", "R"), recursive = TRUE)
#                                               BioCsoft
cat("foo=function(x){x*2}", file = file.path("MyCode", "R", "foo.R"))
#            "http://bioconductor.org/packages/3.0/bioc"  
write.dcf(list(Package = "MyCode", Title = "My Code for this project", Description = "To tackle this problem",
#                                                BioCann
    Version = "0.0", License = "For my eyes only", Author = "First Last <[email protected]>",  
# "http://bioconductor.org/packages/3.0/data/annotation"
    Maintainer = "First Last <[email protected]>"), file = file.path("MyCode", "DESCRIPTION"))
#                                                BioCexp
# OR
# "http://bioconductor.org/packages/3.0/data/experiment"  
# create("path/to/package/pkgname")
#                                              BioCextra
# create() will create R/ directory, DESCRIPTION and NAMESPACE files.
#          "http://bioconductor.org/packages/3.0/extra"  
#                                                  CRAN
#                                "http://cran.fhcrc.org"  
#                                              CRANextra
#                  "http://www.stats.ox.ac.uk/pub/RWin"  
str(index(bioc["BioCsoft"])) # similar to cranJuly2014 object
 
system.time(dg <- makeDepGraph(tags, suggests=TRUE, enhances=TRUE, availPkgs = index(bioc["BioCsoft"]))) # Very quick!
plot(dg, legendPosition = c(-1, 1), vertex.size=20)
</pre>
[[File:deseq2 dep.svg|300px]] [[File:Lumi dep.svg|300px]]


# Step 3 (C/Fortran code, optional)
The dependencies of [http://www.bioconductor.org/packages/release/bioc/html/GenomicFeatures.html GenomicFeature] and [http://www.bioconductor.org/packages/release/bioc/html/GenomicAlignments.html GenomicAlignments] are more complicated. So we turn the 'suggests' option to FALSE.
dir.create(file.path("MyCode", "src"))
<syntaxhighlight lang='rsplus'>
cat("void cfoo(double *a, double *b, double *c){*c=*a+*b;}\n", file = file.path("MyCode",
tags <- "GenomicAlignments"
    "src", "cfoo.c"))
dg <- makeDepGraph(tags, suggests=FALSE, enhances=FALSE, availPkgs = index(bioc["BioCsoft"]))
cat("useDynLib(MyCode)\n", file = file.path("MyCode", "NAMESPACE"))
plot(dg, legendPosition = c(-1, 1), vertex.size=20)
</syntaxhighlight>
[[File:Genomicfeature dep dep.svg|300px]] [[File:Genomicalignments dep.svg|300px]]


# Step 4
=== Github repository ===
load_all("MyCode")
[https://thierrymoudiki.github.io/blog/2020/10/16/r/esgtoolkit-new-cran Submitting R package to CRAN]


# Step 5
== cranlike ==
# Modify R/C/Fortran code and run load_all("MyCode")
https://github.com/r-hub/cranlike


# Step 6 (Automatically generate the documentation, optional)
cranlike keeps the package data in a SQLite database, in addition to the PACKAGES* files. This database is the canonical source of the package data. It can be updated quickly, to add and remove packages. The PACKAGES* files are generated from the database.
document()


# Step 7 (Deployment, create a tarball, optional)
== [http://mran.revolutionanalytics.com/ MRAN] (CRAN only) & checkpoint package ==
build("MyCode")
* http://blog.revolutionanalytics.com/2014/10/explore-r-package-connections-at-mran.html
* [https://rsangole.netlify.app/post/2020/10/10/reproducible-work-in-r/?s=09 Reproducible Work in R]
* [https://datacolada.org/108 MRAN is Dead, long live GRAN] 4/28/2023


# Step 8 (Install the package, optional)
According to the snapsot list [https://cran.microsoft.com/snapshot/ here], the oldest version is 2014-08-18 which corresponds to R 3.1.0.
install()
</syntaxhighlight>


'''Note''':  
[https://mran.revolutionanalytics.com/documents/rro/reproducibility#timemachine checkpoint] package
# '''load_all("FolderName")''' will make the FolderName to become ''like'' a package to be loaded into the current R session so the 2nd item returned from '''search()''' will be '''"package:FolderName"'''. However, the ''FolderName'' does not exist under Program Files/R/R-X.Y.Z/library nor Documents/R/win-library/X.Y/ (Windows OS).
<pre>
# '''build("FolderName")''' will create a tarball in the current directory. User can install the new package for example using Packages -> Install packages from local files on Windows OS. This will build/run vignettes so it may take some time. The tarball will contain a '''build''' folder containing 'vignette.rds' file. It'll also create a new folder '''inst/doc''' containing 3 files (MyPkg.html, MyPkg.Rmd and MyPkg.R). The vignettes may contain a new folder '''MyPkg_cache''' if we use chunk = TRUE option in Rmd file. Note install.packages() will not run the R code in vignettes.
library(checkpoint)
# For the simplest R package, the source code only contains a file <DESCRIPTION> and a folder <R> with individual R files in the text format.
checkpoint("2015-03-31")
</pre>
 
'''Note the Bioconductor packages have no similar solution.'''


== Create a package by RStudio ==
== groundhog package ==
* [https://medium.com/@shiansu/how-to-create-and-distribute-an-r-package-a296217435dc How to Create and Distribute an R Package].
* [https://cran.r-project.org/web/packages/groundhog/index.html groundhog]: Version-Control for CRAN, GitHub, and GitLab Packages (Bioconductor?)
** The goal of the article to set up an easily installable R package on Github for others to use via remotes::install_github().
* It seems groundhog is like checkpoint but groundhog does not depend on MRAN and it will figure out the package dependencies by itself.
** The main tools required are RStudio along with the packages roxygen2 and usethis.
* [https://www.brodrigues.co/blog/2023-01-12-repro_r/ MRAN is getting shutdown] - what else is there for reproducibility with R, or why reproducibility is on a continuum?  The author provides an example where we can integrate "groundhog" in the Dockerfile for reproducibility. Pay attention to the sentence (appear 2 times) '''“why use Docker at all? Since it’s easy to install older versions of R on Windows and macOS, wouldn’t an renv.lock file suffice? Or even just {groundhog} which is arguably even easier to use?” '''
** How to take care of Bioconductor and Github Dependencies
* [https://github.com/rocker-org/rocker-versioned2/issues/593 MRAN is getting shutdown #593] related to Rocker project. Rocker now uses [https://docs.posit.co/rspm/admin/ RSPM (PPM now)] from RStudio.
** How to publish your package to Github
* groundhog.library() differs from the library() function: 1) it installed and loaded packages in one step, 2) it allowed to install multiple packages.
* [https://technistema.com/posts/building-a-corporate-r-package-for-pleasure-and-profit/ Building a Corporate R Package for Pleasure and Profit]


== Binary packages ==
Note I use the docker's R since that's the easiest way to use an old version of R (e.g. for some old R script) in Linux. Note that it will create a new folder '''R_groundhog''' folder in the working directory (see the message below).
* No .R files in the ''R/'' directory. There are 3 files that store the parsed functions in an efficient file format. This is the result of loading all the R code and then saving the functions with ''save()''.
<pre>
* A ''Meta/'' directory contains a number of Rds files. These files contain cached metadata about the package, like what topics the help files cover and parsed version of the ''DESCRIPTION'' file.
$ docker run --rm -it -v $(pwd):/home/docker \
* An ''html/'' directory.
    -w /home/docker -u docker r-base:4.0.2 R
* ''libs/'' directory if you have any code in the ''src/' directory
* The contents of ''inst/'' are moved to the top-level directory.


=== Building the tarball ===
> install.packages("groundhog")
* No matter we uses '''devtools::build()''' or the terminal '''R CMD build MyPkg''' will uses run the R code in vignette. Be cautious on the extra time and storage the process incurred.
> library(groundhog")
* If 'cache = TRUE' is used in vignettes, it will create a new subfolder called MyuPkg_cache under the vignettes folder. This takes a lot of space (eg 1GB in some case).
groundhog needs authorization to save files to '/home/docker/R_groundhog'
Enter 'OK' to provide authorization
OK
The groundhog folder path is now:
/home/docker/R_groundhog/groundhog_library/
Loaded 'groundhog' (version:2.1.0) using R-4.0.2
Tips and troubleshooting: https://groundhogR.com


=== Building the binary ===
> groundhog.library("
<pre>
  library(ggplot2)",
R CMD INSTALL --build MyPkg.tar.gz
    "2020-10-10")
> library()
# Packages in library ‘/usr/local/lib/R/site-library’:
> packageVersion("ggplot2")
[1] ‘3.3.2’  # the latest version is 3.4.0 on R 4.2.2
> library(ggplot2)
</pre>
</pre>
The binary (on Windows) can be installed by '''install.packages("Mypkg.zip",repos=NULL)'''


== data ==
(Current groundhog is v3.1.0) If I don't specify a user in docker run, I'll need to call groundhog.library() twice in order to install packages (eg. "DT" package). In this case I can use '''groundhog:::save.cookie("copy_instead_of_renaming")''' before calling groundhog.library().
http://r-pkgs.had.co.nz/data.html
<pre>
$ docker run -it --rm rocker/verse:4.3.0 bash
root@58978695ec12:/# R
R version 4.3.0 (2023-04-21) -- "Already Tomorrow"
...
> install.packages("groundhog"); library(groundhog)


Three ways to include data in your package.
> .libPaths()
* If you want to store binary data and make it available to the user, put it in '''data/'''. This is the best place to put example datasets.
[1] "/usr/local/lib/R/site-library" "/usr/local/lib/R/library"
* If you want to store parsed data, but not make it available to the user, put it in '''R/sysdata.rda'''. This is the best place to put data that your functions need.
> get.groundhog.folder()
* If you want to store raw data, put it in '''inst/extdata'''.
[1] "/root/R_groundhog/groundhog_library/"


== Vignette ==
> groundhog:::save.cookie("copy_instead_of_renaming")
* [http://www.markvanderloo.eu/yaRb/2019/01/11/add-a-static-pdf-vignette-to-an-r-package/ Add a static pdf vignette to an R package]
groundhog needs authorization to save files to '/root/R_groundhog/'
* [https://www.rdocumentation.org/packages/devtools/versions/2.2.0/topics/build_vignettes devtools::build_vignettes()].  The files are copied in the 'doc' directory and an vignette index is created in 'Meta/vignette.rds', as they would be in a built package.
Enter 'OK' to provide authorization, and 'NO' not to.
* [https://stackoverflow.com/a/37692810 build_vignette can't find functions]
|  >OK


Long execution for R code in vignette
Groundhog folder set to: '/root/R_groundhog/groundhog_library/
* [https://community.rstudio.com/t/caching-chunks-in-rstudio-does-not-work/9040/7 Caching chunks in RStudio does not work]
* [https://rmflight.github.io/posts/2014/07/vignetteAnalysis.html caching doesn't seem to work here (i.e. when used in a document that is a vignette)]


== README.Rmd & README.md files ==
--- You may change it with`set.groundhog.folder(<path>)`---
See [http://r-pkgs.had.co.nz/release.html Releasing a package] from R packages by Hadley Wickham.
Downloading database with information for all CRAN packages ever published
trying URL 'http://s3.wasabisys.com/groundhog/cran.toc.rds'
Content type 'application/octet-stream' length 2010504 bytes (1.9 MB)
==================================================
downloaded 1.9 MB


[https://stackoverflow.com/a/31914830 How to convert .Rmd into .md in R studio?]
Downloading database with installation times for all source packages on CRAN
trying URL 'http://s3.wasabisys.com/groundhog/cran.times.rds'
Content type 'application/octet-stream' length 803912 bytes (785 KB)
==================================================
downloaded 785 KB
> groundhog.library("DT", "2023-4-23")
> find.package("DT")
</pre>


Example: [https://github.com/tidyverse/ggplot2 ggplot2] repository at Github
== rang ==
[http://blog.schochastics.net/post/rang-make-ancient-r-code-run-again/ rang: make ancient R code run again]


It seems RStudio cannot create TOC for *.md files. [[Text_editor#Markdown_TOC_.28table_of_contents.29_extension|Visual Studio Code]] has an extension to do that.
== [https://cran.r-project.org/web/packages/cranly/ cranly] ==
[https://cran.r-project.org/web/packages/cranly/vignettes/dependence_trees.html R package dependence trees]


== What is a library? ==
== sessioninfo ==
A library is simply a directory containing installed packages.
<pre>
tmp = session_info("sessioninfo")
dim(tmp$packages) # [1]  7 11


You can use ''.libPaths()'' to see which libraries are currently active.
tmp = session_info("tidyverse")
<syntaxhighlight lang='rsplus'>
dim(tmp$packages) # [1] 95 11
.libPaths()
</pre>


lapply(.libPaths(), dir)
== Reverse dependence ==
</syntaxhighlight>
* http://romainfrancois.blog.free.fr/index.php?post/2011/10/30/Rcpp-reverse-dependency-graph
* [http://www.markvanderloo.eu/yaRb/2019/04/26/checking-reverse-dependencies-the-tiny-way/ Checking reverse dependencies: the tiny way]


== Object names ==
== Install packages offline ==
* Variable and function names should be lower case.
http://www.mango-solutions.com/wp/2017/05/installing-packages-without-internet/
* Use an underscore (_) to separate words within a name (reserve . for S3 methods).
* [https://en.wikipedia.org/wiki/Camel_case Camel case] is a legitimate alternative, but be consistent! For example, preProcess(), twoClassData, createDataPartition(), trainingRows, trainPredictors, testPredictors, trainClasses, testClasses have been used in [https://cran.r-project.org/web/packages/AppliedPredictiveModeling/index.html Applied Predictive Modeling] by [http://appliedpredictivemodeling.com/ Kuhn & Johnson].
* Generally, variable names should be nouns and function names should be verb.


== Spacing ==
== Install a packages locally and its dependencies ==
* Add a space around the operators +, -, \ and *.  
It's impossible to install the dependencies if you want to install a package locally. See [http://r.789695.n4.nabble.com/Windows-GUI-quot-Install-Packages-from-local-zip-files-quot-and-dependencies-td848173.html Windows-GUI: "Install Packages from local zip files" and dependencies]
* Include a space around the assignment operators, <- and =.
* Add a space around any comparison operators such as == and <.


== Indentation ==
== A minimal R package (for testing purpose) ==
* Use two spaces to indent code.  
* https://github.com/joelnitta/minimal. Question: is there a one from CRAN?
* Never mix tabs and spaces.  
* [https://kbroman.org/pkg_primer/pages/minimal.html The minimal R package]
* RStudio can automatically convert the tab character to spaces (see Tools -> Global options -> Code).
* [https://cran.r-project.org/web/packages/QuadRoot/ QuadRoot] - the smallest R package on CRAN as of 5/10/2023. Others include (starting from the smallest) relen, signibox, freqdist, fdq.


== \dontrun{} ==
== An R package that does not require others during install.packages() ==
* [https://cran.r-project.org/doc/manuals/R-exts.html Writing R Extensions > Documenting functions] and search for '''dontrun'''
* [https://cran.r-project.org/web/packages/crayon/index.html crayon]
* [https://stackoverflow.com/questions/12038160/how-to-not-run-an-example-using-roxygen2 How to not run an example using roxygen2?]
* [https://cran.rstudio.com/web/packages/testit/index.html testit]
* [https://stackoverflow.com/questions/1454211/what-does-not-run-mean-in-r-help-pages What does "not run" mean in R help pages?] See ?example .
* [https://cran.rstudio.com/web/packages/docopt/index.html docopt] and [https://cran.rstudio.com/web/packages/littler/index.html littler]. See also [https://hadley.shinyapps.io/cran-downloads/ cran-downloads] shiny.
* [https://cran.r-project.org/web/packages/Rcpp/index.html Rcpp]


== formatR package ==
= Create a new R package, namespace, documentation =
Use formatR package to clean up poorly formatted code
* http://cran.r-project.org/doc/contrib/Leisch-CreatingPackages.pdf (highly recommend)
<syntaxhighlight lang='rsplus'>
* https://stat.ethz.ch/pipermail/r-devel/2013-July/066975.html
install.packages("formatR")
* [http://stackoverflow.com/questions/7283134/what-is-the-benefit-of-import-in-a-namespace-in-r/7283511#7283511 Benefit of import in a namespace]
formatR::tidy_dir("R")
* This youtube [http://www.youtube.com/watch?v=jGeCCxdZsDQ video] from Tyler Rinker teaches how to use RStudio to develop an R package and also use Git to do version control. Very useful!
</syntaxhighlight>
* [https://github.com/jtleek/rpackages Developing R packages] by Jeff Leek in Johns Hopkins University.
* [http://r-pkgs.had.co.nz/ R packages] book by Hadley Wickham.
* [http://kbroman.org/pkg_primer/ R package primer] a minimal tutorial from Karl Broman.
* [https://datascienceplus.com/how-to-make-and-share-an-r-package-in-3-steps/ How to make and share an R package in 3 steps] (6/14/2017)
* [https://github.com/jennybc/pkg-dev-tutorial Package Development tutorial for useR! 2019 Toulouse]
* [https://devguide.ropensci.org/ rOpenSci Packages: Development, Maintenance, and Peer Review]
* [https://b-rodrigues.github.io/modern_R/package-development.html Package development] from "Modern R with the tidyverse"
* [https://youtu.be/qxRSzDejea4 How to write your own R package] (video, 10 minutes)
* [https://youtu.be/EpTkT6Rkgbs Building R packages with devtools and usethis | RStudio] (video, thomas mock)
* [https://quantixed.org/2022/09/06/the-package-learning-how-to-build-an-r-package/ The Package: learning how to build an R package]
* [https://www.mzes.uni-mannheim.de/socialsciencedatalab/article/r-package/ How to write your own R package and publish it on CRAN]
* [https://www.r-bloggers.com/2024/08/r-package-development-workflow-assuming-youre-using-macos-or-linux/ R package development workflow (assuming you’re using macOS or Linux)]


Another way is to use the '''linter''' package.
== Package structure ==
<syntaxhighlight lang='rsplus'>
http://r-pkgs.had.co.nz/package.html. On Linux/macOS, use '''tree -d DIRNAME''' to show the directories only. At a minimum, we will have '''R''' and '''man''' directories.
install.packages("lintr")
lintr:::lin_package()
</syntaxhighlight>


== Minimal R package for submission ==
* ChangeLog
https://stat.ethz.ch/pipermail/r-devel/2013-August/067257.html and [http://cran.r-project.org/web/packages/policies.html CRAN Repository Policy].
* DESCRIPTION
* MD5
* NAMESPACE
* R/
** zzz.R
* build/
** Package.pdf (eg [https://github.com/cran/dplyr/tree/master/build dplyr])
** vignette.rds
* data/
* demo/
* inst/
** extdata/
** doc/
*** FileName.R
*** FileName.Rmd
*** FileName.html
** include/
** othersYouInclude/
** tinytest/
** CITATION
* man/
** figures/
* src/
* tests/
** testthat
* vignettes/


== r-hub/rhub package: the R package builder service ==
=== NAMESPACE and DESCRIPTION ===
https://github.com/r-hub/proposal
[https://stackoverflow.com/a/13261139 Namespace dependencies not required]. ''If you use import or importFrom in your NAMESPACE file, you should have an entry for that package in the Imports section of your DESCRIPTION file (unless there is a reason that you need to use Depends in which case the package should have an entry in Depends, and not Imports).''
 
=== license ===
* [https://stackoverflow.com/a/38549043 What kind of license is the best license for an R package?]
* https://cran.r-project.org/web/licenses/
* https://r-pkgs.org/description.html#description-license
* [https://win-vector.com/2019/07/30/some-notes-on-gnu-licenses-in-r-packages/ Some Notes on GNU Licenses in R Packages]


* [https://blog.r-hub.io/2019/04/08/rhub-1.1.1/ rhub 1.1.1 is on CRAN!] 2019/4/8
== Install software for PDF output ==
* [https://blog.r-hub.io/2019/03/26/why-care/ R package developers, why should you care about R-hub?] 2019/3/26
* Windows: [http://miktex.org/download Miktex] and [https://pandoc.org/installing.html pandoc] ([http://rprogramming.net/create-html-or-pdf-files-with-r-knitr-miktex-and-pandoc/ Create HTML or PDF Files with R, Knitr, MiKTeX, and Pandoc])
* [https://r-hub.github.io/rhub/articles/local-debugging.html Local Linux checks with Docker]
* Unix: [https://tug.org/texlive/ TeX Live] ('''sudo apt-get install texlive-full''') and [https://pandoc.org/installing.html pandoc]
* https://www.rstudio.com/resources/videos/r-hub-overview/
* Mac: [https://tug.org/mactex/ MacTex]
* http://blog.revolutionanalytics.com/2016/10/r-hub-public-beta.html
* [https://jozef.io/r107-multiplatform-gitlabci-rhub/ Setting up continuous multi-platform R package building, checking and testing with R-Hub, Docker and GitLab CI/CD for free, with a working example] 2019/4/27
* [https://blog.r-hub.io/2019/05/29/keep-up-with-cran/ How to keep up with CRAN policies and processes?] 2019/5/29


== CRAN check API ==
== Windows: Rtools ==
* [https://blog.r-hub.io/2019/06/10/cran-checks-api/ Overview of the CRAN checks API] 2019/6/10
<ul>
* [https://ropensci.org/technotes/2019/10/09/cran-checks-api-update/ update] 2019/10/9
<li>(Old) [https://thecoatlessprofessor.com/programming/installing-rtools-for-compiled-code-via-rcpp/ Installing RTools for Compiled Code via Rcpp]. Just remember to check the option to include some paths in the '''PATH''' environment variable.
<li>[https://cran.rstudio.com/bin/windows/Rtools/rtools40.html Using Rtools4 on Windows]. This version gives more details about the story in Rtools4X versions.
* https://cloud.r-project.org/bin/windows/base/howto-R-4.3.html
<li>Testing Rtools43 on R 4.3.3. According to the information on the website: '''When using R installed by the installer, no further setup is necessary after installing Rtools43 to build R packages from source.''' I can testify that by running ''install.packages("jsonlite", type = "source")'' . We can also verify that make can be found.
<pre>
Sys.which("make")
## "C:\\rtools40\\usr\\bin\\make.exe"
</pre>
</ul>
Screenshots of installation of Rtools44


== Continuous Integration: [https://travis-ci.org/ Travis-CI] (Linux, Mac) ==
[[File:Rtools44.png|350px]]
* [http://juliasilge.com/blog/Beginners-Guide-to-Travis/  A Beginner's Guide to Travis-CI]
* [http://r-pkgs.had.co.nz/tests.html testhat] package. Lots of packages suggest testhat; for example [https://cran.r-project.org/web/packages/princurve/index.html princurve].
* http://johnmuschelli.com/neuroc/getting_ready_for_submission/index.html#61_travis


== Continuous Integration: [https://www.appveyor.com/ Appveyor] (Windows) ==
== R CMD ==
* Appveyor is a continuous integration service that builds projects on Windows machines.  
[https://cran.r-project.org/doc/manuals/R-admin.html R Installation and Administration]
* http://johnmuschelli.com/neuroc/getting_ready_for_submission/index.html#62_appveyor


== Submit packages to cran ==
* R CMD build XXX. Note this will not create pdf files for vignettes. The output is a tarball.
* http://f.briatte.org/r/submitting-packages-to-cran
* R CMD INSTALL
* [https://rmhogervorst.nl/cleancode/blog/2016/07/09/content/post/2016-07-09-submtting-to-cran-first-experience/ Submitting your first package to CRAN, my experience]
* R CMD REMOVE
* [http://johnmuschelli.com/neuroc/getting_ready_for_submission/index.html Preparing Your Package for for Submission] by John Muschelli
* R CMD SHLIB files. For example, "Rcmd shlib *.f *.c -o surv.dll" on Windows.
* https://builder.r-hub.io/. See [[R#Introducing_R-hub_.28rhub_package.29.2C_the_R_package_builder_service|here]].
* R CMD make
* [https://neonira.github.io/op2 The most annoying warning for CRAN submission]
* R CMD check XXX. Useful if we want to create reference manual (PDF file). See [https://stackoverflow.com/a/16987795 R create reference manual with R CMD check].
* R CMD javareconf
 
== usethis package ==
* https://usethis.r-lib.org/. '''usethis''' is a workflow package: it automates repetitive tasks that arise during project setup and development, both for R packages and non-package projects.
** [https://youtu.be/79s3z0gIuFU?t=705 R Package Development 1: Where to Start] by John Muschelli. [https://www.youtube.com/playlist?list=PLk3B5c8iCV-T4LM0mwEyWIunIunLyEjqM R Package Development playlist].
** [https://usethis.r-lib.org/reference/create_package.html create_package(path)] with the package name of your choice.
** [https://javirudolph.github.io/RLadies-Gainesville-FL/20190429-Rudolph-packages/apr29presentation.html#1 Sharing with others and helping yourself] (slides, use right click menu to save as an HTML file)
* [https://www.tidyverse.org/articles/2019/04/usethis-1.5.0/ usethis 1.5.0]
* [https://www.tidyverse.org/blog/2020/04/usethis-1-6-0/ usethis 1.6.0]
* [https://www.tidyverse.org/blog/2020/12/usethis-2-0-0/ usethis 2.0.0]
 
=== Github Actions ===
To use the '''Github Actions''' for continuous integration/CI checks,
* I first follow [https://ropenscilabs.github.io/actions_sandbox/packageci.html this] to run ''usethis::use_github_action_check_release()''. Once I commit and push the files to Github, Github Actions are kicked off. The R console also tell me to copy and paste a line to add a workflow's badge to README.md.
* Then I modify the yaml file to become [https://github.com/r-lib/actions/blob/master/examples/check-standard.yaml this] to run a standard check. This took 3m24s to run.  
* Then I further delete the 'devel' line (line 23) to reduce one more platform to check. This took 3m to check. My example is on [https://github.com/arraytools/rtoy/actions Github] (rtoy).
 
I also try to follow [https://ropenscilabs.github.io/actions_sandbox/websites-using-pkgdown-bookdown-and-blogdown.html Github Actions with R] and create a [https://github.com/r-lib/pkgdown pkgdown]/package documentation web page.
* '''usethis::use_github_actions("pkgdown")''' Now go to Github repo's Settings -> Options and scroll down until you see ''Github Pages''. For ''Source'', the page site should be set to being built from the root folder of the ''gh-pages''.
* I have used Jekyll to create a gh-page. I don't need to delete anything for this new gh-pages. I just need to go to the repository setting and (scroll down until we see Github Pages) change the Source of Github Pages to 'gh-pages branch' from 'master branch'.
* The files on the gh-pages branch are generated by Github Actions; these files are not available on my local machine. My location machine only has '''.github/workflows/pkgdown.yaml''' file.


= C/Fortran =
Question:
== Rmath.h ==
* The workflow file specifies R version and OS platform.  
For example pnorm5() was used by [https://github.com/cran/survival/commit/3f7bbd52fc24f3fb744c5ca82946291e0735811e#diff-c5e184f4d68df5830324d0d15600667cR6 survS.h] by survival package (old version) .
* Right now the workflow file (like pkgdown) is using "r-lib/actions/setup-r@master"  that has an "action.yml" file. The r-version is '3.x' only. What about if R 4.0.0 is released?


== Packages includes Fortran ==
=== Packages, webpages and Github ===
* [https://github.com/cran/survC1/tree/master/src survC1]
[https://debruine.github.io/tutorials/index.html Tutorials] by Lisa DeBruine
* [https://github.com/cran/nlme/tree/master/src nlme]
* [https://github.com/cran/glmnet/tree/master/src glmnet]


On mac, gfortran (6.1) can be downloaded from [https://cran.rstudio.com/bin/macosx/tools CRAN]. It will be installed onto /usr/local/gfortran. Note that the binary will not be present in PATH. So we need to run the following command to make gfortran avaiialbe.
== biocthis ==
<syntaxhighlight lang='bash'>
[https://lcolladotor.github.io/biocthis/ biocthis], [https://speakerdeck.com/lcolladotor/biocthis-tab slides]
sudo ln -s /usr/local/gfortran/bin/gfortran /usr/local/bin/gfortran
</syntaxhighlight>


A useful tool to find R packages containing Fortran code is [https://github.com/r-hub/pkgsearch pkgsearch] package. However, the result is not a comprehensive list of packages containing Fortran code.
== R package depends vs imports ==
<pre>
* http://stackoverflow.com/questions/8637993/better-explanation-of-when-to-use-imports-depends
> pkg_search("Fortran")
* http://stackoverflow.com/questions/9893791/imports-and-depends
- "Fortran" ------------------------------------ 69 packages in 0.009 seconds -
* https://stat.ethz.ch/pipermail/r-devel/2013-August/067082.html
  #    package      version by                    @ title
 
  1 100 covr        3.3.2  Jim Hester          12d Test Coverage for Packages
In the namespace era Depends is never really needed. All modern packages have no technical need for Depends anymore. Loosely speaking the only purpose of Depends today is to expose other package's functions to the user without re-exporting them.
  2  91 inline      0.3.15  Dirk Eddelbuettel    1y Functions to Inline C, ...
 
  3  43 randomForest 4.6.14  Andy Liaw            2y Breiman and Cutler's Ra...
load = functions exported in myPkg are available to interested parties as myPkg::foo or via direct imports - essentially this means the package can now be used
  4  39 deSolve      1.24    Thomas Petzoldt      4M Solvers for Initial Val...
 
  5  27 mnormt      1.5.5  Adelchi Azzalini    3y The Multivariate Normal...
attach = the namespace (and thus all exported functions) is attached to the search path - the only effect is that you have now added the exported functions to the global pool of functions - sort of like dumping them in the workspace (for all practical purposes, not technically)
  6  26 minqa        1.2.4  Katharine M. Mullen  5y Derivative-free optimiz...
 
  7  24 rgcvpack    0.1.4  Xianhong Xie        6y R Interface for GCVPACK...
import a function into a package = make sure that this function works in my package regardless of the search path (so I can write fn1 instead of pkg1::fn1 and still know it will come from pkg1 and not someone's workspace or other package that chose the same name)
  8  22 leaps        3.0    Thomas Lumley        3y Regression Subset Selec...
 
  9  21 akima        0.6.2  Albrecht Gebhardt    3y Interpolation of Irregu...
------------------------------------------------------------------------
10  20 rootSolve    1.7    Karline Soetaert    3y Nonlinear Root Finding,...
* https://stat.ethz.ch/pipermail/r-devel/2013-September/067451.html


> more()
The distinction is between "loading" and "attaching" a package. Loading
- "Fortran" ------------------------------------ 69 packages in 0.009 seconds -
it (which would be done if you had MASS::loglm, or imported it)
   #    package    version  by                    @ title
guarantees that the package is initialized and in memory, but doesn't
  11 15 BB        2019.10.1 Paul Gilbert        11d Solving and Optimizing L...
make it visible to the user without the explicit MASS:: prefix. 
  12 15 limSolve  1.5.5.3  Karline Soetaert    2y Solving Linear Inverse M...
Attaching it first loads it, then modifies the user's search list so the
  13 14 insideRODE 2.0      YUZHUO PAN          7y insideRODE includes buil...
user can see it.
  14 13 earth      5.1.1    Stephen Milborrow    7M Multivariate Adaptive Re...
 
Loading is less intrusive, so it's preferred over attaching.  Both
library() and require() would attach it.
 
=== import() and importFrom() ===
If our package depends on a package, we need to made some changes. Below we assume the package ''glmnet'' in our new package.
 
* DESCRIPTION: '''Imports: glmnet '''
* NAMESPACE: either '''import(glmnet)''' to import all functions from glmnet or '''importFrom(glmnet, cv.glmnet)''' to import 'cv.glmnet' only
* hello.R: nothing needs to be added
 
For more resource, see
* https://r-pkgs.org/namespace.html
* http://r-pkgs.had.co.nz/namespace.html
 
== R package suggests ==
[https://cran.r-project.org/web/packages/stringr/index.html stringr] has suggested '''htmlwidgets'''. An error will come out if the suggested packages are not available.
<syntaxhighlight lang='rsplus'>
> library(stringr)
> str_view(c("abc", "a.c", "bef"), "a\\.c")
Error in loadNamespace(name) : there is no package called ‘htmlwidgets’
</syntaxhighlight>
 
== Useful functions for accessing files in packages ==
* [https://stat.ethz.ch/R-manual/R-devel/library/base/html/system.file.html system.file()]
* [https://stat.ethz.ch/R-manual/R-devel/library/base/html/find.package.html path.package() & find.package()]. Note that path.package() requires the package to be loaded.
* [https://www.rdocumentation.org/packages/base/versions/3.6.2/topics/file.path file.path()]. This is not related to packages.
* [https://www.rdocumentation.org/packages/base/versions/3.6.2/topics/normalizePath normalizePath()]. This is not related to packages.
{{Pre}}
> system.file(package = "batr")
[1] "f:/batr"
> system.file("extdata", "logo.png", package = "cowplot") # Mac
[1] "/Library/Frameworks/R.framework/Versions/4.0/Resources/library/cowplot/extdata/logo.png"
 
> path.package("batr")
[1] "f:\\batr"
> path.package("ggplot2") # Mac
[1] "/Library/Frameworks/R.framework/Versions/4.0/Resources/library/ggplot2"
 
# sometimes it returns the forward slash format for some reason; C:/Program Files/R/R-3.4.0/library/batr
# so it is best to add normalizePath().
> normalizePath(path.package("batr"))
 
> file.path("f:", "git", "surveyor")
[1] "f:/git/surveyor"
</pre>
 
== Internal functions ==
* [https://blog.r-hub.io/2019/12/12/internal-functions/ Internal functions in R packages]
* [https://statisticaloddsandends.wordpress.com/2021/06/10/documentation-for-internal-functions/ Documentation for internal functions]
 
== RStudio shortcuts ==
[[File:RStudio Build.png|200px]]
 
== available package ==
[https://cran.r-project.org/web/packages/available/index.html available]. Check if a given package name is available to use. It checks the name's validity. Checks if it is used on 'GitHub', 'CRAN' and 'Bioconductor'.
 
== Create an R package ==
[https://www.pipinghotdata.com/posts/2020-10-25-your-first-r-package-in-1-hour/?s=09 Your first R package in 1 hour]
 
=== Using usethis ===
[https://trinostics.blogspot.com/2020/04/new-r-package-foo-updated.html New R Package 'foo' -- Updated]
# setwd()
# usethis::create_package("foo")
# usethis::use_git(); usethis_github()
# usethis::use_mit_license("Your name")
# usethis::use_r("foo_function")
# usethis::use_package("dplyr")  # specify import dependency, e.g. dplyr package
# usethis::use_testthat()
# usethis::use_test("firsttest")
# setwd("..")
# roxygen2::roxygenise()
 
=== Using [https://github.com/hadley/devtools devtools] and [http://cran.r-project.org/web/packages/roxygen2/index.html roxygen2] ===
 
* https://www.r-project.org/nosvn/pandoc/devtools.html
* A useful [http://thepoliticalmethodologist.com/2014/08/14/building-and-maintaining-r-packages-with-devtools-and-roxygen2/ post] by Jacob Montgomery. Watch the [https://www.youtube.com/watch?v=9PyQlbAEujY#t=19 youtube video] there. The process requires 3 components: RStudio software, devtools and roxygen2 (creating documentation from R code) packages.
* [https://uoftcoders.github.io/studyGroup/lessons/r/packages/lesson/ MAKING PACKAGES IN R USING DEVTOOLS]
* [http://r-pkgs.had.co.nz/r.html R code workflow] from Hadley Wickham.
* [https://blog.r-hub.io/2020/04/29/maintenance/ Workflow automation tools for package developers]
* [https://jozefhajnala.gitlab.io/r/r102-addin-roxytags/ RStudio:addins part 2 - roxygen documentation formatting made easy]
** Inserting a skeleton - Do this by placing your cursor anywhere in the function you want to document and click Code Tools -> Insert Roxygen Skeleton
* [http://web.mit.edu/insong/www/pdf/rpackage_instructions.pdf Instructions for Creating Your Own R Package]. It includes creating a R package with functions written in C++ via Rcpp helper function.
* [https://www.rstudio.com/wp-content/uploads/2015/06/devtools-cheatsheet.pdf devtools cheatsheet] (2 pages)
* My first R package [https://qualityandinnovation.com/2019/10/13/my-first-r-package-part-1/ Part 1], [https://qualityandinnovation.com/2019/10/13/my-first-r-package-part-2/ Part 2], [https://qualityandinnovation.com/2019/10/13/my-first-r-package-part-3/ Part 3]. It uses 3 packages: usethis, roxygen2 and devtools.
* [https://twitter.com/JennyBryan/status/1364288709265215489?s=20 If you love devtools::load_all(), pkgload is where the magic actually happens]. [https://r-lib.github.io/pkgload/news/index.html pkgload] package.
 
How to use [http://rstudio-pubs-static.s3.amazonaws.com/2556_4e9f1c2af93b4683a19e2303a52bb2d5.html devtools::load_all("FolderName")]. load_all() loads any modified R files, and recompile and reload any modified C or Fortran files.
{{Pre}}
# Step 1
library(devtools)
 
# Step 2
dir.create(file.path("MyCode", "R"), recursive = TRUE)
cat("foo=function(x){x*2}", file = file.path("MyCode", "R", "foo.R"))
write.dcf(list(Package = "MyCode", Title = "My Code for this project", Description = "To tackle this problem",
    Version = "0.0", License = "For my eyes only", Author = "First Last <[email protected]>",
    Maintainer = "First Last <[email protected]>"), file = file.path("MyCode", "DESCRIPTION"))
# OR
# create("path/to/package/pkgname")
# create() will create R/ directory, DESCRIPTION and NAMESPACE files.
 
# Step 3 (C/Fortran code, optional)
dir.create(file.path("MyCode", "src"))
cat("void cfoo(double *a, double *b, double *c){*c=*a+*b;}\n", file = file.path("MyCode",
    "src", "cfoo.c"))
cat("useDynLib(MyCode)\n", file = file.path("MyCode", "NAMESPACE"))
 
# Step 4
load_all("MyCode")
 
# Step 5
# Modify R/C/Fortran code and run load_all("MyCode")
 
# Step 6 (Automatically generate the documentation from R source code,
#        in the man/ folder and export the function in NAMESPACE file.
#        optional, repeat if any function's help has changed)
document("MyCode")
 
# Step 7 (check the package, optional)
check("MyCode")
 
# Step 8 (Deployment, create a tarball,
#        optional, repeat if necessary)
build("MyCode")
 
# Step 9 (Install the package, optional)
install("MyCode")
</pre>
 
'''Note''':
# '''load_all("FolderName")''' will make the FolderName to become ''like'' a package to be loaded into the current R session so the 2nd item returned from '''search()''' will be '''"package:FolderName"'''. However, the ''FolderName'' does not exist under Program Files/R/R-X.Y.Z/library nor Documents/R/win-library/X.Y/ (Windows OS).
# '''build("FolderName")''' will create a tarball in the current directory. User can install the new package for example using Packages -> Install packages from local files on Windows OS. This will build/run vignettes so it may take some time. The tarball will contain a '''build''' folder containing 'vignette.rds' file. It'll also create a new folder '''inst/doc''' containing 3 files (MyPkg.html, MyPkg.Rmd and MyPkg.R). The vignettes may contain a new folder '''MyPkg_cache''' if we use chunk = TRUE option in Rmd file. Note install.packages() will not run the R code in vignettes.
# For the simplest R package, the source code only contains a file <DESCRIPTION> and a folder <R> with individual R files in the text format.
 
=== Using RStudio ===
<ul>
<li>[https://support.rstudio.com/hc/en-us/articles/200486508-Building-Testing-and-Distributing-Packages Building, Testing, and Distributing Packages] from RStudio. <BR>
[[File:RstudioBuild.png|100px]]
</li>
</ul>
* Youtube
** [https://youtu.be/qxRSzDejea4 How to write your own R package] from IDG TECHtalk
** [https://www.youtube.com/playlist?list=PLk3B5c8iCV-T4LM0mwEyWIunIunLyEjqM R Package Development playlist] by John Muschelli.
** https://youtu.be/Mwe64ziVQXA which does not use RStudio to create a new package
* [https://medium.com/@shiansu/how-to-create-and-distribute-an-r-package-a296217435dc How to Create and Distribute an R Package].
** The goal of the article to set up an easily installable R package on Github for others to use via remotes::install_github().
** The main tools required are RStudio along with the packages roxygen2 and usethis.
** How to take care of Bioconductor and Github Dependencies
** How to publish your package to Github
* [https://technistema.com/posts/building-a-corporate-r-package-for-pleasure-and-profit/ Building a Corporate R Package for Pleasure and Profit]
* Toy example*
*# In RStudio, click "File" - "New Project" - "New Directory" - "R package". Package name = "a1" (this naming will guarantee this package will be shown on top of all R packages in RStudio). Press 'Create Project'. This new project folder will have necessary files for an R package including DESCRIPTION, NAMESPACE, R/hello.R, man/hello.Rd. The "hello.R" file will be opened in RStudio automatically.
*# Create a new R file under a1/R folder. An example of this R file <add.R> containing roxygen comments can be found under [http://r-pkgs.had.co.nz/man.html here]. Pressing Ctrl/Cmd + Shift + D (or running '''devtools::document()''') will generate a man/add.Rd.
*# In R, type '''usethis::use_vignette("my-vignette") ''' to create a new vignette. The new vignette "my-vignette.Rmd" will be saved under "a1/vignettes" subfolder. We can modify the Rmd file as we need.
*# In RStudio, click "Build" - "Build Source Package". You will see some messages on the "Build" tab of the top-right panel. Eventually, a tarball "/home/$USERNAME/a1_0.1.0.tar.gz" is created (I create the project under /home/$USERNAME directory).
*# We can install the package in R '''install.packages("~/a1_0.1.0.tar.gz", repos= NULL, type = "source")''' if we have already created the tarball. Another method is to use RStudio "Build" - "Install and Restart" (Ctrl + Shift + B).
*# In RStudio, type '''help(package = "a1") ''' or click "Packages" tab on the bottom-right panel and click "a1" package. It will show a line "User guides, package vignettes and other documentation". The vignette we just created will be available in HTML, source and R code format.
 
=== Using RStudio.cloud ===
There is a problem. We can use devtools::create("/cloud/project") to create a new package. When it builds the source package, the package file will be located in the root directory of the package. However, if we use a local RStudio to create a source package, the source package will be located in the upper directory.
 
== Binary packages ==
* No .R files in the ''R/'' directory. There are 3 files that store the parsed functions in an efficient file format. This is the result of loading all the R code and then saving the functions with ''save()''.
* A ''Meta/'' directory contains a number of Rds files. These files contain cached metadata about the package, like what topics the help files cover and parsed version of the ''DESCRIPTION'' file.
* An ''html/'' directory.
* ''libs/'' directory if you have any code in the ''src/' directory
* The contents of ''inst/'' are moved to the top-level directory.
 
=== Building the tarball ===
* No matter we uses '''devtools::build()''' or the terminal '''R CMD build MyPkg''' it will uses run the R code in vignette. Be cautious on the extra time and storage the process incurred.
* If 'cache = TRUE' is used in vignettes, it will create a new subfolder called MyuPkg_cache under the vignettes folder. This takes a lot of space (eg 1GB in some case).
 
=== Building the binary ===
<pre>
R CMD INSTALL --build MyPkg.tar.gz
# OR
R CMD INSTALL --build Full_Path_Of_MyPkg
</pre>
The binary (on Windows) can be installed by '''install.packages("Mypkg.zip",repos=NULL)'''
 
If the installation is successful, it will overwrite any existing installation of the same package. To prevent changes to the present working installation or to provide an install location with write access, create a suitably located directory with write access and use the -l option to build the package in the chosen location.
<pre>
R CMD INSTALL -l location --build pkg
</pre>
 
== R folder ==
* https://r-pkgs.org/r.html
* zzz.R. .onLoad() function.
* [https://stackoverflow.com/a/20223846 R: How to run some code on load of package?]
 
See an example from DuoClustering2018.
<pre>
#' @importFrom utils read.csv
.onLoad <- function(libname, pkgname) {
  fl <- system.file("extdata", "metadata.csv", package = "DuoClustering2018")
  titles <- utils::read.csv(fl, stringsAsFactors = FALSE)$Title
  ExperimentHub::createHubAccessors(pkgname, titles)
}
</pre>
Note that the environment of a function from the DuoClustering2018 package is not the package name.
<pre>
environment(clustering_summary_filteredExpr10_TrapnellTCC_v2)
<environment: 0x7fe01dbe7dd0>
</pre>
Q: where is the definition of DuoClustering2018::clustering_summary_filteredExpr10_TrapnellTCC_v2()? A: [https://master.bioconductor.org/packages/release/bioc/vignettes/AnnotationHub/inst/doc/CreateAHubPackage.html#building-the-package createHubAccessors() - Creating A Hub Package: ExperimentHub or AnnotationHub].
 
== data ==
http://r-pkgs.had.co.nz/data.html
 
Three ways to include data in your package.
* If you want to store binary data and make it available to the user, put it in '''data/'''. This is the best place to put example datasets.
* If you want to store parsed data, but not make it available to the user, put it in '''R/sysdata.rda'''. This is the best place to put data that your functions need.
<ul>
<li>If you want to store raw data, put it in '''inst/extdata'''. See [https://r-pkgs.org/data.html#data-extdata External data]. An [https://bioconductor.org/packages/release/data/experiment/vignettes/tximportData/inst/doc/tximportData.html example] from tximportData package.
<pre>
# grep -r extdata /home/brb/R/x86_64-pc-linux-gnu-library/4.0
logo_file <- system.file("extdata", "logo.png", package = "cowplot")
orgDBLoc = system.file("extdata", "org.Hs.eg.sqlite", package="org.Hs.eg.db")
 
# grep -r readRDS /home/brb/R/x86_64-pc-linux-gnu-library/4.0
patient.data  <- readRDS("assets/coxnet.RDS")
</pre>
</li>
</ul>
 
[https://blog.r-hub.io/2020/05/29/distribute-data/ How to distribute data with your R package]
 
== Rd file ==
[https://github.com/wviechtb/mathjaxr Using Mathjax in Rd Files]
 
== Vignette ==
* [https://lifehacker.com/how-to-create-vignettes-that-really-pull-a-room-togethe-1846703615 How to Create Vignettes That Really Pull a Room Together]
* See examples from packages like [https://github.com/cran/magrittr magrittr] (Rmd, jpg) or [https://github.com/cran/tidyr tidyr] (Rmd, csv) or [https://github.com/cran/rvest rvest] (Rmd, png) or [https://github.com/mikelove/DESeq2/blob/master/vignettes/DESeq2.Rmd DESeq2].
* Many vignette uses '''output: rmarkdown::html_vignette''' which will expand the width to the page. [https://github.com/mikelove/rnaseqGene/blob/master/vignettes/rnaseqGene.Rmd This one] uses '''output: BiocStyle::html_document''' which will have a [https://bioconductor.org/packages/release/workflows/vignettes/rnaseqGene/inst/doc/rnaseqGene.html narrow width].
* [http://www.markvanderloo.eu/yaRb/2019/01/11/add-a-static-pdf-vignette-to-an-r-package/ Add a static pdf vignette to an R package]
* [https://www.rdocumentation.org/packages/devtools/versions/2.2.0/topics/build_vignettes devtools::build_vignettes()].  The files are copied in the 'doc' directory and an vignette index is created in 'Meta/vignette.rds', as they would be in a built package.
* [https://stackoverflow.com/a/37692810 build_vignette can't find functions]
 
Long execution for R code in vignette
* [https://community.rstudio.com/t/caching-chunks-in-rstudio-does-not-work/9040/7 Caching chunks in RStudio does not work]
* [https://rmflight.github.io/posts/2014/07/vignetteAnalysis.html caching doesn't seem to work here (i.e. when used in a document that is a vignette)]
* [https://trinostics.blogspot.com/2020/05/how-to-add-vignette-to-package-in.html How to Add a Vignette to a Package in RStudio]
* [https://blog.r-hub.io/2020/06/03/vignettes/ Optimal workflows for package vignettes]
 
== NEWS ==
[https://blog.r-hub.io/2020/05/08/pkg-news/ Why and how maintain a NEWS file for your R package?]
 
== README.Rmd & README.md files ==
See [http://r-pkgs.had.co.nz/release.html Releasing a package] from R packages by Hadley Wickham.
 
[https://stackoverflow.com/a/31914830 How to convert .Rmd into .md in R studio?]
 
Example: [https://github.com/tidyverse/ggplot2 ggplot2] repository at Github
 
It seems RStudio cannot create TOC for *.md files. [https://github.com/cran/glmnet/blob/master/vignettes/glmnet_beta.Rmd glmnet] package creates [https://cran.r-project.org/web/packages/glmnet/vignettes/glmnet_beta.pdf TOC] of its vignette by itself. [[Text_editor#Markdown_TOC_.28table_of_contents.29_extension|Visual Studio Code]] has an extension to do that.
 
=== badge ===
[https://github.com/guangchuangyu/badger badger]: Badge for R Package
 
== tests folder and testthat package==
* [http://r-pkgs.had.co.nz/tests.html testthat] package.
** [https://journal.r-project.org/archive/2011/RJ-2011-002/RJ-2011-002.pdf testthat: Get Started with Testing] 2011
** [https://codingclubuc3m.rbind.io/post/2019-11-26/ Automated testing with 'testthat' in practice]
** Lots of packages suggest testthat; for example [https://cran.r-project.org/web/packages/princurve/index.html princurve], [https://github.com/cran/glmnetUtils/blob/master/tests/testthat/test1_glmnet.R glmnetUtils].
** [https://stackoverflow.com/a/52175513 How to run a package's testthat tests]
** [https://support.rstudio.com/hc/en-us/articles/200486508-Building-Testing-and-Distributing-Packages Building, Testing, and Distributing Packages] from RStudio
** '''Run Tests''' button. See [https://rstudio.com/products/rstudio/release-notes/ RStudio release notes] from RStudio v1.2 - April 8, 2019.
** [https://ugoproto.github.io/ugo_r_doc/working_with_rstudio_ide/ Working with the RStudio IDE]
** [http://www.win-vector.com/blog/2019/03/unit-tests-in-r/ Unit Tests in R] 2019
** The result of '''dput''' can be used in expect_equal().
** [https://statisticaloddsandends.wordpress.com/2020/05/11/a-small-gotcha-when-comparing-lists-using-testthat/ A small gotcha when comparing lists using testthat]
 
== .Rbuildignore ==
[https://blog.r-hub.io/2020/05/20/rbuildignore/ Non-standard files/directories, Rbuildignore and inst]
 
== URL checker ==
* [https://blog.r-hub.io/2020/12/01/url-checks/ A NOTE on URL checks of your R package]
* [https://github.com/r-lib/urlchecker urlchecker] package
 
== What is a library? ==
A library is simply a directory containing installed packages.
 
You can use ''.libPaths()'' to see which libraries are currently active.
<syntaxhighlight lang='rsplus'>
.libPaths()
 
lapply(.libPaths(), dir)
</syntaxhighlight>
 
== Object names ==
* Variable and function names should be lower case.
* Use an underscore (_) to separate words within a name (reserve . for S3 methods).
* [https://en.wikipedia.org/wiki/Camel_case Camel case] is a legitimate alternative, but be consistent! For example, preProcess(), twoClassData, createDataPartition(), trainingRows, trainPredictors, testPredictors, trainClasses, testClasses have been used in [https://cran.r-project.org/web/packages/AppliedPredictiveModeling/index.html Applied Predictive Modeling] by [http://appliedpredictivemodeling.com/ Kuhn & Johnson].
* Generally, variable names should be nouns and function names should be verb.
 
== Spacing ==
* Add a space around the operators +, -, \ and *.
* Include a space around the assignment operators, <- and =.
* Add a space around any comparison operators such as == and <.
 
== Indentation ==
* Use two spaces to indent code.
* Never mix tabs and spaces.
* RStudio can automatically convert the tab character to spaces (see Tools -> Global options -> Code).
 
== \dontrun{} ==
* [https://cran.r-project.org/doc/manuals/R-exts.html Writing R Extensions > Documenting functions] and search for '''dontrun'''
* [https://stackoverflow.com/questions/12038160/how-to-not-run-an-example-using-roxygen2 How to not run an example using roxygen2?]
* [https://stackoverflow.com/questions/1454211/what-does-not-run-mean-in-r-help-pages What does "not run" mean in R help pages?] See ?example .
 
== formatR and lintr package ==
Use formatR package to clean up poorly formatted code
<syntaxhighlight lang='rsplus'>
install.packages("formatR")
formatR::tidy_dir("R")
</syntaxhighlight>
 
Another way is to use the [https://github.com/jimhester/lintr lintr] package ([https://en.wikipedia.org/wiki/Lint_(software) lint]).
<syntaxhighlight lang='rsplus'>
install.packages("lintr")
lintr:::lin_package()
</syntaxhighlight>
 
== Rcpp ==
[https://arxiv.org/abs/1911.06416 Thirteen Simple Steps for Creating An R Package with an External C++ Library]
 
== C library ==
[https://working-with-data.mazamascience.com/2021/07/16/using-r-packaging-a-c-library-in-15-minutes/ Using R — Packaging a C library in 15 minutes]
 
== Data package ==
[https://rstudio4edu.github.io/rstudio4edu-book/data-pkg.html Chapter 12 Create a data package] from rstudio4edu
 
== Minimal R package for submission ==
https://stat.ethz.ch/pipermail/r-devel/2013-August/067257.html and [http://cran.r-project.org/web/packages/policies.html CRAN Repository Policy].
 
== Create R Windows Binary on non-Windows OS ==
* [https://stackoverflow.com/a/16745596 Create R Windows Binary from .tar.gz linux]
* [http://win-builder.r-project.org/ win-builder] from r-project.org
 
== r-hub/rhub package: the R package builder service ==
https://github.com/r-hub/proposal, [https://www.r-bloggers.com/2024/04/r-hub-v2/ R-hub v2] 2024/4.
 
* [https://blog.r-hub.io/2019/04/08/rhub-1.1.1/ rhub 1.1.1 is on CRAN!] 2019/4/8
* [https://blog.r-hub.io/2019/03/26/why-care/ R package developers, why should you care about R-hub?] 2019/3/26
* [https://r-hub.github.io/rhub/articles/local-debugging.html Local Linux checks with Docker]
* https://www.rstudio.com/resources/videos/r-hub-overview/
* http://blog.revolutionanalytics.com/2016/10/r-hub-public-beta.html
* [https://jozef.io/r107-multiplatform-gitlabci-rhub/ Setting up continuous multi-platform R package building, checking and testing with R-Hub, Docker and GitLab CI/CD for free, with a working example] 2019/4/27
* [https://blog.r-hub.io/2019/05/29/keep-up-with-cran/ How to keep up with CRAN policies and processes?] 2019/5/29
* [https://blog.r-hub.io/2019/12/19/r-hub-usage/ R-hub usage in a few figures]
 
{{Pre}}
# Today 1/1/2020
$ git clone https://github.com/arraytools/rtoy.git
$ rm -rf rtoy/.git
$ rm rtoy/.gitignore rtoy/_config.yml
$ R
> install.packages("devtools", repos = "https://cran.rstudio.com")
> install.packages("rhub")
> devtools::install_github("r-hub/sysreqs") #needed before calling local_check_linux()
 
> pkg_path <- "~/Downloads/rtoy"
> chk <- local_check_linux(pkg_path, image = "rhub/debian-gcc-release")
 
─  Building package
 
Container name: 6dca434d-84f9-42e2-ab83-b8c364594476-2
It will _not_ be removed after the check.
 
R-hub Linux builder script v0.10.0 (c) R Consortium, 2018-2019
 
Package: /tmp/RtmpviOCT1/file470972a3c4ab/rtoy_0.1.0.tar.gz
Docker image: rhub/debian-gcc-release
Env vars:
R CMD check arguments:
Unable to find image 'rhub/debian-gcc-release:latest' locally
latest: Pulling from rhub/debian-gcc-release
Digest: sha256:a9e01ca57bfd44f20eb6719f0bfecdd8cf0f59610984342598a53f11555b515d
Status: Downloaded newer image for rhub/debian-gcc-release:latest
Sysreqs platform: linux-x86_64-debian-gcc
No system requirements
 
>>>>>==================== Installing system requirements
8fa4f66e41954b4ed1112eb72e76683c28345863fcc7e260edac6a9a30387fed
 
>>>>>==================== Starting Docker container
2dfae75c9de95b598ff8d9cd19d3cfc7ffe7f16edbc3d4f81c896e4e6b956ebd
ls: cannot access '/opt/R-*': No such file or directory
> source('https://bioconductor.org/biocLite.R')
Error: With R version 3.5 or greater, install Bioconductor packages using BiocManager; see https://bioconductor.org/install
Execution halted
Error in run(bash, c(file.path(wd, "rhub-linux.sh"), args), echo = TRUE,  :
  System command error
</pre>
Moreover, it create a new Docker image and a new Docker container. We need to manually clean them:-(
 
Running a check on its own (remote) server works
{{Pre}}
> check_on_linux("rtoy") # will run remotely.
    # We need to verify the email and enter a token.
    # We will get a report and a full build log.
    # The report includes both the linux command and the log from the server.
</pre>
 
Now I go back to the original method.
{{Pre}}
$ R
> install.packages("tinytex")
> tinytex::install_tinytex()
> q()
$ exit
 
$ sudo apt-get install texinfo
$ R CMD build rtoy
$ R CMD check rtoy_0.1.0.tar.gz
 
# Install pandoc
$ wget https://github.com/jgm/pandoc/releases/download/2.9.1/pandoc-2.9.1-1-amd64.deb
$ sudo dpkg -i pandoc-2.9.1-1-amd64.deb
$ R CMD check --as-cran rtoy_0.1.0.tar.gz
# Ignore a 'Note' https://stackoverflow.com/a/23831508
</pre>
 
== rcmdcheck ==
Run R CMD check from R and Capture Results
 
The [https://github.com/r-lib/rcmdcheck rcmdcheck] package was used by [https://github.com/r-lib/actions/tree/master/examples Github Actions for R language] from r-lib/R infrastructure.
 
== CRAN check API ==
* [https://blog.r-hub.io/2019/06/10/cran-checks-api/ Overview of the CRAN checks API] 2019/6/10
* [https://ropensci.org/technotes/2019/10/09/cran-checks-api-update/ update] 2019/10/9
 
== Continuous Integration ==
=== [https://travis-ci.org/ Travis-CI] (Linux, Mac) ===
* [http://juliasilge.com/blog/Beginners-Guide-to-Travis/  A Beginner's Guide to Travis-CI]
* http://johnmuschelli.com/neuroc/getting_ready_for_submission/index.html#61_travis
 
=== Continuous Integration: [https://www.appveyor.com/ Appveyor] (Windows) ===
* Appveyor is a continuous integration service that builds projects on Windows machines.
* http://johnmuschelli.com/neuroc/getting_ready_for_submission/index.html#62_appveyor
 
=== Github Actions ===
* See [[#usethis_package|usethis]] package.
* [https://jozef.io/r922-github-actions-r-packages/ Automating R package checks across platforms with GitHub Actions and Docker in a portable way]. No need to use "usethis" package.
 
=== precommit ===
* https://cran.r-project.org/web/packages/precommit/index.html
* [https://lorenzwalthert.netlify.app/post/pre-commit-hooks-for-r/ precommit initial CRAN release]
 
== Submit packages to cran ==
* https://cran.r-project.org/submit.html
* http://f.briatte.org/r/submitting-packages-to-cran
* [https://rmhogervorst.nl/cleancode/blog/2016/07/09/content/post/2016-07-09-submtting-to-cran-first-experience/ Submitting your first package to CRAN, my experience]
* [https://jef.works/blog/2018/06/18/get-your-package-on-cran-in-10-steps/ Get your R package on CRAN in 10 steps] June 2018
* [http://johnmuschelli.com/neuroc/getting_ready_for_submission/index.html Preparing Your Package for for Submission] by John Muschelli
* https://builder.r-hub.io/. See [[R#Introducing_R-hub_.28rhub_package.29.2C_the_R_package_builder_service|here]].
* [https://neonira.github.io/op2 The most annoying warning for CRAN submission]
* [https://www.mzes.uni-mannheim.de/socialsciencedatalab/article/r-package/ How to write your own R package and publish it on CRAN] '''devtools::release()''', July 2020
* [https://blog.r-hub.io/2020/12/01/url-checks/?s=09 A NOTE on URL checks of your R package]
* [http://r-pkgs.had.co.nz/release.html Releasing a package] from the book "R packages" by Hadley Wickham.
* [https://www.johnmackintosh.net/blog/2021-11-23-cran-success/ I got my first package onto CRAN, and YOU CAN TOO]
* [https://twitter.com/PipingHotData/status/1554560631382200320?s=20&t=FSsEd2IzMdOuK1iA8iXZHg Submitting vroom to CRAN, LIVE!]
 
=== Windows ===
[https://blog.r-hub.io/2020/04/01/win-builder/ Everything you should know about WinBuilder]
 
== Other tips/advice ==
*[https://martinctc.github.io/blog/make-package-even-more-awesome/ Top 10 tips to make your R package even more awesome]
* [https://github.com/MangoTheCat/goodpractice GoodPractice] Advice on R Package Building.
 
= C/Fortran =
== Rmath.h ==
For example pnorm5() was used by [https://github.com/cran/survival/commit/3f7bbd52fc24f3fb744c5ca82946291e0735811e#diff-c5e184f4d68df5830324d0d15600667cR6 survS.h] by survival package (old version) .
 
== Packages includes Fortran ==
Some useful packages containing fortran code.
 
* [https://github.com/cran/survC1/tree/master/src survC1]
* [https://github.com/cran/quantreg/tree/master/src quantreg]
* [https://github.com/cran/nlme/tree/master/src nlme]
* [https://github.com/cran/glmnet/tree/master/src glmnet]
* [https://github.com/cran/bsamGP/tree/master/src bsamGP] (FORTRAN 90). This is searched by using https://www.r-pkg.org/. I am not able to get what I need using the website.
 
My experience on M1 macOS
<ul>
<li>(Outdated) On mac, gfortran (6.1) (X86 not arm) can be downloaded from [https://cran.rstudio.com/bin/macosx/tools CRAN]. It will be installed onto '''/usr/local/gfortran'''. This can be confirmed by:
<pre>
mkdir temp
cd temp
xar -xf ../gfortran-6.1.pkg
lsbom Bom
</pre>
 
Note that the binary will not be present in PATH. So we need to run the following command to make gfortran availalble.
<spre>
sudo ln -s /usr/local/gfortran/bin/gfortran /usr/local/bin/gfortran
</pre>
 
<li>Tested in R 4.4.1, R is looking for '''/opt/gfortran/bin/gfortran'''.
* [https://stackoverflow.com/a/77088891 Installing gfortran on MacBook with Apple M1 chip for use in R].
* See https://mac.r-project.org/tools/. Don't follow https://cran.r-project.org/bin/macosx/tools/ to download gfortran.
* [https://www.r-bloggers.com/2024/01/r-universe-now-builds-macos-arm64-binaries-for-use-on-apple-silicon-aka-m1-m2-m3-systems/ R-universe now builds MacOS ARM64 binaries for use on Apple Silicon (aka M1/M2/M3) systems].
* '''Instruction''':
*# Download "gfortran-12.2-universal.pkg" from https://mac.r-project.org/tools/,
*# Double click the pkg file
*# gfortran will be installed on "/opt/gfortran". When R installed a package containing FORTRAN code, it will automatically look for gfortran from '''/opt/gfortran/bin/gfortran'''. So it is not necessary to make gfortran available in $PATH.
::[[File:GfortranMac.png|150px]]
<li>Note I already had gfortran installed via homebrew for some software. But it is not used by R.
<pre>
$ brew uninstall gfortran
Error: Refusing to uninstall /opt/homebrew/Cellar/gcc/14.1.0_1
because it is required by gstreamer, numpy, openblas and openvino, which are currently installed.
You can override this and force removal with:
  brew uninstall --ignore-dependencies gfortran
 
$ which -a gfortran
/opt/homebrew/bin/gfortran
</pre>
 
<li>'''In order to change mess up anything''', it is better to call '''export PATH="/usr/local/bin:$PATH" ''' when we want to install R packages containing fortran code.
<li>A useful tool to find R packages containing Fortran code is [https://github.com/r-hub/pkgsearch pkgsearch] package. Note
* The result is not a comprehensive list of packages containing Fortran code.
* It seems the result is the same as I got from https://www.r-pkg.org
<pre>
> pkg_search("Fortran")
- "Fortran" ------------------------------------ 69 packages in 0.009 seconds -
  #    package      version by                    @ title
  1 100 covr        3.3.2  Jim Hester          12d Test Coverage for Packages
  2  91 inline      0.3.15  Dirk Eddelbuettel    1y Functions to Inline C, ...
  3  43 randomForest 4.6.14  Andy Liaw            2y Breiman and Cutler's Ra...
  4  39 deSolve      1.24    Thomas Petzoldt      4M Solvers for Initial Val...
  5  27 mnormt      1.5.5  Adelchi Azzalini    3y The Multivariate Normal...
  6  26 minqa        1.2.4  Katharine M. Mullen  5y Derivative-free optimiz...
  7  24 rgcvpack    0.1.4  Xianhong Xie        6y R Interface for GCVPACK...
  8  22 leaps        3.0    Thomas Lumley        3y Regression Subset Selec...
  9  21 akima        0.6.2  Albrecht Gebhardt    3y Interpolation of Irregu...
10  20 rootSolve    1.7    Karline Soetaert    3y Nonlinear Root Finding,...
 
> more()
- "Fortran" ------------------------------------ 69 packages in 0.009 seconds -
   #    package    version  by                    @ title
  11 15 BB        2019.10.1 Paul Gilbert        11d Solving and Optimizing L...
  12 15 limSolve  1.5.5.3  Karline Soetaert    2y Solving Linear Inverse M...
  13 14 insideRODE 2.0      YUZHUO PAN          7y insideRODE includes buil...
  14 13 earth      5.1.1    Stephen Milborrow    7M Multivariate Adaptive Re...
  15 13 cluster    2.1.0    Martin Maechler      4M "Finding Groups in Data"...
  15 13 cluster    2.1.0    Martin Maechler      4M "Finding Groups in Data"...
  16 13 spam      2.3.0.2  ORPHANED            11h SPArse Matrix
  16 13 spam      2.3.0.2  ORPHANED            11h SPArse Matrix
  17 12 diptest    0.75.7    Martin Maechler      4y Hartigan's Dip Test Stat...
  17 12 diptest    0.75.7    Martin Maechler      4y Hartigan's Dip Test Stat...
  18 10 pbivnorm  0.6.0    Brenton Kenkel      5y Vectorized Bivariate Nor...
  18 10 pbivnorm  0.6.0    Brenton Kenkel      5y Vectorized Bivariate Nor...
  19  7 optmatch  0.9.12    Mark M. Fredrickson 17d Functions for Optimal Ma...
  19  7 optmatch  0.9.12    Mark M. Fredrickson 17d Functions for Optimal Ma...
  20  7 lsei      1.2.0    Yong Wang            2y Solving Least Squares or...
  20  7 lsei      1.2.0    Yong Wang            2y Solving Least Squares or...
</pre>
</pre>
 
<li>Another way to find out packages containing fortran code is to run rsync to download src/contrib directory from CRAN and then use grep to find these packages. Note: the source packages takes about 8GB space (2019-10-28).
= Misc =
<pre>
== Build R package faster using multicore ==
mkdir ~/Downloads/cran
http://www.rexamine.com/2015/07/speeding-up-r-package-installation-process/
rsync -avz --delete cran.r-project.org::CRAN/src/contrib/*.tar.gz ~/Downloads/cran/
 
rsync -avz --delete cran.r-project.org::CRAN/src/contrib/PACKAGES ~/Downloads/cran/
The idea is edit the '''/lib64/R/etc/Renviron''' file (where /lib64/R/etc/ is the result to a call to the R.home() function in R) and set:
rsync -avz --delete cran.r-project.org::CRAN/src/contrib/PACKAGES.gz ~/Downloads/cran/
<pre>
cd ~/Downloads/cran
MAKE='make -j 8' # submit 8 jobs at once
find . -xtype l -delete # remove broken symbolic links
</pre>
 
Then build R package as regular, for example,
touch tmp
<pre>
for f in *.gz;
$ time R CMD INSTALL ~/R/stringi --preclean --configure-args='--disable-pkg-config'
do
</pre>
  tar -tzvf $f | grep -E "(\.f|\.f90|\.f95)$"  |& tee -a tmp
 
done
== suppressPackageStartupMessages() and .onAttach() ==
</pre>
[http://www.win-vector.com/blog/2019/08/it-is-time-for-cran-to-ban-package-ads/ It is Time for CRAN to Ban Package Ads]
to check if the tarball contains Fortran 77/90 code.
 
Now to see all packages names we can process it in R
{{Pre}}
library(magrittr)
library(stringr)
x <- read.table("~/Downloads/tmp", stringsAsFactors = F)
strsplit(x$V6, "/") %>% sapply(function(x) x[1]) %>% unique() # 415 packages
strsplit(x$V6, "/") %>% sapply(function(x) x[1]) %>% table() %>% sort() # how many Fortran files in each package
 
str_subset(x$V6, "\\.f90$") %>% strsplit("/") %>% sapply(function(x) x[1]) %>% unique() # Fortran 90 only packages
str_subset(x$V6, "\\.f95$") %>% strsplit("/") %>% sapply(function(x) x[1]) %>% unique() # Fortran 95 only packages
 
str_subset(x$V6, "BayesFM") # f95
</pre>
</li>
</ul>
 
= Misc =
== Datasets in R packages ==
https://vincentarelbundock.github.io/Rdatasets/datasets.html
 
== Turn your analysis into a package ==
[https://twitter.com/neilgcurrie/status/1572254358397681665 Organise your own analysis]
 
== Build R package faster using multicore ==
http://www.rexamine.com/2015/07/speeding-up-r-package-installation-process/
 
The idea is edit the '''/lib64/R/etc/Renviron''' file (where /lib64/R/etc/ is the result to a call to the R.home() function in R) and set:
<pre>
MAKE='make -j 8' # submit 8 jobs at once
</pre>
Then build R package as regular, for example,
<pre>
$ time R CMD INSTALL ~/R/stringi --preclean --configure-args='--disable-pkg-config'
</pre>
 
== suppressPackageStartupMessages() and .onAttach() ==
[https://github.com/cran/KernSmooth/blob/master/R/all.R KernSmooth] package example.
 
[http://www.win-vector.com/blog/2019/08/it-is-time-for-cran-to-ban-package-ads/ It is Time for CRAN to Ban Package Ads]
 
<syntaxhighlight lang='rsplus'>
suppressPackageStartupMessages(library("dplyr"))
</syntaxhighlight>
 
== fusen package ==
* [https://www.r-bloggers.com/2021/08/fusen-is-now-available-on-cran/ {fusen} is now available on CRAN!]
* (Videos) [https://youtu.be/febuOcS70t4?t=1742 How To Build A Package With The "Rmd First" Method], [https://youtu.be/febuOcS70t4?t=2788 fusen::inflate()]
 
== Identifying R Functions & Packages Used in GitHub Repos ==
[https://www.bryanshalloway.com/2022/01/18/identifying-r-functions-packages-used-in-github-repos/ Identifying R Functions & Packages Used in GitHub Repos]: [https://brshallo.github.io/funspotr/ funspotr] package
 
== CRANalerts ==
* https://cranalerts.com/
* [https://deanattali.com/blog/cranalerts/ CRANalerts: Get email alerts when a CRAN package gets updated]


<syntaxhighlight lang='rsplus'>
== R-universe ==
suppressPackageStartupMessages(library("dplyr"))
* [https://ropensci.org/blog/2021/06/22/setup-runiverse/ How to create your personal CRAN-like repository on R-universe]
</syntaxhighlight>
* [https://ropensci.org/blog/2023/05/31/runiverse-snapshots/ Downloading snapshots and creating stable R packages repositories using r-universe]


== CRANalerts ==
== FDA ==
* https://cranalerts.com/  
[https://www.r-consortium.org/blog/2021/12/08/successful-r-based-test-package-submitted-to-fda Successful R-based Test Package Submitted to FDA]
* [https://deanattali.com/blog/cranalerts/ CRANalerts: Get email alerts when a CRAN package gets updated]

Latest revision as of 16:05, 29 August 2024

R package management

Challenges in Package Management

Challenges in Package Management

Packages loaded at startup

getOption("defaultPackages")

How to install a new package

utils::install.packages()

  • By default, install.packages() will check versions and install uninstalled packages shown in 'Depends', 'Imports' , and 'LinkingTo' (DIL) fields. See R-exts manual.
  • Take advantage of Ncpus parameter in install.packages()
  • If we want to install packages listed in 'Suggests' field, we should specify it explicitly by using dependencies argument:
install.packages(XXXX, dependencies = c("Depends", "Imports", "Suggests", "LinkingTo"))
# OR
install.packages(XXXX, dependencies = TRUE)
For example, if I use a plain install.packages() command to install downloader package, it only installs 'digest' and 'downloader' packages. If I use
install.packages("downloader", dependencies=TRUE)
it will also install 'testhat' package.
  • Even a warning is given when some imports package is not available, it does not stop the installation (trying to install plotROC package on mac R 3.5.3). See also Warning: dependency ‘XXX’ is not available.
    > install.packages("plotROC")
    --- Please select a CRAN mirror for use in this session ---
    Warning: dependency ‘gridSVG’ is not available
    trying URL 'https://cloud.r-project.org/bin/macosx/el-capitan/contrib/3.5/plotROC_2.2.1.tgz'
    Content type 'application/x-gzip' length 1288370 bytes (1.2 MB)
    ==================================================
    downloaded 1.2 MB
    
    The downloaded binary packages are in
    	/var/folders/2q/slryb0rx4tj97t66v7l6pwvr_z6g3s/T//Rtmptrf2ZS/downloaded_packages
    > library(gridSVG)
    Error in library(gridSVG) : there is no package called ‘gridSVG’
    > install.packages("gridSVG", type = "source")
    Warning message:
    package ‘gridSVG’ is not available (for R version 3.5.3) 
    > ap <- available.packages()
    > "gridSVG" %in% rownames(ap) # [1] FALSE
    > dim(ap)  # [1] 14220    17
    > library(plotROC)
    Loading required package: ggplot2
Look at CRAN, we see the latest version (1.7-0) of gridSVG depends on the latest version of R (3.6.0). But why even the source is removed from the old version of R?
  • The install.packages function source code can be found in R -> src -> library -> utils -> R -> packages2.R file from Github repository (put 'install.packages' in the search box).

mirror

local({r <- getOption("repos")
       r["CRAN"] <- "http://cran.r-project.org" 
       options(repos=r)
})
options("repos")

RStudio

On my mac,

  • install.packages() will install the packages to User Library '/Users/USERNAME/Library/R/3.6/library'
  • RStudio GUI method will install the packages to System Library '/Library/Frameworks/R.framework/Versions/3.6/Resources/library'. So if we want to remove a package, we need to specify the lib parameter in remove.packages() or clicking on the adjacent X icon to remove it.

utils:::menuInstallLocal() (Windows OS only)

Packages -> Install package(s) from local files...

It works on tarball file.

pacman: Install and load the package at the same time, installing temporarily

p_load() function from the pacman package.

An example of installing the purrr package.

Also used by BBC Visual and Data Journalism cookbook for R graphics

Also used by Biowulf/NIH

For bioconductor, use, for example,

pacman::p_load("BioManager")
pacman::p_load("DESeq2",try.bioconductor=TRUE,update.bioconductor=TRUE)

PS. Brute force method

mypackages<-c("ggplot2", "dplyr")
 
for (p in mypackages){
  cond <- suppressWarnings(!require(p, character.only = TRUE))
  if(cond){
    try(install.packages(p), silent = TRUE)
    library(p, character.only = TRUE)
  }
}

remotes

devtools depends on 92 (non-base) packages and remotes depends on none.

Download and install R packages stored in 'GitHub', 'BitBucket', or plain 'subversion' or 'git' repositories. This package is a lightweight replacement of the 'install_*' functions in 'devtools'.

To install a package from a local machines with all dependency, run remotes::install_local(path = "MyPackage.tar.gz", dependencies=TRUE) or devtools::install() though the later requires to untar the source first.

remotes::install_github() vs devtools::install_github()

See the answers. remotes is a lighter weight package for those who don't need/want all the other functionality in devtools. The remotes package says it copied most of its functionality from devtools, so the functions are likely the same.

devtools

pak

BiocManager

https://cran.r-project.org/web/packages/BiocManager/index.html

pkgman

pkgman: A fresh approach to package installation - Gábor Csárdi

ccache: Faster R package installation

Faster R package installation

Ubuntu

Posit Package Manager/RStudio Package Manager/PPM

  • https://packagemanager.posit.co/client/#/ -> Repository:Bioconductor -> Setup.
    • On Ubuntu (Linux), there is no binary format of Bioconductor packages. P3M only has binary format of CRAN packages.
    • On Windows, I have to install Rtools. After Rtools has been installed, R will recognize it. Go to https://packagemanager.posit.co/client/#/. Select Bioconductor and click "SETUP". Pick Bioconductor version. Copy/paste options() statements into R or put it in the ~/.Rprofile.
    • On macOS, similar to Windows.
  • PPM Admin Guide. It only supports Ubuntu (no Debian), RedHat, OpenSUSE.
  • R Configuration Steps (Linux) -> Using Linux Binary Packages -> Configuring the R User Agent Header from Admin Guide. The step of configuring http user agent header should not be skipped.
  • Posit Package Manager for Linux R Binaries. Put the following in the <.Rprofile> file. If inside the RStudio, we need to quit the current R session first.
    options(HTTPUserAgent = sprintf(
      "R/%s R (%s)", 
      getRversion(), 
      paste(
        getRversion(), 
        R.version["platform"], 
        R.version["arch"], 
        R.version["os"]
      )
    ))
    
    # adjust this for your Linux distribution
    .ppm <- "https://packagemanager.posit.co/cran/__linux__/noble/latest"
    options(repos = c(CRAN = .ppm))
    # verify
    getOption("repos")
    options()$repos
  • It provides pre-compiled binary packages for Linux and Windows OS, but not macOS. When enabled, RStudio Package Manager will serve the appropriate CRAN binaries to R users instead of the source packages, saving R users significant installation time.
  • It is similar to MRAN as it allows users to use particular a snapshot of CRAN as their active repositories within their R session
  • Once configured, users can access RStudio Package Manager through all their familiar tools including base R’s install.packages(), packrat, and devtools.
  • Announcing Public Package Manager and v1.1.6
  • Package Manager allows linux users to install pre-built binaries of the packages which will make install quicker. See an example here.
    # Freeze to Apr 29, 2021 8:00 PM
    options(repos = c(REPO_NAME = "https://packagemanager.posit.co/all/2639103"))
    
    # Using Linux Binary Packages
    https://r-pkgs.example.com/our-cran/__linux__/xenial/latest
    https://packagemanager.posit.co/cran/__linux__/focal/2021-04-23
    
  • Bring Your Own Binary Packages with RSPM
  • Docker images
    • r-base, rocker/r-base don't use PPM (as of R 4.3.3).
    • rocker/r-ver (eg. rocker/r-ver:4.3.3) uses PPM. See the table of images on The versioned stack.
    • Bioconductor (source on github) does take advantage of PPM. In Bioc 3.17/R 4.3.1, Posit's PPM hosts the binaries. As of Bioc 3.18/R 4.3.3, Bioconductor hosts the binaries.
    RStudio will be available on your web browser at http://localhost:8787. The username is "rstudio".
    docker run \
     	-e PASSWORD=bioc \
     	-p 8787:8787 \
     	bioconductor/bioconductor_docker:devel
    R will be available on the terminal
    docker run -it --rm \
        --user rstudio \
        bioconductor/bioconductor_docker:RELEASE_3_18 R
    system.time(BiocManager::install("DESeq2", ask = FALSE))
    # Replacement repositories:
    #     CRAN: https://p3m.dev/cran/__linux__/jammy/latest
    # ...
    # trying URL 'https://bioconductor.org/packages/3.18/container-binaries/bioconductor_docker/src/contrib/bitops_1.0-7_R_x86_64-pc-linux-gnu.tar.gz'
    Content type 'application/gzip' length 24831 bytes (24 KB)
    # ...
    # 52 seconds
    

install a package as it existed on a specific date/snapshot: mran repository

Look at https://cran.microsoft.com/snapshot/, it seems the snapshot went back 2014 for R 3.1.1.

For example,

options(repos = c(CRAN = "https://mran.microsoft.com/snapshot/2022-10-01"))

install.packages("xgboost", repos="https://mran.microsoft.com/snapshot/2022-10-01/")

This trick works great when I try to install an R package (glmnet 3.0-2) on an old version of R. The current glmnet requires R 3.6.0. So even the source package is not available for older versions of R. If I install a package that does not require a very new version of R, that it works. The same problem happens on Windows OS. (today is 2020-05-05)

$ docker run --rm -it r-base:3.5.3
...
> install.packages("glmnet")
Installing package into ‘/usr/local/lib/R/site-library’
(as ‘lib’ is unspecified)
Warning message:
package ‘glmnet’ is not available (for R version 3.5.3)
> install.packages("glmnet", repos="https://mran.microsoft.com/snapshot/2019-09-20/")
...
* DONE (glmnet)

The downloaded source packages are in
	‘/tmp/RtmpoWVWFQ/downloaded_packages’
> packageVersion("glmnet")
[1] ‘2.0.18’
> options()$repos
                         CRAN
"https://cloud.r-project.org"
> install.packages('knitr') # OK.

install a package on an old version of R

  • Currently R is 4.2.2
  • I have build R 4.1.3 and R 4.0.5 from source on Ubuntu 22.04. P.S. We need to include/enable "Source code" URIs Error :: You must put some 'source' URIs in your sources.list.
    sudo apt update
    sudo apt-get build-dep r-base
    
    tar -xzvf R-4.1.3.tar.gz
    cd R-4.1.3
    ./configure
    time make -j2
    bin/R
    
  • I'm trying to install DESEq2 on R 4.1.3 and R 4.0.5
  • On R 4.1.3, the installation is successful.
    install.packages("BiocManager")
    BiocManager::install("DESeq2")   
    packageVersion("DESeq2")  # 1.34.0
    
  • On R 4.0.5, the installation of "locfit" (current version 1.5-9.7) requires R >= 4.1.0. Check on CRAN, we see the locfit version is 1.5-6 for R 4.0.5 (2021-3-31). So I try this version first.
    install.packages("BiocManager")
    install.packages("remotes")
    remotes::install_version("locfit", "1.5-6")
    # Error: a 'NAMESPACE' file is required
    
    # Try the next version 1.5-7
    remotes::install_version("locfit", "1.5-7") # Works
    BiocManager::install("DESeq2")   # Works too
    packageVersion("DESeq2")  # 1.30.1
    
  • Now it is a good opportunity to try renv. So I create a new folder 'testProject' and create a new file 'test.R'. This R file contains only one line: library(DESeq2).
    > setwd("testProj")
    > install.packages("renv")
    > renv::init()
    * Initializing project ...
    * Discovering package dependencies ... Done!
    * Copying packages into the cache ... [79/79] Done!
    One or more Bioconductor packages are used in your project,
    but the BiocManager package is not available.
    
    Consider installing BiocManager before snapshot.
    
    The following package(s) will be updated in the lockfile:
    ...
    The version of R recorded in the lockfile will be updated:
    - R                      [*] -> [4.0.5]
    
    * Lockfile written to '~/Downloads/testProject/renv.lock'.
    * Project '~/Downloads/testProject' loaded. [renv 0.16.0]
    * renv activated -- please restart the R session.
    > renv::install("BiocManager")  # NOT SURE IF THIS IS NECESSARY
    Retrieving 'https://cloud.r-project.org/src/contrib/BiocManager_1.30.19.tar.gz' ...
    	OK [file is up to date]
    Installing BiocManager [1.30.19] ...
    	OK [built from source]
    Moving BiocManager [1.30.19] into the cache ...
    	OK [moved to cache in 20 milliseconds]
    > q()
    

    Now DESeq2 is in "renv.lock" file!

    Note if we accidentally start a different version of R on an renv-ed project based on an older version of R, we shall see some special message informing us The project library is out of sync with the lockfile. At this time, the "renv.lock" is not touched yet.

    # Bootstrapping renv 0.16.0 --------------------------------------------------
    * Downloading renv 0.16.0 ... OK (downloaded source)
    * Installing renv 0.16.0 ... Done!
    * Successfully installed and loaded renv 0.16.0.
    ! Using R 4.2.2 (lockfile was generated with R 4.0.5)
    * Project '~/Downloads/testProject' loaded. [renv 0.16.0]
    * The project library is out of sync with the lockfile.
    * Use `renv::restore()` to install packages recorded in the lockfile.
    
  • What happened if we start with the same version of R but have a different version of renv in the global environment (vs renv.lock)?
    install.packages("remotes")
    remotes::install_version("renv", "0.15.5")
    renv::init()
    q()
    
    # Start the same R from another directory and update renv to the latest version 0.16.0
    # Now go back to the project directory and start R to see what will happen?
    # Nothing....  This is because the same project has the old & same version of "renv" library 
    # in the "$PROJECT/renv" directory
    

    If we delete the "renv" subdirectory, ".Rprofile" file but keep "renv.lock" file, and start R (remember the 'renv' package version in the global R is different from the version in "renv.lock".

    > renv::restore()
    This project has not yet been activated.
    Activating this project will ensure the project library is used during restore.
    Please see `?renv::activate` for more details.
    
    Would you like to activate this project before restore? [Y/n]: y
    Retrieving 'https://cloud.r-project.org/src/contrib/BiocManager_1.30.19.tar.gz' ...
    	OK [file is up to date]
    Installing BiocManager [1.30.19] ...
    	OK [built from source]
    Moving BiocManager [1.30.19] into the cache ...
    	OK [moved to cache in 27 milliseconds]
    * Project '~/Downloads/testProject' loaded. [renv 0.16.0]
    * The project may be out of sync -- use `renv::status()` for more details.
    The following package(s) will be updated:
    
    # Bioconductor =======================
    - AnnotationDbi          [* -> 1.56.2]
    ...
    # CRAN ===============================
    - renv                   [0.16.0 -> 0.15.5]
    ...
    Do you want to proceed? [y/N]: y
    Retrieving 'https://cloud.r-project.org/src/contrib/Archive/renv/renv_0.15.5.tar.gz' ...
    	OK [downloaded 961.3 Kb in 0.2 secs]
    Installing renv [0.15.5] ...
    	OK [built from source]
    Moving renv [0.15.5] into the cache ...
    	OK [moved to cache in 6.8 milliseconds]
    ...
    The following package(s) have been updated:
    
    	renv [installed version 0.15.5 != loaded version 0.16.0]
    
    Consider restarting the R session and loading the newly-installed packages.
    

    All the R packages are restored in the $PROJECT/renv directory.

Check installed Bioconductor version

Following this post, use tools:::.BioC_version_associated_with_R_version().

Mind the '.' in front of the 'BioC'. It may be possible for some installed packages to have been sourced from a different BioC version.

tools:::.BioC_version_associated_with_R_version() # `3.6'
tools:::.BioC_version_associated_with_R_version() == '3.6'  # TRUE

CRAN Package Depends on Bioconductor Package

For example, if I run install.packages("NanoStringNorm") to install the package from CRAN, I may get

ERROR: dependency ‘vsn’ is not available for package ‘NanoStringNorm’

This is because the NanoStringNorm package depends on the vsn package which is on Bioconductor.

Another example is CRAN's tidyHeatmap that imports ComplexHeatmap in Bioconductor.

Another instance is CRAN's biospear (actually plsRcox) that depends on Bioc's 'survcomp' & 'mixOmics'.

One solution is to run a line setRepositories(ind=1:2). See this post or this one. Note that the default repository list can be found at (Ubuntu) /usr/lib/R/etc/repositories file.

options("repos") # display the available repositories (only CRAN)
setRepositories(ind=1:2)
options("repos") # CRAN and bioc are included
#                                        CRAN
#                "https://cloud.r-project.org"
# "https://bioconductor.org/packages/3.6/bioc"

install.packages("biospear") # it will prompt to select CRAN

install.packages("biospear", repos = "http://cran.rstudio.com") # NOT work since bioc repos is erased

This will also install the BiocInstaller package if it has not been installed before. See also Install Bioconductor Packages.

Bioconductor packages depend on CRAN

For example cowplot shows breakpointR from Bioconductor depends on it.

update.packages()

update.packages(ask="graphics") can open a graphical window to select packages.

only upgrade to binary package versions

Try setting options(pkgType = "binary") before running update.packages(). To make this always be the default behavior, you can add that line to your .Rprofile file.

How about options(install.packages.check.source = "no"), options(install.packages.compile.from.source = "never")?

Binary packages only for two versions of R

Check What Repos You are Using.

CRAN only provides binaries for one version of R prior to the current one. So when CRAN moves to post-3.6.* R most non version-stuck mirrors will not have 3.5.* binary versions of packages.

Install a tar.gz (e.g. an archived package) from a local directory

R CMD INSTALL <package-name>.tar.gz

Or in R:

# Method 1: cannot install dependencies 
install.packages(<pathtopackage>, repos = NULL)
# These paths can be source directories or archives or binary package
# archive files  (as created by ‘R CMD build --binary’).
# (‘http://’ and ‘file://’ URLs are also accepted and the files
# will be downloaded and installed from local copies.)

# Method 2: take care of dependencies from CRAN
devtools::install(<directory to package>, dependencies = TRUE) 
                         # this will use 'R CMD INSTALL' to install the package.
                         # It will try to install dependencies of the package from CRAN,
                         # if they're not already installed.

The installation process can be nasty due to the dependency issue. Consider the 'biospear' package

biospear - plsRcox (archived) - plsRglm (archived) - bipartite
                              - lars
                              - pls
                              - kernlab
                              - mixOmics (CRAN->Bioconductor)
                              - risksetROC
                              - survcomp (Bioconductor)
                              - rms

So in order to install the 'plsRcox' package, we need to do the following steps. Note: plsRcox package is back on 6/2/2018.

# For curl
system("apt update")
system("apt install curl libcurl4-openssl-dev libssl-dev")

# For X11
system("apt install libcgal-dev libglu1-mesa-dev libglu1-mesa-dev")
system("apt install libfreetype6-dev") # https://stackoverflow.com/questions/31820865/error-in-installing-rgl-package
source("https://bioconductor.org/biocLite.R")
biocLite("survcomp") # this has to be run before the next command of installing a bunch of packages from CRAN

install.packages("https://cran.r-project.org/src/contrib/Archive/biospear/biospear_1.0.1.tar.gz", 
                 repos = NULL, type="source")
# ERROR: dependencies ‘pkgconfig’, ‘cobs’, ‘corpcor’, ‘devtools’, ‘glmnet’, ‘grplasso’, ‘mboost’, ‘plsRcox’, 
# ‘pROC’, ‘PRROC’, ‘RCurl’, ‘survAUC’ are not available for package ‘biospear’
install.packages(c("pkgconfig", "cobs", "corpcor", "devtools", "glmnet", "grplasso", "mboost", 
                   "plsRcox", "pROC", "PRROC", "RCurl", "survAUC"))
# optional: install.packages(c("doRNG", "mvnfast"))
install.packages("https://cran.r-project.org/src/contrib/Archive/biospear/biospear_1.0.1.tar.gz", 
                 repos = NULL, type="source")
# OR
# devtools::install_github("cran/biospear")
library(biospear) # verify

To install the (deprecated, bioc) packages 'inSilicoMerging',

biocLite(c('rjson', 'Biobase', 'RCurl'))

# destination directory is required
# download.file("http://www.bioconductor.org/packages/3.3/bioc/src/contrib/inSilicoDb_2.7.0.tar.gz", 
#               "~/Downloads/inSilicoDb_2.7.0.tar.gz")
# download.file("http://www.bioconductor.org/packages/3.3/bioc/src/contrib/inSilicoMerging_1.15.0.tar.gz", 
#               "~/Downloads/inSilicoMerging_1.15.0.tar.gz")
# ~/Downloads or $HOME/Downloads won't work in untar()
# untar("~/Downloads/inSilicoDb_2.7.0.tar.gz", exdir="/home/brb/Downloads") 
# untar("~/Downloads/inSilicoMerging_1.15.0.tar.gz", exdir="/home/brb/Downloads") 
# install.packages("~/Downloads/inSilicoDb", repos = NULL)
# install.packages("~/Downloads/inSilicoMerging", repos = NULL)
install.packages("http://www.bioconductor.org/packages/3.3/bioc/src/contrib/inSilicoDb_2.7.0.tar.gz", 
                 repos = NULL, type = "source")
install.packages("http://www.bioconductor.org/packages/3.3/bioc/src/contrib/inSilicoMerging_1.15.0.tar.gz", 
                 repos = NULL, type = "source")

R CMD INSTALL -l LIB/--library=LIB option

Install a package to a custom location

$ R CMD INSTALL -l /usr/me/localR/library myRPackage.tar.gz

Use a package installed in a custom location

R> library("myRPackage", lib.loc="/usr/me/local/R/library")

# OR include below in .bashrc file
$ export R_LIBS=/usr/me/local/R/library
R> .libPaths() # check
R> library("myRPackage")

Install a specific version of R/Bioconductor package

For packages from CRAN, use something like remotes::install_version("dplyr", "1.0.2")

For packages from Bioconductor, see the two solutions R how to install a specified version of a bioconductor package?

Install multiple/different versions of the same R package

https://stackoverflow.com/a/2989369

install.packages("~/Downloads/foo_0.1.1.tar.gz", lib = "/tmp", repos = NULL)
# a new folder "/tmp/foo" will be created
library(foo, lib.loc="/tmp") # Or use 'lib' to be consistent with install.packages()      

library(foo, lib.loc="~/dev/foo/v1")    ## loads v1
# and
library(foo, lib.loc="~/dev/foo/v2")    ## loads v2

packageVersion("foo", lib.loc = "/tmp")
sessionInfo()
help(package = "foo", lib.loc = "/tmp")

remove.packages("foo", lib = "/tmp")

The same works for install.packages(). help(install.packages)

The install_version() from devtools and remotes will overwrite the existing installation.

Query an R package installed locally

packageDescription("MASS")
packageVersion("MASS")

Query an R package (from CRAN) basic information: available.packages()

packageStatus() # Summarize information about installed packages

available.packages() # List Available Packages at CRAN-like Repositories
                     # Even I use an old version of R, it still return the latest version of the packages
                     # The 'problem' happens on install.packages() too.

The available.packages() command is useful for understanding package dependency. Use setRepositories() or 'RGUI -> Packages -> select repositories' to select repositories and options()$repos to check or change the repositories.

The return result of available.packages() depends on the R version.

The number of packages returned from available.packages() is smaller than the number of packages obtained from rsync CRAN Mirror HOWTO/FAQ. For example, 19473 < 25000. Some archived packages are still available via rsync.

Also the packageStatus() is another useful function for query how many packages are in the repositories, how many have been installed, and individual package status (installed or not, needs to be upgraded or not).

> options()$repos 
                       CRAN 
"https://cran.rstudio.com/" 

> packageStatus() 
Number of installed packages:
                                    
                                      ok upgrade unavailable
  C:/Program Files/R/R-3.0.1/library 110       0           1

Number of available packages (each package counted only once):
                                                                                   
                                                                                    installed not installed
  http://watson.nci.nih.gov/cran_mirror/bin/windows/contrib/3.0                            76          4563
  http://www.stats.ox.ac.uk/pub/RWin/bin/windows/contrib/3.0                                0             5
  http://www.bioconductor.org/packages/2.12/bioc/bin/windows/contrib/3.0                   16           625
  http://www.bioconductor.org/packages/2.12/data/annotation/bin/windows/contrib/3.0         4           686
> tmp <- available.packages()
> str(tmp)
 chr [1:5975, 1:17] "A3" "ABCExtremes" "ABCp2" "ACCLMA" "ACD" "ACNE" "ADGofTest" "ADM3" "AER" ...
 - attr(*, "dimnames")=List of 2
  ..$ : chr [1:5975] "A3" "ABCExtremes" "ABCp2" "ACCLMA" ...
  ..$ : chr [1:17] "Package" "Version" "Priority" "Depends" ...
> tmp[1:3,]
            Package       Version Priority Depends                     Imports LinkingTo Suggests             
A3          "A3"          "0.9.2" NA       "xtable, pbapply"           NA      NA        "randomForest, e1071"
ABCExtremes "ABCExtremes" "1.0"   NA       "SpatialExtremes, combinat" NA      NA        NA                   
ABCp2       "ABCp2"       "1.1"   NA       "MASS"                      NA      NA        NA                   
            Enhances License      License_is_FOSS License_restricts_use OS_type Archs MD5sum NeedsCompilation File
A3          NA       "GPL (>= 2)" NA              NA                    NA      NA    NA     NA               NA  
ABCExtremes NA       "GPL-2"      NA              NA                    NA      NA    NA     NA               NA  
ABCp2       NA       "GPL-2"      NA              NA                    NA      NA    NA     NA               NA  
            Repository                                                     
A3          "http://watson.nci.nih.gov/cran_mirror/bin/windows/contrib/3.0"
ABCExtremes "http://watson.nci.nih.gov/cran_mirror/bin/windows/contrib/3.0"
ABCp2       "http://watson.nci.nih.gov/cran_mirror/bin/windows/contrib/3.0"

And the following commands find which package depends on Rcpp and also which are from bioconductor repository.

> pkgName <- "Rcpp"
> rownames(tmp)[grep(pkgName, tmp[,"Depends"])]
> tmp[grep("Rcpp", tmp[,"Depends"]), "Depends"]

> ind <- intersect(grep(pkgName, tmp[,"Depends"]), grep("bioconductor", tmp[, "Repository"]))
> rownames(grep)[ind]
NULL
> rownames(tmp)[ind]
 [1] "ddgraph"            "DESeq2"             "GeneNetworkBuilder" "GOSemSim"           "GRENITS"           
 [6] "mosaics"            "mzR"                "pcaMethods"         "Rdisop"             "Risa"              
[11] "rTANDEM"

CRAN vs Bioconductor packages

> R.version # 3.4.3
# CRAN
> x <- available.packages()
> dim(x)
[1] 12581    17

# Bioconductor Soft
> biocinstallRepos()
                                               BioCsoft 
           "https://bioconductor.org/packages/3.6/bioc" 
                                                BioCann 
"https://bioconductor.org/packages/3.6/data/annotation" 
                                                BioCexp 
"https://bioconductor.org/packages/3.6/data/experiment" 
                                                   CRAN 
                            "https://cran.rstudio.com/" 
> y <- available.packages(repos = biocinstallRepos()[1])
> dim(y)
[1] 1477   17
> intersect(x[, "Package"], y[, "Package"])
character(0)
# Bioconductor Annotation
> dim(available.packages(repos = biocinstallRepos()[2]))
[1] 909  17
# Bioconductor Experiment
> dim(available.packages(repos = biocinstallRepos()[3]))
[1] 326  17

# CRAN + All Bioconductor
> z <- available.packages(repos = biocinstallRepos())
> dim(z)
[1] 15292    17

Downloading Bioconductor package with an old R

When I try to download the GenomicDataCommons package using R 3.4.4 with Bioc 3.6 (the current R version is 3.5.0), it was found it can only install version 1.2.0 instead the latest version 1.4.1.

It does not work by running biocLite("BiocUpgrade") to upgrade Bioc from 3.6 to 3.7.

source("https://bioconductor.org/biocLite.R")
biocLite("BiocUpgrade") 
# Error: Bioconductor version 3.6 cannot be upgraded with R version 3.4.4

See some instruction on RStudio package manager website.

Analyzing data on CRAN packages

R package location when they are installed by root

/usr/local/lib/R/site-library

Customizing your package/library location

Add a personal directory to .libPaths()

.libPaths( c( .libPaths(), "~/userLibrary") )

No need to use the assignment operator.

Install personal R packages after upgrade R, .libPaths(), Rprofile.site, R_LIBS_USER

File Example
Rprofile.site/.Rprofile .libPaths(c("/usr/lib/R/site-library",
      "/usr/lib/R/library"))
Renviron.site/.Renviron R_LIB_SITE="/usr/lib/R/site-library:/usr/lib/R/library"

Scenario: We already have installed many R packages under R 3.1.X in the user's directory. Now we upgrade R to a new version (3.2.X). We like to have these packages available in R 3.2.X.

For Windows OS, refer to R for Windows FAQ

The follow method works on Linux and Windows.

Make sure only one instance of R is running

# Step 1. update R's built-in packages and install them on my personal directory
update.packages(ask=FALSE, checkBuilt = TRUE, repos="http://cran.rstudio.com")

# Step 2. update Bioconductor packages
.libPaths() # The first one is my personal directory
# [1] "/home/brb/R/x86_64-pc-linux-gnu-library/3.2"
# [2] "/usr/local/lib/R/site-library"
# [3] "/usr/lib/R/site-library"
# [4] "/usr/lib/R/library"

Sys.getenv("R_LIBS_USER") # may or may not equivalent to .libPaths()[1]
ul <- unlist(strsplit(Sys.getenv("R_LIBS_USER"), "/"))
src <- file.path(paste(ul[1:(length(ul)-1)], collapse="/"), "3.1") 
des <- file.path(paste(ul[1:(length(ul)-1)], collapse="/"), "3.2") 
pkg <- dir(src, full.names = TRUE)
if (!file.exists(des)) dir.create(des)  # If 3.2 subdirectory does not exist yet!
file.copy(pkg, des, overwrite=FALSE, recursive = TRUE)
source("http://www.bioconductor.org/biocLite.R")
biocLite(ask = FALSE)

From Robert Kabacoff (R in Action)

  • If you have a customized Rprofile.site file (see appendix B), save a copy outside of R.
  • Launch your current version of R and issue the following statements
oldip <- installed.packages()[,1]
save(oldip, file="path/installedPackages.Rdata")

where path is a directory outside of R.

  • Download and install the newer version of R.
  • If you saved a customized version of the Rprofile.site file in step 1, copy it into the new installation.
  • Launch the new version of R, and issue the following statements
load("path/installedPackages.Rdata")
newip <- installed.packages()[,1]
for(i in setdiff(oldip, newip))
  install.packages(i)

where path is the location specified in step 2.

  • Delete the old installation (optional).

This approach will install only packages that are available from the CRAN. It won’t find packages obtained from other locations. In fact, the process will display a list of packages that can’t be installed For example for packages obtained from Bioconductor, use the following method to update packages

source(http://bioconductor.org/biocLite.R)
biocLite(PKGNAME)

Persistent config and data for R packages with .Rprofile and .Renviron

Persistent config and data for R packages. startup, rappdirs, hoardr, keyring.

Would you like to use a personal library instead?

Some posts from internet

  • Setting R_LIBS & avoiding “Would you like to use a personal library instead?”. Note: I try to create ~/.Renviron to add my personal folder in it. But update.packages() still asks me if I like to use a personal library instead (tested on Ubuntu + R 3.4).
  • automatically create personal library in R. Using suppressUpdates + specify lib in biocLite() or update.packages(Sys.getenv("R_LIBS_USER"), ask = F)
    # create local user library path (not present by default)
    dir.create(path = Sys.getenv("R_LIBS_USER"), showWarnings = FALSE, recursive = TRUE)
    # install to local user library path
    install.packages(p, lib = Sys.getenv("R_LIBS_USER"), repos = "https://cran.rstudio.com/")
    # Bioconductor version
    biocLite(p, suppressUpdates = TRUE, lib = Sys.getenv("R_LIBS_USER"))

The problem can happen if the R was installed to the C:\Program Files\R folder by users but then some main packages want to be upgraded. R will always pops a message 'Would you like to use a personal library instead?'.

To suppress the message and use the personal library always,

Actually the following hints will help us to create a convenient function UpdateMainLibrary() which will install updated main packages in the user's Documents directory without a warning dialog.

  • .libPaths() only returns 1 string "C:/Program Files/R/R-x.y.z/library" on the machines that does not have this problem
  • .libPaths() returns two strings "C:/Users/USERNAME/Documents/R/win-library/x.y" & "C:/Program Files/R/R-x.y.z/library" on machines with the problem.
UpdateMainLibrary <- function() {
  # Update main/site packages
  # The function is used to fix the problem 'Would you like to use a personal library instead?'  
  if (length(.libPaths()) == 1) return()
  
  ind_mloc <- grep("Program", .libPaths()) # main library e.g. 2
  ind_ploc <- grep("Documents", .libPaths()) # personal library e.g. 1
  if (length(ind_mloc) > 0L && length(ind_ploc) > 0L)
     # search outdated main packages
	 old_mloc <- ! old.packages(.libPaths()[ind_mloc])[, "Package"] %in% 
	               installed.packages(.libPaths()[ind_ploc])[, "Package"]
     oldpac <- old.packages(.libPaths()[ind_mloc])[old_mloc, "Package"]
	 if (length(oldpac) > 0L)
        install.packages(oldpac, .libPaths()[ind_ploc])  
}

On Linux,

> update.packages()
...
The downloaded source packages are in
‘/tmp/RtmpBrYccd/downloaded_packages’
Warning in install.packages(update[instlib == l, "Package"], l, contriburl = contriburl,  :
                              'lib = "/opt/R/3.5.0/lib/R/library"' is not writable
Would you like to use a personal library instead? (yes/No/cancel) yes
...
> system("ls -lt /home/brb/R/x86_64-pc-linux-gnu-library/3.5 | head")
total 224
drwxrwxr-x  9 brb brb 4096 Oct  3 09:30 survival
drwxrwxr-x  9 brb brb 4096 Oct  3 09:29 mgcv
drwxrwxr-x 10 brb brb 4096 Oct  3 09:29 MASS
drwxrwxr-x  9 brb brb 4096 Oct  3 09:29 foreign

# So new versions of survival, mgc, MASS, foreign are installed in the personal directory
# The update.packages() will issue warnings if we try to run it again. 
# It's OK to ignore these warnings.
> update.packages()
Warning: package 'foreign' in library '/opt/R/3.5.0/lib/R/library' will not be updated
Warning: package 'MASS' in library '/opt/R/3.5.0/lib/R/library' will not be updated
Warning: package 'mgcv' in library '/opt/R/3.5.0/lib/R/library' will not be updated
Warning: package 'survival' in library '/opt/R/3.5.0/lib/R/library' will not be updated

R_LIBS_USER is empty in R 3.4.1

See install.package() error, R_LIBS_USER is empty in R 3.4.1.

List vignettes from a package

vignette(package=PACKAGENAME)

List data from a package

data(package=PACKAGENAME)

sysdata.rda

List all functions of a package

Assume a package is already loaded. Then

ls("package:cowplot")

Getting a list of functions and objects in a package. This also assumes the package in loaded. In addition to functions (separated by primitive and non-primitive), it can show constants and objects.

List installed packages and versions

ip <- as.data.frame(installed.packages()[,c(1,3:4)])
rownames(ip) <- NULL
unique(ip$Priority)
# [1] <NA>        base        recommended
# Levels: base recommended
ip <- ip[is.na(ip$Priority),1:2,drop=FALSE]
print(ip, row.names=FALSE)

Query the names of outdated packages

psi <- packageStatus()$inst
subset(psi, Status == "upgrade", drop = FALSE)
#                     Package                                  LibPath     Version    Priority                Depends
# RcppArmadillo RcppArmadillo C:/Users/brb/Documents/R/win-library/3.2 0.5.100.1.0        <NA>                   <NA>
# Matrix               Matrix       C:/Program Files/R/R-3.2.0/library       1.2-0 recommended R (>= 2.15.2), methods
#                                             Imports LinkingTo                 Suggests
# RcppArmadillo                      Rcpp (>= 0.11.0)      Rcpp RUnit, Matrix, pkgKitten
# Matrix        graphics, grid, stats, utils, lattice      <NA>               expm, MASS
#                                            Enhances    License License_is_FOSS License_restricts_use OS_type MD5sum
# RcppArmadillo                                  <NA> GPL (>= 2)            <NA>                  <NA>    <NA>   <NA>
# Matrix        MatrixModels, graph, SparseM, sfsmisc GPL (>= 2)            <NA>                  <NA>    <NA>   <NA>
#               NeedsCompilation Built  Status
# RcppArmadillo              yes 3.2.0 upgrade
# Matrix                     yes 3.2.0 upgrade

The above output does not show the package version from the latest packages on CRAN. So the following snippet does that.

psi <- packageStatus()$inst
pl <- unname(psi$Package[psi$Status == "upgrade"])  # List package names
ap <- as.data.frame(available.packages()[, c(1,2,3)], stringsAsFactors = FALSE)
out <- cbind(subset(psi, Status == "upgrade")[, c("Package", "Version")], ap[match(pl, ap$Package), "Version"])
colnames(out)[2:3] <- c("OldVersion", "NewVersion")
rownames(out) <- NULL
out
#         Package  OldVersion  NewVersion
# 1 RcppArmadillo 0.5.100.1.0 0.5.200.1.0
# 2        Matrix       1.2-0       1.2-1

To consider also the packages from Bioconductor, we have the following code. Note that "3.1" means the Bioconductor version and "3.2" is the R version. See Bioconductor release versions page.

psic <- packageStatus(repos = c(contrib.url(getOption("repos")),
                                "http://bioconductor.org/packages/3.1/bioc/bin/windows/contrib/3.2",
                                "http://www.bioconductor.org/packages/3.1/data/annotation/bin/windows/contrib/3.2"))$inst
subset(psic, Status == "upgrade", drop = FALSE)
pl <- unname(psic$Package[psic$Status == "upgrade"])

ap   <- as.data.frame(available.packages(c(contrib.url(getOption("repos")),
                                "http://bioconductor.org/packages/3.1/bioc/bin/windows/contrib/3.2",
                                "http://www.bioconductor.org/packages/3.1/data/annotation/bin/windows/contrib/3.2"))[, c(1:3)], 
                      stringAsFactors = FALSE)

out <- cbind(subset(psic, Status == "upgrade")[, c("Package", "Version")], ap[match(pl, ap$Package), "Version"])
colnames(out)[2:3] <- c("OldVersion", "NewVersion")
rownames(out) <- NULL
out
#         Package  OldVersion  NewVersion
# 1         limma      3.24.5      3.24.9
# 2 RcppArmadillo 0.5.100.1.0 0.5.200.1.0
# 3        Matrix       1.2-0       1.2-1

Searching for packages in CRAN

METACRAN (www.r-pkg.org) - Search and browse all CRAN/R packages

cranly visualisations and summaries for R packages

Exploring R packages with cranly

Query top downloaded packages, download statistics

cranlogs

cranlogs package - Download Logs from the RStudio CRAN Mirror. Suitable on R console.

library(cranlogs)
out <- cran_top_downloads("last-week", 100) # 100 is the maximum limit
out$package

packageRank

packageRank package: Computing and Visualizing CRAN Downloads. Suitable to run on RStudio cloud. Include both CRAN and Bioconductor.

> plot(cranDownloads(packages = c("packageRank", "limma"), when = "last-month"))
> plot(cranDownloads(packages = c("shiny", "glmnet"), when = "last-month"))
> plot(cranDownloads(packages = c("shiny", "glmnet"), from = "2019", to ="2019"))
> plot(cranDownloads(packages = c("shiny", "glmnet"), from = "2019-12", to ="2019-12"))
> plot(bioconductorDownloads(packages = c("edgeR", "DESeq2", "Rsubread", "limma"), when = "last-year"))

BiocPkgTools

For Bioconductor packages, try BiocPkgTools. See the paper.

dlstats

dlstats. Monthly download stats of 'CRAN' and 'Bioconductor' packages.

installation path not writeable from running biocLite()

When I ran biocLite() to install a new package, I got a message (the Bioc packages are installed successfully anyway)

...
* DONE (curatedOvarianData)

The downloaded source packages are in
	‘/tmp/RtmpHxnH2K/downloaded_packages’
installation path not writeable, unable to update packages: rgl, rJava,
  codetools, foreign, lattice, MASS, spatial, survival

However, if I uses install.package() it can update the package

> packageVersion("survival")
[1] ‘2.42.3’
> update.packages("survival")  # Not working though no error message
> packageVersion("survival")
[1] ‘2.42.3’
> install.packages("survival")
Installing package into ‘/home/brb/R/x86_64-pc-linux-gnu-library/3.4’
...
* DONE (survival)

The downloaded source packages are in
	‘/tmp/RtmpHxnH2K/downloaded_packages’
> packageVersion("survival")
[1] ‘2.42.6’
> library(survival)
> sessionInfo() # show survival package 2.42-6 was attached

It makes sense to always use personal directory when we install packages. See .libPaths().

Warning: cannot remove prior installation of package

http://stackoverflow.com/questions/15932152/unloading-and-removing-a-loaded-package-withouth-restarting-r

Instance 1.

# Install the latest hgu133plus2cdf package
# Remove/Uninstall hgu133plus2.db package
# Put/Install an old version of IRanges (eg version 1.18.2 while currently it is version 1.18.3)
# Test on R 3.0.1
library(hgu133plus2cdf) # hgu133pluscdf does not depend or import IRanges
source("http://bioconductor.org/biocLite.R")
biocLite("hgu133plus2.db", ask=FALSE) # hgu133plus2.db imports IRanges
# Warning:cannot remove prior installation of package 'IRanges'
# Open Windows Explorer and check IRanges folder. Only see libs subfolder.

Note:

  • In the above example, all packages were installed under C:\Program Files\R\R-3.0.1\library\.
  • In another instance where I cannot reproduce the problem, new R packages were installed under C:\Users\xxx\Documents\R\win-library\3.0\. The different thing is IRanges package CAN be updated but if I use packageVersion("IRanges") command in R, it still shows the old version.
  • The above were tested on a desktop.

Instance 2.

# On a fresh R 3.2.0, I install Bioconductor's depPkgTools & lumi packages. Then I close R, re-open it, 
# and install depPkgTools package again.
> source("http://bioconductor.org/biocLite.R")
Bioconductor version 3.1 (BiocInstaller 1.18.2), ?biocLite for help
> biocLite("pkgDepTools")
BioC_mirror: http://bioconductor.org
Using Bioconductor version 3.1 (BiocInstaller 1.18.2), R version 3.2.0.
Installing package(s) ‘pkgDepTools’
trying URL 'http://bioconductor.org/packages/3.1/bioc/bin/windows/contrib/3.2/pkgDepTools_1.34.0.zip'
Content type 'application/zip' length 390579 bytes (381 KB)
downloaded 381 KB

package ‘pkgDepTools’ successfully unpacked and MD5 sums checked
Warning: cannot remove prior installation of package ‘pkgDepTools’

The downloaded binary packages are in
        C:\Users\brb\AppData\Local\Temp\RtmpYd2l7i\downloaded_packages
> library(pkgDepTools)
Error in library(pkgDepTools) : there is no package called ‘pkgDepTools’

The pkgDepTools library folder appears in C:\Users\brb\Documents\R\win-library\3.2, but it is empty. The weird thing is if I try the above steps again, I cannot reproduce the problem.

Warning: dependency ‘XXX’ is not available

How should I deal with “package 'xxx' is not available (for R version x.y.z)” warning?

Error: there is no package called XXX

The error happened when I try to run library() command on a package that was just installed. R 3.6.0. 'biospear' version is 1.0.2. macOS.

> library(biospear)
Loading required package: pkgconfig
Error: package or namespace load failed for ‘biospear’ in loadNamespace(i, c(lib.loc, .libPaths()), versionCheck = vIi):
 there is no package called ‘mixOmics’

Note

  • The package mixOmics was removed from CRAN. It is now available on Bioconductor.
  • Tested to install on a docker container: docker run --net=host -it --rm r-base
    ERROR: dependency ‘car’ is not available for package ‘plsRglm’
    * removing ‘/usr/local/lib/R/site-library/plsRglm’
    ERROR: dependencies ‘plsRglm’, ‘mixOmics’, ‘survcomp’ are not available for package ‘plsRcox’
    * removing ‘/usr/local/lib/R/site-library/plsRcox’
    ERROR: dependencies ‘devtools’, ‘plsRcox’, ‘RCurl’ are not available for package ‘biospear’
    * removing ‘/usr/local/lib/R/site-library/biospear’
    The car package looks OK on CRAN. survcomp was moved from CRAN to Bioconductor too.
  • As we can see above, the official r-base image does not contain libraries enough to install RCurl/devtools packages. Consider the tidyverse image (based on RStudio image) from the rocker project.
    docker pull rocker/tidyverse:3.6.0
    docker run --net=host -it --rm -e PASSWORD=password -p 8787:8787 rocker/tidyverse:3.6.0
    # the default username is 'rstudio'
    # Open a browser, log in. Run 'install.packages("RCurl")'. It works.
  • Testing on Mint linux also shows errors about dependencies of mixOmics and survcomp.
  • The best practice to install a package that may depend on packages located/moved to Bioconductor: Run setRepositories(ind=1:2) before calling install.packages(). However, it does not remedy the situation that the 1st level imports package (eg plsRcox) was installed before but the 2nd level imports package (eg mixOmics) was not installed.
  • dependsOnPkgs(): Find Reverse Dependencies. It seems it only return packages that have been installed locally. For example, tools::dependsOnPkgs("RcppEigen", "LinkingTo")

Warning: Unable to move temporary installation

The problem seems to happen only on virtual machines (Virtualbox).

  • Warning: unable to move temporary installation `C:\Users\brb\Documents\R\win-library\3.0\fileed8270978f5\quadprog` to `C:\Users\brb\Documents\R\win-library\3.0\quadprog` when I try to run 'install.packages("forecast").
  • Warning: unable to move temporary installation ‘C:\Users\brb\Documents\R\win-library\3.2\file5e0104b5b49\plyr’ to ‘C:\Users\brb\Documents\R\win-library\3.2\plyr’ when I try to run 'biocLite("lumi")'. The other dependency packages look fine although I am not sure if any unknown problem can happen (it does, see below).

Here is a note of my trouble shooting.

  1. If I try to ignore the warning and load the lumi package. I will get an error.
  2. If I try to run biocLite("lumi") again, it will only download & install lumi without checking missing 'plyr' package. Therefore, when I try to load the lumi package, it will give me an error again.
  3. Even I install the plyr package manually, library(lumi) gives another error - missing mclust package.
> biocLite("lumi")
trying URL 'http://bioconductor.org/packages/3.1/bioc/bin/windows/contrib/3.2/BiocInstaller_1.18.2.zip'
Content type 'application/zip' length 114097 bytes (111 KB)
downloaded 111 KB
...
package ‘lumi’ successfully unpacked and MD5 sums checked

The downloaded binary packages are in
        C:\Users\brb\AppData\Local\Temp\RtmpyUjsJD\downloaded_packages
Old packages: 'BiocParallel', 'Biostrings', 'caret', 'DESeq2', 'gdata', 'GenomicFeatures', 'gplots', 'Hmisc', 'Rcpp', 'RcppArmadillo', 'rgl',
  'stringr'
Update all/some/none? [a/s/n]: a
also installing the dependencies ‘Rsamtools’, ‘GenomicAlignments’, ‘plyr’, ‘rtracklayer’, ‘gridExtra’, ‘stringi’, ‘magrittr’

trying URL 'http://bioconductor.org/packages/3.1/bioc/bin/windows/contrib/3.2/Rsamtools_1.20.1.zip'
Content type 'application/zip' length 8138197 bytes (7.8 MB)
downloaded 7.8 MB
...
package ‘Rsamtools’ successfully unpacked and MD5 sums checked
package ‘GenomicAlignments’ successfully unpacked and MD5 sums checked
package ‘plyr’ successfully unpacked and MD5 sums checked
Warning: unable to move temporary installation ‘C:\Users\brb\Documents\R\win-library\3.2\file5e0104b5b49\plyr’ 
         to ‘C:\Users\brb\Documents\R\win-library\3.2\plyr’
package ‘rtracklayer’ successfully unpacked and MD5 sums checked
package ‘gridExtra’ successfully unpacked and MD5 sums checked
package ‘stringi’ successfully unpacked and MD5 sums checked
package ‘magrittr’ successfully unpacked and MD5 sums checked
package ‘BiocParallel’ successfully unpacked and MD5 sums checked
package ‘Biostrings’ successfully unpacked and MD5 sums checked
Warning: cannot remove prior installation of package ‘Biostrings’
package ‘caret’ successfully unpacked and MD5 sums checked
package ‘DESeq2’ successfully unpacked and MD5 sums checked
package ‘gdata’ successfully unpacked and MD5 sums checked
package ‘GenomicFeatures’ successfully unpacked and MD5 sums checked
package ‘gplots’ successfully unpacked and MD5 sums checked
package ‘Hmisc’ successfully unpacked and MD5 sums checked
package ‘Rcpp’ successfully unpacked and MD5 sums checked
package ‘RcppArmadillo’ successfully unpacked and MD5 sums checked
package ‘rgl’ successfully unpacked and MD5 sums checked
package ‘stringr’ successfully unpacked and MD5 sums checked

The downloaded binary packages are in
        C:\Users\brb\AppData\Local\Temp\RtmpyUjsJD\downloaded_packages
> library(lumi)
Error in loadNamespace(i, c(lib.loc, .libPaths()), versionCheck = vIi) : 
  there is no package called ‘plyr’
Error: package or namespace load failed for ‘lumi’
> search()
 [1] ".GlobalEnv"            "package:BiocInstaller" "package:Biobase"       "package:BiocGenerics"  "package:parallel"      "package:stats"        
 [7] "package:graphics"      "package:grDevices"     "package:utils"         "package:datasets"      "package:methods"       "Autoloads"            
[13] "package:base"         
> biocLite("lumi")
BioC_mirror: http://bioconductor.org
Using Bioconductor version 3.1 (BiocInstaller 1.18.2), R version 3.2.0.
Installing package(s) ‘lumi’
trying URL 'http://bioconductor.org/packages/3.1/bioc/bin/windows/contrib/3.2/lumi_2.20.1.zip'
Content type 'application/zip' length 18185326 bytes (17.3 MB)
downloaded 17.3 MB

package ‘lumi’ successfully unpacked and MD5 sums checked

The downloaded binary packages are in
        C:\Users\brb\AppData\Local\Temp\RtmpyUjsJD\downloaded_packages
> search()
 [1] ".GlobalEnv"            "package:BiocInstaller" "package:Biobase"       "package:BiocGenerics"  "package:parallel"      "package:stats"        
 [7] "package:graphics"      "package:grDevices"     "package:utils"         "package:datasets"      "package:methods"       "Autoloads"            
[13] "package:base"         
> library(lumi)
Error in loadNamespace(i, c(lib.loc, .libPaths()), versionCheck = vIi) : 
  there is no package called ‘plyr’
Error: package or namespace load failed for ‘lumi’
> biocLite("plyr")
BioC_mirror: http://bioconductor.org
Using Bioconductor version 3.1 (BiocInstaller 1.18.2), R version 3.2.0.
Installing package(s) ‘plyr’
trying URL 'http://cran.rstudio.com/bin/windows/contrib/3.2/plyr_1.8.2.zip'
Content type 'application/zip' length 1128621 bytes (1.1 MB)
downloaded 1.1 MB

package ‘plyr’ successfully unpacked and MD5 sums checked

The downloaded binary packages are in
        C:\Users\brb\AppData\Local\Temp\RtmpyUjsJD\downloaded_packages

> library(lumi)
Error in loadNamespace(j <- i1L, c(lib.loc, .libPaths()), versionCheck = vIj) : 
  there is no package called ‘mclust’
Error: package or namespace load failed for ‘lumi’

> ?biocLite
Warning messages:
1: In read.dcf(file.path(p, "DESCRIPTION"), c("Package", "Version")) :
  cannot open compressed file 'C:/Users/brb/Documents/R/win-library/3.2/Biostrings/DESCRIPTION', probable reason 'No such file or directory'
2: In find.package(if (is.null(package)) loadedNamespaces() else package,  :
  there is no package called ‘Biostrings’
> library(lumi)
Error in loadNamespace(j <- i1L, c(lib.loc, .libPaths()), versionCheck = vIj) : 
  there is no package called ‘mclust’
In addition: Warning messages:
1: In read.dcf(file.path(p, "DESCRIPTION"), c("Package", "Version")) :
  cannot open compressed file 'C:/Users/brb/Documents/R/win-library/3.2/Biostrings/DESCRIPTION', probable reason 'No such file or directory'
2: In find.package(if (is.null(package)) loadedNamespaces() else package,  :
  there is no package called ‘Biostrings’
Error: package or namespace load failed for ‘lumi’

Other people also have the similar problem. The possible cause is the virus scanner locks the file and R cannot move them.

Some possible solutions:

  1. Delete ALL folders under R/library (e.g. C:/Progra~1/R/R-3.2.0/library) folder and install the main package again using install.packages() or biocLite().
  2. For specific package like 'lumi' from Bioconductor, we can find out all dependency packages and then install them one by one.
  3. Find out and install the top level package which misses dependency packages.
    1. This is based on the fact that install.packages() or biocLite() sometimes just checks & installs the 'Depends' and 'Imports' packages and won't install all packages recursively
    2. we can do a small experiment by removing a package which is not directly dependent/imported by another package; e.g. 'iterators' is not dependent/imported by 'glment' directly but indirectly. So if we run remove.packages("iterators"); install.packages("glmnet"), then the 'iterator' package is still missing.
    3. A real example is if the missing packages are 'Biostrings', 'limma', 'mclust' (these are packages that 'minfi' directly depends/imports although they should be installed when I run biocLite("lumi") command), then I should just run the command remove.packages("minfi"); biocLite("minfi"). If we just run biocLite("lumi") or biocLite("methylumi"), the missing packages won't be installed.

Error in download.file(url, destfile, method, mode = "wb", ...)

HTTP status was '404 Not Found'

Tested on an existing R-3.2.0 session. Note that VariantAnnotation 1.14.4 was just uploaded to Bioc.

> biocLite("COSMIC.67")
BioC_mirror: http://bioconductor.org
Using Bioconductor version 3.1 (BiocInstaller 1.18.3), R version 3.2.0.
Installing package(s) ‘COSMIC.67’
also installing the dependency ‘VariantAnnotation’

trying URL 'http://bioconductor.org/packages/3.1/bioc/bin/windows/contrib/3.2/VariantAnnotation_1.14.3.zip'
Error in download.file(url, destfile, method, mode = "wb", ...) : 
  cannot open URL 'http://bioconductor.org/packages/3.1/bioc/bin/windows/contrib/3.2/VariantAnnotation_1.14.3.zip'
In addition: Warning message:
In download.file(url, destfile, method, mode = "wb", ...) :
  cannot open: HTTP status was '404 Not Found'
Warning in download.packages(pkgs, destdir = tmpd, available = available,  :
  download of package ‘VariantAnnotation’ failed
installing the source package ‘COSMIC.67’

trying URL 'http://bioconductor.org/packages/3.1/data/experiment/src/contrib/COSMIC.67_1.4.0.tar.gz'
Content type 'application/x-gzip' length 40999037 bytes (39.1 MB)

However, when I tested on a new R-3.2.0 (just installed in VM), the COSMIC package installation is successful. That VariantAnnotation version 1.14.4 was installed (this version was just updated today from Bioconductor).

The cause of the error is the available.package() function will read the rds file first from cache in a tempdir (C:\Users\XXXX\AppData\Local\Temp\RtmpYYYYYY). See lines 51-55 of <packages.R>.

 dest <- file.path(tempdir(),
                   paste0("repos_", URLencode(repos, TRUE), ".rds"))
 if(file.exists(dest)) {
    res0 <- readRDS(dest)
 } else {
    ...
 }  

Since my R was opened 1 week ago, the rds file it reads today contains old information. Note that Bioconductor does not hold the source code or binary code for the old version of packages. This explains why biocLite() function broke. When I restart R, the original problem is gone.

If we look at the source code of available.packages(), we will see we could use cacheOK option in download.file() function.

download.file(url, destfile, method, cacheOK = FALSE, quiet = TRUE, mode ="wb")

Another case: Error in download.file(url, destfile, method, mode = "wb", ...)

> install.packages("quantreg")

  There is a binary version available but the source version is later:
         binary source needs_compilation
quantreg   5.33   5.34              TRUE

Do you want to install from sources the package which needs compilation?
y/n: n
trying URL 'https://cran.rstudio.com/bin/macosx/el-capitan/contrib/3.4/quantreg_5.33.tgz'
Warning in install.packages :
  cannot open URL 'https://cran.rstudio.com/bin/macosx/el-capitan/contrib/3.4/quantreg_5.33.tgz': HTTP status was '404 Not Found'
Error in download.file(url, destfile, method, mode = "wb", ...) : 
  cannot open URL 'https://cran.rstudio.com/bin/macosx/el-capitan/contrib/3.4/quantreg_5.33.tgz'
Warning in install.packages :
  download of package ‘quantreg’ failed

It seems the binary package cannot be found on the mirror. So the solution here is to download the package from the R main server. Note that after I have successfully installed the binary package from the main R server, I remove the package in R and try to install the binary package from rstudio.com server agin and it works this time.

> install.packages("quantreg", repos = "https://cran.r-project.org")
trying URL 'https://cran.r-project.org/bin/macosx/el-capitan/contrib/3.4/quantreg_5.34.tgz'
Content type 'application/x-gzip' length 1863561 bytes (1.8 MB)
==================================================
downloaded 1.8 MB

Another case: Error in download.file() on Windows 7

For some reason, IE 8 cannot interpret https://ftp.ncbi.nlm.nih.gov though it understands ftp://ftp.ncbi.nlm.nih.gov.

This is tested using R 3.4.3.

> download.file("https://ftp.ncbi.nlm.nih.gov/geo/series/GSE7nnn/GSE7848/soft/GSE7848_family.soft.gz", "test.soft.gz")
trying URL 'https://ftp.ncbi.nlm.nih.gov/geo/series/GSE7nnn/GSE7848/soft/GSE7848_family.soft.gz'
Error in download.file("https://ftp.ncbi.nlm.nih.gov/geo/series/GSE7nnn/GSE7848/soft/GSE7848_family.soft.gz",  : 
  cannot open URL 'https://ftp.ncbi.nlm.nih.gov/geo/series/GSE7nnn/GSE7848/soft/GSE7848_family.soft.gz'
In addition: Warning message:
In download.file("https://ftp.ncbi.nlm.nih.gov/geo/series/GSE7nnn/GSE7848/soft/GSE7848_family.soft.gz",  :
  InternetOpenUrl failed: 'An error occurred in the secure channel support'

> download.file("ftp://ftp.ncbi.nlm.nih.gov/geo/series/GSE7nnn/GSE7848/soft/GSE7848_family.soft.gz", "test.soft.gz")
trying URL 'ftp://ftp.ncbi.nlm.nih.gov/geo/series/GSE7nnn/GSE7848/soft/GSE7848_family.soft.gz'
downloaded 9.1 MB

ERROR: failed to lock directory

Follow the suggestion to remove the LOCK file. See the post.

It could happened in calling install.packages(), biocLite() or devtools::install_github(), and so on.

Error in unloadNamespace(package)

> d3heatmap(mtcars, scale = "column", colors = "Blues")
Error: 'col_numeric' is not an exported object from 'namespace:scales'
> packageVersion("scales")
[1] ‘0.2.5’
> library(scales)
Error in unloadNamespace(package) : 
  namespace ‘scales’ is imported by ‘ggplot2’ so cannot be unloaded
In addition: Warning message:
package ‘scales’ was built under R version 3.2.1 
Error in library(scales) : 
  Package ‘scales’ version 0.2.4 cannot be unloaded
> search()
 [1] ".GlobalEnv"             "package:d3heatmap"      "package:ggplot2"       
 [4] "package:microbenchmark" "package:COSMIC.67"      "package:BiocInstaller" 
 [7] "package:stats"          "package:graphics"       "package:grDevices"     
[10] "package:utils"          "package:datasets"       "package:methods"       
[13] "Autoloads"              "package:base" 

If I open a new R session, the above error will not happen!

The problem occurred because the 'scales' package version required by the d3heatmap package/function is old. See this post. And when I upgraded the 'scales' package, it was locked by the package was imported by the ggplot2 package.

Unload a package

Add unload = TRUE option to unload the namespace. See detach().

require(splines)
detach(package:splines, unload=TRUE)

crantastic

https://crantastic.org/. A community site for R packages where you can search for, review and tag CRAN packages.

https://github.com/hadley/crantastic

New R packages as reported by CRANberries

http://blog.revolutionanalytics.com/2015/07/mranspackages-spotlight.html

#----------------------------
# SCRAPE CRANBERRIES FILES TO COUNT NEW PACKAGES AND PLOT
#
library(ggplot2)
# Build a vextor of the directories of interest
year <- c("2013","2014","2015")
month <- c("01","02","03","04","05","06","07","08","09","10","11","12")
span <-c(rep(month,2),month[1:7])
dir <- "http://dirk.eddelbuettel.com/cranberries"

url2013 <- file.path(dir,"2013",month)
url2014 <- file.path(dir,"2014",month)
url2015 <- file.path(dir,"2015",month[1:7])
url <- c(url2013,url2014,url2015)

# Read each directory and count the new packages
new_p <- vector()
for(i in url){
  raw.data <- readLines(i)
  new_p[i] <- length(grep("New package",raw.data,value=TRUE))
}

# Plot
time <- seq(as.Date("2013-01-01"), as.Date("2015-07-01"), by="months")
new_pkgs <- data.frame(time,new_p)

ggplot(new_pkgs, aes(time,y=new_p)) +
  geom_line() + xlab("") + ylab("Number of new packages") + 
  geom_smooth(method='lm') + ggtitle("New R packages as reported by CRANberries") 

R packages being removed

Top new packages in 2015

keep.source.pkgs option

State of R packages in your library. The original code formatting and commenting being removed by default, unless one changes some options for installing packages.

  • options(keep.source.pkgs = TRUE)
  • install.packages("rhub", INSTALL_opts = "--with-keep.source", type = "source")
  • R CMD install --with-keep.source

Package installation speed for packages installed with ‘keep.source’ has been improved. 2021-12-2.

Speeding up package installation

An efficient way to install and load R packages

An efficient way to install and load R packages

# Package names
packages <- c("ggplot2", "readxl", "dplyr", "tidyr", "ggfortify", "DT", "reshape2", "knitr", "lubridate", "pwr", "psy", "car", "doBy", "imputeMissings", "RcmdrMisc", "questionr", "vcd", "multcomp", "KappaGUI", "rcompanion", "FactoMineR", "factoextra", "corrplot", "ltm", "goeveg", "corrplot", "FSA", "MASS", "scales", "nlme", "psych", "ordinal", "lmtest", "ggpubr", "dslabs", "stringr", "assist", "ggstatsplot", "forcats", "styler", "remedy", "snakecaser", "addinslist", "esquisse", "here", "summarytools", "magrittr", "tidyverse", "funModeling", "pander", "cluster", "abind")

# Install packages not yet installed
installed_packages <- packages %in% rownames(installed.packages())
if (any(installed_packages == FALSE)) {
  install.packages(packages[!installed_packages])
}

# Packages loading
invisible(lapply(packages, library, character.only = TRUE))

Alternatively use the pacman package.

library( , exclude, include.only)

See ?library

library(tidyverse)
library(MASS, exclude='select')
library(thepackage, include.only="thefunction")

package ‘XXX’ was installed by an R version with different internals

it needs to be reinstalled for use with this R version. The problem seems to be specific to R 3.5.1 in Ubuntu 16.04. I got this message when I try to install the keras and tidyverse packages. The 'XXX' package includes nlme for installing "tidyverse" and Matrix for installing "reticulate". I have already logged in as root. I need to manually install these packages again though it seems I did not see a version change for these packages.

Same error Error: package was installed by an R version with different internals; it needs to be reinstalled for use with this R version.

Today it also happened when I tried to install "pec" which broke when it was installing "Hmisc". The error message is "Error : package ‘rpart’ was installed by an R version with different internals; it needs to be reinstalled for use with this R version". I am using R 3.5.2. rpart version is ‘4.1.13’. The solution is I install rpart again (under my account is enough) though rpart does not have a new version. Then I can install "Hmisc".

packrat and renv

See Reproducible → packrat/renv

R package dependencies

Depends, Imports, Suggests, Enhances, LinkingTo

See Writing R Extensions and install.packages().

  • Depends: list of package names which this package depends on. Those packages will be attached (so it is better to use Imports instead of Depends as much as you can) before the current package when library or require is called. The ‘Depends’ field can also specify a dependence on a certain version of R.
  • Imports: lists packages whose namespaces are imported from (as specified in the NAMESPACE file) but which do not need to be attached.
  • Suggests: lists packages that are not necessarily needed. This includes packages used only in examples, tests or vignettes, and packages loaded in the body of functions.
  • Enhances: lists packages “enhanced” by the package at hand, e.g., by providing methods for classes from these packages, or ways to handle objects from these packages.
  • LinkingTo: A package that wishes to make use of header files in other packages needs to declare them as a comma-separated list in the field ‘LinkingTo’ in the DESCRIPTION file.

Package related functions from package 'utils'

  1. inst - a data frame with columns as the matrix returned by installed.packages plus "Status", a factor with levels c("ok", "upgrade"). Note: the manual does not mention "unavailable" case (but I do get it) in R 3.2.0?
  2. avail - a data frame with columns as the matrix returned by available.packages plus "Status", a factor with levels c("installed", "not installed", "unavailable"). Note: I don't get the "unavailable" case in R 3.2.0?
> x <- packageStatus()
> names(x)
[1] "inst"  "avail"
> dim(x'inst')
[1] 225  17
> x'inst'[1:3, ]
              Package                            LibPath Version Priority               Depends Imports
acepack       acepack C:/Program Files/R/R-3.1.2/library 1.3-3.3     <NA>                  <NA>    <NA>
adabag         adabag C:/Program Files/R/R-3.1.2/library     4.0     <NA> rpart, mlbench, caret    <NA>
affxparser affxparser C:/Program Files/R/R-3.1.2/library  1.38.0     <NA>          R (>= 2.6.0)    <NA>
           LinkingTo                                                        Suggests Enhances
acepack         <NA>                                                            <NA>     <NA>
adabag          <NA>                                                            <NA>     <NA>
affxparser      <NA> R.oo (>= 1.18.0), R.utils (>= 1.32.4),\nAffymetrixDataTestFiles     <NA>
                      License License_is_FOSS License_restricts_use OS_type MD5sum NeedsCompilation Built
acepack    MIT + file LICENSE            <NA>                  <NA>    <NA>   <NA>              yes 3.1.2
adabag             GPL (>= 2)            <NA>                  <NA>    <NA>   <NA>               no 3.1.2
affxparser        LGPL (>= 2)            <NA>                  <NA>    <NA>   <NA>             <NA> 3.1.1
                Status
acepack             ok
adabag              ok
affxparser unavailable
> dim(x'avail')
[1] 6538   18
> x'avail'[1:3, ]
                Package Version Priority                        Depends        Imports LinkingTo
A3                   A3   0.9.2     <NA> R (>= 2.15.0), xtable, pbapply           <NA>      <NA>
ABCExtremes ABCExtremes     1.0     <NA>      SpatialExtremes, combinat           <NA>      <NA>
ABCanalysis ABCanalysis   1.0.1     <NA>                    R (>= 2.10) Hmisc, plotrix      <NA>
                       Suggests Enhances    License License_is_FOSS License_restricts_use OS_type Archs
A3          randomForest, e1071     <NA> GPL (>= 2)            <NA>                  <NA>    <NA>  <NA>
ABCExtremes                <NA>     <NA>      GPL-2            <NA>                  <NA>    <NA>  <NA>
ABCanalysis                <NA>     <NA>      GPL-3            <NA>                  <NA>    <NA>  <NA>
            MD5sum NeedsCompilation File                                      Repository        Status
A3            <NA>             <NA> <NA> http://cran.rstudio.com/bin/windows/contrib/3.1 not installed
ABCExtremes   <NA>             <NA> <NA> http://cran.rstudio.com/bin/windows/contrib/3.1 not installed
ABCanalysis   <NA>             <NA> <NA> http://cran.rstudio.com/bin/windows/contrib/3.1 not installed

download.packages() for source package

Consider the esimate package hosted on r-forge.

download.packages("estimate", destdir = "~/Downloads", 
   repos = "https://R-Forge.R-project.org")

tools package

db <- tools::CRAN_package_db()
nRcpp <- length(tools::dependsOnPkgs("Rcpp", recursive=FALSE, installed=db) )
nCompiled <- table(db[, "NeedsCompilation"])[["yes"]]
propRcpp <- nRcpp / nCompiled * 100
  • package.dependencies(), pkgDepends(), etc are deprecated now, mostly in favor of package_dependencies() which is both more flexible and efficient. See R 3.3.0 News. For example, tools::package_dependencies(c("remotes", "devtools"), recursive=TRUE) shows remotes has only a few dependencies while devtools has a lot.

crandep package

https://cran.r-project.org/web/packages/crandep/index.html. Useful to find reverse dependencies. ?get_dep. Consider the abc package:

get_dep("abc", "depends") # abc depends on these packages
                          # note my computer does not have 'abc' installed 
#   from       to    type reverse
# 1  abc abc.data depends   FALSE
# 2  abc     nnet depends   FALSE
# 3  abc quantreg depends   FALSE
# 4  abc     MASS depends   FALSE
# 5  abc   locfit depends   FALSE

get_dep("abc", "reverse_depends")
#    from       to    type reverse
# 1  abc abctools depends    TRUE
# 2  abc  EasyABC depends    TRUE

x <- get_dep("RcppEigen", c("reverse linking to")) 
dim(x)
# [1] 331   4
head(x, 3)
#        from      to       type reverse
# 1 RcppEigen   abess linking to    TRUE
# 2 RcppEigen    acrt linking to    TRUE
# 3 RcppEigen ADMMnet linking to    TRUE

How does this package depend on this other package

How does this package depend on this other package?, pak::pkg_deps_explain()

pkgndep

remotes

remotes::local_package_deps(dependencies=TRUE) will find and return all dependent packages based on the "DESCRIPTION" file. See an example here.

Bioconductor's pkgDepTools package

The is an example of querying the dependencies of the notorious 'lumi' package which often broke the installation script. I am using R 3.2.0 and Bioconductor 3.1.

The getInstallOrder function is useful to get a list of all (recursive) dependency packages.

source("http://bioconductor.org/biocLite.R")
if (!require(pkgDepTools)) {
  biocLite("pkgDepTools", ask = FALSE)
  library(pkgDepTools)
}
MkPlot <- FALSE

library(BiocInstaller)
biocUrl <- biocinstallRepos()["BioCsoft"]
biocDeps <- makeDepGraph(biocUrl, type="source", dosize=FALSE) # pkgDepTools defines its makeDepGraph()

PKG <- "lumi"
if (MkPlot) {
  if (!require(Biobase))  {
    biocLite("Biobase", ask = FALSE)
    library(Biobase)
  }
  if (!require(Rgraphviz))  {
    biocLite("Rgraphviz", ask = FALSE) 
    library(Rgraphviz)
  }
  categoryNodes <- c(PKG, names(acc(biocDeps, PKG)1))  
  categoryGraph <- subGraph(categoryNodes, biocDeps) 
  nn <- makeNodeAttrs(categoryGraph, shape="ellipse") 
  plot(categoryGraph, nodeAttrs=nn)   # Complete but plot is too complicated & font is too small.
}

system.time(allDeps <- makeDepGraph(biocinstallRepos(), type="source",
                           keep.builtin=TRUE, dosize=FALSE)) # takes a little while
#    user  system elapsed 
# 175.737  10.994 186.875 
# Warning messages:
# 1: In .local(from, to, graph) : edges replaced: ‘SNPRelate|gdsfmt’
# 2: In .local(from, to, graph) :
#   edges replaced: ‘RCurl|methods’, ‘NA|bitops’

# When needed.only=TRUE, only those dependencies not currently installed are included in the list.
x1 <- sort(getInstallOrder(PKG, allDeps, needed.only=TRUE)$packages); x1
 [1] "affy"                              "affyio"                           
 [3] "annotate"                          "AnnotationDbi"                    
 [5] "base64"                            "beanplot"                         
 [7] "Biobase"                           "BiocParallel"                     
 [9] "biomaRt"                           "Biostrings"                       
[11] "bitops"                            "bumphunter"                       
[13] "colorspace"                        "DBI"                              
[15] "dichromat"                         "digest"                           
[17] "doRNG"                             "FDb.InfiniumMethylation.hg19"     
[19] "foreach"                           "futile.logger"                    
[21] "futile.options"                    "genefilter"                       
[23] "GenomeInfoDb"                      "GenomicAlignments"                
[25] "GenomicFeatures"                   "GenomicRanges"                    
[27] "GEOquery"                          "ggplot2"                          
[29] "gtable"                            "illuminaio"                       
[31] "IRanges"                           "iterators"                        
[33] "labeling"                          "lambda.r"                         
[35] "limma"                             "locfit"                           
[37] "lumi"                              "magrittr"                         
[39] "matrixStats"                       "mclust"                           
[41] "methylumi"                         "minfi"                            
[43] "multtest"                          "munsell"                          
[45] "nleqslv"                           "nor1mix"                          
[47] "org.Hs.eg.db"                      "pkgmaker"                         
[49] "plyr"                              "preprocessCore"                   
[51] "proto"                             "quadprog"                         
[53] "RColorBrewer"                      "Rcpp"                             
[55] "RCurl"                             "registry"                         
[57] "reshape"                           "reshape2"                         
[59] "rngtools"                          "Rsamtools"                        
[61] "RSQLite"                           "rtracklayer"                      
[63] "S4Vectors"                         "scales"                           
[65] "siggenes"                          "snow"                             
[67] "stringi"                           "stringr"                          
[69] "TxDb.Hsapiens.UCSC.hg19.knownGene" "XML"                              
[71] "xtable"                            "XVector"                          
[73] "zlibbioc"                         

# When needed.only=FALSE the complete list of dependencies is given regardless of the set of currently installed packages.
x2 <- sort(getInstallOrder(PKG, allDeps, needed.only=FALSE)$packages); x2
 [1] "affy"                              "affyio"                            "annotate"                         
 [4] "AnnotationDbi"                     "base64"                            "beanplot"                         
 [7] "Biobase"                           "BiocGenerics"                      "BiocInstaller"                    
[10] "BiocParallel"                      "biomaRt"                           "Biostrings"                       
[13] "bitops"                            "bumphunter"                        "codetools"                        
[16] "colorspace"                        "DBI"                               "dichromat"                        
[19] "digest"                            "doRNG"                             "FDb.InfiniumMethylation.hg19"     
[22] "foreach"                           "futile.logger"                     "futile.options"                   
[25] "genefilter"                        "GenomeInfoDb"                      "GenomicAlignments"                
[28] "GenomicFeatures"                   "GenomicRanges"                     "GEOquery"                         
[31] "ggplot2"                           "graphics"                          "grDevices"                        
[34] "grid"                              "gtable"                            "illuminaio"                       
[37] "IRanges"                           "iterators"                         "KernSmooth"                       
[40] "labeling"                          "lambda.r"                          "lattice"                          
[43] "limma"                             "locfit"                            "lumi"                             
[46] "magrittr"                          "MASS"                              "Matrix"                           
[49] "matrixStats"                       "mclust"                            "methods"                          
[52] "methylumi"                         "mgcv"                              "minfi"                            
[55] "multtest"                          "munsell"                           "nleqslv"                          
[58] "nlme"                              "nor1mix"                           "org.Hs.eg.db"                     
[61] "parallel"                          "pkgmaker"                          "plyr"                             
[64] "preprocessCore"                    "proto"                             "quadprog"                         
[67] "RColorBrewer"                      "Rcpp"                              "RCurl"                            
[70] "registry"                          "reshape"                           "reshape2"                         
[73] "rngtools"                          "Rsamtools"                         "RSQLite"                          
[76] "rtracklayer"                       "S4Vectors"                         "scales"                           
[79] "siggenes"                          "snow"                              "splines"                          
[82] "stats"                             "stats4"                            "stringi"                          
[85] "stringr"                           "survival"                          "tools"                            
[88] "TxDb.Hsapiens.UCSC.hg19.knownGene" "utils"                             "XML"                              
[91] "xtable"                            "XVector"                           "zlibbioc" 

> sort(setdiff(x2, x1)) # Not all R's base packages are included; e.g. 'base', 'boot', ...
 [1] "BiocGenerics"  "BiocInstaller" "codetools"     "graphics"      "grDevices"    
 [6] "grid"          "KernSmooth"    "lattice"       "MASS"          "Matrix"       
[11] "methods"       "mgcv"          "nlme"          "parallel"      "splines"      
[16] "stats"         "stats4"        "survival"      "tools"         "utils"  

Lumi rgraphviz.svg

Bioconductor BiocPkgTools

Collection of simple tools for learning about Bioc Packages. Functionality includes access to :

  • Download statistics
  • General package listing
  • Build reports
  • Package dependency graphs
  • Vignettes

Overview of BiocPkgTools & Dependency graphs

BiocPkgTools: Toolkit for Mining the Bioconductor Package Ecosystem in biorxiv.org.

miniCRAN package

miniCRAN package can be used to identify package dependencies or create a local CRAN repository. It can be used on repositories other than CRAN, such as Bioconductor.

Before we go into R, we need to install some packages from Ubuntu terminal. See here.

# Consider glmnet package (today is 4/29/2015)
# Version:	2.0-2
# Depends:	Matrix (≥ 1.0-6), utils, foreach
# Suggests:	survival, knitr, lars
if (!require("miniCRAN"))  {
  install.packages("miniCRAN", dependencies = TRUE, repos="http://cran.rstudio.com") # include 'igraph' in Suggests.
  library(miniCRAN)
}
if (!"igraph" %in% installed.packages()[,1]) install.packages("igraph")

tags <- "glmnet"
pkgDep(tags, suggests=TRUE, enhances=TRUE) # same as pkgDep(tags)
#  [1] "glmnet"    "Matrix"    "foreach"   "codetools" "iterators" "lattice"   "evaluate"  "digest"   
#  [9] "formatR"   "highr"     "markdown"  "stringr"   "yaml"      "mime"      "survival"  "knitr"    
# [17] "lars"   

dg <- makeDepGraph(tags, suggests=TRUE, enhances=TRUE) # miniCRAN defines its makeDepGraph()
plot(dg, legendPosition = c(-1, 1), vertex.size=20)

MiniCRAN dep.svg PkgDepTools dep.svg Glmnet dep.svg

We can also display the dependence for a package from the Bioconductor repository.

tags <- "DESeq2"
# Depends	S4Vectors, IRanges, GenomicRanges, Rcpp (>= 0.10.1), RcppArmadillo (>= 0.3.4.4)
# Imports	BiocGenerics(>= 0.7.5), Biobase, BiocParallel, genefilter, methods, locfit, geneplotter, ggplot2, Hmisc
# Suggests	RUnit, gplots, knitr, RColorBrewer, BiocStyle, airway,\npasilla (>= 0.2.10), DESeq, vsn
# LinkingTo     Rcpp, RcppArmadillo
index <- function(url, type="source", filters=NULL, head=5, cols=c("Package", "Version")){
  contribUrl <- contrib.url(url, type=type)
  available.packages(contribUrl, type=type, filters=filters)
}

bioc <- local({
  env <- new.env()
  on.exit(rm(env))
  evalq(source("http://bioconductor.org/biocLite.R", local=TRUE), env)
  biocinstallRepos() # return URLs
})

bioc
#                                               BioCsoft 
#            "http://bioconductor.org/packages/3.0/bioc" 
#                                                BioCann 
# "http://bioconductor.org/packages/3.0/data/annotation" 
#                                                BioCexp 
# "http://bioconductor.org/packages/3.0/data/experiment" 
#                                              BioCextra 
#           "http://bioconductor.org/packages/3.0/extra" 
#                                                   CRAN 
#                                "http://cran.fhcrc.org" 
#                                              CRANextra 
#                   "http://www.stats.ox.ac.uk/pub/RWin" 
str(index(bioc["BioCsoft"])) # similar to cranJuly2014 object 

system.time(dg <- makeDepGraph(tags, suggests=TRUE, enhances=TRUE, availPkgs = index(bioc["BioCsoft"]))) # Very quick!
plot(dg, legendPosition = c(-1, 1), vertex.size=20)

Deseq2 dep.svg Lumi dep.svg

The dependencies of GenomicFeature and GenomicAlignments are more complicated. So we turn the 'suggests' option to FALSE.

tags <- "GenomicAlignments"
dg <- makeDepGraph(tags, suggests=FALSE, enhances=FALSE, availPkgs = index(bioc["BioCsoft"]))
plot(dg, legendPosition = c(-1, 1), vertex.size=20)

Genomicfeature dep dep.svg Genomicalignments dep.svg

Github repository

Submitting R package to CRAN

cranlike

https://github.com/r-hub/cranlike

cranlike keeps the package data in a SQLite database, in addition to the PACKAGES* files. This database is the canonical source of the package data. It can be updated quickly, to add and remove packages. The PACKAGES* files are generated from the database.

MRAN (CRAN only) & checkpoint package

According to the snapsot list here, the oldest version is 2014-08-18 which corresponds to R 3.1.0.

checkpoint package

library(checkpoint)
checkpoint("2015-03-31")

Note the Bioconductor packages have no similar solution.

groundhog package

  • groundhog: Version-Control for CRAN, GitHub, and GitLab Packages (Bioconductor?)
  • It seems groundhog is like checkpoint but groundhog does not depend on MRAN and it will figure out the package dependencies by itself.
  • MRAN is getting shutdown - what else is there for reproducibility with R, or why reproducibility is on a continuum? The author provides an example where we can integrate "groundhog" in the Dockerfile for reproducibility. Pay attention to the sentence (appear 2 times) “why use Docker at all? Since it’s easy to install older versions of R on Windows and macOS, wouldn’t an renv.lock file suffice? Or even just {groundhog} which is arguably even easier to use?”
  • MRAN is getting shutdown #593 related to Rocker project. Rocker now uses RSPM (PPM now) from RStudio.
  • groundhog.library() differs from the library() function: 1) it installed and loaded packages in one step, 2) it allowed to install multiple packages.

Note I use the docker's R since that's the easiest way to use an old version of R (e.g. for some old R script) in Linux. Note that it will create a new folder R_groundhog folder in the working directory (see the message below).

$ docker run --rm -it -v $(pwd):/home/docker \
    -w /home/docker -u docker r-base:4.0.2 R

> install.packages("groundhog")
> library(groundhog")
groundhog needs authorization to save files to '/home/docker/R_groundhog'
Enter 'OK' to provide authorization
OK
The groundhog folder path is now:
/home/docker/R_groundhog/groundhog_library/
Loaded 'groundhog' (version:2.1.0) using R-4.0.2
Tips and troubleshooting: https://groundhogR.com

> groundhog.library("
  library(ggplot2)",
    "2020-10-10")
> library()
# Packages in library ‘/usr/local/lib/R/site-library’:
> packageVersion("ggplot2")
[1] ‘3.3.2’   # the latest version is 3.4.0 on R 4.2.2
> library(ggplot2)

(Current groundhog is v3.1.0) If I don't specify a user in docker run, I'll need to call groundhog.library() twice in order to install packages (eg. "DT" package). In this case I can use groundhog:::save.cookie("copy_instead_of_renaming") before calling groundhog.library().

$ docker run -it --rm rocker/verse:4.3.0 bash
root@58978695ec12:/# R
R version 4.3.0 (2023-04-21) -- "Already Tomorrow"
...
> install.packages("groundhog"); library(groundhog)

> .libPaths()
[1] "/usr/local/lib/R/site-library" "/usr/local/lib/R/library"
> get.groundhog.folder()
[1] "/root/R_groundhog/groundhog_library/"

> groundhog:::save.cookie("copy_instead_of_renaming") 
groundhog needs authorization to save files to '/root/R_groundhog/'
Enter 'OK' to provide authorization, and 'NO' not to.
|   >OK

Groundhog folder set to: '/root/R_groundhog/groundhog_library/

--- You may change it with`set.groundhog.folder(<path>)`---
Downloading database with information for all CRAN packages ever published
trying URL 'http://s3.wasabisys.com/groundhog/cran.toc.rds'
Content type 'application/octet-stream' length 2010504 bytes (1.9 MB)
==================================================
downloaded 1.9 MB

Downloading database with installation times for all source packages on CRAN
trying URL 'http://s3.wasabisys.com/groundhog/cran.times.rds'
Content type 'application/octet-stream' length 803912 bytes (785 KB)
==================================================
downloaded 785 KB
> groundhog.library("DT", "2023-4-23")
> find.package("DT")

rang

rang: make ancient R code run again

cranly

R package dependence trees

sessioninfo

tmp = session_info("sessioninfo")
dim(tmp$packages) # [1]  7 11

tmp = session_info("tidyverse")
dim(tmp$packages) # [1] 95 11

Reverse dependence

Install packages offline

http://www.mango-solutions.com/wp/2017/05/installing-packages-without-internet/

Install a packages locally and its dependencies

It's impossible to install the dependencies if you want to install a package locally. See Windows-GUI: "Install Packages from local zip files" and dependencies

A minimal R package (for testing purpose)

An R package that does not require others during install.packages()

Create a new R package, namespace, documentation

Package structure

http://r-pkgs.had.co.nz/package.html. On Linux/macOS, use tree -d DIRNAME to show the directories only. At a minimum, we will have R and man directories.

  • ChangeLog
  • DESCRIPTION
  • MD5
  • NAMESPACE
  • R/
    • zzz.R
  • build/
    • Package.pdf (eg dplyr)
    • vignette.rds
  • data/
  • demo/
  • inst/
    • extdata/
    • doc/
      • FileName.R
      • FileName.Rmd
      • FileName.html
    • include/
    • othersYouInclude/
    • tinytest/
    • CITATION
  • man/
    • figures/
  • src/
  • tests/
    • testthat
  • vignettes/

NAMESPACE and DESCRIPTION

Namespace dependencies not required. If you use import or importFrom in your NAMESPACE file, you should have an entry for that package in the Imports section of your DESCRIPTION file (unless there is a reason that you need to use Depends in which case the package should have an entry in Depends, and not Imports).

license

Install software for PDF output

Windows: Rtools

  • (Old) Installing RTools for Compiled Code via Rcpp. Just remember to check the option to include some paths in the PATH environment variable.
  • Using Rtools4 on Windows. This version gives more details about the story in Rtools4X versions.
  • Testing Rtools43 on R 4.3.3. According to the information on the website: When using R installed by the installer, no further setup is necessary after installing Rtools43 to build R packages from source. I can testify that by running install.packages("jsonlite", type = "source") . We can also verify that make can be found.
    Sys.which("make")
    ## "C:\\rtools40\\usr\\bin\\make.exe"
    

Screenshots of installation of Rtools44

Rtools44.png

R CMD

R Installation and Administration

  • R CMD build XXX. Note this will not create pdf files for vignettes. The output is a tarball.
  • R CMD INSTALL
  • R CMD REMOVE
  • R CMD SHLIB files. For example, "Rcmd shlib *.f *.c -o surv.dll" on Windows.
  • R CMD make
  • R CMD check XXX. Useful if we want to create reference manual (PDF file). See R create reference manual with R CMD check.
  • R CMD javareconf

usethis package

Github Actions

To use the Github Actions for continuous integration/CI checks,

  • I first follow this to run usethis::use_github_action_check_release(). Once I commit and push the files to Github, Github Actions are kicked off. The R console also tell me to copy and paste a line to add a workflow's badge to README.md.
  • Then I modify the yaml file to become this to run a standard check. This took 3m24s to run.
  • Then I further delete the 'devel' line (line 23) to reduce one more platform to check. This took 3m to check. My example is on Github (rtoy).

I also try to follow Github Actions with R and create a pkgdown/package documentation web page.

  • usethis::use_github_actions("pkgdown") Now go to Github repo's Settings -> Options and scroll down until you see Github Pages. For Source, the page site should be set to being built from the root folder of the gh-pages.
  • I have used Jekyll to create a gh-page. I don't need to delete anything for this new gh-pages. I just need to go to the repository setting and (scroll down until we see Github Pages) change the Source of Github Pages to 'gh-pages branch' from 'master branch'.
  • The files on the gh-pages branch are generated by Github Actions; these files are not available on my local machine. My location machine only has .github/workflows/pkgdown.yaml file.

Question:

  • The workflow file specifies R version and OS platform.
  • Right now the workflow file (like pkgdown) is using "r-lib/actions/setup-r@master" that has an "action.yml" file. The r-version is '3.x' only. What about if R 4.0.0 is released?

Packages, webpages and Github

Tutorials by Lisa DeBruine

biocthis

biocthis, slides

R package depends vs imports

In the namespace era Depends is never really needed. All modern packages have no technical need for Depends anymore. Loosely speaking the only purpose of Depends today is to expose other package's functions to the user without re-exporting them.

load = functions exported in myPkg are available to interested parties as myPkg::foo or via direct imports - essentially this means the package can now be used

attach = the namespace (and thus all exported functions) is attached to the search path - the only effect is that you have now added the exported functions to the global pool of functions - sort of like dumping them in the workspace (for all practical purposes, not technically)

import a function into a package = make sure that this function works in my package regardless of the search path (so I can write fn1 instead of pkg1::fn1 and still know it will come from pkg1 and not someone's workspace or other package that chose the same name)


The distinction is between "loading" and "attaching" a package. Loading it (which would be done if you had MASS::loglm, or imported it) guarantees that the package is initialized and in memory, but doesn't make it visible to the user without the explicit MASS:: prefix. Attaching it first loads it, then modifies the user's search list so the user can see it.

Loading is less intrusive, so it's preferred over attaching. Both library() and require() would attach it.

import() and importFrom()

If our package depends on a package, we need to made some changes. Below we assume the package glmnet in our new package.

  • DESCRIPTION: Imports: glmnet
  • NAMESPACE: either import(glmnet) to import all functions from glmnet or importFrom(glmnet, cv.glmnet) to import 'cv.glmnet' only
  • hello.R: nothing needs to be added

For more resource, see

R package suggests

stringr has suggested htmlwidgets. An error will come out if the suggested packages are not available.

> library(stringr)
> str_view(c("abc", "a.c", "bef"), "a\\.c")
Error in loadNamespace(name) : there is no package called ‘htmlwidgets’

Useful functions for accessing files in packages

> system.file(package = "batr")
[1] "f:/batr"
> system.file("extdata", "logo.png", package = "cowplot") # Mac
[1] "/Library/Frameworks/R.framework/Versions/4.0/Resources/library/cowplot/extdata/logo.png"

> path.package("batr")
[1] "f:\\batr"
> path.package("ggplot2") # Mac
[1] "/Library/Frameworks/R.framework/Versions/4.0/Resources/library/ggplot2"

# sometimes it returns the forward slash format for some reason; C:/Program Files/R/R-3.4.0/library/batr
# so it is best to add normalizePath().
> normalizePath(path.package("batr"))

> file.path("f:", "git", "surveyor")
[1] "f:/git/surveyor"

Internal functions

RStudio shortcuts

RStudio Build.png

available package

available. Check if a given package name is available to use. It checks the name's validity. Checks if it is used on 'GitHub', 'CRAN' and 'Bioconductor'.

Create an R package

Your first R package in 1 hour

Using usethis

New R Package 'foo' -- Updated

  1. setwd()
  2. usethis::create_package("foo")
  3. usethis::use_git(); usethis_github()
  4. usethis::use_mit_license("Your name")
  5. usethis::use_r("foo_function")
  6. usethis::use_package("dplyr") # specify import dependency, e.g. dplyr package
  7. usethis::use_testthat()
  8. usethis::use_test("firsttest")
  9. setwd("..")
  10. roxygen2::roxygenise()

Using devtools and roxygen2

How to use devtools::load_all("FolderName"). load_all() loads any modified R files, and recompile and reload any modified C or Fortran files.

# Step 1
library(devtools)

# Step 2
dir.create(file.path("MyCode", "R"), recursive = TRUE)
cat("foo=function(x){x*2}", file = file.path("MyCode", "R", "foo.R"))
write.dcf(list(Package = "MyCode", Title = "My Code for this project", Description = "To tackle this problem", 
    Version = "0.0", License = "For my eyes only", Author = "First Last <[email protected]>", 
    Maintainer = "First Last <[email protected]>"), file = file.path("MyCode", "DESCRIPTION"))
# OR
# create("path/to/package/pkgname")
# create() will create R/ directory, DESCRIPTION and NAMESPACE files.

# Step 3 (C/Fortran code, optional)
dir.create(file.path("MyCode", "src"))
cat("void cfoo(double *a, double *b, double *c){*c=*a+*b;}\n", file = file.path("MyCode", 
    "src", "cfoo.c"))
cat("useDynLib(MyCode)\n", file = file.path("MyCode", "NAMESPACE"))

# Step 4 
load_all("MyCode")

# Step 5
# Modify R/C/Fortran code and run load_all("MyCode")

# Step 6 (Automatically generate the documentation from R source code, 
#         in the man/ folder and export the function in NAMESPACE file.
#         optional, repeat if any function's help has changed)
document("MyCode")

# Step 7 (check the package, optional)
check("MyCode")

# Step 8 (Deployment, create a tarball, 
#         optional, repeat if necessary)
build("MyCode")

# Step 9 (Install the package, optional)
install("MyCode")

Note:

  1. load_all("FolderName") will make the FolderName to become like a package to be loaded into the current R session so the 2nd item returned from search() will be "package:FolderName". However, the FolderName does not exist under Program Files/R/R-X.Y.Z/library nor Documents/R/win-library/X.Y/ (Windows OS).
  2. build("FolderName") will create a tarball in the current directory. User can install the new package for example using Packages -> Install packages from local files on Windows OS. This will build/run vignettes so it may take some time. The tarball will contain a build folder containing 'vignette.rds' file. It'll also create a new folder inst/doc containing 3 files (MyPkg.html, MyPkg.Rmd and MyPkg.R). The vignettes may contain a new folder MyPkg_cache if we use chunk = TRUE option in Rmd file. Note install.packages() will not run the R code in vignettes.
  3. For the simplest R package, the source code only contains a file <DESCRIPTION> and a folder <R> with individual R files in the text format.

Using RStudio

  • Youtube
  • How to Create and Distribute an R Package.
    • The goal of the article to set up an easily installable R package on Github for others to use via remotes::install_github().
    • The main tools required are RStudio along with the packages roxygen2 and usethis.
    • How to take care of Bioconductor and Github Dependencies
    • How to publish your package to Github
  • Building a Corporate R Package for Pleasure and Profit
  • Toy example*
    1. In RStudio, click "File" - "New Project" - "New Directory" - "R package". Package name = "a1" (this naming will guarantee this package will be shown on top of all R packages in RStudio). Press 'Create Project'. This new project folder will have necessary files for an R package including DESCRIPTION, NAMESPACE, R/hello.R, man/hello.Rd. The "hello.R" file will be opened in RStudio automatically.
    2. Create a new R file under a1/R folder. An example of this R file <add.R> containing roxygen comments can be found under here. Pressing Ctrl/Cmd + Shift + D (or running devtools::document()) will generate a man/add.Rd.
    3. In R, type usethis::use_vignette("my-vignette") to create a new vignette. The new vignette "my-vignette.Rmd" will be saved under "a1/vignettes" subfolder. We can modify the Rmd file as we need.
    4. In RStudio, click "Build" - "Build Source Package". You will see some messages on the "Build" tab of the top-right panel. Eventually, a tarball "/home/$USERNAME/a1_0.1.0.tar.gz" is created (I create the project under /home/$USERNAME directory).
    5. We can install the package in R install.packages("~/a1_0.1.0.tar.gz", repos= NULL, type = "source") if we have already created the tarball. Another method is to use RStudio "Build" - "Install and Restart" (Ctrl + Shift + B).
    6. In RStudio, type help(package = "a1") or click "Packages" tab on the bottom-right panel and click "a1" package. It will show a line "User guides, package vignettes and other documentation". The vignette we just created will be available in HTML, source and R code format.

Using RStudio.cloud

There is a problem. We can use devtools::create("/cloud/project") to create a new package. When it builds the source package, the package file will be located in the root directory of the package. However, if we use a local RStudio to create a source package, the source package will be located in the upper directory.

Binary packages

  • No .R files in the R/ directory. There are 3 files that store the parsed functions in an efficient file format. This is the result of loading all the R code and then saving the functions with save().
  • A Meta/ directory contains a number of Rds files. These files contain cached metadata about the package, like what topics the help files cover and parsed version of the DESCRIPTION file.
  • An html/ directory.
  • libs/ directory if you have any code in the src/' directory
  • The contents of inst/ are moved to the top-level directory.

Building the tarball

  • No matter we uses devtools::build() or the terminal R CMD build MyPkg it will uses run the R code in vignette. Be cautious on the extra time and storage the process incurred.
  • If 'cache = TRUE' is used in vignettes, it will create a new subfolder called MyuPkg_cache under the vignettes folder. This takes a lot of space (eg 1GB in some case).

Building the binary

R CMD INSTALL --build MyPkg.tar.gz
# OR
R CMD INSTALL --build Full_Path_Of_MyPkg 

The binary (on Windows) can be installed by install.packages("Mypkg.zip",repos=NULL)

If the installation is successful, it will overwrite any existing installation of the same package. To prevent changes to the present working installation or to provide an install location with write access, create a suitably located directory with write access and use the -l option to build the package in the chosen location.

R CMD INSTALL -l location --build pkg

R folder

See an example from DuoClustering2018.

#' @importFrom utils read.csv
.onLoad <- function(libname, pkgname) {
  fl <- system.file("extdata", "metadata.csv", package = "DuoClustering2018")
  titles <- utils::read.csv(fl, stringsAsFactors = FALSE)$Title
  ExperimentHub::createHubAccessors(pkgname, titles)
}

Note that the environment of a function from the DuoClustering2018 package is not the package name.

environment(clustering_summary_filteredExpr10_TrapnellTCC_v2)
<environment: 0x7fe01dbe7dd0>

Q: where is the definition of DuoClustering2018::clustering_summary_filteredExpr10_TrapnellTCC_v2()? A: createHubAccessors() - Creating A Hub Package: ExperimentHub or AnnotationHub.

data

http://r-pkgs.had.co.nz/data.html

Three ways to include data in your package.

  • If you want to store binary data and make it available to the user, put it in data/. This is the best place to put example datasets.
  • If you want to store parsed data, but not make it available to the user, put it in R/sysdata.rda. This is the best place to put data that your functions need.
  • If you want to store raw data, put it in inst/extdata. See External data. An example from tximportData package.
    # grep -r extdata /home/brb/R/x86_64-pc-linux-gnu-library/4.0
    logo_file <- system.file("extdata", "logo.png", package = "cowplot")
    orgDBLoc = system.file("extdata", "org.Hs.eg.sqlite", package="org.Hs.eg.db")
    
    # grep -r readRDS /home/brb/R/x86_64-pc-linux-gnu-library/4.0
    patient.data  <- readRDS("assets/coxnet.RDS")
    

How to distribute data with your R package

Rd file

Using Mathjax in Rd Files

Vignette

Long execution for R code in vignette

NEWS

Why and how maintain a NEWS file for your R package?

README.Rmd & README.md files

See Releasing a package from R packages by Hadley Wickham.

How to convert .Rmd into .md in R studio?

Example: ggplot2 repository at Github

It seems RStudio cannot create TOC for *.md files. glmnet package creates TOC of its vignette by itself. Visual Studio Code has an extension to do that.

badge

badger: Badge for R Package

tests folder and testthat package

.Rbuildignore

Non-standard files/directories, Rbuildignore and inst

URL checker

What is a library?

A library is simply a directory containing installed packages.

You can use .libPaths() to see which libraries are currently active.

.libPaths()

lapply(.libPaths(), dir)

Object names

  • Variable and function names should be lower case.
  • Use an underscore (_) to separate words within a name (reserve . for S3 methods).
  • Camel case is a legitimate alternative, but be consistent! For example, preProcess(), twoClassData, createDataPartition(), trainingRows, trainPredictors, testPredictors, trainClasses, testClasses have been used in Applied Predictive Modeling by Kuhn & Johnson.
  • Generally, variable names should be nouns and function names should be verb.

Spacing

  • Add a space around the operators +, -, \ and *.
  • Include a space around the assignment operators, <- and =.
  • Add a space around any comparison operators such as == and <.

Indentation

  • Use two spaces to indent code.
  • Never mix tabs and spaces.
  • RStudio can automatically convert the tab character to spaces (see Tools -> Global options -> Code).

\dontrun{}

formatR and lintr package

Use formatR package to clean up poorly formatted code

install.packages("formatR")
formatR::tidy_dir("R")

Another way is to use the lintr package (lint).

install.packages("lintr")
lintr:::lin_package()

Rcpp

Thirteen Simple Steps for Creating An R Package with an External C++ Library

C library

Using R — Packaging a C library in 15 minutes

Data package

Chapter 12 Create a data package from rstudio4edu

Minimal R package for submission

https://stat.ethz.ch/pipermail/r-devel/2013-August/067257.html and CRAN Repository Policy.

Create R Windows Binary on non-Windows OS

r-hub/rhub package: the R package builder service

https://github.com/r-hub/proposal, R-hub v2 2024/4.

# Today 1/1/2020
$ git clone https://github.com/arraytools/rtoy.git
$ rm -rf rtoy/.git
$ rm rtoy/.gitignore rtoy/_config.yml
$ R
> install.packages("devtools", repos = "https://cran.rstudio.com")
> install.packages("rhub")
> devtools::install_github("r-hub/sysreqs") #needed before calling local_check_linux()

> pkg_path <- "~/Downloads/rtoy"
> chk <- local_check_linux(pkg_path, image = "rhub/debian-gcc-release")

─  Building package

Container name: 6dca434d-84f9-42e2-ab83-b8c364594476-2
It will _not_ be removed after the check.

R-hub Linux builder script v0.10.0 (c) R Consortium, 2018-2019

Package: /tmp/RtmpviOCT1/file470972a3c4ab/rtoy_0.1.0.tar.gz
Docker image: rhub/debian-gcc-release
Env vars:
R CMD check arguments:
Unable to find image 'rhub/debian-gcc-release:latest' locally
latest: Pulling from rhub/debian-gcc-release
Digest: sha256:a9e01ca57bfd44f20eb6719f0bfecdd8cf0f59610984342598a53f11555b515d
Status: Downloaded newer image for rhub/debian-gcc-release:latest
Sysreqs platform: linux-x86_64-debian-gcc
No system requirements

>>>>>==================== Installing system requirements
8fa4f66e41954b4ed1112eb72e76683c28345863fcc7e260edac6a9a30387fed

>>>>>==================== Starting Docker container
2dfae75c9de95b598ff8d9cd19d3cfc7ffe7f16edbc3d4f81c896e4e6b956ebd
ls: cannot access '/opt/R-*': No such file or directory
> source('https://bioconductor.org/biocLite.R')
Error: With R version 3.5 or greater, install Bioconductor packages using BiocManager; see https://bioconductor.org/install
Execution halted
Error in run(bash, c(file.path(wd, "rhub-linux.sh"), args), echo = TRUE,  :
  System command error

Moreover, it create a new Docker image and a new Docker container. We need to manually clean them:-(

Running a check on its own (remote) server works

> check_on_linux("rtoy") # will run remotely. 
     # We need to verify the email and enter a token.
     # We will get a report and a full build log.
     # The report includes both the linux command and the log from the server.

Now I go back to the original method.

$ R
> install.packages("tinytex")
> tinytex::install_tinytex()
> q()
$ exit

$ sudo apt-get install texinfo
$ R CMD build rtoy
$ R CMD check rtoy_0.1.0.tar.gz

# Install pandoc
$ wget https://github.com/jgm/pandoc/releases/download/2.9.1/pandoc-2.9.1-1-amd64.deb
$ sudo dpkg -i pandoc-2.9.1-1-amd64.deb
$ R CMD check --as-cran rtoy_0.1.0.tar.gz
# Ignore a 'Note' https://stackoverflow.com/a/23831508

rcmdcheck

Run R CMD check from R and Capture Results

The rcmdcheck package was used by Github Actions for R language from r-lib/R infrastructure.

CRAN check API

Continuous Integration

Travis-CI (Linux, Mac)

Continuous Integration: Appveyor (Windows)

Github Actions

precommit

Submit packages to cran

Windows

Everything you should know about WinBuilder

Other tips/advice

C/Fortran

Rmath.h

For example pnorm5() was used by survS.h by survival package (old version) .

Packages includes Fortran

Some useful packages containing fortran code.

My experience on M1 macOS

  • (Outdated) On mac, gfortran (6.1) (X86 not arm) can be downloaded from CRAN. It will be installed onto /usr/local/gfortran. This can be confirmed by:
    mkdir temp
    cd temp
    xar -xf ../gfortran-6.1.pkg
    lsbom Bom
    

    Note that the binary will not be present in PATH. So we need to run the following command to make gfortran availalble. <spre> sudo ln -s /usr/local/gfortran/bin/gfortran /usr/local/bin/gfortran

  • Tested in R 4.4.1, R is looking for /opt/gfortran/bin/gfortran.
    GfortranMac.png
  • Note I already had gfortran installed via homebrew for some software. But it is not used by R.
    $ brew uninstall gfortran
    Error: Refusing to uninstall /opt/homebrew/Cellar/gcc/14.1.0_1
    because it is required by gstreamer, numpy, openblas and openvino, which are currently installed.
    You can override this and force removal with:
      brew uninstall --ignore-dependencies gfortran
    
    $ which -a gfortran
    /opt/homebrew/bin/gfortran
    
  • In order to change mess up anything, it is better to call export PATH="/usr/local/bin:$PATH" when we want to install R packages containing fortran code.
  • A useful tool to find R packages containing Fortran code is pkgsearch package. Note
    • The result is not a comprehensive list of packages containing Fortran code.
    • It seems the result is the same as I got from https://www.r-pkg.org
    > pkg_search("Fortran")
    - "Fortran" ------------------------------------ 69 packages in 0.009 seconds -
      #     package      version by                    @ title
      1 100 covr         3.3.2   Jim Hester          12d Test Coverage for Packages
      2  91 inline       0.3.15  Dirk Eddelbuettel    1y Functions to Inline C, ...
      3  43 randomForest 4.6.14  Andy Liaw            2y Breiman and Cutler's Ra...
      4  39 deSolve      1.24    Thomas Petzoldt      4M Solvers for Initial Val...
      5  27 mnormt       1.5.5   Adelchi Azzalini     3y The Multivariate Normal...
      6  26 minqa        1.2.4   Katharine M. Mullen  5y Derivative-free optimiz...
      7  24 rgcvpack     0.1.4   Xianhong Xie         6y R Interface for GCVPACK...
      8  22 leaps        3.0     Thomas Lumley        3y Regression Subset Selec...
      9  21 akima        0.6.2   Albrecht Gebhardt    3y Interpolation of Irregu...
     10  20 rootSolve    1.7     Karline Soetaert     3y Nonlinear Root Finding,...
    
    > more()
    - "Fortran" ------------------------------------ 69 packages in 0.009 seconds -
      #    package    version   by                    @ title
     11 15 BB         2019.10.1 Paul Gilbert        11d Solving and Optimizing L...
     12 15 limSolve   1.5.5.3   Karline Soetaert     2y Solving Linear Inverse M...
     13 14 insideRODE 2.0       YUZHUO PAN           7y insideRODE includes buil...
     14 13 earth      5.1.1     Stephen Milborrow    7M Multivariate Adaptive Re...
     15 13 cluster    2.1.0     Martin Maechler      4M "Finding Groups in Data"...
     16 13 spam       2.3.0.2   ORPHANED            11h SPArse Matrix
     17 12 diptest    0.75.7    Martin Maechler      4y Hartigan's Dip Test Stat...
     18 10 pbivnorm   0.6.0     Brenton Kenkel       5y Vectorized Bivariate Nor...
     19  7 optmatch   0.9.12    Mark M. Fredrickson 17d Functions for Optimal Ma...
     20  7 lsei       1.2.0     Yong Wang            2y Solving Least Squares or...
    
  • Another way to find out packages containing fortran code is to run rsync to download src/contrib directory from CRAN and then use grep to find these packages. Note: the source packages takes about 8GB space (2019-10-28).
    mkdir ~/Downloads/cran
    rsync -avz --delete cran.r-project.org::CRAN/src/contrib/*.tar.gz ~/Downloads/cran/
    rsync -avz --delete cran.r-project.org::CRAN/src/contrib/PACKAGES ~/Downloads/cran/
    rsync -avz --delete cran.r-project.org::CRAN/src/contrib/PACKAGES.gz ~/Downloads/cran/
    cd ~/Downloads/cran
    find . -xtype l -delete # remove broken symbolic links
    
    touch tmp
    for f in *.gz;
    do
      tar -tzvf $f | grep -E "(\.f|\.f90|\.f95)$"  |& tee -a tmp
    done
    

    to check if the tarball contains Fortran 77/90 code.

    Now to see all packages names we can process it in R

    library(magrittr)
    library(stringr)
    x <- read.table("~/Downloads/tmp", stringsAsFactors = F)
    strsplit(x$V6, "/") %>% sapply(function(x) x[1]) %>% unique() # 415 packages
    strsplit(x$V6, "/") %>% sapply(function(x) x[1]) %>% table() %>% sort() # how many Fortran files in each package
    
    str_subset(x$V6, "\\.f90$") %>% strsplit("/") %>% sapply(function(x) x[1]) %>% unique() # Fortran 90 only packages
    str_subset(x$V6, "\\.f95$") %>% strsplit("/") %>% sapply(function(x) x[1]) %>% unique() # Fortran 95 only packages
    
    str_subset(x$V6, "BayesFM") # f95 
    

Misc

Datasets in R packages

https://vincentarelbundock.github.io/Rdatasets/datasets.html

Turn your analysis into a package

Organise your own analysis

Build R package faster using multicore

http://www.rexamine.com/2015/07/speeding-up-r-package-installation-process/

The idea is edit the /lib64/R/etc/Renviron file (where /lib64/R/etc/ is the result to a call to the R.home() function in R) and set:

MAKE='make -j 8' # submit 8 jobs at once

Then build R package as regular, for example,

$ time R CMD INSTALL ~/R/stringi --preclean --configure-args='--disable-pkg-config'

suppressPackageStartupMessages() and .onAttach()

KernSmooth package example.

It is Time for CRAN to Ban Package Ads

suppressPackageStartupMessages(library("dplyr"))

fusen package

Identifying R Functions & Packages Used in GitHub Repos

Identifying R Functions & Packages Used in GitHub Repos: funspotr package

CRANalerts

R-universe

FDA

Successful R-based Test Package Submitted to FDA