Last updated: 2023-09-21
Checks: 1 1
Knit directory: snakemake_tutorial/
This reproducible R Markdown analysis was created with workflowr (version 1.7.1). The Checks tab describes the reproducibility checks that were applied when the results were created. The Past versions tab lists the development history.
The R Markdown file has unstaged changes. To know which version of
the R Markdown file created these results, you’ll want to first commit
it to the Git repo. If you’re still working on the analysis, you can
ignore this warning. When you’re finished, you can run
wflow_publish
to commit the R Markdown file and build the
HTML.
Great! You are using Git for version control. Tracking code development and connecting the code version to the results is critical for reproducibility.
The results in this page were generated with repository version 5757821. See the Past versions tab to see a history of the changes made to the R Markdown and HTML files.
Note that you need to be careful to ensure that all relevant files for
the analysis have been committed to Git prior to generating the results
(you can use wflow_publish
or
wflow_git_commit
). workflowr only checks the R Markdown
file, but you know if there are other scripts or data files that it
depends on. Below is the status of the Git repository when the results
were generated:
Ignored files:
Ignored: .Rproj.user/
Untracked files:
Untracked: code/1.Snakefile
Untracked: code/2.Snakefile
Untracked: code/3.Snakefile
Untracked: code/4.Snakefile
Untracked: code/5.Snakefile
Untracked: code/6.Snakefile
Untracked: code/7.Snakefile
Untracked: code/7.config.yaml
Untracked: code/8.Snakefile
Untracked: code/8.config.yaml
Untracked: code/9.Snakefile
Untracked: code/cluster.yaml
Untracked: code/nohup.out
Untracked: code/run-snakemake8.sh
Untracked: code/run-snakemake9.sh
Untracked: code/snaketutorial.yaml
Untracked: data/chr20.vcf.gz
Untracked: data/chr21.vcf.gz
Untracked: data/chr22.vcf.gz
Unstaged changes:
Modified: analysis/index.Rmd
Modified: analysis/install.Rmd
Modified: analysis/introduction.Rmd
Deleted: code/README.md
Note that any generated files, e.g. HTML, png, CSS, etc., are not included in this status report because it is ok for generated content to have uncommitted changes.
These are the previous versions of the repository in which changes were
made to the R Markdown (analysis/install.Rmd
) and HTML
(docs/install.html
) files. If you’ve configured a remote
Git repository (see ?wflow_git_remote
), click on the
hyperlinks in the table below to view the files as they were in that
past version.
File | Version | Author | Date | Message |
---|---|---|---|---|
html | 5757821 | Jean Morrison | 2023-09-21 | build site |
Rmd | 7957b05 | Jean Morrison | 2023-09-21 | add installation instructions |
html | 7957b05 | Jean Morrison | 2023-09-21 | add installation instructions |
You should do the steps in this section before the day of the tutorial. If you run into an issue, post an issue. That way others who have the same issue will be able to see it. You may find that it is easiest to complete this tutorial on one of the institutional clusters because we will make use of some bioinformatic software that is already installed in those places. However, you can also do it on a personal computer and links to install the required software are given below. The steps you will perform in this section are:
I strongly recommend installing Snakemake via Conda/Mamba. Conda is a tool for managing software dependencies (Mamba is an alternative to Conda). If you install Snakemake via Conda, Conda will manage all of the software dependencies for you and installation will most likely go smoothly. If you install via pip instead, you may run into issues. Full installation instructions can be found on the Snakemake documentation page here, where they recommend using Mamba because it is more efficient. I have included installation instructions for miniconda below. However, you could use any Conda or Mamba installation you like.
If you already have a version of Conda or Mamba installed, skip this step.
The following instructions will install miniconda according to the instructions on the miniconda website. You could also use the graphical installer with instructions here.
On Mac: Open a terminal and navigate to your home directory. Then, type these commands.
mkdir -p ~/miniconda3
curl https://repo.anaconda.com/miniconda/Miniconda3-latest-MacOSX-arm64.sh -o ~/miniconda3/miniconda.sh
bash ~/miniconda3/miniconda.sh -b -u -p ~/miniconda3
rm -rf ~/miniconda3/miniconda.sh
Now initialize miniconda
~/miniconda3/bin/conda init bash
~/miniconda3/bin/conda init zsh
On Linux (e.g. one of the clusters or a Linux operating system on a personal computer): Open a terminal and navigate to your home directory. Then, type these commands.
mkdir -p ~/miniconda3
wget https://repo.anaconda.com/miniconda/Miniconda3-latest-Linux-x86_64.sh -O ~/miniconda3/miniconda.sh
bash ~/miniconda3/miniconda.sh -b -u -p ~/miniconda3
rm -rf ~/miniconda3/miniconda.sh
Now initialize miniconda
~/miniconda3/bin/conda init bash
~/miniconda3/bin/conda init zsh
Now close your terminal and open a new terminal window. If you are
working on the cluster, close your ssh connection and then log back in.
At this point the string (base)
should have appeared at the
beginning of the prompt line in the terminal. For me, this looks
like
(base) [jvmorr@gl-login2 ~]$
On either Mac or Linux, in the terminal type
conda create -c conda-forge -c bioconda -n snakemake snakemake
This installation may take several minutes. There will be a prompt asking you to confirm installation (say yes).
Now test your installation. To activate the Conda environment that Snakemake is installed in type
conda activate snakemake
You should now see (snakemake)
at the beginning of the
prompt line instead of (base)
. To make sure Snakemake is
installed properly, type
snakemake --help
You should see the help page print to the screen.
You will need some way to edit text files. Snakemake is a python-based language so it is very picky about punctuation, spaces, and white space characters. You will need a text editor that only deposits the characters you mean to have in the document.
Here are some options that will work:
nano
.Regardless of what you are using, spend a few moments to make sure you are comfortable editing text files in the system you will be working in.
In this tutorial we will use bcftools, Plink2, and R.
All of these programs are already installed. To access them, you will need to load the modules. You will need to do this every time you open a new terminal window.
module load bcftools
module load plink
module load R
Check the versions of each of these programs. I found these results
bcftools --version
bcftools 1.17
Using htslib 1.17
Copyright (C) 2023 Genome Research Ltd.
License Expat: The MIT/Expat license
This is free software: you are free to change and redistribute it.
There is NO WARRANTY, to the extent permitted by law.
plink2 --version
PLINK v2.00a4LM 64-bit Intel (9 Jan 2023)
R --version
R version 4.2.2 (2022-10-31) -- "Innocent and Trusting"
Copyright (C) 2022 The R Foundation for Statistical Computing
Platform: x86_64-pc-linux-gnu (64-bit)
R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under the terms of the
GNU General Public License versions 2 or 3.
For more information about these matters see
https://www.gnu.org/licenses/.
All of these programs are already installed and you do not need to do anything to access them. Go ahead and check the versions to make sure they are running for you.
bcftools --version
bcftools 1.17
Using htslib 1.17
Copyright (C) 2023 Genome Research Ltd.
License Expat: The MIT/Expat license
This is free software: you are free to change and redistribute it.
There is NO WARRANTY, to the extent permitted by law.
plink2 --version
PLINK v2.00a3LM 64-bit Intel (20 Apr 2021)
R --version
R version 4.3.1 (2023-06-16) -- "Beagle Scouts"
Copyright (C) 2023 The R Foundation for Statistical Computing
Platform: x86_64-pc-linux-gnu (64-bit)
R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under the terms of the
GNU General Public License versions 2 or 3.
For more information about these matters see
https://www.gnu.org/licenses/.
All of these programs are already installed. To access them, you need
to load the modules. You must first load the Bioinformatics
module group and then you can load the modules for bcftools and Plink2.
You will need to do this every time you open a new terminal window.
module load Bioinformatics
module load bcftools
module load plink
module load R
Check the versions:
bcftools --version
bcftools 1.12
Using htslib 1.12
Copyright (C) 2021 Genome Research Ltd.
License Expat: The MIT/Expat license
This is free software: you are free to change and redistribute it.
There is NO WARRANTY, to the extent permitted by law.
plink2 --version
PLINK v2.00a2LM 64-bit Intel (20 Oct 2019)
R --version
R version 4.3.1 (2023-06-16) -- "Beagle Scouts"
Copyright (C) 2023 The R Foundation for Statistical Computing
Platform: x86_64-pc-linux-gnu (64-bit)
R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under the terms of the
GNU General Public License versions 2 or 3.
For more information about these matters see
https://www.gnu.org/licenses/.
Create a directory where you will do this tutorial. You can do this from a terminal by typing
mkdir /my/new/directory
where you substitute the name of your new directory for
/my/new/directory
. For example, I am working on GreatLakes
and I want to do the tutorial in my home directory, so I used
mkdir /home/jvmorr/snakemake_tutorial
You can call your directory whatever you want.
Navigate into your new directory and clone the github directory for the tutorial.
cd snakemake_tutorial
git clone https://github.com/jean997/snakemake_tutorial.git
You will now see a directory called snakemake_tutorial
in your current directory. Verify this by typing ls
. Inside
the directory, you will see the files used to create this website as
well as some directories with material we will use. Check this by
typing
ls snakemake_tutorial
The material you need to complete the tutorial is in the
data/
directory and the code/
directory. We
can get rid of all of the rest. Lets move these two directories up one
level and then delete everything else.
mv snakemake_tutorial/data .
mv snakemake_tutorial/code .
rm -rf snakemake_tutorial