From 566b4b2fdd23c78b8fd6d25ae99a4e22d48f0d76 Mon Sep 17 00:00:00 2001 From: Ali Khan Date: Mon, 16 Dec 2024 10:05:45 -0500 Subject: [PATCH] Port v1.5.2 bugfixes into dev-v2.0.0 (#329) * fix for using T1T2w model run_inference was only accepting a single input image, this makes it accept a list of images too, and makes it so --force-nnunet-model T1T2w grabs both T1w and T2w as inputs. * hipp curvature was being used always, instead of wildcard this didn't affect any workflow computations, just the subsequent dscalar.nii and spec file that would have the wrong curvature map * fix logical error * Bump version to 1.5.2-pre.1 * Bump version to 1.5.2-pre.2 * keep pipeline_description changes --------- Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> --- hippunfold/pipeline_description.json | 14 +++--- hippunfold/workflow/rules/gifti.smk | 2 +- hippunfold/workflow/rules/nnunet.smk | 69 +++++++++++++++++----------- 3 files changed, 50 insertions(+), 35 deletions(-) diff --git a/hippunfold/pipeline_description.json b/hippunfold/pipeline_description.json index b5cc5fa0..706e9b97 100644 --- a/hippunfold/pipeline_description.json +++ b/hippunfold/pipeline_description.json @@ -4,11 +4,11 @@ "DatasetType": "derivative", "GeneratedBy": [ { - "Name": "hippunfold", - "Version": "1.5.4", - "CodeURL": "https://github.com/khanlab/hippunfold", - "Author": "Jordan DeKraker & Ali Khan", - "AuthorEmail": "ali.khan@uwo.ca" - } - ] + "Name": "hippunfold", + "Version": "1.5.2-pre.2", + "CodeURL": "https://github.com/khanlab/hippunfold", + "Author": "Jordan DeKraker & Ali Khan", + "AuthorEmail": "ali.khan@uwo.ca" + } + ] } diff --git a/hippunfold/workflow/rules/gifti.smk b/hippunfold/workflow/rules/gifti.smk index 4daa20b9..884662c0 100644 --- a/hippunfold/workflow/rules/gifti.smk +++ b/hippunfold/workflow/rules/gifti.smk @@ -978,7 +978,7 @@ rule normalize_curvature2: space="{space}", hemi="{hemi}", desc="unnorm", - label="hipp", + label="{autotop}", **inputs.subj_wildcards ), output: diff --git a/hippunfold/workflow/rules/nnunet.smk b/hippunfold/workflow/rules/nnunet.smk index 952146a2..04f31515 100644 --- a/hippunfold/workflow/rules/nnunet.smk +++ b/hippunfold/workflow/rules/nnunet.smk @@ -2,32 +2,35 @@ import re def get_nnunet_input(wildcards): - if config["modality"] == "T2w": - nii = ( - bids( - root=work, - datatype="anat", - **inputs.subj_wildcards, - suffix="T2w.nii.gz", - space="corobl", - desc="preproc", - hemi="{hemi}", - ), - ) + T1w_nii = bids( + root=work, + datatype="anat", + space="corobl", + desc="preproc", + hemi="{hemi}", + suffix="T1w.nii.gz", + **inputs.subj_wildcards, + ) + T2w_nii = bids( + root=work, + datatype="anat", + space="corobl", + desc="preproc", + hemi="{hemi}", + suffix="T2w.nii.gz", + **inputs.subj_wildcards, + ) + if (config["modality"] == "T1w" or config["modality"] == "T2w") and config[ + "force_nnunet_model" + ] == "T1T2w": + return (T1w_nii, T2w_nii) + + elif config["modality"] == "T2w": + return T2w_nii elif config["modality"] == "T1w": - nii = ( - bids( - root=work, - datatype="anat", - **inputs.subj_wildcards, - suffix="T1w.nii.gz", - space="corobl", - desc="preproc", - hemi="{hemi}", - ), - ) + return T1w_nii elif config["modality"] == "hippb500": - nii = bids( + return bids( root=work, datatype="dwi", hemi="{hemi}", @@ -37,7 +40,6 @@ def get_nnunet_input(wildcards): ) else: raise ValueError("modality not supported for nnunet!") - return nii def get_model_tar(): @@ -94,6 +96,19 @@ def parse_trainer_from_tar(wildcards, input): return trainer +def get_cmd_copy_inputs(wildcards, input): + in_img = input.in_img + if isinstance(in_img, str): + # we have one input image + return f"cp {in_img} tempimg/temp_0000.nii.gz" + else: + cmd = [] + # we have multiple input images + for i, img in enumerate(input.in_img): + cmd.append(f"cp {img} tempimg/temp_{i:04d}.nii.gz") + return " && ".join(cmd) + + rule run_inference: """ This rule uses either GPU or CPU . It also runs in an isolated folder (shadow), with symlinks to inputs in that folder, copying over outputs once complete, so temp files are not retained""" @@ -101,7 +116,7 @@ rule run_inference: in_img=get_nnunet_input, model_tar=get_model_tar(), params: - temp_img="tempimg/temp_0000.nii.gz", + cmd_copy_inputs=get_cmd_copy_inputs, temp_lbl="templbl/temp.nii.gz", model_dir="tempmodel", in_folder="tempimg", @@ -148,7 +163,7 @@ rule run_inference: # run inference #copy from temp output folder to final output "mkdir -p {params.model_dir} {params.in_folder} {params.out_folder} && " - "cp {input.in_img} {params.temp_img} && " + "{params.cmd_copy_inputs} && " "tar -xf {input.model_tar} -C {params.model_dir} && " "export RESULTS_FOLDER={params.model_dir} && " "export nnUNet_n_proc_DA={threads} && "