From aa12fa5bdfd5491db68ec61355f70266e3517a4b Mon Sep 17 00:00:00 2001 From: Phillip Chlap Date: Mon, 25 Nov 2024 04:16:16 +1100 Subject: [PATCH] Fix issue interpolating when many slices are missing --- pydicer/convert/data.py | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/pydicer/convert/data.py b/pydicer/convert/data.py index 85d130c..d63b14e 100644 --- a/pydicer/convert/data.py +++ b/pydicer/convert/data.py @@ -165,14 +165,17 @@ def handle_missing_slice( # find where the missing slices are missing_indices = np.where(slice_thickness_variations)[0] + # Track offset to load correct files since df_files changes during loop + ind_offset = 0 + for missing_index in missing_indices: num_missing_slices = ( int(slice_location_diffs[missing_index] / expected_slice_diff) - 1 ) # locate nearest DICOM files to the missing slices - prior_dcm_file = df_files.iloc[missing_index]["file_path"] - next_dcm_file = df_files.iloc[missing_index + 1]["file_path"] + prior_dcm_file = df_files.iloc[missing_index + ind_offset]["file_path"] + next_dcm_file = df_files.iloc[missing_index + ind_offset + 1]["file_path"] prior_dcm = pydicom.read_file(prior_dcm_file) next_dcm = pydicom.read_file(next_dcm_file) @@ -234,6 +237,8 @@ def handle_missing_slice( df_files = pd.concat([df_files, pd.DataFrame([interp_df_row])]) df_files.sort_values(by="slice_location", inplace=True) + ind_offset += 1 + return df_files.file_path.tolist()