Skip to content

Latest commit

 

History

History
248 lines (167 loc) · 9.11 KB

README.md

File metadata and controls

248 lines (167 loc) · 9.11 KB

Docker Image CI

hadaca 3 - Health Data Challenge

Purpose

HADACA 3 is the third edition of a Health Data Challenge, organized by the PEPR Santé Numérique (M4DI axis) and the University Grenoble-Alpes data challenges hub (TIMC, IAB and GRICAD). It will take place from December 2nd to 6th, 2024,

The goal of this challenge is to explore and potentially discover new methods to resolve deconvolution problems.

The HADACA 3 challenge begins with a bulk dataset in the form of a matrix, containing the expression profiles of k different cells. Participants are required to retrieve the expression type of each cell using any available methods, such as machine learning.

Participants will submit their method in the form of an R program, which will then be ingested and scored using a ground truth matrix. In the final phase of this challenge, the best method submitted by each participant will be evaluated on a different dataset. The aim of this final phase is to ensure the method is not overfitted.

Conda environement

Set up your conda environement as follow:

TODO: update the following chunk.

conda create -n hadaca3_env
conda activate hadaca3_env
#mamba install -y -c anaconda -c bioconda -c conda-forge -c r r-base snakemake=7.32.4 python=3.9 r-rmarkdown r-prettydoc r-seurat r-clue bioconductor-complexheatmap r-viridis r-magrittr r-dplyr r-nnls graphviz r-tictoc  graphviz python-kaleido tenacity plotly r-bisquerna r-extraDistr r-MASS r-EPIC

Generate smoothie challenge

cd phase-0-smoothie
sh generate_bundle_smoothie.sh 

Build hadaca3_pyr docker image

The docker named hadaca3_pyr also has impleted python as well.

cd ~/projects/hadaca3/docker/codabench_hadaca3_pyr

sudo docker build -t hombergn/hadaca3_pyr .

#see existing images 
sudo docker images 


# log in on docker hub (the username here is hombergn)
sudo docker login -u  hombergn

# rename image if necessary  
#sudo docker tag light_hadaca hombergn/hadaca3_light 

#upload on dockerhub
sudo docker push hombergn/hadaca3_light:latest
sudo docker push hombergn/hadaca3_pyr:latest
sudo docker push hombergn/hadaca3_final:latest

#Single command to build and push. 
sudo docker build -t hombergn/hadaca3_pyr .  && sudo docker push hombergn/hadaca3_pyr:latest

Scripts availabale and guide:

Summary of scripts available:

  • generate_fake_data.R: R script to generates fake data. It does not take any argument.
  • clean.sh: Bash script that deletes temporary file and all data.
  • generate_data.sh: Bash script that either take one argument and generates the real data or no argument and execute generate_fake_data.R.
  • prepare2score_locally.sh: Bash script that generates temporary path and folder used by the ingestion and scoring program when executed locally. It depends on clean.sh and generate_data.sh and therefor takes one optionnal argument to either generates real data or fake.
  • automated_docker_test.sh: Bash script that test the ingestion and scoring program locally with the docker container. It takes one optionnal argument to either generates real data or fake and executes the following steps:
    1. Build the docker image.
    2. Generates data with generate_data.sh.
    3. Run the submission script to generates a submission program. Note: It will create and use the latest Program.R inside the submissions folder of the local startink_kit folder.
    4. Prepare the data to be executed locally with; prepare2score_locally.sh.
    5. Execute the ingestion program on docker
    6. Execute the scoring program on docker with the prediction file created with the previous step.
    7. Test the existence of the output file accuracy.rds. If this file exist: it is a sucess, otherwise it is a failure and the script stop here. In that case the file logs contain potentially usefull informations to debug.
    8. If the previous test was a sucess, clean.sh is exectued.
  • generate_bundle.sh: Bash script that will generates data and creates bundle.zip with all its dependancies. bundle.zip is ready to be uploaded on Codabench, under benchmark, management and then the green bouton upload. It also takes one optionnal argument to either generates real or fake data.

Download git:

cd ~ && mkdir projects
cd ~/projects
git clone [email protected]:bcm-uga/hadaca3.git
cd hadaca3

Generate a submission:

cd starting_kit
Rscript submission_script.R

you can generate a submission on a docker : sudo docker run -it --rm --name my-running-script -v "$PWD":/usr/src/myapp -w /usr/src/myapp hombergn/hadaca3_pyr python submission_script.py

