From 4e6a95269a285b66bfeac09093f2ff348a26b30f Mon Sep 17 00:00:00 2001 From: Ritvik Vasan Date: Fri, 18 Oct 2024 09:53:20 -0700 Subject: [PATCH 1/3] add filename_or_obj metatata to multidim dataloader to create io maps --- configs/experiment/local/eval_scale1_new.yaml | 8 ++++---- cyto_dl/callbacks/image_saver.py | 6 ++++-- cyto_dl/datamodules/multidim_image.py | 6 ++++++ 3 files changed, 14 insertions(+), 6 deletions(-) diff --git a/configs/experiment/local/eval_scale1_new.yaml b/configs/experiment/local/eval_scale1_new.yaml index 552cd824..c7d2d046 100644 --- a/configs/experiment/local/eval_scale1_new.yaml +++ b/configs/experiment/local/eval_scale1_new.yaml @@ -28,17 +28,17 @@ trainer: model: compile: True - #save_dir: /allen/aics/assay-dev/users/Suraj/EMT_Work/image_analysis_test/EMT_image_analysis/Colony_mask_training_inference/eval_whole_movie_multiscale_patch1_zarr_aws + save_dir: /allen/aics/assay-dev/users/Suraj/EMT_Work/image_analysis_test/EMT_image_analysis/Colony_mask_training_inference/eval_whole_movie_multiscale_patch1_zarr_aws data: csv_path: /allen/aics/assay-dev/users/Suraj/EMT_Work/image_analysis_test/EMT_image_analysis/Colony_mask_training_inference/sample_csv/predict_all_cells_mask_zarr_aws_v0.csv #path to csv containing test movies #batch_size: 1 - _aux: + _aux: patch_shape: [16, 128, 128] callbacks: predict_saving: _target_: cyto_dl.callbacks.ImageSaver - save_dir: /allen/aics/assay-dev/users/Suraj/EMT_Work/image_analysis_test/EMT_image_analysis/Colony_mask_training_inference/eval_whole_movie_multiscale_patch1_zarr_aws + save_dir: ${model.save_dir} stages: ["predict"] - save_input: False \ No newline at end of file + save_input: False diff --git a/cyto_dl/callbacks/image_saver.py b/cyto_dl/callbacks/image_saver.py index 4458016f..100a2d32 100644 --- a/cyto_dl/callbacks/image_saver.py +++ b/cyto_dl/callbacks/image_saver.py @@ -19,8 +19,9 @@ def __init__( Parameters ---------- - save_dir: Union[str, Path] - Directory to save images + save_dir: Union[str, Path] + Directory to save images. Only testing saves in this directory, prediction + saves in model save directory save_every_n_epochs:int=1 Frequency to save images stages:List[str]=["train", "val"] @@ -49,6 +50,7 @@ def on_predict_batch_end( if outputs is None: # image has already been saved return + for i, head_io_map in enumerate(io_map.values()): for k, save_path in head_io_map.items(): self._save(save_path, outputs[k]["pred"][i]) diff --git a/cyto_dl/datamodules/multidim_image.py b/cyto_dl/datamodules/multidim_image.py index 14643061..0d76d1b4 100644 --- a/cyto_dl/datamodules/multidim_image.py +++ b/cyto_dl/datamodules/multidim_image.py @@ -97,6 +97,9 @@ def _get_timepoints(self, row, img): step = row.get(self.time_step_column, 1) timepoints = range(start, stop + 1, step) if stop > 0 else range(img.dims.T) return list(timepoints) + + def _get_filename(self, image_input_path): + return image_input_path.split('/')[-1].split('.')[0] def get_per_file_args(self, df): img_data = [] @@ -105,6 +108,8 @@ def get_per_file_args(self, df): img = BioImage(row[self.img_path_column]) scenes = self._get_scenes(row, img) timepoints = self._get_timepoints(row, img) + filename = self._get_filename(row[self.img_path_column]) + for scene in scenes: for timepoint in timepoints: img_data.append( @@ -115,6 +120,7 @@ def get_per_file_args(self, df): "scene": scene, "T": timepoint, "original_path": row[self.img_path_column], + "filename_or_obj": filename, # needs to be part of metadata to generate IO maps } ) img_data.reverse() From 7ff26444f2674f8f3097228c68d8c66eafdcea16 Mon Sep 17 00:00:00 2001 From: Ritvik Vasan Date: Fri, 18 Oct 2024 10:03:06 -0700 Subject: [PATCH 2/3] run pre-commit --- .../data/local/segmentation_all_cells_mask_from_zarr.yaml | 3 --- configs/model/local/segmentation_all_cells_mask.yaml | 2 +- cyto_dl/callbacks/image_saver.py | 4 ++-- cyto_dl/datamodules/multidim_image.py | 6 +++--- 4 files changed, 6 insertions(+), 9 deletions(-) diff --git a/configs/data/local/segmentation_all_cells_mask_from_zarr.yaml b/configs/data/local/segmentation_all_cells_mask_from_zarr.yaml index e34a7724..cfa29d75 100644 --- a/configs/data/local/segmentation_all_cells_mask_from_zarr.yaml +++ b/configs/data/local/segmentation_all_cells_mask_from_zarr.yaml @@ -5,7 +5,6 @@ batch_size: 1 pin_memory: True #persistent_workers: False - csv_path: img_path_column: movie_path channel_column: bf_channel @@ -14,5 +13,3 @@ out_key: ${source_col} transforms: - _target_: monai.transforms.ToTensor - _target_: monai.transforms.NormalizeIntensity - - diff --git a/configs/model/local/segmentation_all_cells_mask.yaml b/configs/model/local/segmentation_all_cells_mask.yaml index c9994ac0..823ab05d 100644 --- a/configs/model/local/segmentation_all_cells_mask.yaml +++ b/configs/model/local/segmentation_all_cells_mask.yaml @@ -41,7 +41,7 @@ _aux: - - ${target_col} - _target_: cyto_dl.nn.BaseHead loss: - _target_: monai.losses.GeneralizedDiceFocalLoss ##Main loss + _target_: monai.losses.GeneralizedDiceFocalLoss ##Main loss sigmoid: True postprocess: input: diff --git a/cyto_dl/callbacks/image_saver.py b/cyto_dl/callbacks/image_saver.py index 100a2d32..2b95a1fe 100644 --- a/cyto_dl/callbacks/image_saver.py +++ b/cyto_dl/callbacks/image_saver.py @@ -19,9 +19,9 @@ def __init__( Parameters ---------- - save_dir: Union[str, Path] + save_dir: Union[str, Path] Directory to save images. Only testing saves in this directory, prediction - saves in model save directory + saves in model save directory save_every_n_epochs:int=1 Frequency to save images stages:List[str]=["train", "val"] diff --git a/cyto_dl/datamodules/multidim_image.py b/cyto_dl/datamodules/multidim_image.py index 0d76d1b4..f7295b07 100644 --- a/cyto_dl/datamodules/multidim_image.py +++ b/cyto_dl/datamodules/multidim_image.py @@ -97,9 +97,9 @@ def _get_timepoints(self, row, img): step = row.get(self.time_step_column, 1) timepoints = range(start, stop + 1, step) if stop > 0 else range(img.dims.T) return list(timepoints) - + def _get_filename(self, image_input_path): - return image_input_path.split('/')[-1].split('.')[0] + return image_input_path.split("/")[-1].split(".")[0] def get_per_file_args(self, df): img_data = [] @@ -120,7 +120,7 @@ def get_per_file_args(self, df): "scene": scene, "T": timepoint, "original_path": row[self.img_path_column], - "filename_or_obj": filename, # needs to be part of metadata to generate IO maps + "filename_or_obj": filename, # needs to be part of metadata to generate IO maps } ) img_data.reverse() From 57f9b3232da0ed853446d63de3237ff615ce554d Mon Sep 17 00:00:00 2001 From: Ritvik Vasan Date: Fri, 18 Oct 2024 11:01:07 -0700 Subject: [PATCH 3/3] add timepoint to filename --- cyto_dl/datamodules/multidim_image.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/cyto_dl/datamodules/multidim_image.py b/cyto_dl/datamodules/multidim_image.py index f7295b07..8f3c69d8 100644 --- a/cyto_dl/datamodules/multidim_image.py +++ b/cyto_dl/datamodules/multidim_image.py @@ -120,7 +120,7 @@ def get_per_file_args(self, df): "scene": scene, "T": timepoint, "original_path": row[self.img_path_column], - "filename_or_obj": filename, # needs to be part of metadata to generate IO maps + "filename_or_obj": filename + f"_{timepoint}", # needs to be part of metadata to generate IO maps } ) img_data.reverse()