Intro to Programming
When coding, we also want to have coding buddies. This will be something we explore in the future.
Intro to the Command Line
Client Access
The command line is where a lot of bioinformatics work is done. You can find setup options on the HPC wiki here.
While Mac users already have the terminal application on their computer, there will be some missing commands. See the Command Line Personalization section on this page for more.
You will also want to install a free FTP client such as WinSCP, CyberDuck or Filezilla to have a GUI to move files to and from the server and your computer. Be sure to use the SFTP option for connection type.
Logging in
If this is your first time logging in, follow the steps listed on the HPC wiki here.
Otherwise, in your computer’s terminal, run the following command:
$ ssh <PMACS_ID>@consign.pmacs.upenn.edu
Make sure to insert your own PMACS ID to replace
If you are not asked for your password and the request eventually times out, make sure that you are connected to the VPN.
Command Line Personalization
In your home directory is a file called .bashrc on the HPC server. Your .bashrc file is run whenever you start a new terminal on the server by logging in and run before all of your job submissions. Here are some suggested lines:
if [ $HOSTNAME != "consign.hpc.local" ] &&
[ $HOSTNAME != "mercury.pmacs.upenn.edu" ] &&
[ $HOSTNAME != "hpclogin.pmacs.upenn.edu" ] &&
[ $HOSTNAME != "hpclogin1" ]; then
module load R4.3
module load python/3.11
module load sratoolkit/3.1.0
module load curl
module load fastqc/0.11.7
fi
This way, we are all working on the same version of R and python and so that you can use some commonly used tools without thinking about it in the future.
There is some software that we’ve locally installed for the lab, and you can use it by adding this to your .bashrc file in the above if
statement:
if [ $HOSTNAME != "consign.hpc.local" ] &&
[ $HOSTNAME != "mercury.pmacs.upenn.edu" ] &&
[ $HOSTNAME != "hpclogin.pmacs.upenn.edu" ] &&
[ $HOSTNAME != "hpclogin1" ]; then
# ...
LAB_SOFTWARE="/project/hipaa_ycheng11lab/software/"
SOFTBIN="${LAB_SOFTWARE}/bin/"
PATH=$SOFTBIN:$PATH
export PATH # This line goes after all of your other PATH stuff
export CPATH=$LAB_SOFTWARE/include:$CPATH
export LD_LIBRARY_PATH=$LAB_SOFTWARE/lib:$LD_LIBRARY_PATH
export LIBRARY_PATH=$LAB_SOFTWARE/lib:$LIBRARY_PATH
export PYTHONPATH=/project/hipaa_ycheng11lab/software/python/lib/python3.11/site-packages/:/project/hipaa_ycheng11lab/software/python/bin/:$PYTHONPATH
# ...
fi
While much of your time will be on the server, you may find the need to use the terminal on your own system.
Mac’s should install homebrew
, a synonymous program to apt-get
, yum
or pip
that will make installing other things easier. Run this command in your terminal:
/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"
Follow the prompts and then test it out by installing a tool such as wget
. This command can download files from the internet and is installed like this on MacOS
brew install wget
This applies for both Mac and Windows users, but instructions are here for Windows. In MobaXterm, you can go to settings -> configurations and under Terminal Features you can set logging to printable output with timestamps. There have been countless times when having an exact image of commands I ran with timestamps have helped me figure something out.
You can also create SSH sessions for Mercury and Consign on MobaXterm. With this, you can right click on the session, edit session and put in Advanced SSH Settings -> Execute Command newgrp hipaa_ycheng11lab
. This will make it so that files you create will be fully available to members of our lab.
Interactive Nodes
For the next two sections, the directions will mirror those in the HPC User Guide. I would suggest looking through the guide for more information.
If you have a compute-intensive job, you should use an interactive node to run it rather than running it directly on the cluster head node (consign.pmacs.upenn.edu).
To request an interactive node, run the following command.
$ bsub -Is bash
Most likely, you will want to request more memory or cores for this larger job. Here is an example:
$ bsub -n 4 -R "rusage[mem=75000] span[hosts=1]" -M 75000 -Is bash
For descriptions of the added parameters, refer to the table in the Submitting Jobs section.
If you are requesting an interactive node to use a Jupyter notebook within the node, there are additional steps. The process below is for Mac users. For other devices, follow the steps here.
- Navigate to the root directory of your work. All of the files you need access to should be here or in a subdirectory.
-
Within an interactive node with the necessary resources requested, run the following command:
[
@node### ~]$ jupyter notebook --ip $(hostname) -
Next, you need to setup an SSH tunnel to the Jupyter notebook session in a another local terminal with the following command:
$ ssh -L 8888:node###:8888 <your_username>@consign.pmacs.upenn.edu
Make sure to change ### and
to the node name and your username, respectively. Sometimes, the notebook's port is not 8888, so be aware of that. - You should be able to get to your jupyter notebook session by accessing the localhost specific link generated in the output of the
jupyter notebook --ip $(hostname)
command. The link that starts with “http://127.0.0.1”. Note that this is a unique URL for this session only.
Submitting Jobs
To run shell scripts, the most basic way is to run the following command. $ bsub
$ bsub -J IHRA_markers -e IHRA_markers.%J.error -n 8 -R -M 1024 'rusage[mem=1024] span[hosts=1]' bash IHRA_gene_marker_predicates.bash
Descriptions of parameters:
-J IHRA_markers LSF job name -o IHRA_markers.%J.out Name of the job output file (necessary to receive an output file) -e IHRA_markers.%J.error Name of the job error file (necessary to receive an error file) -n 8 Number of cores requested -M 1024 MB of memory for this job -R ‘rusage[mem=1024] span[hosts=1]’ Make sure the job’s assigned node has enough memory and that all cores are on the same worker node bash Job type IHRA_gene_marker_predicates.bash Script name
Alternatively, to run LSF job scripts, run the following command:
$ bsub < <script_name>
The job’s parameters are in the header of the file itself. Here is a generic one of these scripts:
#!/bin/bash
#BSUB -J JNAME
#BSUB -o JNAME.%J.out
#BSUB -e JNAME.%J.error
#BSUB -n 1
#BSUB -M 10
#BSUB -R "rusage[mem=10] span[hosts=1]"
#BSUB -notify done # Whenever the job finishes, email
#BSUB -u <username>@pennmedicine.upenn.edu # User's email, both this and above are required for emails
echo "hello"
Intro to Python
Intro to R
Quite a lot of biostat packages are run in R for a few reasons:
- CRAN
- Statistics oriented syntax
- Rstudio
CRAN stands for the “Comprehensive R Archive Network” and is where you are likely to find additional R code for your use. By simply performing installPackages(“magittr”)
in the R interpretter, R will go to CRAN through your internet connection and install that package for you. All you have to do is library(magittr)
all of the magittr package is available to you!
R is statistically oriented in quite a few different ways. The base package that is loaded for you when you open R contains native operators for linear algebra and set operations, such as %in% for testing set intersection and %o% for outer products. It has a base system of plotting and quickly creating test data, such as the built-in datasets and the r* distribution functions.
Rstudio is the IDE that has everything you would want to run, troubleshoot and profile code. It allows you to run your code right from the source editor. Feel free to customize the look of your Rstudio to fit your needs.
If you are using a large dataset, remember that the Rstudio server that you should have access has a limit of 20GB of memory. If you need to use more than that, you must use an interactive session with enough memory and use the command line. If you figure out how to run your own Rstudio server on the HPC to tunnel into, reach out to Jeff at Jeffrey.Maurer@pennmedicine.upenn.edu or reach out less formally in Slack.