This task calculates a cloud mask for the following sensors: Landsat 4-5 TM, Landsat 7 ETM+, Landsat 8, and Sentinel-2.
This task requires extra steps to calibrate and layer-stack the imagery before creating a cloud mask. Consider using the simpler CalculateCloudMaskForProduct task.
You must supply an input raster containing multispectral bands that have been calibrated to top-of-atmosphere (TOA) reflectance. The following inputs are optional:
- A thermal-band raster calibrated to brightness temperatures, in Kelvins.
- Landsat-8 only and Sentinel-2 only: A cirrus-band raster, calibated to TOA reflectance.
If you are working with Landsat 8 data, you can optionally create a layer stack that contains the TOA reflectance and TOA cirrus bands.
ENVI uses the Fmask algorithm cited in the following references:
Zhu, Z., S. Wang, and C. E. Woodcock. "Improvement and Expansion of the Fmask Algorithm: Cloud, Cloud Shadow, and Snow Detection for Landsats 4-7, 8, and Sentinel 2 Images." Remote Sensing of Environment 159 (2015): 269-277, doi:10.1016/j.rse.2014.12.014 (paper for Fmask version 3.2).
Zhu, Z., and C. E. Woodcock. "Object-Based Cloud and Cloud Shadow Detection in Landsat Imagery." Remote Sensing of Environment 118 (2012): 83-94, doi:10.1016/j.rse.2011.10.028 (paper for Fmask version 1.6).
Example
This example calculates a cloud mask for a Landsat-8 file. Update the file name and location with your own data. This example assumes that the pixel sizes for all rasters are 30 meters. No layer stacking is required.
e = ENVI()
File = 'LC80410302013213LGN00_MTL.txt'
Raster = e.OpenRaster(File)
OLIBands = Raster[0]
CirrusBand = Raster[2]
ThermalBands = Raster[3]
RadTask = ENVITask('RadiometricCalibration')
RadTask.INPUT_RASTER = OLIBands
RadTask.CALIBRATION_TYPE = 'Top-of-Atmosphere Reflectance'
RadTask.Execute
CirrusRadTask = ENVITask('RadiometricCalibration')
CirrusRadTask.INPUT_RASTER = CirrusBand
CirrusRadTask.CALIBRATION_TYPE = 'Top-of-Atmosphere Reflectance'
CirrusRadTask.Execute
BTTask = ENVITask('RadiometricCalibration')
BTTask.INPUT_RASTER = ThermalBands
BTTask.CALIBRATION_TYPE = 'Brightness Temperature'
BTTask.Execute
CloudTask = ENVITask('CalculateCloudMaskUsingFmask')
CloudTask.INPUT_BRIGHTNESS_TEMPERATURE_RASTER = BTTask.OUTPUT_RASTER
CloudTask.INPUT_CIRRUS_RASTER = CirrusRadTask.OUTPUT_RASTER
CloudTask.INPUT_REFLECTANCE_RASTER = RadTask.OUTPUT_RASTER
CloudTask.Execute
DataColl = e.Data
DataColl.Add, CloudTask.OUTPUT_RASTER
View = e.GetView()
Layer = View.CreateLayer(CloudTask.OUTPUT_RASTER)
View.Zoom, /FULL_EXTENT
The result of this process is a binary image where cloud (masked) pixels have values of 0 and non-cloud (non-masked) pixels have values of 1. To apply the mask to the input reflectance raster, add the following steps. The masked pixels will have NoData values.
rasterWithMask = ENVIMaskRaster( $
RadTask.OUTPUT_RASTER, $
CloudTask.OUTPUT_RASTER)
DataColl.Add, rasterWithMask
Layer2 = View.CreateLayer(rasterWithMask)
You can use the rasterWithMask raster for any subsequent image processing now that you calibrated it to top-of-atmosphere reflectance and applied a cloud mask. If you will perform spectral analysis on the data, you should correct for atmospheric effects next by using the ENVIQUACTask routine.
Syntax
Result = ENVITask('CalculateCloudMaskUsingFmask')
Input properties (Set, Get): INPUT_BRIGHTNESS_TEMPERATURE_RASTER, INPUT_CIRRUS_RASTER, KERNEL_SIZE, CLOUD_THRESHOLD, OUTPUT_RASTER_URI, INPUT_REFLECTANCE_RASTER
Output properties (Get only): OUTPUT_RASTER
Properties marked as "Set" are those that you can set to specific values. You can also retrieve their current values any time. Properties marked as "Get" are those whose values you can retrieve but not set.
Methods
This task inherits the following methods from ENVITask:
AddParameter
Execute
Parameter
ParameterNames
RemoveParameter
Properties
This task inherits the following properties from ENVITask:
COMMUTE_ON_DOWNSAMPLE
COMMUTE_ON_SUBSET
DESCRIPTION
DISPLAY_NAME
NAME
REVISION
TAGS
This task also contains the following properties:
KERNEL_SIZE (optional)
Specify the number of pixels along one side of a square kernel. The default value is 7 (to create a 7 x 7 array). Cloud regions are dilated by this kernel size before output.
CLOUD_THRESHOLD (optional)
Specify a floating-point threshold for cloud probability over clear-land and clear-water regions. The default value is 22.5.
INPUT_BRIGHTNESS_TEMPERATURE_RASTER (optional)
Specify a thermal band raster, calibrated to brightness temperatures. The input wavelengths must range from 10.4 to 12.5 µm. First execute the RadiometricCalibration task with the CALIBRATION_TYPE property set to Brightness Temperature, then pass its output to INPUT_BRIGHTNESS_TEMPERATURE_RASTER.
See Metaspectral Datasets for instructions on specifying the correct array element for the thermal bands.
INPUT_CIRRUS_RASTER (optional)
Specify a Landsat-8 cirrus band raster, calibrated to top-of-atmosphere reflectance. The input wavelengths must range from 1.36 to 1.385 µm. First execute the RadiometricCalibration task with the CALIBRATION_TYPE property set to Top-of-atmosphere Reflectance, then pass its output to INPUT_CIRRUS_RASTER. See Metaspectral Datasets for instructions on specifying the correct array element for the cirrus band.
INPUT_REFLECTANCE_RASTER (required)
Specify a raster containing the Landsat multispectral bands, calibrated to top-of-atmosphere (TOA) reflectance. First execute the RadiometricCalibration task with the CALIBRATION_TYPE property set to Top-of-atmosphere Reflectance, then pass its output to INPUT_REFLECTANCE_RASTER.
- Landsat 4-5 TM: Bands 1-5, 7
- Landsat-7 ETM+: Bands 1-7
- Landsat-8 OLI: Coastal aerosol, Blue, Green, Red, NIR, SWIR1, SWIR2
See Metaspectral Datasets for instructions on specifying the correct array element for the multispectral bands.
The input wavelengths must be within the following ranges:
- Blue: 0.45 - 0.523 µm
- Green: 0.52 - 0.605 µm
- Red: 0.63 - 0.69 µm
- NIR: 0.75 - 0.9 µm
- SWIR1: 1.55 - 1.75 µm
- SWIR2: 2.05 - 2.380 µm
OUTPUT_RASTER
This is a reference to the output raster of filetype ENVI.
OUTPUT_RASTER_URI (optional)
Specify a string with the fully qualified filename and path of the associated OUTPUT_RASTER. If you do not specify this property, or set it to an exclamation symbol (!), a temporary file will be created.
Version History
API Version
4.2
See Also
ENVITask, CalculateCloudMaskForProduct Task, RadiometricCalibration Task, QUAC Task, ENVILayerStackRaster