This repository has two purposes:
- Template for eDNA analysis and visualization
- House current analysis versions
The motivation is to standardize and document data analysis of ongoing eDNA monitoring in Palau. The aim is to reduce capacity required to analyize data and make workflow reproducible over monitoring efforts. We aim to prevent the loss of knowledge and proceedure as monitoring project grows and ages.
The directory structure and files:
├── data
│ ├── raw
│ └── processed
├── images
├── products
├── renv
│ ├── activate.R
│ └── setttings.json
├── scripts
│ └── color_palette.R
├── .Rprofile
├── .gitignore
├── PalaueDNA.Rproj
├── PalaueDNA_analysis_Nov2021.qmd
├── PalaueDNA_analysis_template.qmd
├── PalaueDNA_analysis_template.html
├── README.md
└── renv.lock
Folder descriptions:
data/
contains 2 subfolders:raw/
andprocessed/
.- put your data in the
raw/
folder - the analysis code will produce data products that are saved into the
processed/
folder
- put your data in the
products/
folder contains figures and maps created and saved by the analysisrenv/
stores the project package version control- do not need to directly interact with these files - they are used in several
renv::
package commands
- do not need to directly interact with these files - they are used in several
scripts/
folder contains short pieces of R code that do specific things (i.e. scripts)- can be run within the analysis
File Descirptions:
.Rprofile
stores Rstudio preferences for running code (hidden file).gitignore
list of file that git will not pay attention to or trackPalaueDNA.Rproj
R project container all code and files run in this mini environmentPalaueDNA_analysis_[...].qmd
Analysis files for specific sampling events (MonthYear)PalaueDNA_analysis_template.qmd
Template for analysis and visualization. Make a copy of this file and rename copy to start a new analysis. Update this file to make changes for future analyses.PalaueDNA_analysis_template.html
The rendered output created byPalaueDNA_analysis_template.qmd
for easy reference of report. Need to open in browser windowREADME.md
contains project description and instruction in markdownrenv.lock
record of package dependencies and versions used to construct this project.
- Copy this repository to your local machine (choose one method/bullet)
- Download Software from Zenodo --> [paste future DOI badge here]
- In the command line:
# run in command line shell
git clone https://github.com/closek/Palau-eDNA-Project.git
cd yourprojectname
- Github webpage
Repo URL
:- click green
<> Code
tab with drop down menu, selectLocal
tab, clickDownload ZIP
- open
.zip
file on local computer
- click green
- Open
.Rproj
in Rstudio or your R environment of choice - Install
renv
if not already installed (usually a one-time setup on a new system:
# Run in R console
install.packages("renv")
- Activate
renv
project environment- ensures that
renv
is actively managing the library paths for your project.
- ensures that
# Run in R console
renv::activate()
- Restore Dependencies
- install project dependencies as specified in the
renv.lock
file and installs the exact versions of the packages that the project depends on
- install project dependencies as specified in the
# Run in R console
renv::restore()
- Work with project
- after these steps, your copy of the analysis R environment should be sest up with all the necessary packages and you can start working on the project.
- The initial activation and restoration manual steps taken above will only be needed to set up the project for the first time
We used the renv
package to manage & record package versions. This records the version of R, package versions, and their dependencies into a file renv.lock
at the root of this .Rproj
. The purpose of this is to allow users on different computer setups and in the future to reproduce the results of this project in the same way. This is because different package versions can behave differently version to version, and even introduce errors or produced different results. By using the same exact set of package versions that the authors used to write the code, the same results can be reproduced and prevent unintended errors.
Renv
creates a separate custom project library that is separate from the system library typically used when the library()
function is called. This means that when you recreate the renv
project library by calling renv::restore()
you will likely need to install many packages. Many may be already installed in your system library, but they will need to be installed again into this custom renv
project library with the exact version recorded in the renv.lock
file. All files, folders, and scripts within the .Rproj
will share the renv
project library.
- For more information about
renv
and how to add/update therenv
project library -> https://rstudio.github.io/renv/articles/renv.html . - Note You may need to download a different version of R to work with this project
This analysis template is a collaboration between @closek, @theamarks, and the Palau International Coaral Reef Center
MIT License
Copyright (c) 2023 Collin Colsek & Althea Marks
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.