From b303b74874d40bbda7a5d60f3c9f7cc9010444ee Mon Sep 17 00:00:00 2001 From: Sharon Fitzpatrick Date: Wed, 17 Apr 2024 16:35:50 -0700 Subject: [PATCH] finish testing filtering out cloudy images and update printed msg when image is filtered out --- src/coastsat/SDS_download.py | 1 + src/coastsat/SDS_preprocess.py | 10 ++-------- 2 files changed, 3 insertions(+), 8 deletions(-) diff --git a/src/coastsat/SDS_download.py b/src/coastsat/SDS_download.py index cbe33f0..018e1b3 100644 --- a/src/coastsat/SDS_download.py +++ b/src/coastsat/SDS_download.py @@ -991,6 +991,7 @@ def retrieve_images( fn = [filepath_ms,filepath_swir,filepath_QA] + # Removes images whose cloud cover and no data coverage exceeds the threshold skip_image=SDS_preprocess.filter_images_by_cloud_cover_nodata(fn,satname, cloud_mask_issue,max_cloud_no_data_cover,cloud_threshold, do_cloud_mask=True, s2cloudless_prob=60) # if the images was filtered out, skip the image being saved as a jpg diff --git a/src/coastsat/SDS_preprocess.py b/src/coastsat/SDS_preprocess.py index 2525040..e0ccd4b 100644 --- a/src/coastsat/SDS_preprocess.py +++ b/src/coastsat/SDS_preprocess.py @@ -66,7 +66,6 @@ def filter_images_by_cloud_cover_nodata(fn, satname, cloud_mask_issue, max_cloud if max_cloud_no_data_cover is None and max_cloud_cover is None: # nothing was filtered return False return False - print(f"max_cloud_no_data_cover: {max_cloud_no_data_cover}, max_cloud_cover: {max_cloud_cover}") ( im_ms, georef, @@ -115,9 +114,8 @@ def remove_files_above_threshold(filepaths: list[str], prc: float, threshold: in Returns: bool: True if files were removed, False otherwise. """ - print(f"prc: {prc}, threshold: {threshold} {msg}") if prc > threshold: - print(f"skipping image {os.path.basename(filepaths[0])} {msg} {prc*100:.2f}%") + print(f"skipping image '{os.path.basename(filepaths[0])}' {msg} {prc*100:.2f}% exceeds threshold of {threshold*100:.2f}%") # delete files that exceed the cloud cover threshold for file in filepaths: os.remove(file) @@ -283,7 +281,7 @@ def pad_edges(im_swir: np.ndarray, im_nodata: np.ndarray) -> np.ndarray: if right_pad > 0: im_nodata[:, -right_pad:] = True - # Apply this padding to your masks or other arrays as needed + # Apply this padding to your masks im_nodata[:top_pad, :] = True im_nodata[:, :left_pad] = True return im_nodata @@ -570,10 +568,6 @@ def get_zero_pixels(im_ms: np.ndarray, shape: tuple) -> np.ndarray: im_zeros = np.ones(shape).astype(bool) for k in [1, 3, 4]: # loop through the Green, NIR and SWIR bands im_zeros = np.logical_and(np.isin(im_ms[:, :, k], 0), im_zeros) - # modify the logic to add ANY pixel with 0 intensity in ANY of the Green, NIR and SWIR bands to the im_zeros mask - # im_zeros = np.zeros(shape).astype(bool) - # for k in [1, 3, 4]: # loop through the Green, NIR and SWIR bands - # im_zeros = np.logical_or(np.isin(im_ms[:, :, k], 0), im_zeros) return im_zeros