From e7e648e58f09e881e67568b2d31677e3260024d8 Mon Sep 17 00:00:00 2001 From: isaaccorley <22203655+isaaccorley@users.noreply.github.com> Date: Mon, 22 May 2023 15:23:09 +0000 Subject: [PATCH 1/5] fix randomgrayscale device bug --- torchgeo/transforms/color.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/torchgeo/transforms/color.py b/torchgeo/transforms/color.py index 199b1279c72..5459fc2f854 100644 --- a/torchgeo/transforms/color.py +++ b/torchgeo/transforms/color.py @@ -70,7 +70,7 @@ def apply_transform( Returns: The augmented input. """ - weights = flags["weights"][..., :, None, None] + weights = flags["weights"][..., :, None, None].to(input.device) out = input * weights out = out.sum(dim=-3) out = out.unsqueeze(-3).expand(input.shape) From 3092ce08e0e96c96799d6127d61c7cc8d98f7e9f Mon Sep 17 00:00:00 2001 From: isaaccorley <22203655+isaaccorley@users.noreply.github.com> Date: Mon, 22 May 2023 15:23:23 +0000 Subject: [PATCH 2/5] add random brightness and contrast augs to moco --- torchgeo/trainers/moco.py | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/torchgeo/trainers/moco.py b/torchgeo/trainers/moco.py index 09431a0b11c..8404108e2e3 100644 --- a/torchgeo/trainers/moco.py +++ b/torchgeo/trainers/moco.py @@ -62,6 +62,8 @@ def moco_augmentations( T.RandomGrayscale(weights=weights, p=0.2), # Not appropriate for multispectral imagery, seasonal contrast used instead # K.ColorJitter(brightness=0.4, contrast=0.4, saturation=0.4, hue=0.4, p=1) + K.RandomBrightness(brightness=(0.8, 1.0), p=0.8), + K.RandomContrast(contrast=(0.8, 1.0), p=0.8), K.RandomHorizontalFlip(), K.RandomVerticalFlip(), # added data_keys=["input"], @@ -74,6 +76,8 @@ def moco_augmentations( # K.ColorJitter( # brightness=0.4, contrast=0.4, saturation=0.4, hue=0.1, p=0.8 # ) + K.RandomBrightness(brightness=(0.8, 1.0), p=0.8), + K.RandomContrast(contrast=(0.8, 1.0), p=0.8), T.RandomGrayscale(weights=weights, p=0.2), K.RandomGaussianBlur(kernel_size=(ks, ks), sigma=(0.1, 2), p=0.5), K.RandomHorizontalFlip(), @@ -88,6 +92,8 @@ def moco_augmentations( # K.ColorJitter( # brightness=0.4, contrast=0.4, saturation=0.2, hue=0.1, p=0.8 # ) + K.RandomBrightness(brightness=(0.8, 1.0), p=0.8), + K.RandomContrast(contrast=(0.8, 1.0), p=0.8), T.RandomGrayscale(weights=weights, p=0.2), K.RandomGaussianBlur(kernel_size=(ks, ks), sigma=(0.1, 2), p=1), K.RandomHorizontalFlip(), @@ -100,6 +106,8 @@ def moco_augmentations( # K.ColorJitter( # brightness=0.4, contrast=0.4, saturation=0.2, hue=0.1, p=0.8 # ) + K.RandomBrightness(brightness=(0.8, 1.0), p=0.8), + K.RandomContrast(contrast=(0.8, 1.0), p=0.8), T.RandomGrayscale(weights=weights, p=0.2), K.RandomGaussianBlur(kernel_size=(ks, ks), sigma=(0.1, 2), p=0.1), K.RandomSolarize(p=0.2), From 1b6e2491027084be207d36399ffab0b2f2a4e652 Mon Sep 17 00:00:00 2001 From: isaaccorley <22203655+isaaccorley@users.noreply.github.com> Date: Mon, 22 May 2023 15:36:23 +0000 Subject: [PATCH 3/5] update simclr --- torchgeo/trainers/simclr.py | 2 ++ 1 file changed, 2 insertions(+) diff --git a/torchgeo/trainers/simclr.py b/torchgeo/trainers/simclr.py index 2d29944fd46..d879fedcdcb 100644 --- a/torchgeo/trainers/simclr.py +++ b/torchgeo/trainers/simclr.py @@ -49,6 +49,8 @@ def simclr_augmentations(size: int, weights: Tensor) -> nn.Module: K.RandomVerticalFlip(), # added # Not appropriate for multispectral imagery, seasonal contrast used instead # K.ColorJitter(brightness=0.8, contrast=0.8, saturation=0.8, hue=0.2, p=0.8) + K.RandomBrightness(brightness=(0.8, 1.0), p=0.8), + K.RandomContrast(contrast=(0.8, 1.0), p=0.8), T.RandomGrayscale(weights=weights, p=0.2), K.RandomGaussianBlur(kernel_size=(ks, ks), sigma=(0.1, 2)), data_keys=["input"], From 70ddb79c49a4edccc37fab7e38c67196300d9ede Mon Sep 17 00:00:00 2001 From: isaaccorley <22203655+isaaccorley@users.noreply.github.com> Date: Tue, 23 May 2023 15:34:15 +0000 Subject: [PATCH 4/5] update augmentation values --- torchgeo/trainers/moco.py | 16 ++++++++-------- torchgeo/trainers/simclr.py | 4 ++-- 2 files changed, 10 insertions(+), 10 deletions(-) diff --git a/torchgeo/trainers/moco.py b/torchgeo/trainers/moco.py index 8404108e2e3..2e1c9b52c5a 100644 --- a/torchgeo/trainers/moco.py +++ b/torchgeo/trainers/moco.py @@ -62,8 +62,8 @@ def moco_augmentations( T.RandomGrayscale(weights=weights, p=0.2), # Not appropriate for multispectral imagery, seasonal contrast used instead # K.ColorJitter(brightness=0.4, contrast=0.4, saturation=0.4, hue=0.4, p=1) - K.RandomBrightness(brightness=(0.8, 1.0), p=0.8), - K.RandomContrast(contrast=(0.8, 1.0), p=0.8), + K.RandomBrightness(brightness=(0.6, 1.4), p=1.0), + K.RandomContrast(contrast=(0.6, 1.4), p=1.0), K.RandomHorizontalFlip(), K.RandomVerticalFlip(), # added data_keys=["input"], @@ -76,8 +76,8 @@ def moco_augmentations( # K.ColorJitter( # brightness=0.4, contrast=0.4, saturation=0.4, hue=0.1, p=0.8 # ) - K.RandomBrightness(brightness=(0.8, 1.0), p=0.8), - K.RandomContrast(contrast=(0.8, 1.0), p=0.8), + K.RandomBrightness(brightness=(0.6, 1.4), p=0.8), + K.RandomContrast(contrast=(0.6, 1.4), p=0.8), T.RandomGrayscale(weights=weights, p=0.2), K.RandomGaussianBlur(kernel_size=(ks, ks), sigma=(0.1, 2), p=0.5), K.RandomHorizontalFlip(), @@ -92,8 +92,8 @@ def moco_augmentations( # K.ColorJitter( # brightness=0.4, contrast=0.4, saturation=0.2, hue=0.1, p=0.8 # ) - K.RandomBrightness(brightness=(0.8, 1.0), p=0.8), - K.RandomContrast(contrast=(0.8, 1.0), p=0.8), + K.RandomBrightness(brightness=(0.6, 1.4), p=0.8), + K.RandomContrast(contrast=(0.6, 1.4), p=0.8), T.RandomGrayscale(weights=weights, p=0.2), K.RandomGaussianBlur(kernel_size=(ks, ks), sigma=(0.1, 2), p=1), K.RandomHorizontalFlip(), @@ -106,8 +106,8 @@ def moco_augmentations( # K.ColorJitter( # brightness=0.4, contrast=0.4, saturation=0.2, hue=0.1, p=0.8 # ) - K.RandomBrightness(brightness=(0.8, 1.0), p=0.8), - K.RandomContrast(contrast=(0.8, 1.0), p=0.8), + K.RandomBrightness(brightness=(0.6, 1.4), p=0.8), + K.RandomContrast(contrast=(0.6, 1.4), p=0.8), T.RandomGrayscale(weights=weights, p=0.2), K.RandomGaussianBlur(kernel_size=(ks, ks), sigma=(0.1, 2), p=0.1), K.RandomSolarize(p=0.2), diff --git a/torchgeo/trainers/simclr.py b/torchgeo/trainers/simclr.py index d879fedcdcb..b09b0e591cf 100644 --- a/torchgeo/trainers/simclr.py +++ b/torchgeo/trainers/simclr.py @@ -49,8 +49,8 @@ def simclr_augmentations(size: int, weights: Tensor) -> nn.Module: K.RandomVerticalFlip(), # added # Not appropriate for multispectral imagery, seasonal contrast used instead # K.ColorJitter(brightness=0.8, contrast=0.8, saturation=0.8, hue=0.2, p=0.8) - K.RandomBrightness(brightness=(0.8, 1.0), p=0.8), - K.RandomContrast(contrast=(0.8, 1.0), p=0.8), + K.RandomBrightness(brightness=(0.2, 1.8), p=0.8), + K.RandomContrast(contrast=(0.2, 1.8), p=0.8), T.RandomGrayscale(weights=weights, p=0.2), K.RandomGaussianBlur(kernel_size=(ks, ks), sigma=(0.1, 2)), data_keys=["input"], From 19a26119ec3338fd54e5bb5baf2245378d8c6823 Mon Sep 17 00:00:00 2001 From: isaaccorley <22203655+isaaccorley@users.noreply.github.com> Date: Tue, 23 May 2023 15:34:31 +0000 Subject: [PATCH 5/5] kornia 0.6.9+ required for RandomBrightness --- environment.yml | 2 +- requirements/min-reqs.old | 2 +- setup.cfg | 4 ++-- 3 files changed, 4 insertions(+), 4 deletions(-) diff --git a/environment.yml b/environment.yml index 1290e0dd2e2..de47c5cc647 100644 --- a/environment.yml +++ b/environment.yml @@ -24,7 +24,7 @@ dependencies: - hydra-core>=1 - ipywidgets>=7 - isort[colors]>=5.8 - - kornia>=0.6.5 + - kornia>=0.6.9 - laspy>=2 - lightly>=1.4.4 - lightning>=1.8 diff --git a/requirements/min-reqs.old b/requirements/min-reqs.old index d74ce8e414e..84375103261 100644 --- a/requirements/min-reqs.old +++ b/requirements/min-reqs.old @@ -4,7 +4,7 @@ setuptools==42.0.0 # install einops==0.3.0 fiona==1.8.19 -kornia==0.6.5 +kornia==0.6.9 lightly==1.4.4 lightning==1.8.0 matplotlib==3.3.3 diff --git a/setup.cfg b/setup.cfg index 4e93bcd906d..c6bd83251b0 100644 --- a/setup.cfg +++ b/setup.cfg @@ -28,8 +28,8 @@ install_requires = # fiona 1.8.19+ required to fix erroneous warning # https://github.com/Toblerity/Fiona/issues/986 fiona>=1.8.19,<2 - # kornia 0.6.5+ required due to change in kornia.augmentation API - kornia>=0.6.5,<0.7 + # kornia 0.6.9+ required for kornia.augmentation.RandomBrightness + kornia>=0.6.9,<0.7 # lightly 1.4.4+ required for MoCo v3 support lightly>=1.4.4 # lightning 1.8+ is first release