Python library for cloud and cloud shadow segmentation in Sentinel-2
Project description
Welcome to CloudS2Mask ☁️
💡 About
CloudS2Mask is an open-source Python library that efficiently segments clouds and cloud shadows in Sentinel-2 imagery using state-of-the-art deep learning techniques.
🎯 Features
- High-precision cloud and cloud shadow segmentation for Sentinel-2 L1C imagery.
- Rapid processing: Approximately 2.2 seconds per scene at 20m resolution (RTX 4090, AMD Ryzen 9 5950X).
- Compatibility with both GPU and non-GPU systems.
- Supported on Linux, Windows, and macOS.
🚀 Installation
Windows Users with NVIDIA GPUs: Before installing CloudS2Mask, ensure you've installed PyTorch with CUDA support, then follow the steps below.
Mac and Linux Users: You can proceed with the installation commands below.
To install using pip.
pip install clouds2mask
Or manually.
git clone https://github.com/DPIRD-DMA/CloudS2Mask
cd CloudS2Mask
pip install -q .
cd ..
💻 Usage
Here's a simple demonstration of how to use CloudS2Mask:
All you need to do is pass a list of Sentinel-2 level 1C 'SAFE' directories to CloudS2Mask.
from pathlib import Path
from clouds2mask import (
create_settings,
batch_process_scenes,
)
output_dir = Path("./outputs")
l1c_folders_path = Path("/path/to/your/S2_l1c_SAFE/folders")
l1c_folders = list(l1c_folders_path.glob("*.SAFE"))
scene_settings = create_settings(
sent_safe_dirs=l1c_folders,
output_dir=output_dir,
processing_res=20,
)
paths_to_masks = batch_process_scenes(scene_settings)
⚙️ Performance Tuning
CloudsS2Mask offers a range of performance and accuracy options, here are some examples,
Settings for high accuracy inference:
scene_settings = create_settings(
sent_safe_dirs=l1c_folders,
output_dir=output_dir,
batch_size=32,
tta_max_depth=2,
processing_res=10,
model_ensembling=True,
)
Settings for fast inference:
scene_settings = create_settings(
sent_safe_dirs=l1c_folders,
output_dir=output_dir,
batch_size=32,
processing_res=20,
output_compression=None,
)
Settings for CPU inference:
scene_settings = create_settings(
sent_safe_dirs=l1c_folders,
output_dir=output_dir,
batch_size=1,
processing_res=20,
)
CloudS2Mask will try to auto detect acceleration cards such as NVIDIA GPUs or Apple MPS, but you can also manually specify them like this:
scene_settings = create_settings(
sent_safe_dirs=l1c_folders,
output_dir=output_dir,
pytorch_device='MPS',
)
👏 Contributing
We welcome all contributions! Feel free to open an issue or submit a pull request.
📄 License
This project is licensed under the MIT License - please refer to the LICENSE file for more details.
📝 Contact
For support, bug reporting, or to contribute, feel free to reach out at nicholas.wright@dpird.wa.gov.au.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file clouds2mask-1.1.0.tar.gz
.
File metadata
- Download URL: clouds2mask-1.1.0.tar.gz
- Upload date:
- Size: 25.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2502c2efb4fd66871f0c17c2746c35ca8d6c845fa947d3c0c27a0c6bf0bfe1d8 |
|
MD5 | fd62338f1238662c20da44e1a8190102 |
|
BLAKE2b-256 | bf1ef81c6353ababd83e4484dc28a5e379344648c64015efa20ce070fa8a154e |
File details
Details for the file clouds2mask-1.1.0-py3-none-any.whl
.
File metadata
- Download URL: clouds2mask-1.1.0-py3-none-any.whl
- Upload date:
- Size: 30.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6e16d194fea11df29eeb343e9bae1020ed8adad6ad3809c95ae11dae53f5cee2 |
|
MD5 | 2b13e076642423a02f76bb36cdecf17a |
|
BLAKE2b-256 | 2c8110e4d9d001b82489c2b4991660fe8b1a96462d761754738debc0d3a82e3d |