## This script contains all commands executed in the PROJECT wqr487 and can be run again using the ASAP_run docker (https://hub.docker.com/layers/fabdavid/asap_run) echo '*******************Reproducing analysis of PROJECT wqr487 / ASAP23**********************' echo '***************************************************************************************' ## CONFIGURATION (edit below to match your machine; lines until the separator) export ASAP_PROJECTS_DIR=/asap_projects ## change this to write analysis results there (there will be subdirectory for each project key). export LOOM_DIR=$ASAP_PROJECTS_DIR/loom_files export ASAP_DATA_DB_HOST=localhost; export ASAP_DATA_DB_PORT=5432 export PSQL_DIR=/usr/pgsql-10/bin ## ========================================================= export PROJECT_DIR=$ASAP_PROJECTS_DIR/wqr487 ## Pull Docker images (must run before any docker run in this script) docker pull fabdavid/asap_run:v5 ## Host LOOM staging directory (inside Docker volume) docker run --entrypoint '/bin/sh' --rm -v $ASAP_PROJECTS_DIR:$ASAP_PROJECTS_DIR fabdavid/asap_run:v5 -c "mkdir -p $LOOM_DIR; chmod 777 $LOOM_DIR" echo 'This project is PUBLIC => Nothing to do' ## Local PostgreSQL: create ASAP data database and load dump if missing if ! psql -lqt | cut -d \| -f 1 | grep -qw asap_data_v5; then echo 'Create database asap_data_v5'; echo '$PSQL_DIR/createdb -p $ASAP_DATA_DB_PORT asap_data_v5'; $PSQL_DIR/createdb -p $ASAP_DATA_DB_PORT asap_data_v5; echo 'wget -qO - https://asap.epfl.ch/dumps/asap_data_v5.sql.gz | gunzip | grep -v \'AS integer\' | $PSQL_DIR/psql -p $ASAP_DATA_DB_PORT asap_data_v5'; wget -qO - https://asap.epfl.ch/dumps/asap_data_v5.sql.gz | gunzip | grep -v 'AS integer' | $PSQL_DIR/psql -p $ASAP_DATA_DB_PORT asap_data_v5; fi ## Project directory on the shared volume docker run --entrypoint '/bin/sh' --rm -v $ASAP_PROJECTS_DIR:$ASAP_PROJECTS_DIR fabdavid/asap_run:v5 -c "mkdir -p $PROJECT_DIR" ## Step output directories (one folder per pipeline step that has runs) docker run --entrypoint '/bin/sh' --rm -v $ASAP_PROJECTS_DIR:$ASAP_PROJECTS_DIR fabdavid/asap_run:v5 -c "mkdir -p $PROJECT_DIR/parsing/ && mkdir -p $PROJECT_DIR/normalization/ && mkdir -p $PROJECT_DIR/markers/ && mkdir -p $PROJECT_DIR/marker_enrich/" ## Parsed LOOM file (public: wget; private: place file then symlink as below) echo 'Loading parsed Loom file...' docker run --entrypoint '/bin/sh' --rm -v $ASAP_PROJECTS_DIR:$ASAP_PROJECTS_DIR fabdavid/asap_run:v5 -c "wget -qO $PROJECT_DIR/parsing/output.loom 'https://asap.epfl.ch/projects/wqr487/get_file?filename=parsing/output.loom'" ## Re-execute each recorded run (parsing step is skipped; LOOM is already in place) ## ---------------------------------------------------------------- ## Run 73704 Normalization (Normalization #1 asap_seurat) ## ---------------------------------------------------------------- ## Ensure output directory exists docker run --entrypoint '/bin/sh' --rm -v $ASAP_PROJECTS_DIR:$ASAP_PROJECTS_DIR fabdavid/asap_run:v5 -c "mkdir -p $PROJECT_DIR/normalization/73704/" ## Running Normalization [73704] [Normalization #1 asap_seurat] (input_matrix:parsing scale_factor:10000) echo '-> Running Normalization [73704] [Normalization #1 asap_seurat] (input_matrix:parsing scale_factor:10000)' ## Command docker run -v /data/asap2_test:/data/asap2_test --name asap_dev_73704 --net=host -e HOST_USER_ID=$(id -u) -e HOST_USER_GID=$(id -g) --entrypoint '/bin/sh' --rm -v $ASAP_PROJECTS_DIR:$ASAP_PROJECTS_DIR fabdavid/asap_run:v5 -c "sh -c 'java -jar /srv/ASAP.jar -T Normalization -loom /data/asap2/users/1/wqr487/parsing/output.loom -o /data/asap2/users/1/wqr487/normalization/73704/output.json -oAnnot /layers/norm_1_asap_seurat -scaleFactor 10000 1> /data/asap2/users/1/wqr487/normalization/73704/exec.out 2> /data/asap2/users/1/wqr487/normalization/73704/exec.err'" ## ---------------------------------------------------------------- ## Run 137307 Find markers (Find markers #1 asap_markers) ## ---------------------------------------------------------------- ## Ensure output directory exists docker run --entrypoint '/bin/sh' --rm -v $ASAP_PROJECTS_DIR:$ASAP_PROJECTS_DIR fabdavid/asap_run:v5 -c "mkdir -p $PROJECT_DIR/markers/137307/" ## Running Find markers [137307] [Find markers #1 asap_markers] () echo '-> Running Find markers [137307] [Find markers #1 asap_markers] ()' ## Command docker run -v /data/asap2_test:/data/asap2_test --name asap_dev_137307 --net=host -e HOST_USER_ID=$(id -u) -e HOST_USER_GID=$(id -g) --entrypoint '/bin/sh' --rm -v $ASAP_PROJECTS_DIR:$ASAP_PROJECTS_DIR fabdavid/asap_run:v5 -c "sh -c 'java -jar /srv/ASAP.jar -T FindMarkers --loom /data/asap2/users/1/wqr487/parsing/output.loom -o /data/asap2/users/1/wqr487/markers/137307 --iAnnot /col_attrs/annotation --id 471403 1> /data/asap2/users/1/wqr487/markers/137307/exec.out 2> /data/asap2/users/1/wqr487/markers/137307/exec.err'" ## ---------------------------------------------------------------- ## Run 137308 Marker enrichment (Marker enrichment #2 asap_marker_enrichment) ## ---------------------------------------------------------------- ## Ensure output directory exists docker run --entrypoint '/bin/sh' --rm -v $ASAP_PROJECTS_DIR:$ASAP_PROJECTS_DIR fabdavid/asap_run:v5 -c "mkdir -p $PROJECT_DIR/marker_enrich/137308/" ## Running Marker enrichment [137308] [Marker enrichment #2 asap_marker_enrichment] () echo '-> Running Marker enrichment [137308] [Marker enrichment #2 asap_marker_enrichment] ()' ## Command docker run -v /data/asap2_test:/data/asap2_test --name asap_dev_137308 --net=host -e HOST_USER_ID=$(id -u) -e HOST_USER_GID=$(id -g) --entrypoint '/bin/sh' --rm -v $ASAP_PROJECTS_DIR:$ASAP_PROJECTS_DIR fabdavid/asap_run:v5 -c "sh -c 'java -jar /srv/ASAP.jar -T MarkerEnrichment -i /data/asap2/users/1/wqr487/markers/137307 -o /data/asap2/users/1/wqr487/markers/137308 --genesets 671,672,673,2371,3138 -h $ASAP_DATA_DB_HOST:$ASAP_DATA_DB_PORT/asap_data_v5 1> /data/asap2/users/1/wqr487/markers/137308/exec.out 2> /data/asap2/users/1/wqr487/markers/137308/exec.err'" ## ---------------------------------------------------------------- ## Run 343173 Find markers (Find markers #2 asap_markers) ## ---------------------------------------------------------------- ## Ensure output directory exists docker run --entrypoint '/bin/sh' --rm -v $ASAP_PROJECTS_DIR:$ASAP_PROJECTS_DIR fabdavid/asap_run:v5 -c "mkdir -p $PROJECT_DIR/markers/343173/" ## Running Find markers [343173] [Find markers #2 asap_markers] (input_matrix:parsing) echo '-> Running Find markers [343173] [Find markers #2 asap_markers] (input_matrix:parsing)' ## Command docker run -v /data/asap2_test:/data/asap2_test --name asap_dev_343173 --net=host -e HOST_USER_ID=$(id -u) -e HOST_USER_GID=$(id -g) --entrypoint '/bin/sh' --rm -v $ASAP_PROJECTS_DIR:$ASAP_PROJECTS_DIR fabdavid/asap_run:v5 -c "sh -c 'java -jar /srv/ASAP.jar -T FindMarkers --loom /data/asap2/users/1/wqr487/parsing/output.loom -o /data/asap2/users/1/wqr487/markers/343173 --iAnnot /col_attrs/annotation --id 471403 --is_count_table true 1> /data/asap2/users/1/wqr487/markers/343173/exec.out 2> /data/asap2/users/1/wqr487/markers/343173/exec.err'" ## ---------------------------------------------------------------- ## Run 343174 Marker enrichment (Marker enrichment #3 asap_marker_enrichment) ## ---------------------------------------------------------------- ## Ensure output directory exists docker run --entrypoint '/bin/sh' --rm -v $ASAP_PROJECTS_DIR:$ASAP_PROJECTS_DIR fabdavid/asap_run:v5 -c "mkdir -p $PROJECT_DIR/marker_enrich/343174/" ## Running Marker enrichment [343174] [Marker enrichment #3 asap_marker_enrichment] () echo '-> Running Marker enrichment [343174] [Marker enrichment #3 asap_marker_enrichment] ()' ## Command docker run -v /data/asap2_test:/data/asap2_test --name asap_dev_343174 --net=host -e HOST_USER_ID=$(id -u) -e HOST_USER_GID=$(id -g) --entrypoint '/bin/sh' --rm -v $ASAP_PROJECTS_DIR:$ASAP_PROJECTS_DIR fabdavid/asap_run:v5 -c "sh -c 'java -jar /srv/ASAP.jar -T MarkerEnrichment -i /data/asap2/users/1/wqr487/markers/343173 -o /data/asap2/users/1/wqr487/markers/343174 --genesets 671,672,673,2371,3138 -h $ASAP_DATA_DB_HOST:$ASAP_DATA_DB_PORT/asap_data_v5 1> /data/asap2/users/1/wqr487/markers/343174/exec.out 2> /data/asap2/users/1/wqr487/markers/343174/exec.err'" ## ---------------------------------------------------------------- ## Run 384666 Find markers (Find markers #3 asap_markers) ## ---------------------------------------------------------------- ## Ensure output directory exists docker run --entrypoint '/bin/sh' --rm -v $ASAP_PROJECTS_DIR:$ASAP_PROJECTS_DIR fabdavid/asap_run:v5 -c "mkdir -p $PROJECT_DIR/markers/384666/" ## Running Find markers [384666] [Find markers #3 asap_markers] (input_matrix:parsing) echo '-> Running Find markers [384666] [Find markers #3 asap_markers] (input_matrix:parsing)' ## Command docker run -v /data/asap2_test:/data/asap2_test --name asap_dev_384666 --net=host -e HOST_USER_ID=$(id -u) -e HOST_USER_GID=$(id -g) --entrypoint '/bin/sh' --rm -v $ASAP_PROJECTS_DIR:$ASAP_PROJECTS_DIR fabdavid/asap_run:v5 -c "sh -c 'java -jar /srv/ASAP.jar -T FindMarkers --loom /data/asap2/users/1/wqr487/parsing/output.loom -o /data/asap2/users/1/wqr487/markers/384666 --iAnnot /col_attrs/sample_id --id 471370 --is_count_table true 1> /data/asap2/users/1/wqr487/markers/384666/exec.out 2> /data/asap2/users/1/wqr487/markers/384666/exec.err'" ## ---------------------------------------------------------------- ## Run 384667 Marker enrichment (Marker enrichment #4 asap_marker_enrichment) ## ---------------------------------------------------------------- ## Ensure output directory exists docker run --entrypoint '/bin/sh' --rm -v $ASAP_PROJECTS_DIR:$ASAP_PROJECTS_DIR fabdavid/asap_run:v5 -c "mkdir -p $PROJECT_DIR/marker_enrich/384667/" ## Running Marker enrichment [384667] [Marker enrichment #4 asap_marker_enrichment] () echo '-> Running Marker enrichment [384667] [Marker enrichment #4 asap_marker_enrichment] ()' ## Command docker run -v /data/asap2_test:/data/asap2_test --name asap_dev_384667 --net=host -e HOST_USER_ID=$(id -u) -e HOST_USER_GID=$(id -g) --entrypoint '/bin/sh' --rm -v $ASAP_PROJECTS_DIR:$ASAP_PROJECTS_DIR fabdavid/asap_run:v5 -c "sh -c 'java -jar /srv/ASAP.jar -T MarkerEnrichment -i /data/asap2/users/1/wqr487/markers/384666 -o /data/asap2/users/1/wqr487/markers/384667 --genesets 671,672,673,2371,3138 -h $ASAP_DATA_DB_HOST:$ASAP_DATA_DB_PORT/asap_data_v5 1> /data/asap2/users/1/wqr487/markers/384667/exec.out 2> /data/asap2/users/1/wqr487/markers/384667/exec.err'" ## ---------------------------------------------------------------- ## Run 676978 Find markers (Find markers #4 asap_markers) ## ---------------------------------------------------------------- ## Ensure output directory exists docker run --entrypoint '/bin/sh' --rm -v $ASAP_PROJECTS_DIR:$ASAP_PROJECTS_DIR fabdavid/asap_run:v5 -c "mkdir -p $PROJECT_DIR/markers/676978/" ## Running Find markers [676978] [Find markers #4 asap_markers] (input_matrix:parsing) echo '-> Running Find markers [676978] [Find markers #4 asap_markers] (input_matrix:parsing)' ## Command docker run -v /data/asap2_test:/data/asap2_test --name asap_dev_676978 --net=host -e HOST_USER_ID=$(id -u) -e HOST_USER_GID=$(id -g) --entrypoint '/bin/sh' --rm -v $ASAP_PROJECTS_DIR:$ASAP_PROJECTS_DIR fabdavid/asap_run:v5 -c "sh -c 'java -jar /srv/ASAP.jar -T FindMarkers --loom /data/asap2/users/1/wqr487/parsing/output.loom -o /data/asap2/users/1/wqr487/markers/676978 --iAnnot /col_attrs/Clustering_Annotation --id 471393 --is_count_table true 1> /data/asap2/users/1/wqr487/markers/676978/exec.out 2> /data/asap2/users/1/wqr487/markers/676978/exec.err'"