Generation of challenge packs
Project description
🛠️ grand-challenge-forge
A utility that generates distributable items that help challenge organizers set up their challenge more easily on Grand-Challenge.org.
Install
Install via PyPi:
pip install grand-challenge-forge
grand-challenge-forge --help
📦 Challenge packs
A challenge pack consists of challenge-tailored examples for the following:
- A script to automate uploading data to an archive
- A submission algorithm that can be submitted to a challenge phase
- An evaluation method that evaluates algorithm submissions and generates performance metrics for ranking
Usage
PACK generation
grand-challenge-forge pack pack-context.json
Will use the context found in pack-context.json
and generate a pack at the current working directory in
a directory dist/
(default).
Example of the content of pack-context.json
{
"challenge": {
"slug": "challenge-slug",
"phases": [
{
"slug": "phase-slug",
"archive": {
"url": "https://grand-challenge.org/archives/archive-slug/"
},
"algorithm_inputs": [
{
"slug": "input-ci-slug",
"kind": "Segmentation",
"super_kind": "Image",
"relative_path": "images/input-value"
},
{
"slug": "another-input-ci-slug",
"kind": "Anything",
"super_kind": "File",
"relative_path": "another-input-value.json"
}
],
"algorithm_outputs": [
{
"slug": "output-ci-slug",
"kind": "Image",
"super_kind": "Image",
"relative_path": "images/output-value"
},
{
"slug": "another-output-ci-slug",
"kind": "Anything",
"super_kind": "File",
"relative_path": "output-value.json"
}
]
},
{
"slug": "another-phase-slug",
"archive": {
"url": "https://grand-challenge.org/archives/another-archive-slug/"
},
"algorithm_inputs": [
{
"slug": "input-ci-slug",
"kind": "Image",
"super_kind": "Image",
"relative_path": "images/input-value"
}
],
"algorithm_outputs": [
{
"slug": "another-output-ci-slug",
"kind": "Anything",
"super_kind": "File",
"relative_path": "output-value.json"
}
]
}
]
}
}
Alternatively, you generate a pack by providing a JSON string directly:
grand-challenge-forge pack --output-dir /tmp '{ "challenge": { "slug": "a-slug"...'
This will output a pack directory in the /tmp
directory.
[!NOTE] By default, the forge does quality checks on the pack that may require docker. You can disable these via
-n
Via API pack generation can be done via:
from grand_challenge_forge.forge import generate_challenge_pack
from Pathlib import Path
qc = []
generate_challenge_pack(
context={"challenge": {...}}
output_path=Path("dist/"),
quality_control_registry=qc,
delete_existing=False,
)
for check in qc:
check()
ALGORITHM-TEMPLATE generation
grand-challenge-forge algorithm algorithm-context.json
Will use the context found in algorithm-context.json
and generate a algorith-template directory at the current working directory in a directory dist/
(default).
Example of the content of algorithm-context.json
{
"algorithm": {
"title": "An Algorithm Title",
"slug": "an-algorithm-title",
"url": "https://grand-challenge.org/algorithms/an-algorithm/",
"inputs": [
{
"slug": "input-ci-slug",
"kind": "Segmentation",
"super_kind": "Image",
"relative_path": "images/input-value"
},
{
"slug": "another-input-ci-slug",
"kind": "Anything",
"super_kind": "File",
"relative_path": "another-input-value.json"
}
],
"outputs": [
{
"slug": "output-ci-slug",
"kind": "Image",
"super_kind": "Image",
"relative_path": "images/output-value"
},
{
"slug": "another-output-ci-slug",
"kind": "Anything",
"super_kind": "File",
"relative_path": "output-value.json"
}
]
},
}
Alternatively, you generate an algorithm template by providing a JSON string directly:
grand-challenge-forge algorithm --output-dir /tmp '{ "algorithm": { ... } }'
This will output an algorithm-template directory in the /tmp
directory.
[!NOTE] By default, the forge does quality checks on the template that may require docker. You can disable these via
-n
Via API the algorithm-template generation can be done via:
from grand_challenge_forge.forge import generate_algorithm_template
from Pathlib import Path
qc = []
generate_algorithm_template(
context={"algorithm": { ... }}
output_path=Path("dist/"),
quality_control_registry=qc,
delete_existing=False,
)
for check in qc:
check()
🏗️ Development
Install locally
Install grand-challenge-forge locally (requires poetry
):
git clone https://github.com/DIAGNijmegen/rse-grand-challenge-forge.git
cd rse-grand-challenge-forge
poetry install
poetry run grand-challenge-forge --help
Pre-commit hooks
Several linters and stylers run to check the formatting during continuous integration. Ensure they are run before committing by installing pre-commit.
Running Tests
use tox
to run all tests across all supported python versions:
pip install tox
tox
Dependencies
Under the hood grand-challenge-forge uses:
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file grand_challenge_forge-0.6.1.tar.gz
.
File metadata
- Download URL: grand_challenge_forge-0.6.1.tar.gz
- Upload date:
- Size: 33.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.4 CPython/3.10.15 Linux/6.5.0-1025-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 279f1c4836a125ae85c3c74cab5a2a25cab30aa6c93c87839038287e26bab0d2 |
|
MD5 | 4c9bbe30d9fa11890b948381dac14b17 |
|
BLAKE2b-256 | 0cb84e598ef120969ef0fdca2e5e4fd7317d465e16449b566f83391c330c0c24 |
File details
Details for the file grand_challenge_forge-0.6.1-py3-none-any.whl
.
File metadata
- Download URL: grand_challenge_forge-0.6.1-py3-none-any.whl
- Upload date:
- Size: 46.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.4 CPython/3.10.15 Linux/6.5.0-1025-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1a1c6fb256395de896b53fb25ce89d13181f78f9363c97e421cf07e14bd3d8b5 |
|
MD5 | 9ed729c70e5619bedd457aa88fcea536 |
|
BLAKE2b-256 | 19d6332111da3f42b5eab6a80aa8759c7aae544f7c9fcf55bf13c33727710f4c |