or with :

sudo docker run -v .:/hadaca3 -w /hadaca3 hombergn/hadaca3_pyr Rscript submission_script.R

Run ingestion and scoring locally:

/!\ This local test no longer works when using sourced files in program.R that call sub_programm in the folder modules.

Once "submissions" folder created by the submission script inside starting kit, you can test locally the ingestion and scoring program.

cd ~/projects/hadaca3/phase-1_2_3
sh prepare2score_locally.sh

Rscript ingestion_program/ingestion.R \
    ingestion_program \
    input_data \
    test_output/res \
    starting_kit/submissions

Rscript scoring_program/scoring.R  \
    test_output \
    test_output \
    scoring_program


cd test_output
mkdir -p input/ref
mkdir -p input/res
cd input
cp ../ref/groundtruth_smoothies_fruits.rds ref/
cp ../res/prediction.rds res/


Rscript -e 'rmarkdown::render("../../scoring_program/detailed_results.Rmd")'
  

Build bundle and deploy on codabench

The bundle bundle.zip is created with the script generate_bundle.sh

cd ~/projects/hadaca3/phase-1_2_3
sh generate_bundle.sh

Log in codabench website, then from the benchmark dropdown menu select Management.

Select upload and select bundle.zip created earlier.

Run docker image locally

Run all the test automatically with the script automated_docker_test.sh:

cd ~/projects/hadaca3/phase-1_2_3
sh automated_docker_test.sh

Or test each step manualy with the following commands :

First prepare the docker submission with the script prepare2score_locally.sh

cd ~/projects/hadaca3/phase-1_2_3
sh prepare2score_locally.sh

The following block is only there to show all arguments in a digestible way.

#sudo docker run --rm  \
#    -v $PWD/ingestion_program:/app/program  \
#    -v $PWD/test_output/res:/app/output  \
#    -v $PWD/starting_kit/submissions:/app/ingested_program  \
#    -w /app/program \ 
#    -v $PWD/input_data:/app/input_data \
#    hombergn/hadaca3_pyr \
#    Rscript /app/program/ingestion.R /app/program /app/input_data /app/output /app/ingested_program

Run the follwing command to test the ingestion program using the docker.

sudo docker run --rm  -v $PWD/ingestion_program:/app/program  -v $PWD/test_output/res:/app/output  -v $PWD/starting_kit/submissions:/app/ingested_program  -w /app/program  -v $PWD/input_data:/app/input_data hombergn/hadaca3_pyr Rscript /app/program/ingestion.R /app/program /app/input_data /app/output /app/ingested_program

This block is only there to show all arguments in a digestible way.

#sudo docker run --rm \
#    -v $PWD/scoring_program:/app/program \
#    -v $PWD/test_output:/app/output \
#    -w /app/program 
#    -v $PWD/test_output:/app/input \
#    hombergn/hadaca3_pyr \
#    Rscript /app/program/scoring.R /app/input /app/output /app/program

Run the following command to test scoring program using dockers.

sudo docker run --rm  -v $PWD/scoring_program:/app/program  -v $PWD/test_output:/app/output  -w /app/program  -v $PWD/test_output:/app/input  hombergn/hadaca3_pyr  Rscript /app/program/scoring.R /app/input /app/output /app/program

Conda Environment

To reduces setup complexitie for both R and python users, (particularly essential for Python users), there is a conda environnement recepe available

To activate this envrionnement :

cd ~/projects/hadaca3/phase-1_2_3/docker/codabench_hadaca3_pyr/environment/
conda env create -f environment-r.yml && conda activate h3
cd - 

Todo:

  • Improve handling of severals datasets with a global variable: now there is variable called nb_datasets in a lots of files:
  • sub_ingestion.(py/R)
  • submission_script.(py/R)
  • detailed_results.Rmd
  • scoring.R

The variable nb_datasets stand for the number of datasets per phase in the phase 2 and 3. for instance if nb_datasets=4, there are 4 datasets in phase 2 and 4 others datasets in phase 3.

To improve for next challenge

  • create vm docker depending on the challenge business
  • add submissions (meta) informations inside the detialed view
  • Add participants to create their conda env/.
  • **Use other type of data the rds ! ! ! **
  • Define precisely the naming of the final data and create small data from the beginning which will make everything faster !
  • Ask participants for their packages after the phase 1 => recreate the docker and env.