From 1c73842045f937784e9d235a31f9888aadbe7cb8 Mon Sep 17 00:00:00 2001 From: Michelle Wang Date: Tue, 19 Mar 2024 01:04:44 -0400 Subject: [PATCH] Fix TractoFlow symlink bugs (#202) * bind tractoflow-specific derivatives folder * fix tractogram loading with Nibabel * do not move non-symlink files (e.g. READMEs) --- nipoppy/workflow/proc_pipe/tractoflow/run_tractoflow.py | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/nipoppy/workflow/proc_pipe/tractoflow/run_tractoflow.py b/nipoppy/workflow/proc_pipe/tractoflow/run_tractoflow.py index 2ad4f88d..d9ffd0c6 100644 --- a/nipoppy/workflow/proc_pipe/tractoflow/run_tractoflow.py +++ b/nipoppy/workflow/proc_pipe/tractoflow/run_tractoflow.py @@ -473,7 +473,7 @@ def run(participant_id, global_configs, session_id, output_dir, use_bids_filter, ## build paths to files bids_dir = Path(f"{DATASET_ROOT}/bids").resolve() - tractoflow_dir = f"{output_dir}/tractoflow/{TRACTOFLOW_VERSION}" + tractoflow_dir = Path(f"{output_dir}/tractoflow/{TRACTOFLOW_VERSION}").resolve() ## Copy bids_filter.json if use_bids_filter: @@ -685,7 +685,7 @@ def run(participant_id, global_configs, session_id, output_dir, use_bids_filter, logger.info(f"Running TractoFlow for participant: {participant_id}") ## singularity - SINGULARITY_CMD=f"{SINGULARITY_COMMAND} exec --cleanenv -H {nextflow_logdir} -B {nextflow_logdir}:/nextflow -B {LOGDIR} -B {output_dir} {SINGULARITY_TRACTOFLOW}" + SINGULARITY_CMD = f"{SINGULARITY_COMMAND} exec --cleanenv -H {nextflow_logdir} -B {nextflow_logdir}:/nextflow -B {LOGDIR} -B {tractoflow_dir} {SINGULARITY_TRACTOFLOW}" CMD=SINGULARITY_CMD + " " + CMD_ARGS logger.info("+"*75) @@ -703,7 +703,7 @@ def run(participant_id, global_configs, session_id, output_dir, use_bids_filter, # do clean-up # check if tractogram is a valid file - trk = nib.streamlines.load(Path(tractoflow_out_dir, 'PFT_Tracking', f"{participant_id}__pft_tracking_prob_wm_seed_0.trk")) + trk = nib.streamlines.load(str(Path(tractoflow_out_dir, participant_id, 'PFT_Tracking', f'{participant_id}__pft_tracking_prob_wm_seed_0.trk'))) # if the the last file created (tractogram) can be validly loaded, # processing is done. @@ -716,7 +716,8 @@ def run(participant_id, global_configs, session_id, output_dir, use_bids_filter, # convert symlinks to real files for out in out_files: - move_target_to_symlink(out) + if out.is_symlink(): + move_target_to_symlink(out) # remove tractoflow_input_dir shutil.rmtree(tractoflow_nxtf_inp)