This repository contains a set of models built on and for public datasets (PANDA, TCGA). Detailed instructions to on-board the datasets and run the models are provided on readthedocs.
For working on the histopathology folder, please create a separate Conda environment.
cd hi-ml-cpath
make env
You can then activate the environment via conda activate HimlHisto
. Set VSCode to use this Conda environment, by choosing "Python: Select Interpreter"
from the command palette.
If the dependencies need to be updated, please modify hi-ml-cpath/primary_deps.yml
, and then run the script
hi-ml-cpath/create_and_lock_environment.sh
. This will create a full "locked" environment specification with pinned
versions of all depdencies.
In addition, please download an AzureML workspace configuration file for the workspace that you wish to use:
- In the browser, navigate to the workspace in question
- Click on the drop-down menu on upper right of the page, to the left of your account picture.
- Select "Download config file".
- Save that file into the the repository root.
Once that config file is in place, all Python runs that you start inside the hi-ml-cpath
folder will automatically use this config file.
To test your setup, please execute in the hi-ml-cpath
folder:
conda activate HimlHisto
python ../hi-ml/src/health_ml/runner.py --model health_cpath.TcgaCrckImageNetMIL --cluster=training-nd24
This should start an AzureML job in the AzureML workspace that you configured above via config.json
. You may need to adjust the name of
the compute cluster (training-nd24
in the above example).
If you start your jobs in the hi-ml-cpath
folder, they will automatically pick up the Conda environment file that is present in that folder.
If you start your jobs in a different folder, you need to add the --conda_env
option to point to the file <repo_root>/hi-ml-cpath/environment.yml
.
In the hi-ml-cpath
folder, run
make call_pytest
Inside of VSCode, all tests in the repository should be picked up automatically. You can exclude the tests for the hi-ml
and hi-ml-azure
packages by
modifying python.testing.pytestArgs
in the VSCode .vscode/settings.json
file.
The test pipeline for the histopathology folder contains a run of pytest
on a machine with 2 GPUs. Only tests that are
marked with the pytest
mark gpu
are executed on that GPU machine. Note that all tests that bear the gpu
mark will
also be executed when running on a CPU machine. You need to manually add a skipif
flag for tests that are meant to
exclusively run on GPU machines. This also helps to ensure that the test suite can pass when executed outside of the
build agents.
- Tests that run only on a CPU machine: Provide no
pytest
marks
def test_my_code() -> None:
pass
- Tests that run on both on a CPU and on a GPU machine: Add
@pytest.mark.gpu
@pytest.mark.gpu
def test_my_code() -> None:
pass
- Tests that run only on a GPU machine:
from health_ml.utils.common_utils import is_gpu_available
no_gpu = not is_gpu_available()
@pytest.mark.skipif(no_gpu, reason="Test requires GPU")
@pytest.mark.gpu
def test_my_code() -> None:
pass