From 0268b023177e5cf2ce77d4e8a92f51a6689eb647 Mon Sep 17 00:00:00 2001 From: Spiros Maggioros Date: Thu, 31 Oct 2024 01:23:56 +0200 Subject: [PATCH] [BIDS] Generate BIDS output --- NiChart_DLMUSE/__main__.py | 11 +++++--- NiChart_DLMUSE/utils.py | 57 +++++++++++++++++++++++++++----------- 2 files changed, 48 insertions(+), 20 deletions(-) diff --git a/NiChart_DLMUSE/__main__.py b/NiChart_DLMUSE/__main__.py index 2971cf2..84898a3 100644 --- a/NiChart_DLMUSE/__main__.py +++ b/NiChart_DLMUSE/__main__.py @@ -10,7 +10,7 @@ import threading from .dlmuse_pipeline import run_pipeline -from .utils import merge_output_data, remove_subfolders, split_data, collect_T1 +from .utils import merge_bids_output_data, merge_output_data, remove_subfolders, split_data, collect_T1 # VERSION = pkg_resources.require("NiChart_DLMUSE")[0].version VERSION = "1.0.5" @@ -141,7 +141,10 @@ def main() -> None: print(args) print() - if len(os.listdir(out_dir)) != 0: + if not os.path.isdir(out_dir): + print(f"Can't find {out_dir}, creating it...") + os.system(f"mkdir {out_dir}") + elif len(os.listdir(out_dir)) != 0: print(f"Emptying output folder: {out_dir}...") os.system(f"rm -r {out_dir}/*") @@ -152,7 +155,7 @@ def main() -> None: # Run pipeline if args.bids == True: - collect_T1(in_dir) + collect_T1(in_dir, out_dir) no_threads = int(args.cores) subfolders = split_data("raw_temp_T1", no_threads) @@ -177,10 +180,10 @@ def main() -> None: t.join() merge_output_data(out_dir) + merge_bids_output_data(out_dir) remove_subfolders("raw_temp_T1") remove_subfolders(out_dir) - else: no_threads = int(args.cores) subfolders = split_data(in_dir, no_threads) diff --git a/NiChart_DLMUSE/utils.py b/NiChart_DLMUSE/utils.py index 4028b15..f8245a9 100644 --- a/NiChart_DLMUSE/utils.py +++ b/NiChart_DLMUSE/utils.py @@ -135,6 +135,19 @@ def make_img_list(in_data: str) -> pd.DataFrame: # Return out dataframe return df_out +def get_bids_prefix(filename: str) -> str: + """ + Returns the prefix of a bids file + """ + prefix = "" + idx = 0 + char = filename[idx] + while char != '_': + prefix += char + idx += 1 + char = filename[idx] + + return prefix def dir_size(in_dir: str) -> int: """ @@ -160,7 +173,7 @@ def dir_foldercount(in_dir: str) -> int: return size -def collect_T1(in_dir: str) -> None: +def collect_T1(in_dir: str, out_dir: str) -> None: """ This function collects all the raw T1 images from the passed BIDS input dir and it creates a temporary folder that will act as a generic dataset with only T1 images @@ -171,6 +184,8 @@ def collect_T1(in_dir: str) -> None: # create the raw_temp_T1 folder that will host all the T1 images os.system("mkdir raw_temp_T1") + os.system(f"cp -r {in_dir}/* {out_dir}/") + total_subs = dir_foldercount(in_dir) accepted_subfolders = [] for i in range(1, total_subs): @@ -185,6 +200,17 @@ def collect_T1(in_dir: str) -> None: os.system(f"cp {os.path.join(in_dir, sub)}/anat/* raw_temp_T1") +def merge_bids_output_data(out_data: str) -> None: + """ + Move all the images on the s5_relabeled subfolder to the subfolder of their prefix + """ + dlmuse_images = [] + + for img in os.listdir(os.path.join(out_data, "s5_relabeled")): + img_prefix = get_bids_prefix(img) + os.system(f"mv {os.path.join(out_data, "s5_relabeled")}/{img} {img_prefix}/anat/") + + def split_data(in_dir: str, N: int) -> list: """ @@ -231,37 +257,36 @@ def remove_subfolders(in_dir: str) -> None: def merge_output_data(in_dir: str) -> None: """ Takes all the results from the temp_working_fir and moves them into - the results/ subfolder in the output folder + the output folder """ - os.system(f"mkdir {in_dir}/results") - os.system(f"mkdir {in_dir}/results/s1_reorient_lps") - os.system(f"mkdir {in_dir}/results/s2_dlicv") - os.system(f"mkdir {in_dir}/results/s3_masked") - os.system(f"mkdir {in_dir}/results/s4_dlmuse") - os.system(f"mkdir {in_dir}/results/s5_relabeled") - os.system(f"mkdir {in_dir}/results/s6_combined") + os.system(f"mkdir {in_dir}/s1_reorient_lps") + os.system(f"mkdir {in_dir}/s2_dlicv") + os.system(f"mkdir {in_dir}/s3_masked") + os.system(f"mkdir {in_dir}/s4_dlmuse") + os.system(f"mkdir {in_dir}/s5_relabeled") + os.system(f"mkdir {in_dir}/s6_combined") for dir in os.listdir(in_dir): if dir == "results": continue os.system( - f"mv {in_dir}/{dir}/temp_working_dir/s1_reorient_lps/* {in_dir}/results/s1_reorient_lps/" + f"mv {in_dir}/{dir}/temp_working_dir/s1_reorient_lps/* {in_dir}/s1_reorient_lps/" ) os.system( - f"mv {in_dir}/{dir}/temp_working_dir/s2_dlicv/* {in_dir}/results/s2_dlicv/" + f"mv {in_dir}/{dir}/temp_working_dir/s2_dlicv/* {in_dir}/s2_dlicv/" ) os.system( - f"mv {in_dir}/{dir}/temp_working_dir/s3_masked/* {in_dir}/results/s3_masked/" + f"mv {in_dir}/{dir}/temp_working_dir/s3_masked/* {in_dir}/s3_masked/" ) os.system( - f"mv {in_dir}/{dir}/temp_working_dir/s4_dlmuse/* {in_dir}/results/s4_dlmuse/" + f"mv {in_dir}/{dir}/temp_working_dir/s4_dlmuse/* {in_dir}/s4_dlmuse/" ) os.system( - f"mv {in_dir}/{dir}/temp_working_dir/s5_relabeled/* {in_dir}/results/s5_relabeled/" + f"mv {in_dir}/{dir}/temp_working_dir/s5_relabeled/* {in_dir}/s5_relabeled/" ) os.system( - f"mv {in_dir}/{dir}/temp_working_dir/s6_combined/* {in_dir}/results/s6_combined/" + f"mv {in_dir}/{dir}/temp_working_dir/s6_combined/* {in_dir}/s6_combined/" ) - os.system(f"mv {in_dir}/{dir}/*.nii.gz {in_dir}/results/") + os.system(f"mv {in_dir}/{dir}/*.nii.gz {in_dir}/")