Atcor3 Manual

You are on page 1of 280

Atmospheric / Topographic Correction for Satellite Imagery

(ATCOR-2/3 User Guide, Version 9.2.0, March 2018)

R. Richter1 and D. Schläpfer2


1
DLR - German Aerospace Center, D - 82234 Wessling, Germany
2
ReSe Applications LLC , Langeggweg 3, CH-9500 Wil SG, Switzerland
DLR-IB 565-01/2018
2

The cover image shows a Sentinel-2A scene from San Francisco, acquired November 17, 2015.
Top left to right: original scene (RGB = 665, 560, 443 nm), dehazed scene including cirrus removal,
classification map (blue: water, light blue: cirrus over water, brown: land, yellow: cirrus over land).
Bottom left to right: subset (8 km x 8 km) of original scene, dehazed subset, cirrus map (the darker
colors indicates indicate increasing cirrus optical thickness).
The cirrus clouds of varying optical thickness are successfully removed.

ATCOR-2/3 User Guide, Version 9.2.0, March 2018

Authors:
R. Richter1 and D. Schläpfer2
1 DLR - German Aerospace Center, D - 82234 Wessling , Germany
2 ReSe Applications LLC, Langeggweg 3, CH-9500 Wil SG, Switzerland


c All rights are with the authors of this manual.

Distribution:
ReSe Applications Schläpfer
Langeggweg 3, CH-9500 Wil, Switzerland

Updates: see ReSe download page: www.rese-apps.com/software/download

The ATCOR R trademark is held by DLR and refers to the satellite and airborne versions of the
software.
The MODTRAN R trademark is being used with the express permission of the owner, the United
States of America, as represented by the United States Air Force.
Contents

1 Introduction 13

2 Basic Concepts in the Solar Region 16


2.1 Radiation components . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18
2.2 Spectral calibration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21
2.3 Inflight radiometric calibration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22
2.4 De-shadowing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23
2.5 BRDF correction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25

3 Basic Concepts in the Thermal Region 29

4 Workflow 31
4.1 Menus Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31
4.2 First steps with ATCOR . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 33
4.3 Survey of processing steps . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37
4.4 Directory structure of ATCOR . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38
4.5 Convention for file names . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38
4.6 User-defined hyperspectral sensors . . . . . . . . . . . . . . . . . . . . . . . . . . . . 40
4.6.1 Definition of a new sensor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41
4.7 Spectral smile sensors . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43
4.8 Haze, cloud, water map . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45
4.9 Processing of multiband thermal data . . . . . . . . . . . . . . . . . . . . . . . . . . 46
4.10 External water vapor map . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50
4.11 External AOT 550 nm map . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50
4.12 External float illumination file and de-shadowing . . . . . . . . . . . . . . . . . . . . 50

5 Description of Modules 52
5.1 Menu: File . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53
5.1.1 Display ENVI File . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53
5.1.2 Show Textfile . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 57
5.1.3 Select Input Image . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 57
5.1.4 Resize Input Image . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 57
5.1.5 Rename File Group . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 58
5.1.6 Import: Geographic Lat/Lon . . . . . . . . . . . . . . . . . . . . . . . . . . . 59
5.1.7 Import: Various File Formats . . . . . . . . . . . . . . . . . . . . . . . . . . . 60
5.1.8 Import . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 60
5.1.9 Export . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 61
5.1.10 Plot Sensor Response . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62

3
CONTENTS 4

5.1.11 Plot Calibration File . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62


5.1.12 Read Sensor Meta Data . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62
5.1.13 Show System File . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 63
5.1.14 Edit Preferences . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64
5.2 Menu: Sensor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 66
5.2.1 Define Sensor Parameters . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 67
5.2.2 FTS Generate Wavelength File from (cm-1) in ENVI hdr . . . . . . . . . . . 68
5.2.3 Generate Spectral Filter Functions . . . . . . . . . . . . . . . . . . . . . . . . 70
5.2.4 Apply Spectral Shift to Sensor . . . . . . . . . . . . . . . . . . . . . . . . . . 71
5.2.5 BBCALC : Blackbody Function . . . . . . . . . . . . . . . . . . . . . . . . . . 72
5.2.6 RESLUT : Resample Atm. LUTS from Database . . . . . . . . . . . . . . . . 73
5.3 Menu: Topographic . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 74
5.3.1 DEM Import: Import Global DEM . . . . . . . . . . . . . . . . . . . . . . . . 74
5.3.2 DEM Import: Geographic Lat/Lon DEM . . . . . . . . . . . . . . . . . . . . 75
5.3.3 DEM Import: Geo-TIFF . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 75
5.3.4 DEM Import: ARC GRID ASCII . . . . . . . . . . . . . . . . . . . . . . . . . 75
5.3.5 DEM Preparation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 76
5.3.6 Slope/Aspect . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 77
5.3.7 Skyview Factor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 78
5.3.8 Cast Shadow Mask . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 79
5.3.9 Image Based Shadows . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 80
5.3.10 DEM Smoothing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 81
5.3.11 Quick Topographic (no atm.) Correction . . . . . . . . . . . . . . . . . . . . 82
5.4 Menu: ATCOR . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 84
5.4.1 The ATCOR main panel . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 84
5.4.2 ATCOR2: standard sensors, flat terrain . . . . . . . . . . . . . . . . . . . . . 84
5.4.3 ATCOR3: standard sensors, rugged terrain . . . . . . . . . . . . . . . . . . . 84
5.4.4 ATCOR2: Advanced Sensors . . . . . . . . . . . . . . . . . . . . . . . . . . . 85
5.4.5 ATCOR3: Advanced Sensors . . . . . . . . . . . . . . . . . . . . . . . . . . . 86
5.4.6 SPECTRA module . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 88
5.4.7 Aerosol Type . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 89
5.4.8 Visibility Estimate . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 89
5.4.9 Inflight radiometric calibration module . . . . . . . . . . . . . . . . . . . . . . 89
5.4.10 Shadow removal panels . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 92
5.4.11 Panels for Image Processing . . . . . . . . . . . . . . . . . . . . . . . . . . . . 95
5.4.12 Start ATCOR Process (Batch / Tiled) . . . . . . . . . . . . . . . . . . . . . 100
5.4.13 Sentinel-2 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 101
5.4.14 Landsat-8 TIRS: Calculate Temperature . . . . . . . . . . . . . . . . . . . . . 103
5.5 Menu: BRDF . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 104
5.5.1 BREFCOR Correction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 104
5.5.2 Nadir normalization (Wide FOV Imagery) . . . . . . . . . . . . . . . . . . . . 106
5.5.3 Mosaicking . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 107
5.5.4 Empirical Deshading . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 108
5.6 Menu: Filter . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 110
5.6.1 Resample a Spectrum . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 110
5.6.2 Low pass filter a Spectrum . . . . . . . . . . . . . . . . . . . . . . . . . . . . 110
5.6.3 Spectral Polishing: Statistical Filter . . . . . . . . . . . . . . . . . . . . . . . 111
5.6.4 Spectral Polishing: Radiometric Variation . . . . . . . . . . . . . . . . . . . . 112
CONTENTS 5

5.6.5 Flat Field Polishing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 113


5.6.6 Pushbroom Polishing / Destriping . . . . . . . . . . . . . . . . . . . . . . . . 113
5.6.7 Spectral Smile Interpolation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 114
5.6.8 Cast Shadow Border Removal . . . . . . . . . . . . . . . . . . . . . . . . . . . 116
5.7 Menu: Simulation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 118
5.7.1 TOA/At-Sensor Radiance Cube . . . . . . . . . . . . . . . . . . . . . . . . . . 118
5.7.2 TOA/At-Sensor Thermal Radiance . . . . . . . . . . . . . . . . . . . . . . . . 118
5.7.3 At-Sensor Apparent Reflectance . . . . . . . . . . . . . . . . . . . . . . . . . 118
5.7.4 TOA/At-Sensor Spectra Simulation . . . . . . . . . . . . . . . . . . . . . . . 119
5.7.5 Vicarious Validation (At-Sensor) . . . . . . . . . . . . . . . . . . . . . . . . . 121
5.7.6 Resample Image Cube . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 122
5.8 Menu: Tools . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 124
5.8.1 Solar Zenith and Azimuth . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 124
5.8.2 Classification of Surface Reflectance Signatures . . . . . . . . . . . . . . . . . 125
5.8.3 SPECL for User Defined Sensors . . . . . . . . . . . . . . . . . . . . . . . . . 125
5.8.4 Add a Blue Spectral Channel . . . . . . . . . . . . . . . . . . . . . . . . . . . 126
5.8.5 Spectral Smile Detection . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 128
5.8.6 Spectral Calibration (Atm. Absorption Features) . . . . . . . . . . . . . . . . 131
5.8.7 Calibration Coefficients with Regression . . . . . . . . . . . . . . . . . . . . . 132
5.8.8 Convert High Res. Database (New Solar Irradiance) . . . . . . . . . . . . . . 134
5.8.9 Convert .atm for another Irradiance Spectrum . . . . . . . . . . . . . . . . . 134
5.8.10 MTF, PSF, and effective GIFOV . . . . . . . . . . . . . . . . . . . . . . . . . 134
5.9 Menu: Help . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 137
5.9.1 Help Options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 137

6 Batch Processing Reference 138


6.1 Starting ATCOR from console . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 138
6.2 Using the batch mode from within IDL . . . . . . . . . . . . . . . . . . . . . . . . . 139
6.3 Batch modules, keyword-driven modules . . . . . . . . . . . . . . . . . . . . . . . . . 141
6.4 Meta File Reader . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 154

7 Value Added Products 156


7.1 LAI, FPAR, Albedo . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 156
7.2 Surface energy balance . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 158

8 Sensor simulation of hyper/multispectral imagery 164

9 Implementation Reference and Sensor Specifics 169


9.1 The Monochromatic atmospheric database . . . . . . . . . . . . . . . . . . . . . . . . 169
9.1.1 Visible / Near Infrared region . . . . . . . . . . . . . . . . . . . . . . . . . . . 169
9.1.2 Thermal region . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 170
9.1.3 Database update with solar irradiance . . . . . . . . . . . . . . . . . . . . . . 171
9.1.4 Sensor-specific atmospheric database . . . . . . . . . . . . . . . . . . . . . . . 172
9.1.5 Resample sensor-specific atmospheric LUTs with another solar irradiance . . 172
9.2 Supported I/O file types . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 173
9.2.1 Side inputs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 174
9.2.2 Main output . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 175
9.2.3 Side outputs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 176
9.3 Preference parameters for ATCOR . . . . . . . . . . . . . . . . . . . . . . . . . . . . 177
CONTENTS 6

9.4 Job control parameters of the ”inn” file . . . . . . . . . . . . . . . . . . . . . . . . . 180


9.5 Problems and Hints . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 187
9.6 Supported sensors without import function . . . . . . . . . . . . . . . . . . . . . . . 189
9.7 Import for standard sensors . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 189
9.8 Metadata files (geometry and calibration) . . . . . . . . . . . . . . . . . . . . . . . . 192
9.8.1 Import Landsat Data . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 192
9.8.2 Landsat-5 TM, Landsat-7 ETM+ . . . . . . . . . . . . . . . . . . . . . . . . . 193
9.8.3 Landsat-8 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 194
9.8.4 Landsat-8 TIRS . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 194
9.8.5 Import Sentinel-2 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 198
9.8.6 SPOT-1 to SPOT-5 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 199
9.8.7 SPOT-6, SPOT-7 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 201
9.8.8 ALOS AVNIR-2 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 201
9.8.9 Ikonos . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 201
9.8.10 Quickbird . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 202
9.8.11 IRS-1C/1D Liss . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 202
9.8.12 IRS-P6 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 203
9.8.13 ASTER . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 203
9.8.14 DMC (Disaster Monitoring Constellation) . . . . . . . . . . . . . . . . . . . . 203
9.8.15 RapidEye . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 204
9.8.16 GeoEye-1 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 204
9.8.17 WorldView-2 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 204
9.8.18 THEOS . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 205
9.8.19 Pleiades . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 205
9.8.20 Planet Labs, TripleSat . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 205

10 Theoretical Background 206


10.1 Basics on radiative transfer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 209
10.1.1 Solar spectral region . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 209
10.1.2 Illumination based shadow detection and correciton . . . . . . . . . . . . . . 215
10.1.3 Integrated Radiometric Correction (IRC) . . . . . . . . . . . . . . . . . . . . 220
10.1.4 Spectral solar flux, reflected surface radiance . . . . . . . . . . . . . . . . . . 221
10.1.5 Thermal spectral region . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 222
10.2 Masks for haze, cloud, water, snow . . . . . . . . . . . . . . . . . . . . . . . . . . . . 227
10.3 Quality layers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 231
10.4 Quality confidence layer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 232
10.5 Standard atmospheric conditions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 232
10.5.1 Constant visibility (aerosol) and atmospheric water vapor . . . . . . . . . . . 232
10.5.2 Aerosol retrieval and visibility map . . . . . . . . . . . . . . . . . . . . . . . . 233
10.5.3 Water vapor retrieval . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 240
10.6 Non-standard conditions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 242
10.6.1 Haze removal . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 242
10.6.2 Haze removal with HTM . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 242
10.6.3 Haze removal with HOT . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 243
10.6.4 Haze or sun glint removal over water . . . . . . . . . . . . . . . . . . . . . . . 245
10.6.5 Cirrus removal . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 247
10.6.6 De-shadowing with matched filter . . . . . . . . . . . . . . . . . . . . . . . . . 249
10.7 Correction of BRDF effects . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 255
CONTENTS 7

10.7.1 Nadir normalization method . . . . . . . . . . . . . . . . . . . . . . . . . . . 255


10.7.2 Empirical incidence BRDF correction in rugged terrain . . . . . . . . . . . . 257
10.7.3 BRDF effect correction (BREFCOR) . . . . . . . . . . . . . . . . . . . . . . . 260
10.7.4 BRDF cover index . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 261
10.8 Summary of atmospheric correction steps . . . . . . . . . . . . . . . . . . . . . . . . 264
10.8.1 Algorithm for flat terrain . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 265
10.8.2 Algorithm for rugged terrain . . . . . . . . . . . . . . . . . . . . . . . . . . . 267
10.9 Accuracy of the method . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 267

References 269

A Altitude Profile of Standard Atmospheres 276

B Comparison of Solar Irradiance Spectra 279


List of Figures

2.1 Visibility, AOT, and total optical thickness, atmospheric transmittance. . . . . . . . 17


2.2 Schematic sketch of solar radiation components in flat terrain. . . . . . . . . . . . . . 19
2.3 Wavelength shifts for an AVIRIS scene. . . . . . . . . . . . . . . . . . . . . . . . . . 22
2.4 Radiometric calibration with multiple targets using linear regression. . . . . . . . . . 24
2.5 Sketch of a cloud shadow geometry. . . . . . . . . . . . . . . . . . . . . . . . . . . . . 24
2.6 De-shadowing of an Ikonos image of Munich. . . . . . . . . . . . . . . . . . . . . . . 25
2.7 Zoomed view of central part of Figure 2.6. . . . . . . . . . . . . . . . . . . . . . . . . 26
2.8 Nadir normalization of an image with hot-spot geometry. Left: reflectance image
without BRDF correction. Right: after empirical BRDF correction. . . . . . . . . . . 26
2.9 BRDF correction in rugged terrain imagery. Left: image without BRDF correction.
Center: after BRDF correction with threshold angle βT = 65◦ . Right: illumination
map = cosβ. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27
2.10 Effect of BRDF correction on mosaic (RapidEye image, DLR) c . . . . . . . . . . . 28

3.1 Atmospheric transmittance in the thermal region. . . . . . . . . . . . . . . . . . . . . 29


3.2 Radiation components in the thermal region. . . . . . . . . . . . . . . . . . . . . . . 30

4.1 Top level graphical interface of ATCOR. . . . . . . . . . . . . . . . . . . . . . . . . . 31


4.2 Top level graphical interface of ATCOR: ”File” and ”Import”. . . . . . . . . . . . . 32
4.3 Top level graphical interface of ATCOR: ”Sensor”. . . . . . . . . . . . . . . . . . . . 33
4.4 Topographic modules. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 33
4.5 Top level graphical interface of ATCOR: ”Atmospheric Correction”. . . . . . . . . . 34
4.6 ATCOR panel for flat terrain imagery. . . . . . . . . . . . . . . . . . . . . . . . . . . 35
4.7 Image processing options. Right panel appears if a cirrus band exists. . . . . . . . . 36
4.8 Panel for DEM files. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36
4.9 Typical workflow of atmospheric correction. . . . . . . . . . . . . . . . . . . . . . . . 37
4.10 Input / output image files during ATCOR processing. . . . . . . . . . . . . . . . . . 38
4.11 Directory structure of ATCOR. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39
4.12 Template reference spectra from the ’spec lib’ library. . . . . . . . . . . . . . . . . . 40
4.13 Directory structure of ATCOR with hyperspectral add-on. . . . . . . . . . . . . . . . 41
4.14 Supported analytical channel filter types. . . . . . . . . . . . . . . . . . . . . . . . . 42
4.15 Optional haze/cloud/water output file. . . . . . . . . . . . . . . . . . . . . . . . . . . 46
4.16 Path radiance and transmittace of a SEBASS scene derived from the ISAC method. 48
4.17 Comparison of radiance and temperature at sensor and at surface level. . . . . . . . 49

5.1 Top level menu of the satellite ATCOR. . . . . . . . . . . . . . . . . . . . . . . . . . 52


5.2 The File Menu . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53
5.3 Band selection dialog for ENVI file display . . . . . . . . . . . . . . . . . . . . . . . . 54

8
LIST OF FIGURES 9

5.4 Display of ENVI imagery . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 56


5.5 Simple text editor to edit plain text ASCII files . . . . . . . . . . . . . . . . . . . . . 57
5.6 Resize ATCOR input imagery . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 58
5.7 Import Geographic Lat/Lon image files . . . . . . . . . . . . . . . . . . . . . . . . . 59
5.8 Plotting the explicit sensor response functions . . . . . . . . . . . . . . . . . . . . . . 62
5.9 Plotting a calibration file . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 63
5.10 Read sensor meta file. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64
5.11 Displaying a calibration file (same file as in Fig. 5.9) . . . . . . . . . . . . . . . . . . 64
5.12 Panel to edit the ATCOR preferences. . . . . . . . . . . . . . . . . . . . . . . . . . . 65
5.13 The ’Sensor’ Menu . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 66
5.14 Sensor definition files: the three files on the left have to be provided/created by the
user. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 66
5.15 Definition of a new sensor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 67
5.16 Spectral Filter Creation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 69
5.17 Spectral Filter Creation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 70
5.18 Application of spectral shift to sensor . . . . . . . . . . . . . . . . . . . . . . . . . . 71
5.19 Black body function calculation panel . . . . . . . . . . . . . . . . . . . . . . . . . . 72
5.20 Panels of RESLUT for resampling the atmospheric LUTs. . . . . . . . . . . . . . . . 73
5.21 Topographic modules. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 74
5.22 Import DEM from global elevation data. . . . . . . . . . . . . . . . . . . . . . . . . . 75
5.23 Import DEM from ARC GRID ASCII. . . . . . . . . . . . . . . . . . . . . . . . . . . 75
5.24 DEM Preparation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 76
5.25 Slope/Aspect Calculation panel . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 77
5.26 Panel of SKYVIEW. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 78
5.27 Example of a DEM (left) with the corresponding sky view image (right). . . . . . . . 79
5.28 Panel of Cast Shadow Mask Calculation (SHADOW). . . . . . . . . . . . . . . . . . 79
5.29 Panel of Image Based Shadows. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 80
5.30 Panel of DEM smoothing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 82
5.31 Topographic correction only, no atmospheric correction. . . . . . . . . . . . . . . . . 83
5.32 The ’ATCOR’ Menu . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 84
5.33 ATCOR panel. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 85
5.34 Panel for DEM files. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 86
5.35 Panel to make a decision in case of a DEM with steps. . . . . . . . . . . . . . . . . . 86
5.36 Influence of DEM artifacts on the solar illumination image. . . . . . . . . . . . . . . 87
5.37 SPECTRA module. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 88
5.38 Radiometric calibration: target specification panel. . . . . . . . . . . . . . . . . . . . 90
5.39 Radiometric CALIBRATION module. . . . . . . . . . . . . . . . . . . . . . . . . . . 91
5.40 Normalized histogram of unscaled shadow function. . . . . . . . . . . . . . . . . . . . 92
5.41 Panel to define the parameters for interactive de-shadowing. . . . . . . . . . . . . . . 93
5.42 Quicklook of de-shadowing results. . . . . . . . . . . . . . . . . . . . . . . . . . . . . 94
5.43 Image processing options. Right panel appears if a cirrus band exists. . . . . . . . . 95
5.44 Emissivity selection panel. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 95
5.45 Options for haze processing. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 96
5.46 Reflectance ratio panel for dark reference pixels. . . . . . . . . . . . . . . . . . . . . 96
5.47 Incidence BRDF compensation panel. . . . . . . . . . . . . . . . . . . . . . . . . . . 97
5.48 Value added panel for a flat terrain. . . . . . . . . . . . . . . . . . . . . . . . . . . . 98
5.49 Value added panel for a rugged terrain. . . . . . . . . . . . . . . . . . . . . . . . . . 98
5.50 LAI / FPAR panel . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 99
LIST OF FIGURES 10

5.51 Job status window. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 99


5.52 ATCOR Tiled Processing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 101
5.53 Sentinel-2 Angular processing. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 102
5.54 TIRS module. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 103
5.55 Filter modules. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 104
5.56 BREFCOR correction panel (satellite version). . . . . . . . . . . . . . . . . . . . . . 105
5.57 Nadir normalization. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 106
5.58 Mosaicking Tool. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 107
5.59 Deshading/Brighness Adjustment Tool . . . . . . . . . . . . . . . . . . . . . . . . . . 109
5.60 Filter modules. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 110
5.61 Resampling of a (reflectance) spectrum. . . . . . . . . . . . . . . . . . . . . . . . . . 110
5.62 Low pass filtering of a (reflectance) spectrum. . . . . . . . . . . . . . . . . . . . . . . 111
5.63 Statistical spectral polishing. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 112
5.64 Radiometric spectral polishing. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 112
5.65 Flat field radiometric polishing. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 113
5.66 Pushbroom radiometric polishing. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 114
5.67 Spectral smile interpolation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 115
5.68 Shadow border removal tool . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 117
5.69 Simulation modules menu. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 118
5.70 Apparent Reflectance Calculation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 119
5.71 TOA radiance calculation from ground reference reflectance spectral library . . . . . 120
5.72 TOA radiance validation against calibrated image spectra . . . . . . . . . . . . . . . 121
5.73 Plot sample of validation against calibrated image spectra . . . . . . . . . . . . . . . 123
5.74 The tools menu. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 124
5.75 Calculation of sun angles. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 124
5.76 Examples of reflectance spectra and associated classes. . . . . . . . . . . . . . . . . . 126
5.77 SPECL: spectral classification of reflectance cube. . . . . . . . . . . . . . . . . . . . 126
5.78 Example of classification with SPECL. . . . . . . . . . . . . . . . . . . . . . . . . . . 127
5.79 Spectral smile detection . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 130
5.80 SPECTRAL CAL.: spectral calibration . . . . . . . . . . . . . . . . . . . . . . . . . 132
5.81 CAL REGRESS.: radiometric calibration with more than one target . . . . . . . . . 132
5.82 Convert monochromanic database to new solar reference function . . . . . . . . . . . 134
5.83 Convert atmlib to new solar reference function . . . . . . . . . . . . . . . . . . . . . 135
5.84 MTF and effective GIFOV. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 136
5.85 The help menu. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 137

7.1 Water vapor partial pressure. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 160


7.2 Air emissivity. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 161

8.1 Weight factors of hyperspectral bands. . . . . . . . . . . . . . . . . . . . . . . . . . . 165


8.2 Sensor simulation in the solar region. . . . . . . . . . . . . . . . . . . . . . . . . . . . 166
8.3 Graphical user interface of program ”HS2MS”. . . . . . . . . . . . . . . . . . . . . . 167
8.4 TOA radiances for three albedos. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 168

9.1 Monochromatic atmospheric database. . . . . . . . . . . . . . . . . . . . . . . . . . . 170


9.2 Solar irradiance database. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 172
9.3 User interface to convert database from one to another solar irradiance. . . . . . . . 173
9.4 GUI panels of the satellite version of program RESLUT. . . . . . . . . . . . . . . . . 174
9.5 Surface temperature error depending on water vapor column (emissivity=0.98). . . . 195
LIST OF FIGURES 11

9.6 Surface temperature error depending on water vapor column (water surface). . . . . 196
9.7 Spectral emissivity of water. Symbols mark the TIRS channel center wavelengths. . 196
9.8 Surface temperature error depending on water vapor column (emissivity=0.95). . . . 197
9.9 SPOT orbit geometry. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 200
9.10 Solar and view geometry. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 200

10.1 Main processing steps during atmospheric correction. . . . . . . . . . . . . . . . . . . 207


10.2 Visibility / AOT retrieval using dark reference pixels. . . . . . . . . . . . . . . . . . 208
10.3 Radiation components, illumination and viewing geometry. . . . . . . . . . . . . . . 209
10.4 Schematic sketch of solar radiation components in flat terrain. . . . . . . . . . . . . . 211
10.5 Radiation components in rugged terrain, sky view factor. . . . . . . . . . . . . . . . 213
10.6 Solar illumination geometry and radiation components. . . . . . . . . . . . . . . . . 215
10.7 Combination of illumination map (left) with cast shadow fraction (middle) into con-
tinuous illumination field (right). . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 216
10.8 Derivation of cast shadow mask from original image by calculating land index, water
index, water mask, a combination of both and applying a threshold of 0.33 to the
output. The indices (in blue) are linearly scaled between 0.2 and 0.6 in this sample. 218
10.9 Effect of combined topographic / cast shadow correction: left: original RGB image;
right: corrected image (data source: Leica ADS, central Switzerland 2008, courtesy
of swisstopo). . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 219
10.10Effect of cast shadow correction (middle) and shadow border removal (right) for
building shadows. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 220
10.11Radiation components in the thermal region. . . . . . . . . . . . . . . . . . . . . . . 223
10.12Quality confidence Q(SZA) and Q(AOT550). . . . . . . . . . . . . . . . . . . . . . . 233
10.13Schematic sketch of visibility determination with reference pixel. . . . . . . . . . . . 235
10.14Correlation of reflectance in different spectral regions. . . . . . . . . . . . . . . . . . 236
10.15Rescaling of the path radiance with the blue and red band. . . . . . . . . . . . . . . 237
10.16Optical thickness as a function of visibility and visibility index. . . . . . . . . . . . . 239
10.17Reference and measurement channels for the water vapor method. . . . . . . . . . . 240
10.18APDA ratio with an exponential fit function for the water vapor. . . . . . . . . . . . 241
10.19Haze removal method. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 244
10.20Subset of Ikonos image of Dresden, 18 August 2002. . . . . . . . . . . . . . . . . . . 245
10.21Haze removal over water, ALOS-AVNIR2 . . . . . . . . . . . . . . . . . . . . . . . . 246
10.22Sketch of a cloud shadow geometry. . . . . . . . . . . . . . . . . . . . . . . . . . . . . 249
10.23Flow chart of processing steps during de-shadowing. . . . . . . . . . . . . . . . . . . 250
10.24Normalized histogram of unscaled shadow function. . . . . . . . . . . . . . . . . . . . 251
10.25Cloud shadow maps of a HyMap scene. . . . . . . . . . . . . . . . . . . . . . . . . . 252
10.26De-shadowing of a Landsat-7 ETM+ scene. . . . . . . . . . . . . . . . . . . . . . . . 255
10.27Nadir normalization of an image with hot-spot geometry. . . . . . . . . . . . . . . . 257
10.28Geometric functions for empirical BRDF correction. Left: Functions G eq. (10.127)
for different values of the exponent b. Right: Functions G of eq. (10.127) for b=1
and different start values of βT . The lower cut-off value is g=0.2. . . . . . . . . . . . 259
10.29BRDF model calibration scheme . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 263
10.30Image correction scheme. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 264
10.31BREFCOR mosaic correction: Top: uncorrected, Bottom: corrected (RapidEye
chessboard image mosaic, (c) DLR). . . . . . . . . . . . . . . . . . . . . . . . . . . . 265
10.32Weighting of q function for reference pixels. . . . . . . . . . . . . . . . . . . . . . . . 266
List of Tables

4.1 Example of a sensor definition file (no thermal bands). . . . . . . . . . . . . . . . . . 42


4.2 Sensor definition file: instrument with thermal bands. . . . . . . . . . . . . . . . . . 43
4.3 Sensor definition file: smile sensor without thermal bands. . . . . . . . . . . . . . . . 44
4.4 Class label definition of ”hcw” file. . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47

6.1 Command Line Batch Process Options . . . . . . . . . . . . . . . . . . . . . . . . . . 139

7.1 Heat fluxes for the vegetation and urban model. . . . . . . . . . . . . . . . . . . . . . 162

9.1 Elevation and tilt angles for Ikonos. . . . . . . . . . . . . . . . . . . . . . . . . . . . 202


9.2 Radiometric coefficients c1 for ASTER. . . . . . . . . . . . . . . . . . . . . . . . . . 203

10.1 Class labels in the hcw file. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 228


10.2 Visibility iterations on negative reflectance pixels (red, NIR bands). . . . . . . . . . 234

A.1 Altitude profile of the dry atmosphere. . . . . . . . . . . . . . . . . . . . . . . . . . . 276


A.2 Altitude profile of the midlatitude winter atmosphere. . . . . . . . . . . . . . . . . . 277
A.3 Altitude profile of the fall (autumn) atmosphere. . . . . . . . . . . . . . . . . . . . . 277
A.4 Altitude profile of the 1976 US Standard. . . . . . . . . . . . . . . . . . . . . . . . . 277
A.5 Altitude profile of the subarctic summer atmosphere. . . . . . . . . . . . . . . . . . . 278
A.6 Altitude profile of the midlatitude summer atmosphere. . . . . . . . . . . . . . . . . 278
A.7 Altitude profile of the tropical atmosphere. . . . . . . . . . . . . . . . . . . . . . . . 278

12
Chapter 1

Introduction

The objective of any radiometric correction of airborne and spaceborne imagery of optical sensors is
the extraction of physical earth surface parameters such as spectral albedo, directional reflectance
quantities, emissivity, and temperature. To achieve this goal, the influence of the atmosphere,
solar illumination, sensor viewing geometry, and terrain information have to be taken into account.
Although a lot of information from airborne and satellite imagery can be extracted without radio-
metric correction, the physical model based approach as implemented in ATCOR offers advantages,
especially when dealing with multitemporal data and when a comparison of different sensors is re-
quired. In addition, the full potential of imaging spectrometers can only be exploited with this
approach.

Although physical models can be quite successful to eliminate atmospheric and topographic ef-
fects they inherently rely on an accurate spectral and radiometric sensor calibration and on the
accuracy and appropriate spatial resolution of a digital elevation model (DEM) in rugged terrain.
In addition, many surfaces have a bidirectional reflectance behavior, i.e., the reflectance depends
on the illumination and viewing geometry. The usual assumption of an isotropic or Lambertian
reflectance law is appropriate for small field-of-view (FOV < 30o , scan angle < ±15o ) sensors if
viewing does not take place in the solar principal plane. However, for large FOV sensors and / or
data recording close to the principal plane the anisotropic reflectance behavior of natural surfaces
causes brightness gradients in the image. These effects can be removed with an empirical method
that normalizes the data to nadir reflectance values. In addition, for rugged terrain areas illumi-
nated under low local solar elevation angles, these effects also play a role and can be taken care of
with an empirical method included in the ATCOR package.

The ATCOR software was developed to cover about 80% of the typical cases with a reasonable
amount of coding. It is difficult if not impossible to achieve satisfactory results for all possible
cases. Special features of ATCOR are the consideration of topographic effects and the capability
to process thermal band imagery.

There are two ATCOR models available, one for satellite imagery, the other one for airborne im-
agery ([?], [?]). The satellite version of ATCOR supports all major commercially available small-
to-medium FOV sensors with a sensor-specific atmospheric database of look-up tables (LUTs)
containing the results of pre-calculated radiative transfer calculations. New sensors will be added
on demand. The current list of supported sensors is available at this web address. A simple in-
terface has been added to provide the possibility to include user-defined instruments. It is mainly
intended for hyperspectral sensors where the center wavelength of channels is not stable and a

13
CHAPTER 1. INTRODUCTION 14

re-calculation of atmospheric LUTs is required.

An integral part of all ATCOR versions is a large database containing the results of radiative trans-
fer calculations based on the Modtran 5
R code (Berk et al. 1998, 2008, 2016). While ATCOR uses
the AFRL MODTRAN code to calculate the database of atmospheric look-up tables (LUT), the
correctness of the LUT’s is the responsibility of ATCOR.

Historical note:
For historical reasons, the satellite codes are called ATCOR-2 (flat terrain, two geometric degrees-
of-freedom DOF [?]) and ATCOR-3 (three DOF’s, mountainous terrain [?]). They support all
commercially available small to medium FOV satellite sensors with a sensor-specific atmospheric
database. The scan angle dependence of the atmospheric correction functions within a scene is
neglected here.

The airborne version is called ATCOR-4, to indicate the four geometric DOF’s x, y, z, and scan
angle [?]. It includes the scan angle dependence of the atmospheric correction functions, a nec-
essary feature, because most airborne sensors have a large FOV up to 60◦ - 90◦ . While satellite
sensors always operate outside the atmosphere, airborne instruments can operate in altitudes of a
few hundred meters up to 20 km. So the atmospheric database has to cover a range of altitudes.
Since there is no standard set of airborne instruments and the spectral / radiometric performance
might change from year to year due to sensor hardware modifications, a monochromatic atmo-
spheric database was compiled based on the Modtran 5 R radiative transfer code. This database
has to be resampled for each user-defined sensor.

Organization of the manual:

Chapters 2 and 3 contain a short description of the basic concepts of atmospheric correction which
will be useful for newcomers. Chapter 2 discusses the solar spectral region, while chapter 3 treats
the thermal region. Chapter 4 presents the workflow in ATCOR, and chapter 5 contains a detailed
description of the graphical user interface panels of the major modules. Chapter 6 describes the
batch processing capabilities with ATCOR. It is followed by chapters on sensor simulation, imple-
mentation issues, and sensor specifics.. The theoretical background of ATCOR is described in a
separate document [?].

Information on the IDL version of ATCOR can be found on the internet: https://www.rese-apps.
com

What is new in the 2019 version:

• The pre-classification maps of ’scene out hcw.bsq’ and ’scene haze map.bsq’ are harmonized.

• The water, shadow, snow classification is improved. A class ’cloud shadow’ is added to the
’scene out hcw.bsq’.

• The cloud shadow mask is based on the cloud mask, the potential shadow mask, and geometric
criteria. Patches of the cloud mask are shifted according to the solar azimuth angle, and the
shift vector depends on the solar zenith and azimuth angles and the cloud height. Since the
cloud height is not known, the method iterates the height from 300 m above ground to 6 km,
CHAPTER 1. INTRODUCTION 15

and for cirrus clouds from 6 km to 15 km. The approach can handle different cloud heights
in the various parts of a scene.

• Another pre-classification map ’scene out csw.bsq’ with only 6 basic classes is provided (cloud,
semi-transparent cloud, shadow, water, snow/ice, clear) as many applications do not need the
22 classes of ’scene out hcw.bsq’.

• The performance of the dehaze module is improved.

• A conversion tool (visibility < −− > AOT550nm) is available (main menu, Tools) to convert
AERONET aerosol optical thickness AOT(550nm) into visibility and vice versa.

• New modules for topographic correction have been added.

• Additional sensors are supported: Superview-1 (Chinese instrument, 4 multispectral VNIR


bands at 2 m, panchromatic at 0.5 m), Venus (French/Israel, 12 VNIR bands at 5 m).

• The documentation of the User’s Manual is updated.The theoretical background of ATCOR


is described in a separate document.
Chapter 2

Basic Concepts in the Solar Region

Standard books on optical remote sensing contain an extensive presentation on sensors, spectral
signatures, and atmospheric effects where the interested reader is referred to (Slater 1980 [?], Asrar
1989 [?], Schowengert 1997 [?]).
This chapter describes the basic concept of atmospheric correction. Only a few simple equations
(2.1-2.16) are required to understand the key issues. We start with the radiation components and
the relationship between the at-sensor radiance and the digital number or grey level of a pixel. Then
we are already able to draw some important conclusions about the radiometric calibration. We
continue with some remarks on how to select atmospheric parameters. Next is a short discussion
about the thermal spectral region. The remaining sections present the topics of BRDF correction,
spectral / radiometric calibration, and de-shadowing. For a discussion of the haze removal method
the reader is referred to chapter 10.6.3.

Two often used parameters for the description of the atmosphere are ’visibility’ and ’optical thick-
ness’.

Visibility and optical thickness

The visibility (horizontal meteorological range) is approximately the maximum horizontal distance
a human eye can recognize a dark object against a bright sky. The exact definition is given by the
Koschmieder equation:
1 1 3.912
V IS = ln = (2.1)
β 0.02 β
where β is the extinction coefficient (unit km−1 ) at 550 nm. The term 0.02 in this equation is an
arbitrarily defined contrast threshold. Another often used concept is the optical thickness of the
atmosphere (δ) which is the product of the extinction coefficient and the path length x (e.g., from
sea level to space in a vertical path) :
δ=β x (2.2)
The optical thickness is a pure number. In most cases, it is evaluated for the wavelength 550 nm.
Generally, there is no unique relationship between the (horizontal) visibility and the (vertical) total
optical thickness of the atmosphere. However, with the MODTRAN R radiative transfer code a
certain relationship has been defined between these two quantities for clear sky conditions as shown
in Fig. 2.1 (left) for a path from sea level to space. The optical thickness can be defined separately
for the different atmospheric constituents (molecules, aerosols), so there is an optical thickness due

16
CHAPTER 2. BASIC CONCEPTS IN THE SOLAR REGION 17

to molecular (Rayleigh) and aerosol scattering, and due to molecular absorption (e.g., water water,
ozone etc.). The total optical thickness is the sum of the thicknesses of all individual contributors :

δ = δ(molecular scattering) + δ(aerosol) + δ(molecular absorption) (2.3)

The MODTRAN R visibility parameter scales the aerosol content in the boundary layer (0 - 2 km
altitude). For visibilities greater than 100 km the total optical thickness asymptotically approaches
a value of about 0.17 which (at 550 nm) is the sum of the molecular thickness (δ = 0.0973) plus ozone
thickness (δ = 0.03) plus a very small amount due to trace gases, plus the contribution of residual
aerosols in the higher atmosphere (2 - 100 km) with δ = 0.04. The minimum optical thickness
or maximum visibility is reached if the air does not contain aerosol particles (so called ”Rayleigh
limit”) which corresponds to a visibility of 336 km at sea level and no aerosols in the boundary
layer and higher atmosphere. In this case the total optical thickness (molecular and ozone) is
about δ = 0.13. Since the optical thickness due to molecular scattering (nitrogen and oxygen) only
depends on pressure level it can be calculated accurately for a known ground elevation. The ozone
contribution to the optical thickness usually is small at 550 nm and a climatologic/geographic
average (331 DU) can be taken. Nevertheless, if scene information on ozone is available, it can
be specified as an input parameter. This leaves the aerosol contribution as the most important
component which varies strongly in space and time. Therefore, the aerosol optical thickness (AOT)
at 550 nm is often used to characterize the atmosphere instead of the visibility.

Figure 2.1: Visibility, AOT, and total optical thickness, atmospheric transmittance.

The atmospheric (direct or beam) transmittance for a vertical path through the atmosphere can
be calculated as :

τ = e−δ (2.4)

Fig. 2.1 (right) shows an example of the atmospheric transmittance from 0.4 to 2.5 µm. The
spectral regions with relatively high transmittance are called ”atmospheric window” regions. In
absorbing regions the name of the molecule responsible for the attenuation of radiation is included.

Apparent reflectance
CHAPTER 2. BASIC CONCEPTS IN THE SOLAR REGION 18

The apparent reflectance describes the combined earth/atmosphere behavior with respect to the
reflected solar radiation:
π d2 L
ρ(apparent) = (2.5)
E cosθs
where d is the earth-sun distance in astronomical units, L = c0 + c1 DN is the at-sensor radiance,
c0 , c1 , DN , are the radiometric calibration offset, gain, and digital number, respectively. E and θs
are the extraterrestrial solar irradiance and solar zenith angle, respectively. For imagery of satellite
sensors the apparent reflectance is also named top-of-atmosphere (TOA) reflectance.

2.1 Radiation components


We start with a discussion of the radiation components in the solar region, i.e., the wavelength
spectrum from 0.35 - 2.5 µm. Figure 2.2 shows a schematic sketch of the total radiation signal at
the sensor. It consists of three components:

1. path radiance (L1 ), i.e., photons scattered into the sensor’s instantaneous field-of-view, with-
out having ground contact.

2. reflected radiation (L2 ) from a certain pixel: the direct and diffuse solar radiation incident
on the pixel is reflected from the surface. A certain fraction is transmitted to the sensor. The
sum of direct and diffuse flux on the ground is called global flux.

3. reflected radiation from the neighborhood (L3 ), scattered by the air volume into the current
instantaneous direction, the adjacency radiance. As detailed in [56] the adjacency radiation
L3 consists of two components (atmospheric backscattering and volume scattering) which are
combined into one component in Fig. 2.2 to obtain a compact description.

Only radiation component 2 contains information from the currently viewed pixel. The task of
atmospheric correction is the calculation and removal of components 1 and 3, and the retrieval of
the ground reflectance from component 2.

So the total radiance signal L can be written as :

L = Lpath + Lref lected + Ladj (= L1 + L2 + L3 ) (2.6)

The path radiance decreases with wavelength. It is usually very small for wavelengths greater than
800 nm. The adjacency radiation depends on the reflectance or brightness difference between the
currently considered pixel and the large-scale (0.5-1 km) neighborhood. The influence of the adja-
cency effect also decreases with wavelength and is very small for spectral bands beyond 1.5 µm [56].

For each spectral band of a sensor a linear equation describes the relationship between the recorded
brightness or digital number DN and the at-sensor radiance (Fig. 2.2) :

L = c0 + c1 ∗ DN (2.7)

The c0 and c1 are called radiometric calibration coefficients. The radiance unit in ATCOR is
mW cm−2 sr−1 µm−1 . For instruments with an adjustable gain setting g the corresponding equation
is :
c1
L = c0 + ∗ DN (2.8)
g
CHAPTER 2. BASIC CONCEPTS IN THE SOLAR REGION 19

Figure 2.2: Schematic sketch of solar radiation components in flat terrain.


L1 : path radiance, L2 : reflected radiance, L3 : adjacency radiation.

During the following discussion we will always use eq. (2.7). Disregarding the adjacency component
we can simplify eq. (2.6)

L = Lpath + Lref lected = Lpath + τ ρEg /π = c0 + c1 DN (2.9)

where τ , ρ, and Eg are the ground-to-sensor atmospheric transmittance, surface reflectance, and
global flux on the ground, respectively. Solving for the surface reflectance we obtain :
π{d2 (c0 + c1 DN ) − Lpath }
ρ= (2.10)
τ Eg

The factor d2 takes into account the sun-to-earth distance (d is in astronomical units), because the
LUT’s for path radiance and global flux are calculated for d=1 in ATCOR. Equation (2.9) is a key
formula to atmospheric correction. A number of important conclusions can now be drawn:

• An accurate radiometric calibration is required, i.e., a knowledge of c0 , c1 in each spectral


band.

• An accurate estimate of the main atmospheric parameters (aerosol type, visibility or optical
thickness, and water vapor) is necessary, because these influence the values of path radiance,
transmittance, and global flux.

• If the visibility is assumed too low (optical thickness too high) the path radiance becomes
high, and this may cause a physically unreasonable negative surface reflectance. Therefore,
dark surfaces of low reflectance, and correspondingly low radiance c0 + c1 DN , are especially
sensitive in this respect. They can be used to estimate the visibility or at least a lower
bound. If the reflectance of dark areas is known the visibility can actually be calculated. The
interested reader may move to chapter 10.5.2, but this is not necessary to understand the
remaining part of the chapter.

• If the main atmospheric parameters (aerosol type or scattering behavior, visibility or optical
thickness, and water vapor column) and the reflectance of two reference surfaces are measured,
CHAPTER 2. BASIC CONCEPTS IN THE SOLAR REGION 20

the quantities Lpath , τ , ρ, and Eg are known. So, an ”inflight calibration” can be performed
to determine or update the knowledge of the two unknown calibration coefficients c0 (k), c1 (k)
for each spectral band k, see section 2.3.

Selection of atmospheric parameters

The optical properties of some air constituents are accurately known, e.g., the molecular or Rayleigh
scattering caused by nitrogen and oxygen molecules. Since the mixing ratio of nitrogen and oxygen
is constant the contribution can be calculated as soon as the pressure level (or ground elevation)
is specified. Other constituents vary slowly in time, e.g., the CO2 concentration. ATCOR calcu-
lations are performed for a CO2 concentration of 400 ppmv (2015 release). Later releases might
update the concentration if necessary. Ozone may also vary in space and time. Since ozone usually
has only a small influence, ATCOR employs a fixed value of 331 DU (Dobson units, correspond-
ing to the former unit 0.331 atm-cm, for a ground at sea level) representing average conditions.
However, if ozone information is available from other sources and if it deviates more than 10 DU
from the reference level (331 DU) then it can be specified as an additional input parameter [61].
The three most important atmospheric parameters that vary in space and time are the aerosol
type, the visibility or optical thickness, and the water vapor. We will mainly work with the term
visibility (or meteorological range), because the radiative transfer calculations were performed with
the Modtran 5 R code (Berk et al., 1998, 2008), and visibility is an intuitive input parameter in
MODTRAN , although the aerosol optical thickness can be used as well. ATCOR employs a
R
database of LUTs calculated with Modtran 5. R

Aerosol type
The aerosol type includes the absorption and scattering properties of the particles, and the wave-
length dependence of the optical properties. ATCOR supports four basic aerosol types: rural,
urban, maritime, and desert. The aerosol type can be calculated from the image data provided
that the scene contains vegetated areas. Alternatively, the user can make a decision, usually based
on the geographic location. As an example, in areas close to the sea the maritime aerosol would be
a logical choice if the wind was coming from the sea. If the wind direction was toward the sea and
the air mass is of continental origin the rural, urban, or desert aerosol would make sense, depending
on the geographical location. If in doubt, the rural (continental) aerosol is generally a good choice.
The aerosol type also determines the wavelength behavior of the path radiance. Of course, nature
can produce any transitions or mixtures of these basic four types. However, ATCOR is able to
adapt the wavelength course of the path radiance to the current situation provided spectral bands
exist in the blue-to-red- region and the scene contains reference areas of known reflectance behavior.
The interested reader may read chapter 10.5.2 for details.

Visibility estimation
Two options are available in ATCOR:

• An interactive estimation in the SPECTRA module (compare chapter 5). The spectra of
different targets in the scene can be displayed as a function of visibility. A comparison
with reference spectra from libraries determines the visibility. In addition, dark targets like
vegetation in the blue-to-red spectrum or water in the red-to-NIR can be used to estimate
the visibility.

• An automatic calculation of the visibility can be performed if the scene contains dark reference
pixels. The interested reader is referred to chapter 10.5.2 for details.
CHAPTER 2. BASIC CONCEPTS IN THE SOLAR REGION 21

Water vapor column


The water vapor content can be automatically computed if the sensor has spectral bands in water
vapor regions (e.g., 920-960 nm). The approach is based on the differential absorption method
and employs bands in absorption regions and window regions to measure the absorption depth,
see chapter 10.5.3. Otherwise, if a sensor does not possess spectral bands in water vapor regions,
e.g. Landsat TM or SPOT, an estimate of the water vapor column based on the season (summer
/ winter) is usually sufficient. Typical ranges of water vapor columns are (sea-level-to space):

tropical conditions: wv=3-5 cm (or g cm−2 )


midlatitude summer: wv= 2-3 cm
dry summer, spring, fall: wv=1-1.5 cm
dry desert or winter: wv=0.3-0.8 cm

2.2 Spectral calibration


This section can be skipped if data processing is only performed for imagery of broad-band sensors.
Sensor calibration problems may pertain to spectral properties, i.e., the channel center positions
and / or bandwidths might have changed compared to laboratory measurements, or the radiometric
properties, i.e., the offset (co ) and slope (c1 ) coefficients, relating the digital number (DN) to the
at-sensor radiance L = c0 + c1 ∗ DN . Any spectral mis-calibration can usually only be detected
from narrow-band hyperspectral imagery as discussed in this section. For multispectral imagery,
spectral calibration problems are difficult or impossible to detect, and an update is generally only
performed with respect to the radiometric calibration coefficients, see chapter 2.3.

Surface reflectance spectra retrieved from narrow-band hyperspectral imagery often contain spikes
and dips in spectral absorption regions of atmospheric gases (e.g., oxygen absorption around 760
nm, water vapor absorption around 940 nm). These effects are most likely caused by a spectral
mis-calibration. In this case, an appropiate shift of the center wavelengths of the channels will
remove the spikes. This is performed by an optimization procedure that minimizes the deviation
between the surface reflectance spectrum and the corresponding smoothed spectrum. The merit
function to be minimized is
n
{ρsurf
X
χ2 (δ) = i (δ) − ρsmooth
i }2 (2.11)
i=1

where ρsurf
i (δ) is the surface reflectance in channel i calculated for a spectral shift δ, ρsmooth
i is the
smoothed (low pass filtered) reflectance, and n is the number of bands in each spectrometer of a
hyperspectral instrument. So the spectral shift is calculated independently for each spectrometer.
In the currently implemented version, the channel bandwidth is not changed and the laboratory
values are assumed valid. More details of the method are described in [?]. A spectral re-calibration
should precede any re-calibration of the radiometric calibration coefficients; see section 5.8.6 for
details about this routine.

Figure 2.3 shows a comparison of the results of the spectral re-calibration for a soil and a vegetation
target retrieved from an AVIRIS scene (16 Sept. 2000, Los Angeles area). The flight altitude was
20 km above sea level (asl), heading west, ground elevation 0.1 km asl, the solar zenith and azimuth
CHAPTER 2. BASIC CONCEPTS IN THE SOLAR REGION 22

Figure 2.3: Wavelength shifts for an AVIRIS scene.

angles were 41.2◦ and 135.8◦ . Only part of the spectrum is shown for a better visual comparison
of the results based on the original spectral calibration (thin line) and the new calibration (thick
line). The spectral shift values calculated for the 4 individual spectrometers of AVIRIS are 0.1,
-1.11, -0.88, and -0.21 nm, respectively.

2.3 Inflight radiometric calibration


Inflight radiometric calibration experiments are performed to check the validity of the laboratory
calibration. For spaceborne instruments processes like aging of optical components or outgassing
during the initial few weeks or months after launch often necessitate an updated calibration. This
approach is also employed for airborne sensors because the aircraft environment is different from
the laboratory and this may have an impact on the sensor performance. The following presenta-
tion only discusses the radiometric calibration and assumes that the spectral calibration does not
change, i.e., the center wavelength and spectral response curve of each channel are valid as obtained
in the laboratory, or it was already updated as discussed in chapter 2.2. Please refer to section
5.4.9 for further detail about how to perform an inflight calibration.

The radiometric calibration uses measured atmospheric parameters (visibility or optical thickness
from sun photometer, water vapor content from sun photometer or radiosonde) and ground re-
flectance measurements to calculate the calibration coefficients c0 , c1 of equation (2.7) for each
band. For details, the interested reader is referred to the literature (Slater et al., 1987 [?], Santer
et al. 1992, Richter 1997). Depending of the number of ground targets we distinguish three cases:
a single target, two targets, and more than two targets.

Calibration with a single target


In the simplest case, when the offset is zero (c0 = 0), a single target is sufficient to determine the
calibration coefficient c1 :

L1 = c1 DN1∗ = Lpath + τ ρ1 Eg /π (2.12)


CHAPTER 2. BASIC CONCEPTS IN THE SOLAR REGION 23

Lpath , τ , and Eg are taken from the appropriate LUT’s of the atmospheric database, ρ1 is the
measured ground reflectance of target 1, and the channel or band index is omitted for brevity.
DN1∗ is the digital number of the target, averaged over the target area and already corrected for
the adjacency effect. Solving for c1 yields:

L1 Lpath + τ ρ1 Eg /π
c1 = ∗ = (2.13)
DN1 DN1∗

Remark: a bright target should be used here, because for a dark target any error in the ground
reflectance data will have a large impact on the accuracy of c1 .

Calibration with two targets

In case of two targets a bright and a dark one should be selected to get a reliable calibration. Using
the indices 1 and 2 for the two targets we have to solve the equations:

L1 = c0 + c1 ∗ DN1∗ L2 = c0 + c1 ∗ DN2∗ (2.14)

This can be performed with the c0 &c1 option of ATCOR’s calibration module, see chapter 5. The
result is:
L1 − L2
c1 = (2.15)
DN1∗ − DN2∗

c0 = L1 − c1 ∗ DN1∗ (2.16)

Equation (2.15) shows that DN1∗ must be different from DN2∗ to get a valid solution, i.e., the two
targets must have different surface reflectances in each band. If the denominator of eq. (2.15) is
zero ATCOR will put in a 1 and continue. In that case the calibration is not valid for this band.
The requirement of a dark and a bright target in all channels cannot always be met.

Calibration with n > 2 targets

In cases where n > 2 targets are available the calibration coefficients can be calculated with a least
squares fit applied to a linear regression equation, see figure 2.4. This is done by the ”cal regress”
program of ATCOR. It employs the ”*.rdn” files obtained during the single-target calibration (the
”c1 option” of ATCOR’s calibration module. See section 5.8.7 for details about how to use this
routine.
Note: If several calibration targets are employed, care should be taken to select targets without
spectral intersections, since calibration values at intersection bands are not reliable. If intersections
of spectra cannot be avoided, a larger number of spectra should be used, if possible, to increase the
reliability of the calibration.

2.4 De-shadowing
Remotely sensed optical imagery of the Earth’s surface is often contaminated with cloud and cloud
shadow areas. Surface information under cloud covered regions cannot be retrieved with optical
sensors, because the signal contains no radiation component being reflected from the ground. In
shadow areas, however, the ground-reflected solar radiance is always a small non-zero signal, be-
cause the total radiation signal at the sensor contains a direct (beam) and a diffuse (reflected
CHAPTER 2. BASIC CONCEPTS IN THE SOLAR REGION 24

Figure 2.4: Radiometric calibration with multiple targets using linear regression.

skylight) component. Even if the direct solar beam is completely blocked in shadow regions, the
reflected diffuse flux will remain, see Fig. 2.5. Therefore, an estimate of the fraction of direct solar
irradiance for a fully or partially shadowed pixel can be the basis of a compensation process called
de-shadowing or shadow removal. The method can be applied to shadow areas cast by clouds or
buildings.

Figure 2.5: Sketch of a cloud shadow geometry.

Figure 2.6 shows an example of removing building shadows. The scene covers part of the central
area of Munich. It was recorded by the Ikonos-2 sensor (17 Sept. 2003). The solar zenith and
azimuth angles are 46.3◦ and 167.3◦ , respectively. After shadow removal the scene displays a much
lower contrast, of course, but many details can be seen that are hidden in the uncorrected scene, see
the zoom images of figure 2.7. The central zoom image represents the shadow map, scaled between
0 and 1000. The darker the area the lower the fractional direct solar illumination, i.e. the higher
the amount of shadow. Some artifacts can also be observed in Figure 2.6, e.g., the Isar river at the
bottom right escaped the water mask, entered the shadow mask, and is therefore overcorrected.

The proposed de-shadowing technique works for multispectral and hyperspectral imagery over land
CHAPTER 2. BASIC CONCEPTS IN THE SOLAR REGION 25

Figure 2.6: De-shadowing of an Ikonos image of Munich.


European
c Space Imaging GmbH 2003. Color coding: RGB = bands 4/3/2 (800/660/550 nm).
Left: original, right: de-shadowed image.

acquired by satellite / airborne sensors. The method requires a channel in the visible and at least
one spectral band in the near-infrared (0.8-1 µm) region, but performs much better if bands in the
short-wave infrared region (around 1.6 and 2.2 µm) are available as well. A fully automatic shadow
removal algorithm has been implemented. However, the method involves some scene-dependent
thresholds that might be optimized during an interactive session. In addition, if shadow areas are
concentrated in a certain part of the scene, say in the lower right quarter, the performance of the
algorithm improves by working on the subset only.

The de-shadowing method employs masks for cloud and water. These areas are identified with
spectral criteria and thresholds. Default values are included in a file in the ATCOR path, called
”preferences/preference parameters.dat”. As an example, it includes a threshold for the reflectance
of water in the NIR region, ρ=5% . So, a reduction of this threshold will reduce the number of
pixels in the water mask. A difficult problem is the distinction of water and shadow areas. If water
bodies are erroneously included in the shadow mask, the resulting surface reflectance values will be
too high.

Details about the processing panels can be found in section 5.4.10.

2.5 BRDF correction


The reflectance of many surface covers depends on the viewing and solar illumination geometry.
This behavior is described by the bidirectional reflectance distribution function (BRDF). It can
clearly be observed in scenes where the view and / or sun angles vary over a large angular range.

Since most sensors of the satellite version of ATCOR have a small field-of-view, these effects play
a role in rugged terrain, for the wide FOV sensors such as IRS-1D WiFS or MERIS, and if mosaics
CHAPTER 2. BASIC CONCEPTS IN THE SOLAR REGION 26

Figure 2.7: Zoomed view of central part of Figure 2.6.


Courtesy of European Space Imaging, Color coding: RGB = bands 4/3/2.
Left: original, center: shadow map, right: de-shadowed image.

of images registered with variable observation angles are to be produced.

For flat terrain scenes across-track brightness gradients that appear after atmospheric correction
are caused by BRDF effects, because the sensor’s view angle varies over a large range. In extreme
cases when scanning in the solar principal plane, the brightness is particularly high in the hot spot
angular region where retroreflection occurs, see Figure 2.8, left image, left part. The opposite scan
angles (with respect to the central nadir region) show lower brightness values.

A simple method, called nadir normalization or across-track illumination correction, calculates


the brightness as a function of scan angle, and multiplies each pixel with the reciprocal function
(compare Section 10.7.1 ).

Figure 2.8: Nadir normalization of an image with hot-spot geometry. Left: reflectance image without
BRDF correction. Right: after empirical BRDF correction.

The BRDF effect can be especially strong in rugged terrain with slopes facing the sun and others
oriented away from the sun. In areas with steep slopes the local solar zenith angle β may vary
from 0◦ to 90◦ , representing geometries with maximum solar irradiance to zero direct irradiance,
i.e., shadow. The angle β is the angle between the surface normal of a DEM pixel and the solar
zenith angle of the scene. In mountainous terrain there is no simple method to eliminate BRDF
CHAPTER 2. BASIC CONCEPTS IN THE SOLAR REGION 27

effects. The usual assumption of an isotropic (Lambertian) reflectance behavior often causes an
overcorrection of faintly illuminated areas where local solar zenith angles β range from 60◦ - 90◦ .
These areas appear very bright, see Figure 2.9, left part.

Figure 2.9: BRDF correction in rugged terrain imagery. Left: image without BRDF correction. Center:
after BRDF correction with threshold angle βT = 65◦ . Right: illumination map = cosβ.

To avoid a misclassification of these bright areas the reflectance values have to be reduced (Fig.
2.9, center part). In ATCOR empirical geometry-dependent functions are used for this purpose.
In the simplest cases, the empirical BRDF correction employs only the local solar zenith angle β
and a threshold βT to reduce the overcorrected surface reflectance ρL with a factor, depending on
the incidence angle. For details the interested reader is referred to section 10.7.2.

The third method available in ATCOR is the BRDF effects correction (BREFCOR) method, which
uses both the scene illumination and per-pixel observation angle. It may also be used if a number of
satellite scenes are to be mosaicked. It follows a novel scheme based on a fuzzy surface classification
and uses BRDF models for the correction. The process follows the below steps:

1. perform a fuzzy BRDF-Class-Index (BCI) image classification

2. calibrate the BRDF-model using a number of scenes, e.g. meant for mosaicing

3. calculate the anisotropy index for each spectral band using the calibrated model and the BCI

4. correct the image using the anisotropy index

Further details about this methods can be found in section 10.7.3.


CHAPTER 2. BASIC CONCEPTS IN THE SOLAR REGION 28

Figure 2.10: Effect of BRDF correction on mosaic (RapidEye image, DLR)


c
Chapter 3

Basic Concepts in the Thermal


Region

Fig. 3.1 (left) presents an overview of the atmospheric transmittance in the 2.5 - 14 µm region. The
main absorbers are water vapor and CO2 which totally absorb in some parts of the spectrum. In the
thermal region (8 - 14 µm) the atmospheric transmittance is mainly influenced by the water vapor
column, ozone (around 9.6 µm) and CO2 (at 14 µm). Fig. 3.1 (right) shows the transmittance
for three levels of water vapor columns w=0.4, 1.0, 2.9 cm, representing dry, medium, and humid
conditions. The aerosol influence still exists, but is strongly reduced compared to the solar spectral
region because of the much longer wavelength. So an accurate estimate of the water vapor column
is required in this part of the spectrum to be able to retrieve the surface properties, i.e., spectral
emissivity and surface temperature.

Figure 3.1: Atmospheric transmittance in the thermal region.

Similar to the solar region, there are three radiation components: thermal path radiance (L1 ), i.e.,
photons emitted by the atmospheric layers, emitted surface radiance (L2 ), and reflected radiance
(L3 ).
In the thermal spectral region from 8 - 14 µm the radiance signal can be written as

L = Lpath + τ LBB (T ) + τ (1 − )F/π (3.1)

29
CHAPTER 3. BASIC CONCEPTS IN THE THERMAL REGION 30

Figure 3.2: Radiation components in the thermal region.


L1 = LP , L2 = τ  LBB (T ), L3 = τ (1 − ) F/π .

where Lpath is the thermal path radiance, i.e., emitted and scattered radiance of different layers of
the air volume between ground and sensor, τ is the atmospheric ground-to-sensor transmittance,
 is the surface emissivity ranging between 0 and 1, LBB (T ) is Planck’s blackbody radiance of a
surface at temperature T , and F is the thermal downwelling flux of the atmosphere, see Fig. 3.2.
So the total signal consists of path radiance, emitted surface radiance, and reflected atmospheric
radiation. The adjacency radiation, i.e., scattered radiation from the neighborhood of a pixel, can
be neglected because the scattering efficiency decreases strongly with wavelength.

For most natural surfaces the emissivity in the 8-12 µm spectral region ranges between 0.95 and
0.99. Therefore, the reflected downwelling atmospheric flux contributes only a small fraction to the
signal. Neglecting this component for the simplified discussion of this chapter we can write
L − Lpath c0 + c1 DN − Lpath
LBB (T ) = = (3.2)
τ τ
In the thermal region the aerosol type plays a negligible role because of the long wavelength, and
atmospheric water vapor is the dominating parameter. So the water vapor, and to a smaller de-
gree the visibility, determine the values of Lpath and τ . In case of coregistered bands in the solar
and thermal spectrum the water vapor and visibility calculation may be performed with the solar
channels. In addition, if the surface emissivity is known, the temperature T can be computed from
eq. (3.2) using Planck’s law.

For simplicity a constant emissivity  = 1.0 or  = 0.98 is often used and the corresponding
temperature is called brightness temperature. The kinetic surface temperature differs from the
brightness temperature if the surface emissivity does not match the assumed emissivity. With the
assumption  = 1.0 the kinetic temperature is always higher than the brightness temperature. As
a rule of thumb an emissivity error of 0.01 (one per cent) yields a surface temperature error of 0.5K.

For rugged terrain imagery no slope/aspect correction is performed for thermal bands, only the
elevation-dependence of the atmospheric parameters is taken into account.
Chapter 4

Workflow

This chapter familiarizes the user with ATCOR 2/3’s workflow and with the program’s basic
functionality using the graphical user interface. A detailed description of all modules and user
interface panels is given in the subsequent chapter 5.
ATCOR may also be used in batch mode for most of its functions. A description of the batch mode
can be found in chapter 6.

4.1 Menus Overview


To start ATCOR, go to the ’bin’ directory of the ATCOR installation and double click the starter
application ’ATCOR.exe’ (for windows) or ’ATCOR.app’ (for MacOS) or ’atcor.sh’ (for Linux).
You may also open the file ’atcor.sav’ using through IDL or the IDL virtual machine Either the
graphical user interface of Fig. 4.1 will pop up - in unlicensed mode the information as of how to
obtain a license is displayed. For users having a IDL developer license you may type atcor on the
IDL command line after having added the atcor -directory to the IDL search path.

Note : Software startup calls are logged with Licensed User Name and Machine ID on a ReSe
Server to keep track of license use. This allows for more flexibility in licensing schemes (startup
logging is only performed as long as an internet connection is active).
A large number of processing modules is available from the GUI main level as described in chapter
5. Most of them can be used without reading a detailed manual description because they contain
explanations in the panels themselves. However, the next section guides the ATCOR newcomer
during the atmospheric correction of a sample scene.

Figure 4.1: Top level graphical interface of ATCOR.

The functions in the ”File” menu allow the display of an image file, the on-screen display of
calibration files, sensor response curves etc, see Fig. 4.2. More details about this menu are given
in chapter 5.1.

31
CHAPTER 4. WORKFLOW 32

Figure 4.2: Top level graphical interface of ATCOR: ”File” and ”Import”.

The ”Sensor” menu of Fig. 4.1 is available if the module for hyperspectral (or user-defined) sensors
is licensed. It contains routines to create spectral filter curves (rectangular, Gaussian, etc) from
ENVI header or from an ASCII file provided by the user, calculates atmospheric look-up tables
(LUTs) for new sensors, and computes the radiance/temperature functions for thermal bands; see
Fig. 4.3 and chapter 5.2.
The ”Topographic” menu contains programs to import and prepare DEM data, for the calculation
of slope/aspect images from a digital elevation model, for the skyview factor, and for topographic
shadow. Furthermore, it supports the smoothing of DEMs and its related layers, see chapter 5.3.
The menu ”ATCOR” gives access to the ATCOR core processes for atmospheric correction in flat
and rugged terrain, supporting multispectral and hyperspectral instruments. It also allows the haze
removal on raw DN data and the start of tiled processing. It is further described in section 4.2
below and chapter 5.4.
The ”BRDF” menu provides access to the BREFCOR BRDF effects correction method and to the
nadir normalization for wide field-of-view imagery and to a mosaicking tool; see chapters 5.5 and
5.5.2.
The ”Filter” menu provides spectral filtering of single spectra (reflectance, emissivity, radiance)
provided as ASCII files, spectral filtering of image cubes, and spectral polishing; see chapter 5.6.
CHAPTER 4. WORKFLOW 33

Figure 4.3: Top level graphical interface of ATCOR: ”Sensor”.

Figure 4.4: Topographic modules.

The ”Simulation” menu provides programs for the simulation of at-sensor radiance scenes based
on surface reflectance (or emissivity and temperature) images; see chapter 5.7.
The ”Tools” menu contains a collection of useful routines such as the calculation of the solar zenith
and azimuth angles, spectral classification, adding of a synthetic blue channel for multispectral
sensors without a blue band (e.g. SPOT), spectral calibration, conversion of the monochromatic
atmospheric database from one to another solar irradiance spectrum, and more; see chapter 5.8.
Finally, the ”Help” menu allows browsing of the ATCOR user manual, provides a link to web
resources, and displays license and credits information, and give access to online software updates
and components; see chapter 5.9.

4.2 First steps with ATCOR


The ’ATCOR’ button of Fig. 4.5 displays the choices ’ATCOR2: standard sensors, flat terrain’ and
’ATCOR3: standard sensors, rugged terrain’. If the add-on for user-defined (mainly hyperspectral)
sensors is included, then the buttons ’ATCOR2: advanced sensors, flat terrain’ and ’ATCOR3:
advanced sensors, rugged terrain’ will also appear, compare Fig. 4.5. The difference being that
the ’advanced sensors’ are either self defined or are containing water vapor bands for water vapor
transmittance correciton, whereas ’standard sensors’ are operating in the atmospheric spectral
windows only.
Another option allows to start the ATCOR processing in GUI-batch or tiling mode, i.e., the image
CHAPTER 4. WORKFLOW 34

is divided into sub-images in x and y direction as specified by the user. This mode is intended for
large scenes, compare section 5.4.12; note that the ’*.inn’ file with the processing parameters must
already exist. Separate processing options are available for Sentinel-2 and Landsat-8 imagery as
their radiometric and spatial configuration requires specific processing steps.

Figure 4.5: Top level graphical interface of ATCOR: ”Atmospheric Correction”.

Let us start with a scene from a flat terrain area where no digital elevation model (DEM) is
needed. Then the panel of Fig. 4.6 will pop up. First, the ’INPUT IMAGE FILE’ has to be
selected. ATCOR requires the band sequential format (BSQ) for the image data with an ENVI
header. The TIFF format is supported with some restrictions, see chapter 9.2. Next the acquisition
date of the image has to be updated with the corresponding button. We work from top to bottom
to specify the required information. The scale factor defines the multiplication factor for surface
reflectance (range 0 - 100%) in the output file. A scale factor of 1 yields the output as float data
(4 bytes per pixel). However, a scale factor of 100 is recommended if the input data is 16 bit (2
bytes) per pixel, so a surface reflectance value of say 20.56% is coded as 2056 and is stored as a 2
byte integer which means the file size is only half of the float file size. If the input data is 8 bit
data then a scale factor of 4 is recommended, i.e., a surface reflectance of 20.56% will be coded as
82.
If the input file name is ”image.bsq” then the default output file name for the atmospherically cor-
rected image is ”image atm.bsq”. The user may modify the output name, but it is recommended
to keep the ” atm.bsq” qualifier to facilitate the use of subsequent programs. Then the sensor view
geometry has to be specified as well as the sensor and the calibration file. The atmospheric file
contains the look-up table (LUT) results of the radiative transfer calculations, separately for the
solar and thermal region. These LUTs are calculated for a nadir view, but for tilt sensors the
files ”phasefct*.bin” in the ”../atcor/bin” directory contain the path radiance as a function of the
scattering angle, and the appropriate file is automatically included.

Note that for a new user-specified sensor, these LUTs have to be calculated once prior to the first
call of ATCOR. This is done with the module RESLUT (see section 5.2.6) available under the
’Sensor’ menu.
It is recommended to check the quality of the atmospheric correction before processing the image
data. For that purpose, the SPECTRA module should be used where the surface reflectance of small
user-defined boxes can be evaluated and compared with library spectra, compare chapter 5.4.6. In
CHAPTER 4. WORKFLOW 35

Figure 4.6: ATCOR panel for flat terrain imagery.

case of calibration problems, the spectral calibration module, available from the ’Tools’ button of
Fig. 4.1, and the radiometric (inflight) calibration may be employed before finally processing the
image data. The ’AEROSOL TYPE’ button provides an estimate for the recommended aerosol
type (e.g. rural, maritime, urban) derived from the scene. This module also provides a visibility
value for each aerosol type based on reference pixels (dark vegetation) in the scene. The ’VISIB.
ESTIMATE’ button provides a visibility value for the selected aerosol type by checking dark
scene pixels in the red band (vegetation, water) and NIR band (water). It is assumed that the
lowest reflectance in the red band is 0.01 (1 percent) and 0.0 in the NIR band. Therefore, the
obtained visibility value usually can be considered as a lower bound. The higher visibility value
(of ’AEROSOL TYPE’ and ’VISIB. ESTIMATE’ ) is recommended as a start visibility for the
SPECTRA module.
The ’Inflight Calibration’ is described in chapter 5.4.9. This module is usually not required for first
use of the software.
The ’WATER VAPOR’ button can be used to test the appropriate band combinations for the
retrieval of a water vapor map without a calculation of the surface reflectance cube.
Th button IMAGE PROCESSING starts the atmospheric correction process from the entered
parameters. A series of sequential panels are displayed after this button is pressed. Fig. 4.7 shows
the panel with the image processing options. Some options may not be accessible, they are blocked
if the required spectral bands are missing.
In case of a mountainous terrain the ATCOR3 button has to be selected (Fig. 4.1, ”ATCOR”).
This panel is similar to Fig. 4.6, but an additional panel for the specification of the DEM files will
CHAPTER 4. WORKFLOW 36

appear (Fig. 4.8). The user has to provide the DEM file matched to the size of the input image.
The slope and aspect files can be calculated from the corresponding module under ”Topographic”
(Fig. 4.1). These two files may need a special treatment as discussed in chapter 5.4.11. Therefore,
they are not automatically created from the elevation file. The ”skyview” file and cast shadow file
are optional, only required in extremely steep terrain. The ”skyview” calculation can also be found
under the ”Topographic” label of Fig. 4.1.

Figure 4.7: Image processing options. Right panel appears if a cirrus band exists.

Figure 4.8: Panel for DEM files.

Depending on the selected image processing option some additional panels may pop up. Most of
them are listed in chapter 5.5.2, but they are self-explaining and will not be discussed here. They
also contain default settings which can be used in most cases. When the main panel (Fig. 4.6)
is left and the ”SPECTRA” or ”IMAGE PROCESSING” sections are entered, all information is
written to a processing initialization (.inn) file, e.g., ”image.inn”. When reloading the input file
this information is read from the .inn file, so a new specification of all processing parameters is not
necessary. Therefore, this .inn file can also be used for a batch processing, see chapter 6.
CHAPTER 4. WORKFLOW 37

The remaining sub-chapters of chapter 4 may be skipped during the first reading if the definition of
user-defined (hyperspectral) sensors is not relevant. These sub-chapters can be consulted if specific
questions arise, e.g., about batch job processing.

4.3 Survey of processing steps


Figure 4.9 shows the typical workflow of atmospheric correction. A detailed description of the
corresponding graphicical user interface for each module is given in chapter 5. First, the image is
loaded with possibly some additional information (DEM files). Then the sensor has to be defined,
the radiometric calibration file, and a basic atmosphere/aerosol type combination, e.g. a summer
atmosphere with a rural aerosol. It is recommended to check the validity of the calibration and
to estimate the visibility (and perhaps the atmospheric water vapor column wv) before processing
the image cube. The SPECTRA module can be employed for this purpose, see chapter 5.4.6.
Reflectance spectra of scene targets can be displayed as a function of visibility and water vapor
(the winter, fall, summer, and tropical atmospheres have different wv contents, see appendix A)
and compared with field or library spectra. If calibration problems exist in a few channels a copy
of the calibration file can be edited in these channels to match the reference spectrum. If there are
problems in many channels the inflight radiometric calibration module should be used to generate
a calibration file as discussed in chapter 5.4.9.

Figure 4.9: Typical workflow of atmospheric correction.

When the calibration file is OK the user can continue with the image processing. Depending on
the available sensor channels there are options to process the imagery with constant or variable
CHAPTER 4. WORKFLOW 38

visibility and atmospheric water vapor. For large FOV sensors an option is available to correct
for across-track illumination (BRDF) effects. This is especially useful if the image recording took
place in the solar principal plane. In addition, a spectral polishing can be performed for the
atmospherically and / or BRDF corrected data as indicated by the dotted lines of figure 4.9 . The
polishing requires hyperspectral imagery. Finally, a classification may be performed.
Figure 4.10 shows the input / output image files associated with ATCOR processing. On the left
part the flat terrain case is treated, on the right part the rugged terrain case. In mountainous
terrain, the DEM, DEM slope and aspect files are required. Optional input are the skyview file
and the shadow map, the latter can also be calculated on-the-fly. The slope and aspect files can be
calculated from ATCOR’s interactive menu, or run as a batch job (slopasp batch see chapter 6.3).
The skyview file has to be computed with the skyview program, see chapter 5.3.7.

Figure 4.10: Input / output image files during ATCOR processing.

4.4 Directory structure of ATCOR


Figure 4.11 shows the directory structure of the satellite version of ATCOR. There are a num-
ber of sub-directories with the following content: The ’bin’ directory holds the ATCOR program
with all modules as listed in chapter 5. The ’cal’ directory holds all supported satellite sensors
in sensor-specific sub-directories. The sensor definition is contained in two files: one contains the
extraterrestrial solar irradiance (e.g. ’e0 solar aster.spc’ ), the second one contains the radiomet-
ric calibration coefficients, e.g., ’aster.cal’. The ’atm lib’ contains the results of the atmospheric
database after resampling with the sensor-specific spectral response curves. The ’spec lib’ is a di-
rectory containing prototype reflectance spectra of water, soils, vegetation, asphalt etc. Here the
user can also put field measurements of surface reflectance spectra resampled for the appropriate
sensor. This is useful for inflight calibration or comparison of scene spectra with ground spectra.
Finally, the ’demo data’ contains some demo imagery to be able to run ATCOR immediately.

4.5 Convention for file names


Although file names are arbitrary it is useful to agree on some conventions to facilitate the search
of files, especially concerning the extensions of file names.
CHAPTER 4. WORKFLOW 39

Figure 4.11: Directory structure of ATCOR.

Input images to ATCOR must have the band sequential format (BSQ), therefore it is recommended
to employ the ’.bsq’ as an extension, e.g. ’image1.bsq’ . Then in this example the default output
file name of ATCOR will be ’image1 atm.bsq’ and a log report of the processing is available in
’image1 atm.log’.
Once an image is processed with ATCOR all input parameters are saved in a file ’*.inn’ that is
automatically loaded should the image be processed again.
The recommended extension for the radiometric calibration files is ’.cal’ . Other extensions are
’* ele.bsq’ for the digital elevation file, ’* slp.bsq’ for the DEM slope file, ’* asp.bsq’ for the DEM as-
pect, ’* sky.bsq’ for the sky view file, ’* ilu.bsq’ for the solar illumination file in rugged terrain, and
’ cla.bsq’ for the classification map of SPECL. The visibility index map is named ’* visindex.bsq’,
the aerosol optical thickness is ’* aot.bsq’, the cloud/building shadow map is named ’* fshd.bsq’,
and the atmospheric water vapor map ’* wv.bsq’.
Thermal band imagery
In case of thermal band imagery the surface temperature and emissivity are stored in separate files.
Surface temperature is appended to the reflectance cube, i.e. is included as the last channel in the
’* atm.bsq’ file, e.g., ’image1 atm.bsq’.
The surface temperature calculation is based on an assumption for the emissivity. A constant
emissivity or a surface cover-dependent emissivity can be selected as options. The simple case of a
3-class emissivity file (vegetation  = 0.97, soil  = 0.96, others  = 0.98) is calculated on the fly.
Its output file name is ’image1 atm emi3.bsq’, the ’3’ indicating the 3 classes.
In case of standard sensors with multiple thermal bands, e.g. ASTER, the spectral emissivity
channels are not computed and ATCOR uses only one of the thermal bands, band 13 in case of
ASTER. If ASTER band 13 is offered as a single-channel input file to ATCOR the emissivity
is set to a constant value of  = 0.98 for the surface brightness temperature calculation. If all
CHAPTER 4. WORKFLOW 40

Figure 4.12: Template reference spectra from the ’spec lib’ library.
The dashed spectra are resampled with the Landsat-5 TM filter curves.

reflective bands and the thermal bands of ASTER are geocoded and offered as a 14-channel file to
ATCOR then the 3-class emissivity option is also available. If a user is interested in derived surface
emissivity data, the corresponding instrument (e.g., ASTER) has to be defined as a user-specified
sensor, see chapter 4.6.

4.6 User-defined hyperspectral sensors


Examples of satellite hyperspectral sensors are Hyperion and CHRIS/Proba. Since the channel
center wavelength of these instruments may change from scene to scene, they have to be treated
as user-specified sensors, and a flexible interface has been implemented to enable the calculation
of atmospheric LUTs adapted to the spectral channel properties. This interface is similar to the
one for the airborne ATCOR, and the corresponding part of the airborne ATCOR user manual
is repeated here. The hyperspectral tool is an optional add-on to the satellite ATCOR. Although
it is mainly intended for hyperspectral sensors it can of course also be employed for user-defined
multispectral instruments.
The first step is the definition of a new ’sensor’ subdirectory, compare Figure 4.13 and Fig. 5.14.
It serves as the start folder of further subdirectories for the user-defined hyperspectral sensors, e.g.,
’chris m1’. A few sensor description files have to be created by the user, as explained in the next
section.
CHAPTER 4. WORKFLOW 41

Figure 4.13: Directory structure of ATCOR with hyperspectral add-on.

4.6.1 Definition of a new sensor


A few steps have to be taken to include a new satellite sensor in ATCOR. They are supported by
the respective panels. On the level of the ATCOR installation directory, the following steps are to
be taken:

• A new sensor subdirectory in the ”.../atcor/sensor/” folder has to be created. This is easiest
done using the routine Define Sensor Parameters as described in chapter 5.2.1. Please make
sure this name does not agree with an existing multispectral sensor name in the ”../atcor/cal/”
directory. This process may also be done manually by copying and adapting an existing user-
defined sensor or one of the samples provided (or use the function above to make the changes).

• A sensor-definition file must be specified - this is also done with the routine Define Sensor
Parameters. If you’re about editing the sensor manually, you may just copy any of the existing
files, e.g., ”sensor chris m1.dat”, and modify the appropriate lines, see the next table.

• A wavelength file (’*.wvl’) or an ENVI header file(’*.hdr) containing center wavelength and
FWHM information has to be specified. The wvl-file is a simple ASCII file with three columns
(band number, center wavelength, and bandwidth), compare Fig. 5.14. Center wavelength
and bandwidth may be given in the nm or µm unit. The first line may contain an optional
header with text. This wavelength file or the ENVI header file will be used to create the
spectral response function for each band as a numerical table (the ’band*.rsp’ files), compare
Fig. 5.14.
Eight analytical filter shapes can be selected from the top level graphical interface (Fig. 4.1
when selecting the menu ’Sensor’, then choose the ’Create Channel Filter Files’ button. Then
the menu of Fig. 4.14 will pop up, and one of these 8 filter shapes can be selected. Filter
numbers 1 to 4 are of the Butterworth type, the slow drop-off for the Butterworth order 1
is truncated at the 0.05 response and set to zero. The filter type 9 (parameter filter type
CHAPTER 4. WORKFLOW 42

in Table 4.3) is reserved for arbitrary user-specified channel filter functions (the ’band*.rsp’
files).

• A calibration file (e.g., ”chris m1.cal”) has to be provided in the new sensor sub-directory
(this file is created automatically if using the function Define Sensor Parameters).

• The RESLUT (resample atmospheric LUTs) program has to be run to generate the atmo-
spheric LUTs for the new sensor employing the monochromatic atmospheric database in
”.../atcor/atm database/”. These resampled ’*.atm’ files will automatically be placed in a
sub-directory of ’.../atcor/atm lib/’ with the name of the selected sensor. RESLUT will
also create the resampled spectrum of the extraterrestrial solar irradiance in the appropriate
”.../sensor/chris m1/” folder, see chapter 9.1.4, e.g., ”e0 solar chris m1.spc”.

Remember that the sensors might have to be specified as scene-dependent if the center wavelengths
and/or bandwidths change, so you might need sensor subdirectories such as ”chris m1 11april2003”
or ”chris m1 scene3 29june2004”.

Figure 4.14: Supported analytical channel filter types.

The next two tables present examples of a sensor definition file for an instrument without thermal
bands and with thermal bands, respectively.

5.0 6000 across-track FOV [degree], pixels per line (dummy to agree with airborne ATCOR)
1 128 first, last reflective band (0.35-2.55 µm)
0 0 first, last mid IR band (2.6 -7.0 µm)
0 0 first, last thermal band (7.0 -14 µm)
1 flag for tilt capability (1=yes, 0=no)
0 required dummy

Table 4.1: Example of a sensor definition file (no thermal bands).

Line 1 is retained to be compatible with the airborne version of ATCOR. Line 6 is a required
dummy to be compatible with previous versions.

Any mid-IR bands are skipped in the processing, the surface temperature band (itemp band) is
appended after the reflective bands as the last channel of the ” atm.bsq” output file.
CHAPTER 4. WORKFLOW 43

4.0 3000 cross-track FOV [degree], pixels per line (dummy to agree with airborne ATCOR
1 72 first, last reflective band (0.35-2.55 µm)
73 73 first, last mid IR band (2.6 -7.0 µm)
74 79 first, last thermal band (7.0 -14 µm)
0 flag for tilt capability (1=yes, 0=no)
0 no gain settings (required dummy)
77 temperature band (itemp band=77)

Table 4.2: Sensor definition file: instrument with thermal bands.

4.7 Spectral smile sensors


Imaging systems can employ different techniques to record a scene: the whiskbroom design uses
a rotating or oscillating mirror to collect an image line in across-track direction (with one or a
few detector elements per spectral band). The forward direction is provided by the motion of the
platform. Secondly, a pushbroom linear array can perform the same task without moving optical
elements, but the number of array lines (each recording a certain spectral channel) in the focal
plane is limited. The third imaging technique employs an area detector array where one direction
collects the spatial information (across-track) and the orthogonal direction covers the spectral di-
mension. The advantage of the last two techniques is a longer pixel dwell time and a potentially
improved signal-to-noise ratio (SNR). The drawback is a substantial increase in the spectral and
radiometric characterization, i.e., a change of the channel center wavelength across the columns
of the array (spectral ”smile”), spatial misregistration (”keystone”), and detector non-uniformity
problems [29], [7], [59]. Typical representatives of the whiskbroom type are Landsat TM/ ETM,
HyMap, AVIRIS, and Daedalus. These instruments almost show no spectral smile, i.e., the channel
center position and bandwidth do not depend on column pixel location. Spaceborne hyperspectral
instruments showing the ”smile” effect are Hyperion and CHRIS/Proba, airborne instruments are
for example CASI-1500 and APEX.

This section describes the ATCOR input files required for smile sensors. There are only two changes
compared to the ”non-smile” instruments:

• The sensor definition file, e.g., ”sensor chris mode3.dat”, needs one more line (see Table 4.3)
containing the parameters ismile (=1 if smile sensor, otherwise 0) and filter type (a number
between 1 and 9 for the type of channel filter function) compare section 4.6.1 and Fig. 4.14.
The filter types 1 to 8 are analytical functions, filter type 9 is reserved for arbitrary user-
defined channel filter functions (the ’band*.rsp’ files). Center wavelength and bandwidth for
each channel are defined in the wavelength file (’*.wvl’ ) pertaining to the center pixel=column
of the detector array.

• For each spectral channel j the channel center wavelength λc (j) depends on the image column
or pixel position x. The absolute value of λc (j) is specified in the wavelength file used to
generate the spectral channel response functions, and it is also included in the sensor-specific
solar irradiance file (e.g., ”e0 solar chris mode3.spc”). If n is the number of image columns,
the change ∆(x, j) of the center wavelength λc (j) with the pixel position x can be described
as a 4th order polynomial (using the nm unit):

∆(x, j)[nm] = a0 (j) + a1 (j) · x + a2 (j) · x2 + a3 (j) · x3 + a4 (j) · x4 (4.1)


CHAPTER 4. WORKFLOW 44

λc (x, j) = λc (j) + ∆(x, j) (4.2)

The first left-hand image pixel is x=0, the last right-hand image pixel is x=(n-1). The
coefficients ai (j) have to be stored in an ASCII file, corresponding to the band sequence.
The first column must contain the wavelength or band number, followed by the five channel-
dependent coefficients (beginning with a0 and ending with a4 ), one line per channel. The
fixed file name is smile poly ord4.dat and it has to be located in the corresponding sensor sub-
directory. In the ideal case these coefficients should be derived from laboratory measurements.
Since an accurate description is only required for channels in atmospheric absorption regions,
the 5 coefficients can be set to zero for the remaining regions, but they must be provided for
each channel. If all 5 coefficients are set to zero for a certain channel, this channel is processed
in the ”non-smile” mode which will expedite the processing.

• Optionally, the spectral bandwidth (FWHM) might also depend on the image column. Again,
a 4th-order polynomial is used to describe the bandwidth change depending on column posi-
tion x and channel j :

∆1 (x, j)[nm] = b0 (j) + b1 (j) · x + b2 (j) · x2 + b3 (j) · x3 + b4 (j) · x4 (4.3)

F W HM (x, j) = F W HM (j) + ∆1 (x, j) (4.4)

The fixed file name is smile poly ord4 fwhm.dat and it has to be located in the corresponding
sensor sub-directory. It is an ASCII file with 6 columns per channel, the first column is the
channel number or wavelength, the remaining columns contain the polynomial coefficients
starting with b0 .

2.0 512 across-track FOV [degree], pixels per line


1 128 first, last reflective band (0.35-2.55 µm)
0 0 first, last mid IR band (2.6 -7.0 µm)
0 0 first, last thermal band (7.0 -14 µm)
0 no tilt in flight direction
0 required dummy
1 5 1=smile sensor, 5 = Gaussian spectral channel filter

Table 4.3: Sensor definition file: smile sensor without thermal bands.

Imagery from smile sensors must be processed in the raw geometry (IGM Image Geometry Map)
to preserve the original image columns. During the surface reflectance retrieval the atmospheric /
topographic correction is performed on a per column basis, i.e., to each image column its appropriate
center wavelength /bandwidth is associated.
The per-column processing typically implies a factor of 8 increase in processing time. The following
steps are to be performed:

1. Define a sensor (∗wvl, ∗cal, ∗rsp files, RESLUT) using the original set of wavelengths (pre-
launch values, as provided with the data from the data provider),
CHAPTER 4. WORKFLOW 45

2. Run the smile detection tool (compare Section 5.8.5, using the sensor defined in 1 and ap-
propriate absorption features, to derive the polynomial coefficients smile poly ord4.dat for
smile correction in step 3; alternatively: enter the smile polynomial factors from laboratory
calibration. Note: if two detectors are in the sensor system, this should be done separately
for VNIR and SWIR, option ’repeat values’, resolution 0.02 nm. Combine the two files for
VNIR and SWIR manually into one file afterwards.

3. Using the same sensor as above, run the atmospheric correction with the smile correction
option switched ’ON’; (after putting the new file smile poly ord4.dat into the sensor definition
directory),

4. Apply the spectral polishing routine (see Section 5.6.3 and 5.6.4, and

5. Run the Spectral Smile Interpolation module (see Section 5.6.7 on the atmospherically cor-
rected image.

4.8 Haze, cloud, water map


Although the surface reflectance cube (and temperature / emissivity for thermal channels) is the
main result of the atmospheric correction, some additional products are often requested. One of
these products is a map of the haze, cloud, water and land pixels of a scene. This map not only
delivers a basic scene classification, but it may also contain information about potential processing
problems. For example, if turbid water pixels are not included in the water mask, the haze mask
may also be not appropriate and consequently, results of the haze removal over land might be of
poor quality. Such a pre-classification as part of the atmospheric correction has a long history
[?, ?, ?, ?, ?, ?, ?]. It is also employed as part of NASA’s automatic processing chain for MODIS
[?] using the classes land, water, snow/ice, cloud, shadow, thin cirrus, sun glint, etc.

Therefore, the calculated haze/cloud/water map is a useful optional output of ATCOR. It is enabled
by setting the parameter ihcw = 1 in the preference parameters.dat file (see chapter 9.3). If the file
name of the imagery is ”image.bsq” the corresponding map is named ”image out hcw.bsq”. It is a
1-channel false-color coded ENVI file. In principle, if a certain mask of ”image out hcw.bsq” (say
haze pixels) contains artifacts, it may be edited, and if the edited file is named ”image hcw.bsq”
it will automatically be used for the ATCOR processing. This means ATCOR can repeat the
processing with an improved (edited) haze mask.
The file ”image hcw.bsq” can also be provided by an external (ATCOR-independent) source. In
any case, if this files exists, ATCOR will skip its internal calculations of these masks and use the
pre-calculated map.
The haze/cloud/water file contains the following classes (see Table 4.4):

• land

• water

• boundary layer haze (two classes: thin-to-medium haze, and medium-to-thick haze)

• cirrus (three classes for thin, medium, thick; and cirrus cloud, thick cirrus cloud), provided a
narrow channel around 1.38 µm exists.

• cloud over land, cloud over water


CHAPTER 4. WORKFLOW 46

Figure 4.15: Optional haze/cloud/water output file.

• snow (requires a 1.6 µm channel)

• saturated pixels using the criterion T > 0.9 ∗ DNmax where T is a threshold set at 0.9 times
the maximum digital number. This criterion is only used for 8 bit and 16 bit (signed or
unsigned) data, no threshold is defined for 32 bit (integer or float) data. As an example,
for an 8 bit/pixel data encoding we obtain T = 0.9*255 = 230, and pixels with a grey value
greater than 230 are flagged as (truly or potentially) saturated.
Although the saturation nominally starts at DNmax some sensors already show a non-linear
behavior around 0.9 ∗ DNmax , so the factor 0.9 is a precaution to be on the safe side.
This saturation check is performed for two channels in the visible region (blue band around
470-500 nm, and a green band around 550 nm). For multispectral sensors, the blue band
is usually the critical one concerning saturation. For hyperspectral sensors with many blue
bands the one closest to 450 nm is taken. Although the haze/cloud/water file contains
saturated pixels based on two visible bands, the percentage of saturated pixels for all bands
will be given in the corresponding ”.log” file. However, the check of the blue and green
channel normally captures all saturated pixels.

The thresholds for the cirrus class definition are described in chapter 10.2.

Note: cloud (or building) shadow pixels are not included here, they are stored separately (file
image fshd.bsq”).

4.9 Processing of multiband thermal data


Several options have been implemented to process multiband thermal data, see chapter 10.1.5 for
details. Apart from the final products (surface temperature and emissivity) intermediate products
are available such as surface radiance, at-sensor blackbody temperature, and surface blackbody
temperature. The intermediate products might be useful to trace back spectral or radiometric
problems. If image.bsq denotes the file name of the input image then the following products are
available:

• image atm emi3.bsq : 3 or 4 emissivity classes obtained from an on-the-fly (in memory)
pre-classification (vegetation, soil, sand, water). The pre-classification requires daytime data
acquisition and spectral bands in the solar region. This file has one channel with the emissivity
CHAPTER 4. WORKFLOW 47

label definition
0 geocoded background
1 shadow
2 thin cirrus (water)
3 medium cirrus (water)
4 thick cirrus (water)
5 land
6 saturated
7 snow
8 thin cirrus (land)
9 medium cirrus (land)
10 thick cirrus (land)
11 thin-medium haze/land
12 medium-thick haze/land
13 thin-medium haze/water
14 medium-thick haze/water
15 cloud/land
16 cloud/water
17 water
18 cirrus cloud
19 cirrus cloud thick

Table 4.4: Class label definition of ”hcw” file.

values for the specified thermal band, or in case of ANEM the pixel-dependent values assign
the maximum emissivity of all available thermal bands.

• image atm emiss.bsq contains the spectral emissivity map for all thermal channels.

• image atm emiss lp3.bsq is the same emissivity map but filtered with a 3-channel low pass
filter to smooth spectral noise features (requires at least 10 thermal bands).

• image atm emiss lp5.bsq is the same emissivity map but filtered with a 5-channel low pas
filter to smooth spectral noise features (requires at least 30 thermal bands).

• image atm isac emiss.bsq : emissivity cube for the ISAC algorithm.

• image at sensor channel tmax.bsq : map of channel numbers with maximum at-sensor tem-
perature.

• image at surface channel tmax.bsq : map of channel numbers with maximum surface tem-
perature.

• image at sensor tbb.bsq : at-sensor brightness temperature cube

• image at surface tbb.bsq : at-surface brightness temperature cube.

The last channel of image atm.bsq contains the surface temperature map evaluated with the ap-
propriate emissivity, the preceding thermal channels in this file contain the surface radiance.
In case of the ISAC algorithm an additional file image isac lpath trans.dat contains the spectral
CHAPTER 4. WORKFLOW 48

path radiance and transmittance estimates for the scene. Fig. 4.16 shows an example of these
spectra derived from a SEBASS scene.

Figure 4.16: Path radiance and transmittace of a SEBASS scene derived from the ISAC method.

Fig. 4.17 presents the at-sensor/at-surface radiance and brightness temperatures. The at-sensor
products clearly show the atmospheric absorption features which are removed in the at-surface
quantities, apart from small residual effects. The bottom graphic presents the corresponding surface
emissivity spectrum.
CHAPTER 4. WORKFLOW 49

Figure 4.17: Comparison of radiance and temperature at sensor and at surface level.
CHAPTER 4. WORKFLOW 50

4.10 External water vapor map


Sometimes, it is convenient to use an external water vapor map, even if this map could be de-
rived from the scene. If the scene is named ”scene.bsq” then the external map should be named
”scene wv.bsq” and it must have the same number of image lines and pixels per line as the scene.
If this file is available in the same directory as the scene, it will be automatically used during the
processing and the usage is also documented in the log file (”scene atm.log”). Note: this feature is
only supported for instruments that are able to retrieve the water vapor column with the intrinsic
channels, because the prerequisite is the availability of the corresponding LUTs.

4.11 External AOT 550 nm map


Although ATCOR calculates the aerosol optical thickness map (at 550 nm) if the variable aerosol
option is set (parameter npref=1 in the ’*.inn’ file), the import of an external AOT(550nm) map is
also supported. This file should be located in the same folder as the scene. If the file name of the
image is ’scene.bsq’ then the corresponding AOT map should be named ’scene aot550.bsq’. The
size of this map should match the scene size (i.e. same number of columns and lines as the scene).
If this map is stored as float data, then it contains the original AOT(550nm) values (i.e. without
scale factor). This map can also be provided as 16-bit signed or unsigned integer with a mandatory
scale factor of 1,000.
Note: The internal calculation of the aerosol optical thickness map is performed with DDV and
water areas. Additionally, the path radiance in the blue-red spectrum is re-scaled to fit the surface
reflectance of DDV pixels in the scene if required. However, for an external AOT550 map no re-
scaling of the selected aerosol path path radiance is conducted. Therefore, if the internal AOT550
file is copied and used as an external AOT map both results may differ.

4.12 External float illumination file and de-shadowing


If the scene is processed with a DEM the additional files of slope, aspect (and optionally skyview
and cast shadow) are used to calculate the solar illumination map (cosine of the local solar zenith
angle), which is stored as byte data (range 0-100, scale factor 100) as side output. If the file name
of the input scene is scene.bsq then the corresponding illumination file is named scene ilu.bsq.
However, there is an option to process an external illumination map and skip the internal calcula-
tion. In this case the requested condition is a float-coded file (range 0 - 1) with the nomenclature
scene raw ilu.bsq (first priority) or scene ilu.bsq (second priority) to distinguish it from an internal
calculation (if an internal calculation was performed previously). The image-based shadow detec-
tion routine Topographic:Image Based Shadows algorithm optionally stores results in a multi-layer
file, and the first layer is the float-coded illumination, which will be read automatically for ATCOR
processing upon availability. In case of a rugged terrain, the terrain illumination can be encoded
in conjunction with the cast shadow information within the * ilu file. The menu ATCOR:Define
Side Inputs allows to select or deselect the illumination map to be used as side input.
Two de-shadowing methods are implemented in ATCOR: the matched filter approach (see chapter
10.6.6) and the illumination-based approach (see chapter 10.1.2). The latter delivers a float-coded
illumination file (range 0 - 1) containing the fractional shadow.
If a float-coded illumination file exists in the folder of the input scene, then it is used for de-
shadowing, also for the flat terrain case (without DEM files). Therefore, it has always the first
CHAPTER 4. WORKFLOW 51

priority. If the matched filter de-shadowing is intended, then the float-coded illumination file has
to be renamed or temporarily removed from this folder.
Internally, the range 0 - 1 of the float illumination is then re-scaled to 0 - 1000 to be compatible with
the matched filter de-shadowing case (only for the purpose of de-shadowing, not for the correction
of terrain effects).
The menu ATCOR:Define Side Inputs allows to select or deselect an illumination file to be used
as side input.
Chapter 5

Description of Modules

For most ATCOR modules a convenient graphical user interface is available, while the processing
may also be performed by submitting batch jobs (compare Section 6). When Starting ATCOR-3,
the binary atcor.sav is opened by the IDL virtual machine. The main interface is a floating pull-
down menu, see Figure 5.1, with a thematic grouping of modules. A detailed discussion of the
interactive panel-driven modules is given hereafter whereas a description of the batch commands
can be found in chapter 6.

Figure 5.1: Top level menu of the satellite ATCOR.

52
CHAPTER 5. DESCRIPTION OF MODULES 53

5.1 Menu: File


The menu ’File’ offers some collaborative tools for handling of the data and ENVI files. Below, a
short description of the individual functions is given:

Figure 5.2: The File Menu

5.1.1 Display ENVI File


Use this function for displaying a band sequential ENVI-formatted file in a simple way 1
An initial dialog allows to select the band(s) to display - either a true color, CIR color, or a single
band mode may be selected.
After band selection, the following options are available within the file viewer from the menu:

1
The ENVI format is a raw binary file, accompanied by an ASCII header ∗.hdr; in ATCOR it should be stored
in band sequential order. Note: this ENVI file display routine may be used separately using the GLIMPS software,
available free of charge from ReSe Applications.
CHAPTER 5. DESCRIPTION OF MODULES 54

Figure 5.3: Band selection dialog for ENVI file display

File:Show ENVI Header Displays the ENVI header of the current image in a new editable
window. This allows to make changes to the ENVI header. Note that the file needs to be
loaded from scratch if changes have been made.

File:Band Selection Allows to select a new combination of spectral bands and updates the dis-
play.

File:Display ENVI Image Displays an additional ENVI image in a new window.

File:Plot Spectral Library Displays the spectra of an ENVI spectral library.

File:Preview Displays the current image display as JPG in the native image file viewer of the
operating system.

File:Close Closes the window.

Edit:Equalize Image Performs a histogram equalization on the three bands.

Edit:Scale Image Applies standard linear scaling on the imagery using 6 differing methods.

Edit:Scale Zoom Applies standard linear scaling on the imagery using 6 differing methods on
the statistics of the Zoom Window.

Edit:No Scaling Reverts to unscaled display of the image.

Edit:Scale to Range Scales a single-band image linearly to a range entered as lower and upper
limit (only applicable in single band displays).

Edit:Load Color Table Loads the standard color table (applicable for single band display only).

Edit:Flip Vertically Flips the image display vertically, e.g. for unrectified images.

Edit:Resize Image Allows to resize the currently displayed image to new spatial dimensions,
optionally based on a reference image.
CHAPTER 5. DESCRIPTION OF MODULES 55

Profile:Horizontal Opens a window for a horizontal profile through the image (of the first band
only). The profile is updated for the cursor location in the zoom window whenever the zoom
window is clicked.

Profile:Vertical Opens a window for a vertical profile through the image (of the first band only).

Profile:Spectrum Opens a window for a spectrum of the image (for images with 4 and more
bands only); use the middle mouse button to show the spectrum directly.

Calculate:Empirical Correction Allows to perform a white target or empirical line correction


on the basis of one or two reference spectra.

Calculate:Dark Target Correction Allows to perform a simple dark target subtraction on the
image, based on image statistics.

Calculate:Band Index Allows to calculate a spectral band index from the currently displayed
image such as band ratio or NDVI-type of indices.

Calculate:Spectral Classification Allows to calculate a spectral quantification/classification us-


ing the spectral angle mapper or spectral fitting technique.

Calculate:Change Detection Calculates the difference between two image bands of the same
spatial dimensions.

Calculate:Statistics Calculate the statistics per spectral band from the current image and stores
the result as either an SLB or TEXT file.

Export Allows to export the currently displayed image of either the zoom or the full image window
to one of the given image data formats.The displayed image may be exported as a scaled
8bit/24bit image to the available standard image formats. Furthermore, the displayed color
bar may be exported for use in publications (makes sense for single band images only).

Note: when middle or right -clicking in the zoom window, the current image value and location is
displayed, or a small plot of the spectrum at this pixel location is created (same as the function
Profile:Spectrum of above). The menu in the such loaded window allows to save the spectrum to
an ASCII table, to adapt the graph’s properties and font size, configure the display and to output
the graph to an appropriate graphics format.
The position field may be used to jump to a given coordinate by entering the coordinates manually
and using the ’Enter’ key on the keyboard. The button ¿Get Position¡ is used to get the currently
stored coordinates from clipboard, whereas the button ¿Push Position¡ lets you push the currently
showns coordinates to clipboard.
CHAPTER 5. DESCRIPTION OF MODULES 56

Figure 5.4: Display of ENVI imagery


CHAPTER 5. DESCRIPTION OF MODULES 57

5.1.2 Show Textfile


Use this function if you need to edit a plain text file which comes together with the data to be
processed. The file is opened in a simple editor and may be changed and saved. Simple copy-paste
is also enabled in this small editor. For opening and printing the file in an OS-native text editor,
you may use the preview function. The function comes handy if an ENVI header needs to be
checked or updated (e.g.). Selecting the ’Save’ or the ’Save As’ function in the submenu will allow
to overwrite the file or to create a new one.

Figure 5.5: Simple text editor to edit plain text ASCII files

5.1.3 Select Input Image


This function allows to select the basis input image (i.e., the band sequential uncorrected image
data in ENVI format). It is useful to define the starting point including the default paths of the
images for further processing.

5.1.4 Resize Input Image


This tool allows to resize some georeferenced ATCOR input data to new spatial dimensions (without
resampling).
The following inputs are necessary:

Inputs Files:

• Input Image Name: name of input data file to be resized

• Input DEM Name: name of input elevation data file (this line may be left empty if no DEM
is available)

Dimensions:
CHAPTER 5. DESCRIPTION OF MODULES 58

• Upper Left corner: coordinates of upper left corner pixel (ENVI convention: lower left edge
of upper left corner pixel is pixel 1/1) - the button ”Get UL Position” may be used to get
the upper left position of the image subset from a coordinate stored with the ’Push Position’
button in an ENVI file display windwo
• Use Reference File: the coordinates of a reference file may be used
• Number of Pixels: size of output file in pixels in x and y direction (ncols, nrows) starting at
upper left corner.
• Output name Basis: name of output main file; auxiliary files are stored according to ATCOR
conventions, i.e. ∗ ele.bsq etc.

Output: Based on the output name (Basis) the auxiliary files are stored according to ATCOR
conventions, i.e. ∗ ele.bsq etc. Possible outputs are:
• at sensor radiance image (ATCOR main input image)
• scan angle file ( ∗ sca.bsq if available)
• illumination file (∗ ilu.bsq if available)
• elevation file (if set)
• side layers of topography: ∗ slp, ∗ asp, ∗ sky.

Figure 5.6: Resize ATCOR input imagery

5.1.5 Rename File Group


Use this function to rename a full group of ATCOR files. ATCOR processing relies on a significant
number of files which can be renamed all at once, including the entries in the ∗.inn file. The such
renamed data set is ready for further ATCOR processing.
CHAPTER 5. DESCRIPTION OF MODULES 59

5.1.6 Import: Geographic Lat/Lon


ATCOR requires that all input data are in cartesian metric coordinate systems. If data is provided
in geographic coordinates (i.e. as latitude/longitude values) a conversion to a metric system is
required at first.

Figure 5.7: Import Geographic Lat/Lon image files

Inputs:

• ENVI or GEOTIFF Input File: Lat/Lon input file (in ENVI *.bsq or GEOTIFF format) -
tiff files with *.tfw world file are to be imported by Import:Geo-TIFF first.

• Output Resolution: Size of one DEM pixel in meters (will be the same for x and y dimension).

• Interpolation of missing values: missing data in the Image (normally values below 0 or below
-9000) are filled in by interpolation during the coordinate conversion process.

• Threshold: values equal or below the threshold value are interpolated. This parameter does
not apply if no interpolation is selected.

• Coordinate conversion: select target projection/datum. For UTM the default zone may be
selected to create a UTM WGS1984 projection.

• Output File: name of new file to be created.


CHAPTER 5. DESCRIPTION OF MODULES 60

Output: Upon the action Import Lat/Lon Data, a new file is created, which is based on the given
geometric coordinate system and saved to an output file in ENVI format. An ENVI formatted file
is created and the coordinate system is updated. For TIFF files, a conversion to ENVI format is
first executed, resulting in a file named [outfile] latlon.bsq.

5.1.7 Import: Various File Formats


Some standard formats are supported for importing data layers to an ENVI band sequential format,
vor efficient use with ATCOR-4:

Geo-TIFF Multi-Band GEOTIFF or TIFF file in band ascending order; for TIFF files, a tiff
world file *.tfw is required for coordinates definition.

RGBN-Geo-TIFF Geotiff in 4-band configuration, storage order R-G-B-N (e.g. for photogram-
metric data)

NRGB-Geo-TIFF Geotiff in 4-band configuration, storage order N-R-G-B

JPEG2000-Geo Import of JPEG2000 file (extension .jp2) with embedded georeferencing infor-
mation in geotiff or gml format.

ENVI BIP Image Imports and transforms an ENVI image in BIP (band interleaved by pixel)
format to the ATCOR default BSQ (band sequential) format.

ENVI BIL Image Imports and transforms an ENVI image in BIL (band interleaved by line)
format to the ATCOR default BSQ (band sequential) format.

Erdas Imagine Imports an uncompressed image in ERDAS Imagine format to ENVI format
(specifically suited for DEM data import).

5.1.8 Import
A small number of standard formats is supported for importing data layers to be used with ATCOR-
3:

Geo-TIFF Multi-Band geotiff in band ascending order.

RGBN-Geo-TIFF Geotiff in 4-band configuration, storage order R-G-B-N (e.g. for photogram-
metric data)

NRGB-Geo-TIFF Geotiff in 4-band configuration, storage order N-R-G-B

JPEG2000-Geo Import of JPEG2000 file (extension .jp2) with embedded georeferencing infor-
mation in geotiff or gml format.

ENVI BIP Image Imports and transforms an ENVI image in BIP (band interleaved by pixel)
format to the ATCOR default BSQ (band sequential) format.

ENVI BIL Image Imports and transforms an ENVI image in BIL (band interleaved by line)
format to the ATCOR default BSQ (band sequential) format.

Erdas Imagine Imports an uncompressed image in ERDAS Imagine format to ENVI format
(specifically suited for DEM data import).
CHAPTER 5. DESCRIPTION OF MODULES 61

DMC Imports the standard DMC files.

Landsat-4/5 Imports the standard Landsat 4/5 files.

Landsat-7 Imports the standard Landsat 7 files.

Landsat-8 OLI Imports the standard TIF files from Landsat-8 OLI data to an ENVI BSQ
format containing the correct order of bands (wavelength-ascending) for further processing
in ATCOR. The panchromatic band is not included in this multispectral set of bands.

Landsat-8 OLI+TIRS Imports the standard TIF files from Landsat-8 OLI + TIRS data to an
ENVI BSQ format containing the correct order of bands (wavelength-ascending) for further
processing in ATCOR. The panchromatic band is not included in this multispectral set of
bands.

Pleiades Imports the standard Pleiades files.

RapidEye Imports the standard RapidEye, mode1 files.

Sentinel-2 Imports the standard JPEG2000 (.jp2) files. Each of the 13 bands is a separate file.
The import reads all files, and converts them into (1) a 13-channel ENVI BSQ file (all bands
at 20 m), (2) a separate 4-channel BSQ with the 10 m bands. In addition, the original TOA
reflectance is converted into TOA radiance, and the ’*.inn’ and ’*.cal’ files are calculated for
the 13-channel and 4-channel files.

Worldview-2 Imports the standard Wordview-2 files.

Hyperion Image (TIF) Imports a Hyperion image in TIFF format and converts to 242 ENVI
bands.

Hyperion Raw Image Imports a Hyperion image in ENVI format, 242 spectral bands for use
with ATCOR. The number of bands is reduced to 167 according to the sensor definition
provided with the software.

5.1.9 Export
Transformation and export of standard ENVI format outputs to:

ENVI BIP Image Transforms and Exports an ENVI BSQ (band sequential) image to BIP for-
mat.

ENVI BIL Image Transforms and Exports an ENVI BSQ (band sequential) image to BIL for-
mat.

Multiband TIFF creates an universal multiband TIFF image from the input ENVI file.

Use the function ’Display ENVI file’ (see section 5.1.1) to export JPG, PNG or TIFF imagery in
RGB or grayscale for illustration purposes.
CHAPTER 5. DESCRIPTION OF MODULES 62

5.1.10 Plot Sensor Response


In the panel Plot Sensor Response, one may select the respective sensor response from within the
available response functions in the ATCOR installation (or elsewhere). When selecting a response
file, the related bands are loaded automatically and the total number of bands is displayed. The
band range for display can be adjusted manually afterwards.
Normalization of the curves can be such that the area below the curves is constant (same weight
of the functions) or the maximum is at 1 for all curves. The displayed graph may be adjusted in
appearance and size and finally being exported to a standard graphics file for further use.

Figure 5.8: Plotting the explicit sensor response functions

5.1.11 Plot Calibration File


When selecting this function, the dialog defaults to the atcor installation for the selection of a ∗.cal
file to be displayed. Both, gain and offset are then plotted in the same graph to get an overview of
their relative values.

5.1.12 Read Sensor Meta Data


This function reads standard Meta information as provided by the data providers together with the
imagery. The meta data is read and stored into the standard .inn file and a .cal file is created to be
used for subsequent ATCOR processing. The list of supported sensors can be seen in Figure 5.10,
i.e., DMC, Formosat, Landsat, Pleiades, Rapideye, SPOT, Theos, Quickbird, and WorldView-2/3,
ZY-3, and more.
CHAPTER 5. DESCRIPTION OF MODULES 63

Figure 5.9: Plotting a calibration file

5.1.13 Show System File


This is the same function as ’Show Textfile’ but defaults always to the ATCOR installation in order
to allow to select an ATCOR system file from within the installation, such as the cal-files, the solar
reference files, the sensor definition files. The function then allows to adjust and save the respective
text contents of the selected file.
CHAPTER 5. DESCRIPTION OF MODULES 64

Figure 5.10: Read sensor meta file.

Figure 5.11: Displaying a calibration file (same file as in Fig. 5.9)

5.1.14 Edit Preferences


The default settings of ATCOR may be edited through this panel. The updated preferences are
then written to the ASCII file as displayed at the top of the panel. The preferences persist for the
user who started the ATCOR application the next time the system is started and also for batch
processing.
NOTE: Preferences are set when one of the ATCOR modules has been opened. So, one should
select one of the modules from within the menu ’ATCOR’ before editing the preferences. For a
description of the preferences, please refer to Section 9.3.
CHAPTER 5. DESCRIPTION OF MODULES 65

Figure 5.12: Panel to edit the ATCOR preferences.


CHAPTER 5. DESCRIPTION OF MODULES 66

5.2 Menu: Sensor


The menu ’Sensor’ is used to create and edit a new sensor from calibration information. This
function is only required if the sensor is not supported as standard sensor by ATCOR, typically for
experimental purposes.

Figure 5.13: The ’Sensor’ Menu

Fig. 5.14 shows the three required steps to include a new user-defined (usually hyperspectral)
sensor to ATCOR. The example uses a sensor with 96 spectral bands, denoted as ’sensor x96’. A
sub-directory of ’.../atcor/sensor/’ has to be created (named ’x96’) and the three files as displayed
in Fig. 5.14 have to be placed in this sub-directory. This procedure is supported by the Function
’Define Sensor Parameters’. After execution of steps 1 and 2, the new sensor will be automatically
detected when ATCOR is started. Details about the sensor definition files are explained in chapter
4.5. Template files of several sensors are included in the distribution.

Figure 5.14: Sensor definition files: the three files on the left have to be provided/created by the user.
CHAPTER 5. DESCRIPTION OF MODULES 67

5.2.1 Define Sensor Parameters


This panel is the first step if a new sensor is to be defined. The panel as displayed in Fig. 5.15
allows the below options.

Figure 5.15: Definition of a new sensor

Sensor Selection Select any of the already defined sensors from within ATCOR - a sensor is
selected by its sensor definition file (sensor∗.dat) within a sensor directory. Use the function ’New
Sensor’ in case your sensor has not yet been defined.

Inputs

Sensor Type This is to be selected first, smile sensor and thermal sensors require additional
inputs (as displayed in the panel).

Sensor Total FOV [deg] : edge to edge FOV in across track direction in degrees.

Number of Across Track Pixels: : Nominal number of pixels in the unrectified data.

First, last Reflective Band: Band numbers (starting at one) - none: 0


CHAPTER 5. DESCRIPTION OF MODULES 68

First, last Mid IR Band: Band numbers (starting at one) - none: 0


First, last Thermal IR Band: Band numbers (starting at one) - none: 0
Applied scaling factor: Enter the constant scaling factor which had been applied to the data
to fit it to an integer data type from mW/(cm2 srµm). Typical values are 100, 500 or 1000.
The ∗.cal file will be created with constant values for all bands according to this value. If the
scaling factor is not constant, the ∗.cal file is to be edited manually.
NOTE: a scale factor of zero or below inhibits to write a cal-file.
Calibration Pressure: absolute pressure in hPa of instrument during spectral calibration in lab-
oratory.
Instrument Pressure: pressure of instrument during operations
’Absolute’: pressurized instrument with constant pressure as of this value
’Relative’: pressure difference to in-flight ambient pressure (in hPa; value of 0 hPa is ambient
pressure)
Thermal Sensor: Temperature Band Number: Spectral band used for temperature retrieval
algorithm (Optional -according to sensor type)
Smile Sensor: Smile Sensor Response Type , this selection may be required for convolution
when sensor definition is not given explicitly: ’Butterworth Order 1 (slow drop-off)’, ’Butter-
worth Order 2 (close to Gauss)’ ’Butterworth Order 3 (between Gauss/Rect)’, ’Butterworth
Order 4 (close to Rectangular)’ ’Gaussian ’ ’Rectangular ’, ’Triangular ’, ’Decreasing Binning
(from Rectangular to Triangular)’, or ’ - Arbitrary - (as of ∗.rsp files) ’. The last option is
the recommned default for smile correction.
Button: Import Smile File : Use this button to import a smile file ∗.dat as created by the AT-
COR smile detection routine into the sensor definition to the required file smile poly ord4.dat.

Actions
New Sensor : A new sensor is created within the ATCOR installation, which results in a new
directory in the ’sensor’ directory of the installation.
Delete : Allows to delete any sensor directory and all of its contents.
Update Sensor : The sensor parameters of the selected sensor definition are updated according
to the settings.
Rename : The current sensor is renamed (both directory and sensor∗.dat file)

Outputs A new sensor ∗.dat file, and possibly ’sensor’ directory is created.
ATTENTION: this routine requires write-access to the sensor directory of the ATCOR installation.

5.2.2 FTS Generate Wavelength File from (cm-1) in ENVI hdr


ATCOR requires the spectral response of all bands of a sensor being present as a spectral filter file
(response file) ∗.rsp in wavelength units, whereas Fourier Transform Spectrometers often use the
cm-1 unit as a reference. Use this function to convert the cm-1 reference to band response files
suited for ATCOR (compare Fig. 5.16).
CHAPTER 5. DESCRIPTION OF MODULES 69

Figure 5.16: Spectral Filter Creation

Inputs

• Read the center wavenumber (cm-1) from the ENVI header

• Specify the bandwidth (cm-1), same for all channels

• Radiance scale factor c1 (L = c1*DN with L in mW cm-2 sr-1 um-1) (same c1 for all bands)

• Sensor folder name

Outputs File ”*.wvl” in the sensor folder containing 3 columns:

• channel number

• channel center wavelength (micron)

• bandwidth (micron)

File ”*.cal” in the sensor folder containing 3 columns:

• wavelength (micron)

• radiometric offset c0 (assumed as c0=0)

• c1 (radiometric gain)

Procedure The original FTS scene with the radiance bandwidth in (cm-1) and increasing wavenum-
bers per channel should be converted into a scene with increasing wavelength and radiance band-
width in wavelength. The constant wavenumber bandwidth (bww nu) implies a variable wavelength
bandwidth (bww vl). The radiance conversion from wavenumber to wavelength is based on the
equations:

L(wnu, bww nu) ∗ ν 2


L(λ, bww vl) = , (5.1)
10000
CHAPTER 5. DESCRIPTION OF MODULES 70

where ν = wavenumber(cm−1 ) and bwν = bandwidth(cm−1 ) (same for all bands).


λ = reverse(10000./ν) (wavelength in micron) bwλ = (λ1 − λ2 )/2.0 (bandwidth in micron)
with λ2 = reverse(10000./(ν − bwν )) and λ1 = reverse(10000./(ν + bwν )).
Next step: ’Generate Spectral Filter Functions (*.rsp)’

5.2.3 Generate Spectral Filter Functions


ATCOR requires the spectral response of all bands of a sensor being present as a spectral filter
file (response file) ∗.rsp . For spectroscopic instruments, the band characteristics are often only
available by band center and width at FWHM (Full width half maximum). This function creates
the response curves from the latter information (compare Fig. 5.17).

Figure 5.17: Spectral Filter Creation

Inputs

Wavelength File An ENVI header file (standard .hdr) or a wavelength reference file.
Format of ASCII File: 3 columns, no header; column 1: band number; column2: center
wavelength; column 3: band width. Unit: [nm] or [µm] (same for columns 2 and 3).
Note: if the FWHM is not contained in the ENVI header or in the ASCII file, a bandwidth
resolution is assumed which corresponds to 1.2 times the spectral sampling interval.
CHAPTER 5. DESCRIPTION OF MODULES 71

Type of Filter Function The type defines the basic shape of each of the created response curves.
Options are: Butterworth Order 1 (slow drop-off)
Butterworth Order 2 (close to Gauss)
Butterworth Order 3 (between Gauss/Rect)
Butterworth Order 4 (close to Rectangular)
Gaussian
Rectangular
Triangular
Decreasing Binning (from Rectangular to Triangular)

Spectral Binning Factor This factor allows binning of channels, e.g., a factor 4 will combine
four spectral response functions to produce the equivalent new channel filter function. This
is a convenient feature for programmable instruments (e.g., HySpex or Specim AISA). For
using this function, a wavelength reference file containing the unbinned spectral response is
required as an input.

Outputs
A numbered series of band ∗.rsp files are written to the path indicated by the output directory.
The files contain wavelength reference and the relative response in two ASCII formatted columns.

5.2.4 Apply Spectral Shift to Sensor


This is a tool to shift the spectral response of a predefined sensor or to change the FWHM values of
the sensor based spectral position and FWHM detection results from the ATCOR smile detection
routine.

Figure 5.18: Application of spectral shift to sensor

Inputs

• input sensor definition file (sensor ∗.dat)

• smile file (from smile detection routine) - or FWHM file (smile poly ord4.dat or smile poly ord4 fwhm.dat)

• New Sensor Name: directory name of new sensor.


CHAPTER 5. DESCRIPTION OF MODULES 72

Outputs

A new sensor definition is created which is shifted against the original sensor by the values given in
the smile definition file. The shift is calculated as across track average of the band-wise polynomial.
All components of old sensor other than the response files are copied to the new sensor directory.
One may use this function for a constant offset by creation of a text file with the number of lines
= number of bands and the second column containing the spectral offset to be applied.

5.2.5 BBCALC : Blackbody Function


This routine calculates the blackbody function as described in section 10.1.5, weighted by the
spectral response curve of the thermal band used for the temperature retrieval (compare Fig.
5.19).

Figure 5.19: Black body function calculation panel

Inputs
Spectral response file Select the ∗.rsp file of the spectral band in the thermal IR to be used for
temperature retrieval.
Exponential Fit - Limits The lower and the higher limit of the temperatures for which a fitting
function should be created.
Unit of radiance output Select the unit either per micron or without normalization.

Outputs A file ∗ hs.bbfit is created containing the fitting parameters.


CHAPTER 5. DESCRIPTION OF MODULES 73

5.2.6 RESLUT : Resample Atm. LUTS from Database


The monochromatic database of atmospheric LUTs has to be resampled for the specific channel
filter functions of each sensor. Details are given in chapters 4.6.1 to 9.1.4. Figure 5.20 repeats the
panels of the LUT-resampling program RESLUT. The resampling has to be done separately for the
reflective and thermal region. Only the required range of flight altitudes and aerosol types should
be selected.

Figure 5.20: Panels of RESLUT for resampling the atmospheric LUTs.


CHAPTER 5. DESCRIPTION OF MODULES 74

5.3 Menu: Topographic


The ”Topographic” menu contains programs for the calculation of slope/aspect images from a dig-
ital elevation model, the skyview factor, and topographic shadow. Furthermore, it supports the
smoothing of DEMs and its related layers.

Figure 5.21: Topographic modules.

5.3.1 DEM Import: Import Global DEM


Import Global (Lat/Lon) DEM from SRTM or GMTED data to cartesian metric coordinates. The
approx. 200m (0.5 arc min) resolution global DEM data is available for download through the help
menu.

Inputs:

• Longitude range: range in longitude direction; pixel edges - in decimal degrees only!

• Latitude range: range in latitude direction; pixel edges [deg]

• Output Resolution: output pixel size (default: 200m)

• Coordinate System: Select the appropriate projection string. For UTM, the ’Default’ button
will use WGS-1984 standard zone informaiton.

• Output DEM : name of DEM (∗ ele.bsq) to be written.

Action: Pushing the button ’Get Lon/Lat from UTM Image’ will allow to select the target image
(in UTM coordinates) in order to find the correct lon/lat range for global data extraction.

Restrictions: The DEM named DEM SRTM30 WORLD.DEM or the 7.5 Arcsec GMTED 2010
dem (GMTED2010.jp2) have to be available in the demo data/global/ directory of the ATCOR
installation. If both are present, the higher resolution data is taken automatically.

Output: converted DEM as ENVI file in UTM coordinates.


CHAPTER 5. DESCRIPTION OF MODULES 75

Figure 5.22: Import DEM from global elevation data.

5.3.2 DEM Import: Geographic Lat/Lon DEM


This function imports an ENVI or GEOTIFF formatted DEM to a cartesian coordinate system.
During datum conversion, the height values (z-value) in the DEM is also adjusted depending on
the selected output coordinate system definition. More details about coordinate conversion can be
found in Section 5.1.6.

5.3.3 DEM Import: Geo-TIFF


This function import a GEOTIFF file to an ENVI formatted elevation data file.

5.3.4 DEM Import: ARC GRID ASCII


This procedure reads a standard ARC GRID digitial elevation model.

Figure 5.23: Import DEM from ARC GRID ASCII.


CHAPTER 5. DESCRIPTION OF MODULES 76

Inputs:

• Filename: Name of DEM to be read (usually extension *.asc)

• Default output value for found missing data: Value to be written to the pixels as defined by
the NODATA keyword in the GRID file - if output value is less than zero, the mean of the
read data is put to the missing pixels

Actions:

• View Parameters: Shows the header information of the GRID file.

• Read DEM]: Reads the DEM based on the given definition and stores it to a single channel
ENVI formatted file (if required).

Output: converted DEM as ENVI file in arbitrary coordinates.

5.3.5 DEM Preparation


The purpose of this program is to provide a tool to resize a DEM to an image cube’s dimensions.
This menu function as depicted in Fig. 5.24 allows to calculate both layers in one step.

Figure 5.24: DEM Preparation

Inputs:

• Input DEM file] Input DEM (typically large than image).

• Input Image file] This is the target image (georeferenced). The DEM is automatically resized
to its dimensions

• Window Diameter for DEM Processor] Size of the kernel in number of pixels; the slope and
aspect and sky view side outputs are calculated using this kernel size and the output DEM
is smoothed by this kernel size.
CHAPTER 5. DESCRIPTION OF MODULES 77

• Options] The writing of side outputs (i.e. slp and asp and sky may be triggered by des-
electing either of the first two options. The option ”Fill in Missing Background Values” is
used if the DEM is incomplete, the missing parts are filled with an average value from the
DEM.

Outputs: An ATCOR elevation file ele.bsq is written of the same size and location as the
reference Image. Optionally, files of slope and aspect and sky view are created, same size as DEM.
Attention: Both the DEM and the image should be represented in the same coordinate system and
cover the same area. If the DEM is too small, the remaining parts of the image are filled with a
zero value.
Note: this routine is only meant for rectified imagery. If working in raw geometry data format, the
PARGE routine for inversion of DEM related layers to raw geometry is required.

5.3.6 Slope/Aspect
Slope and aspect are to be calculated from the DEM before ATCOR is run for rugged terrain. This
menu function as depicted in Fig. 5.25 allows to calculate both layers in one step.

Figure 5.25: Slope/Aspect Calculation panel

Inputs
• Input DEM file] The standard DEM file used for atmospheric correction. This DEM should
be in meters.
• Output file names] The names for the output files are entered automatically and can’t be
changed as ATCOR asks these files to be named exactly according to the conventions.
• Kernel Size Box] Size of the kernel in number of pixels; the slope and aspect is calculated
as gradient of the pixels at the edges of this box - the default value is 3 pixels (i.e. direct
neighbors of center pixel).
CHAPTER 5. DESCRIPTION OF MODULES 78

• DEM resolution] This is the pixel size, a default of 30m is assumed. This needs to be entered
manually.

• DEM height unit] The unit of the values in the DEM, usually a DEM is stored in meters, but
sometimes an integer DEM is stored as dm or cm data in order to preserve disk space.

Outputs The two files of slope and aspect are created, same size as DEM, integer data.

5.3.7 Skyview Factor


The sky view factor of a DEM is calculated with a ray tracing program and ranges from vsky =
0 to 1, with 1 indicating a full hemispherical view. Data in the sky view file are scaled from 0 to
100% and coded as byte. The sky view factor determines the fraction of the hemispherical diffuse
sky flux and 1-vsky(x,y) determines the fraction of radiation reflected from surrounding mountains
onto the considered pixel, see chapter 10.1.1. This program is also available in the batch mode, see
chapter 6.3.
Input parameters besides the DEM file are:

• DEM horizontal resolution in meters: the x and y resolution must be the same.

• DEM height unit: supported units are m, dm, and cm.

• Angular resolution (degrees) in azimuth and elevation.

• The undersampling factor of the DEM in pixels. For large DEM’s the skyview processing
may be very time consuming unless an undersampling is chosen here.

Figure 5.26: Panel of SKYVIEW.


CHAPTER 5. DESCRIPTION OF MODULES 79

Figure 5.27: Example of a DEM (left) with the corresponding sky view image (right).

Figure 5.26 shows the GUI panel, and figure 5.27 presents a skyview image derived from a DEM
image. An angular azimuth / elevation resolution of 10 degrees / 5 degrees is recommended. For
large images it causes a high execution time which can be reduced by selecting an undersampling
factor of 3 pixels. A high angular resolution is more important than a low undersampling factor.

5.3.8 Cast Shadow Mask


The calculation of the cast shadow map is done by ATCOR after reading the DEM files. If the
shadow map is computed ”on-the-fly” it is kept in memory, and it is not stored as a separate file.
If the user wants to inspect the DEM shadow map the program ”shadow” has to be started before
running ATCOR. The program accepts float values of the solar zenith and azimuth angles. The
output file name of the DEM cast shadow map includes the zenith and azimuth angles rounded to
integer values.

Figure 5.28: Panel of Cast Shadow Mask Calculation (SHADOW).

The DEM cast shadow map is a binary file where shadow pixels are coded with 0 and sunlit pixels
with 1. It includes self shadowing and cast shadow effects. Self shadowing consists of pixels oriented
away from the sun with slopes steeper than the solar elevation angle. The cast shadow calculation
is based on a ray tracing algorithm and includes shadow regions caused by higher surrounding
CHAPTER 5. DESCRIPTION OF MODULES 80

mountains. Figure 5.28 shows the GUI panel.

5.3.9 Image Based Shadows


This routine detects the fractional shadows in the image using a multi-index based approach as
described in [?]. A floating point illumination file is saved to be used as input for atmospheric
correction. Figure 5.29 shows the GUI panel. NOTE: this function is found in the menu ’Filter’
for ATCOR versions without support for terrain correction.

Figure 5.29: Panel of Image Based Shadows.

Input Files:

• Input File: file to be analyzed, requires at least 4 bands (Blue, Green, Red, NIR)

• Calibration File: *.cal file for current input file (usually found in the sensor or cal directory
of the ATCOR installation).

• Solar Reference File: e0 solar: solar irradiance file for current input, this file is also situated
in the sensor or cal directory

Options:

• Include Terrain Illumination - calculates the illumination based on slope and aspect files and
the solar illumination angles as defined below

• Use 490 Blue Reference - use the band closest to 490nm as blue band instead of 430nm. this
function is to be used if calibration in the blue is not accurate.
CHAPTER 5. DESCRIPTION OF MODULES 81

• Calculate Skyview Estimate - calculates an estimate of the local skyview fraction on the basis
of a linear model.
• Desert Mode (Ignore Water) - does not try to find shadows over water bodies.
• Apply Shade Pixel Filter - filters single pixels within full cast shadow areas
• Write all Side Layers - creates a file containing all indices calculated during the processing
in 5-7 layers. This function may be useful to find the appropriate range limits for a sensor
system or imaging situation
• Limits of Index: - The lower and upper boundary can be set in order to derive a continuous
fractional shadow from index. Larger values will result in large fractions of shadows being
detected. The range can not exceed 0 to 2 in any case (default values are 0.5 to 1)
Parameters used for terrain illumination and skyview estimate:
• Slope File Name: Name of input Slope file to be used for illumination calculation (the corre-
sponding asp.bsq’ file needs also to be present)
• Solar Zenith/Azimuth and Aircraft altitude above ground: solar angles (zenith/azimuth) for
this data set and optionally the flight altitude above ground (airborne ATCOR version only)

Output: A combined index is created based on NIR brightness, and two red/blue and green/blue
indices which results in a scaled number between 0 for full cast shadow and 1 for full illumination
which is proportional to the cast shadow. The illumination layer is in the first band of the output
file in case of multiband (all layers) output.s

5.3.10 DEM Smoothing


Smooth a DEM (or any other single-band image) in order to remove artifacts in the atmospherically
corrected imagery. All related DEM-layers are automatically smoothed as well (e.g. slope / aspect
/ skyview). Alternatively, this task could be done with any image processing software.

Inputs:
• Input DEM/File Name] Usually a DEM ∗ ele.bsq is selected here; but any other single band
ENVI image or the ∗ ilu.bsq file is also accepted. The routine searches automatically for
related files (i.e. ∗ sky, ∗ slp , and/or ∗ asp) and smoothes them with the same parameters.
• Diameter of DEM Filter: Size of filter box in pixels (diameter)
• Output Name: Name of Elevation file output (auxiliary layer names will be derived from
that)

Outputs: ENVI file(s) smoothed or filtered by the given factor and method:

Actions:
• Smooth: uses the standard smoothing (i.e., lowpass-filter) in the spatial domain.
• Median: uses a median filter for data correction, e.g., to remove noise or outliers from the
DEM.
CHAPTER 5. DESCRIPTION OF MODULES 82

ATTENTION: The ∗ ilu file is not smoothed automatically by this routine. If the ilu has
already been calculated before, it should be either removed or be smoothed separately.

Figure 5.30: Panel of DEM smoothing

5.3.11 Quick Topographic (no atm.) Correction


The quick topographic correction routine (TOPOCOR) tries to eliminate the slope/aspect topo-
graphic effects and neglects the atmospheric influence. The program runs very fast and the output
image contains the modified digital numbers. Processing with TOPOCOR can be done with or
without display of images. The DEM slope and aspect files have to be specified on a separate panel
that pops up after the input image has been specified. The topographic correction implemented
here multiplies the DN value with a factor f that depends on the local solar zenith angle β and a
weighting coefficient w. The wavelength-depending weighting w is based on a typical value of the
ratio of the direct to total (direct + diffuse) solar flux on the ground.

f = 1 − (1 − cosΘS /cosβ)w if λ < 1.1µm (5.2)

f = cosΘS /cosβ if λ ≥ 1.1µm (5.3)

ΘS is the solar zenith angle of the scene. For λ ≥ 1.1µm the diffuse flux is neglected, i.e., w=1.
The factor f is 1 for a flat terrain and some bounds were employed to prevent overcorrection. So
for each pixel the new digital number is calculated as

DN (new) = DN ∗ f (5.4)

The method was compared with the standard Minnaert correction (eq. 5.5) and was superior in
most cases. Figure 5.31 shows the GUI panel.
cosΘS log(cosΘS /cosβ)
f ={ } (5.5)
cosβ
CHAPTER 5. DESCRIPTION OF MODULES 83

Figure 5.31: Topographic correction only, no atmospheric correction.


CHAPTER 5. DESCRIPTION OF MODULES 84

5.4 Menu: ATCOR


The menu ’ATCOR’ contains the main processing modules of ATCOR, i.e., the panels for ATCOR2
(flat terrain) and ATCOR3 (rugged terrain). Two modes are distinguished: pre-defined and user-
defined, usually multispectral and hyperspectral sensors, respectively. In this section, the main
panels are first shortly described. Thereafter, the subroutines SPECTRA and IFCALI and all
panels related to them are explained.

Figure 5.32: The ’ATCOR’ Menu

5.4.1 The ATCOR main panel


Figure 5.33 (top) shows the input parameters required for ATCOR. The lower part of the panel
contains buttons for selecting SPECTRA, determining the aerosol type, employing inflight radio-
metric CALIBRATION, and starting the image processing. The processing options are shown in
the separate panel as described in section 5.4.11. The trivial panels, e.g., band selection, spatial
subimage etc. will not be shown here. The panels should be filled or clicked in the top-down
direction. The message widget at the bottom will display hints, warnings, or errors.

5.4.2 ATCOR2: standard sensors, flat terrain


The panel as described above and in figure 5.33 will appear when ATCOR2 is selected. This
function is meant for multispectral standard instruments without cirrus and water vapor bands.

5.4.3 ATCOR3: standard sensors, rugged terrain


In case of the rugged terrain version of ATCOR the panel for the DEM files has to be specified in
addition (Figure 5.34). It pops up after the input file has been specified. A quick quality check is
performed on the DEM files. The solar illumination file is calculated and if its standard deviation
is large the panel of Figure 5.35 pops up with a warning. In this case the DEM elevation file (and
the derived files of DEM slope, aspect etc) probably have a lot of large steps. The DEM resolution
is often not appropriate for high spatial resolution imagery, and integer coded DEM’s might have
to be resampled and stored as float data. Appropiate action for resampling or low pass filtering is
recommended in these cases, see the tips in chapter 9.5. Figure 5.36 shows an example in terms of
the DEM illumination. The top image is obtained after low pass filtering the original elevation file,
CHAPTER 5. DESCRIPTION OF MODULES 85

Figure 5.33: ATCOR panel.

the central image is the illumination based on the original DEM, and the bottom shows a 100 pixel
transsect of the original elevation data revealing the steps. The original DEM had a resolution of
30 m, was coded as 16 bit integer, and initially resampled to the 6 m pixel size of the image with
integer arithmetic. After reprocessing the elevation file the other DEM derived files should also be
reprocessed.
The pixel size of the DEM files must be the same as the image pixel size specified on the main
panel, see figure 5.33. The physical units of pixel size (m) and adjacency range (km) are also used
to calculate the equivalent number of pixels needed to cover the adjacency range.

5.4.4 ATCOR2: Advanced Sensors


The menus for advanced sensors is meant for hyperspectral, user defined or advanced multispectral
systems containing water vapor or cirrus bands (e.g., Sentinel-2). It share the same functionalities
as described above for multispectral systems in both flat and rugged terrain options. The major
difference is the requirement of a specific sensor definition; ie. the sensor definition is editable and
adjustable. The ATCOR2 variant is recommended to speed up processing time and for fast checks
as hyperspectral image processing may be very time consuming in rugged terrain.
CHAPTER 5. DESCRIPTION OF MODULES 86

Figure 5.34: Panel for DEM files.

Figure 5.35: Panel to make a decision in case of a DEM with steps.

5.4.5 ATCOR3: Advanced Sensors


This routine is to be taken if highest accuracy is required in terrain for imaging spectroscopy in-
struments. The functionality is analoguous as described for the other panels.
CHAPTER 5. DESCRIPTION OF MODULES 87

Figure 5.36: Influence of DEM artifacts on the solar illumination image.


Top: illumination with low pass filtered DEM; middle: illumination based on original DEM;
bottom: 100 m transsect using original DEM, pixel size is 6 m.
CHAPTER 5. DESCRIPTION OF MODULES 88

5.4.6 SPECTRA module


The SPECTRA module (see figure 5.37) serves to extract spectra of different targets of the scene
as a function of the visibility. It is started from within one of the four possible ATCOR main
panels. These spectra can be compared to field spectra or library spectra to estimate the visibility.
Scene-derived spectra also may indicate calibration errors in certain channels. In that case, a copy
of the sensor calibration file can be edited to match the retrieved reflectance with the field / library
spectrum or the inflight calibration module may be employed (see chapter 5.4.9).

In most cases it is useful to check some scene-derived target spectra, e.g. water, vegetation, or soils,
before starting the processing of the image cube at the risk of ”blind” processing and obtaining
wrong results.

Figure 5.37: SPECTRA module.

To obtain a target spectrum of the scene click at any position in the image. In figure 5.37 the
solid white-line spectrum at the top shows a coniferous forest signature, the green line represents
a spruce reference spectrum taken from the spec lib directory, already resampled for the Landsat-5
TM sensor. The symbols mark the TM center wavelengths. A reference spectrum can be loaded
when clicking the corresponding button at the top right of the panel. The bottom graphics shows
soil and water spectra taken from the scene and a soil reference spectrum from the spec lib library.
CHAPTER 5. DESCRIPTION OF MODULES 89

An exact match of scene spectra and library spectra cannot be expected, but the trends (spectral
shapes) should be consistent.

The parameter Visibility can be set in the corresponding widget near the center of the panel and its
influence on the retrieved spectrum will be shown when placing the target box in the scene. To vary
the atmospheric water vapor content the user should switch to the main panel and select a different
atmosphere, e.g. switch from the mid-latitude summer atmosphere (with a column wv=2.9 cm) to
a tropical atmosphere (with wv=4.1 cm), compare chapter 6. Most multispectral satellite sensors
do not have spectral bands placed in water vapor regions, so the retrieved reflectance signature will
show a rather small dependence on the water vapor estimate. For sensors with water vapor bands,
e.g., Hyperion or MOS-B, the retrieved reflectance spectrum strongly depends on the water vapor
content. In this case, the water vapor map can be derived during the image processing (see the
panel of figure 5.33) as part of the reflectance retrieval. Note that the water vapor is not retrieved
from the image pixel for correction in the SPECTRA module as it is done in the image processing
for hyperspectral systems.

The button ”Save last spectrum” (upper right corner of figure 5.37) can be used to save the selected
surface reflectance spectrum. A sequence of target DN spectra can also be generated here that is
required as input to the spectral calibration module (currently only available for the hyperspectral
add-on module). Up to 9 targets can be defined to be used in the spectral calibration. They have to
be labeled consecutively, e.g. ”target1”, ”target2”, etc. These output file names (without file name
extension) have to be specified after pressing the button ”Save last spectrum”. For each target
name three files will be generated, e.g., ”target1.dat” (surface reflectance spectrum), ”target1.txt”
(a description file), and ”target1 dn1.dat” (the DN spectrum). The sequence of ”target∗ dn∗.dat”
files is used in the spectral calibration module.

5.4.7 Aerosol Type


The aerosol type is a parameter which is fixed for atmospheric correction. This routine searches
automatically for the best suited aerosol type for the currently selected image. This type can then
be used when selecting the atmospheric file.

5.4.8 Visibility Estimate


ATCOR uses the Dark Dense Vegetation (DDV) approach to calculate the best visibility for an
image. This button allows to calculate the visibility estimate for the whole image without going
into the image processing. Note, that for the ’Variable Visibility’ option, the visibility map will be
calculated anyway from the image during the image processing.

5.4.9 Inflight radiometric calibration module


This chapter presents the GUI for the inflight calibration, which may also be invoked from one of
the four possible ATCOR main panels. The purpose is the calculation of the radiometric calibration
coefficients for spectral bands in the solar region based on measured ground reflectance spectra.
The user should be familiar with chapter 2.3 before using this function.
Note: a ground reflectance spectrum from a field spectrometer has to be resampled with the channel
filter curves of the selected sensor. The field spectrometer file format should be converted into a
simple ASCII file containing the wavelength (nm or µm) in the first column and reflectance in
CHAPTER 5. DESCRIPTION OF MODULES 90

the second column. The resampling can then be done with the sequence ”Filter”, ”Resample a
Spectrum” from the ATCOR main panel. The result is an ASCII file with 2 columns: the first
contains the channel center wavelength (the nm and µm unit is allowed), the second contains the
resampled reflectance value (either in the 0 - 1 or 0 - 100% range).
If ”target1” is the name of the target, ATCOR provides three ASCII files with information on
target / background properties and the derived calibration file. These are the output of the ”c1”
option of ATCOR’s calibration module,

• File ”target1.adj” contains the original target DN1 , the adjacency corrected DN1∗ , and the
ground reflectance data for each band.

• File ”target1.rdn” (radiance versus digital number) contains the band center wavelength,
target radiance L1 and corresponding digital number. This file can be used as input to a
regression program ”cal regress” that allows the calculation of the calibration coefficients
with a least squares fit in case of multiple targets (more than two).

• File ”target1.cal” contains three columns: band center wavelength, offset or bias set to zero
(c0 = 0), and c1 according to equation (2.13).

Remark: a bright target should be used here, because for a dark target any error in the ground
reflectance data will have a large impact on the accuracy of c1 .

Figure 5.38: Radiometric calibration: target specification panel.

At the top line of the menu of figure 5.38 the mode of calibration is specified: one or two targets
can be employed by selecting the button ’c1’ or ’c0 & c1, respectively. If a calibration is intended
CHAPTER 5. DESCRIPTION OF MODULES 91

for n > 2 targets, each target has to be specified separately in the ’c1’ mode, which creates a file
’target i.rdn’ (i=1, 2, ..., n) with the name ’target i’ specified by the user. These files contain
the radiance and corresponding digital number spectrum as a 2-column ASCII table, and they are
employed in the batch module cal regress (see chapter 5) to calculate a least squares regression
for the calibration coefficients. Next the target box size and the corresponding ground reflectance
file have to be specified. The button for the file name of target 2 is insensitive, because the single
target mode was selected here. Then the file name for the calibration results should be specified.
The default name is ”test.cal”. However, it is recommended to include the name of the ground
target here. Now the target(s) can be clicked in the zoom window that pops up automatically.
Target 1 has to be clicked with mouse button 1 (mb1, left), target 2 with mouse button 2 (mb2,
center). The zoom window is moved in the main window by pressing mb1 (for target 1) and mb2
(for target 2). Alternatively, the target coordinates (x / y = column / line) can be specified.
In addition to the file ”xxx.cal” the files ”xxx.rdn” (radiance versus digital number), and ”xxx.adj”
(original and adjacency corrected DN’s) are automatically created.

Figure 5.39: Radiometric CALIBRATION module.

The appearance of the inflight calibration module is similar to the SPECTRA module. In the
left part the image is loaded. A zoom window can be created and two contrast stretching options
(Gaussian and histogram equalization) are available. In the right part two windows are provided
to display the c1 spectrum and the box-averaged target DN spectrum. The ymin / ymax widgets
allow the user to scale the graphical display. The parameters visibility and adjacency range can be
varied and their influence on the calibration curve can be studied.
CHAPTER 5. DESCRIPTION OF MODULES 92

5.4.10 Shadow removal panels


The interactive session of the de-shadowing method enables the setting of three parameters that
influence the results, compare Figures 5.40, 5.41:

1. a threshold ΦT for the unscaled shadow function Φ = PhiU to define the core size of the
shadow regions, see chapter 10.6.6 for details.

2. the maximum range Φmax for re-scaling the unscaled shadow function Φ = PhiU into the
(0,1) interval of the scaled shadow function.

3. the last parameter sets the minimum value of the scaled shadow function Φ∗ = PhiS, typically
in the range PhiS=0.02 - 0.10, i.e., the darkest shadow pixels of the scene are treated as being
illuminated with a fraction PhiS of the direct solar irradiance.

Figure 5.40: Normalized histogram of unscaled shadow function.

The first two parameters are most important. The last parameter is not very critical, and a default
value in the range PhiS=0.04 - 0.08 covers most cases of interest.
The linear type of re-scaling of PhiU is recommened. The ”exponential” option exaggerates the
de-shadowing results, but it can be used to enhance the trends for a quick visual inspection.
When pressing the button ”Run Interactive De-Shadowing”, a reduced size image of the original
scene, the shadow mask, and the de-shadowed image will pop up with the histogram of PhiU
containing the threshold for core areas (point 1 of Fig. 5.41), the range of re-scaling of PhiU (point
2), and the current value for PhiS (point 3). Now these three parameters can be modified, and
the results will again be shown as the corresponding quicklook image and histogram. When good
results have been obtained the parameters can be saved and the final image processing can take
place.
Figure 5.42 presents an example with two iterations. Results for iteration 1 contain too many
shadow pixels (black areas in the central section of the image), therefore the threshold = -0.15
was decreased to -0.38 (parameter 1 of Fig. 5.41). After de-shadowing, most areas in the shadow
mask were overcorrected in iteration 1, therefore the maximum range = 0.40 was decreased to 0.19
(parameter 2 of Fig. 5.41, see diagonal line from lower left to upper right in histogram of Fig. 5.42).
The shadow mask for iteration 2 is appropriate, and no overcorrection effects can be observed.
CHAPTER 5. DESCRIPTION OF MODULES 93

Figure 5.41: Panel to define the parameters for interactive de-shadowing.

Note: when leaving the panel of Fig. 5.41 it is possible to edit the cloud shadow map before
continuing the scene processing, using any available image processing software. Then the edited
map is employed for the processing. This provides some flexibility because it is difficult to calculate
a satisfactory shadow map in all cases.
CHAPTER 5. DESCRIPTION OF MODULES 94

Figure 5.42: Quicklook of de-shadowing results.


Top left: histogram of PhiU (threshold=-0.15, range=0.40), iteration 1. Top right: histogram of
PhiU (threshold= -0.38, range=0.19), iteration 2. Center: results for iteration 1, left-to-right:
original, shadow mask, de-shadowed image. Bottom: results for iteration 2.
CHAPTER 5. DESCRIPTION OF MODULES 95

5.4.11 Panels for Image Processing


When pressing the button ”IMAGE PROCESSING” in one of the main panel (figure 5.33) some
additional panels will pop up. First, the processing options are to be selected (see figure 5.43).

Figure 5.43: Image processing options. Right panel appears if a cirrus band exists.

Options that are not allowed for a specific sensor will appear insensitive. If the haze removal
option is selected in combination with ”Variable Visibility” the visibility index (proportional to
total optical thickness) map is coded with the values 0-182. The value visindex=0 corresponds to
visibility 190 km, each integer step of 1 corresponds to an AOT increase of 0.006. The array serves
as a fast method of addressing the radiative transfer quantities (transmittance, path radiance etc)
in case of a spatially varying visibility, i.e., in combination with the DDV algorithm. IF the ”Haze
or Sunglint Removal” button is selected the next panel will ask for haze removal over land (option
1), haze or sunglint removal over water (option 2), or haze removal over land and water (option 3).
In case of thermal bands, an emissivity selection panel will appear:

Figure 5.44: Emissivity selection panel.

The first two options are available for instruments with only a single thermal band, the NEM and
CHAPTER 5. DESCRIPTION OF MODULES 96

ISAC options require multiple thermal bands and are not shown if there are less than 5 thermal
bands. The surface classes (water, vegetation, soil etc) are calculated on-the-fly employing the
surface reflectance spectra from the reflective bands.
Figure 5.45 shows the panel with the two options for haze over land processing as explained in
chapter 10.6.3.

Figure 5.45: Options for haze processing.

The panel of figure 5.46 pops up when the spatially varying visibility option was selected and if the
sensor has a 2.2 µm (or 1.6 µm) band (or at least a red and NIR band) required for the automatic
masking of the dark reference pixels, compare chapter 10.5.2.

Figure 5.46: Reflectance ratio panel for dark reference pixels.


CHAPTER 5. DESCRIPTION OF MODULES 97

The panel of figure 5.47 pops up for rugged terrain and contains the input parameters to incidence
BRDF compensation due to terrain variations as discussed in chapter 2.5.

Figure 5.47: Incidence BRDF compensation panel.

Figures 5.48 and 5.49 are associated with the value added products as described in chapter 7.
This value added file contains up to 10 channels if the sensor has thermal bands. In case of a flat
terrain, the air temperature has to be specified. For a rugged terrain, air temperature at some base
elevation and the air temperature gradient as well as water vapor have to be defined.
If the value added option is selected another panel pops up (Figure 5.50). It contains parameters
for the leaf area index (LAI model) and FPAR model as described in chapter 7.
Finally, a job status window indicates the processing progress.
Note:
The job status window of ATCOR shows the percentage of processed image data and the estimated
remaining time. The time estimate is based on the processing time for the current band. The time
per band increases for channels in atmospheric water vapor regions, it decreases in regions where
interpolation is applied, e.g., around 1400 nm. However, the time also depends on other factors
such as the overall CPU load in case of multi-user machines, or the traffic on net-worked machines.
Accordingly, the estimate for the remaining time is not always continuously decreasing, but may
increase sometimes.
CHAPTER 5. DESCRIPTION OF MODULES 98

Figure 5.48: Value added panel for a flat terrain.

Figure 5.49: Value added panel for a rugged terrain.


CHAPTER 5. DESCRIPTION OF MODULES 99

Figure 5.50: LAI / FPAR panel

Figure 5.51: Job status window.


CHAPTER 5. DESCRIPTION OF MODULES 100

5.4.12 Start ATCOR Process (Batch / Tiled)


This is a way to start a batch process of ATCOR from within the ATCOR GUI (instead of the
standard batch-based process ’atcor tile’ or any other ’∗ batch’ end-to-end process).
Using this panel, one may start an end-to-end process for the supported sensor systems or start
a spearate atcor process. The latter requires that an ∗.inn file has been created before by going
through the atcor GUI or by editing a respective ASCII file manually or by using the routine
write atcor inn file.pro provided in the directory docu of the ATCOR installation.

Inputs The below parameters are to be entered for processing:

• Input file name: name of image data cube to be processed or the first band image in case of
standard multi-band satellite imagery. For ’ATCOR Standard’ processing, the file must be
in ENVI BSQ format, accompanied by a valid ∗.inn file for processing.

• Flat (ATCOR-2) or Rugged (ATCOR-3): you may choose either of the two processing options
to be applied. For ATCOR Standard, elvevation parameters are read from the *inn file. For
satellite batch processes, either ground elevation or elevation data file are to be entered.

• Ground Elevation [km]: Enter the value in case you want to perform a flat processing with
constant ground elevation.

• Input Elevation file: Optional name of Elevation file, for terrain processing (rugged mode).

• Name of output cube: Optional name of output cube to be created (by default, a file named
[input] atm.bsq is created.)

• Number of tiles in X and Y dimensions - the total number of tiles to process is then X x Y
tiles.

• Batch process: Select the atcor batch process:


Dehazing: perform dehazing on raw data only
ATCOR Standard: perform atcor2 tile or atcor3 tile batch process
Sensor specific: perform an end-to-end batch process on original satellite imagery.

• Apply dehazing first: push this button to perform a dehazing on raw data before running the
selected batch process (n/a for dehazing process).

After starting the process using the ’run’ button, the messages are printed to the console and a log
file is written to [input].log. Error and status messages may be found in the *.log file during and
after processing. If for ATCOR-3 a global (WGS-84 based) DEM in geographic coordinates or one
of the global DEMs provided with atcor is selected, the DEM is resized automatically to the image
dimensions. The image has to be in UTM coordinates for this purpose.

Actions
• ’Run’: Starts the process (sorry, this may take some time)

• ’Show Log’: Shows the last log file which had been created.

• ’Display Output’: Displays the ENVI file as given in the Output Cube field directly.
CHAPTER 5. DESCRIPTION OF MODULES 101

Figure 5.52: ATCOR Tiled Processing

5.4.13 Sentinel-2
Use this function to perform a Sentinel-2 processing, including angular dependency on viewing
angle.
CHAPTER 5. DESCRIPTION OF MODULES 102

Figure 5.53: Sentinel-2 Angular processing.


CHAPTER 5. DESCRIPTION OF MODULES 103

5.4.14 Landsat-8 TIRS: Calculate Temperature

Figure 5.54: TIRS module.

Use this function to calculate the surface temperature from Landsat-8 TIRS data using an advanced
dual band split window technique.
CHAPTER 5. DESCRIPTION OF MODULES 104

5.5 Menu: BRDF


The ”BRDF” menu provides access to the simple nadir normalization method and the more ad-
vanced BREFCOR BRDF correction.

Figure 5.55: Filter modules.

5.5.1 BREFCOR Correction


This module calculates an observer BRDF correction using a model based approach. (see chapters
2.5, 10.7.3). Figure 5.56 shows the corresponding GUI panel.

The BREFCOR was originally implemented for the airborne version of ATCOR for sensors with a
large FOV. It has been adapted specifically for the processing of image mosaics if the scenes have
been acquired at various tilt and solar zenith angles. It may, e.g., be used for processing RapidEye
or Worldview imagery. The BREFCOR software is delivered as part of ATCOR for correction of
observer BRDF effects using an unique cover-dependent approach.
For the satellite version, the correction works on a number of atmospherically corrected reflectance
images, e.g. before doing some mosaicking.
Two major options for correction are available:

• ’Model based’ - The Ross Thick-Li-Sparse reciprocal BRDF model kernels are used for cor-
rection of the imagery. The various viewing angles of the individual images provided are used
as reference points to calibrate the kernel weighting factors and the isotropic component of
the BRDF models. This model requires a sufficient number of images for good calibration as
a variety of incidence and viewing angles are required.

• ’Empirical’ - If the number of images is small, the model based correction does not lead to
good results. The empirical BRDF correction simply adjusts the mean of surface cover types
to a global mean.

The following inputs are necessary:

Inputs Files: A list of atmospherically corrected input files has to be compiled ( atm.bsq). The
ATCOR *.inn file is used for the meta data information. It should be named according to the
ATCOR convention and situated at the same folder as the atm file. Files are added using the
’Add File(s)’ button on top, while entries may be removed by the ’Remove Entry’ button.
CHAPTER 5. DESCRIPTION OF MODULES 105

Figure 5.56: BREFCOR correction panel (satellite version).

Model Options:

• Roujean Geometric Kernel: the Roujean Kernel is used for the geometric part of the model
(instead of the Li Sparse model).

• Maignan Hot Spot Geometry: use the improved hot spot geometry for the volumetric kernel
as proposed by Maignan (RSE, 2003).

• Spectral Smoothing of Model: Smooth the weighting functions in the spectral dimension -
this option is useful for hyperspectral instruments only to avoid spectral artifacts.

• Model Interpolation: Interpolate missing values in the model from neighbors (by linear inter-
polation). Default: no interpolation.

• Use Precalculated Model: use an existing model file fitting to your data. NOTE: the model
file should have the same number of bands and have the same calibration granularity as of
the current settings.

• Write ANIF outputs: By default, the corrected image is written. Use this option to get
the side outputs; i.e. the files * anif (anisotropy map) and the * bci which is the BRDF
correction index used to discriminate the BRDF classes.
CHAPTER 5. DESCRIPTION OF MODULES 106

Calibration Granularity: For calibration of the model, the image is segmentated in a number
of BRDF classes. The number of pre-defined classes can be selected; calibration on a bigger number
of classes leads to better accuracy of the correction, while it requires good image statistics.

Reflectance scale factor: Constant Factor which is to be applied to the input image (which
has to be directional reflectance) to convert the image DNs to absolute reflectance values (between
0 and 1)

Output Definition: The directory for all outputs, the BRDF model file name and the file name
appendix can be defined here.

Actions:

• Calibrate Model: the model calibration file is created without applying a correction to the
images.

• Run Model Based: the model based BRDF correction is performed.

• Run Empirical: the empirical BRDF correction is performed.

5.5.2 Nadir normalization (Wide FOV Imagery)


This module (NADIR REFL) performs an empirical BRDF correction by normalizing the across-
track radiance gradients to the nadir brightness value (see chapters 2.5, 10.7.1). Figure 5.57 shows
the corresponding GUI panel.

The nadir normalization was originally implemented for the airborne version of ATCOR and re-
quires a minimum field-of-view of 20◦ . Therefore, it might also be of interest for some of the
supported satellite sensors, e.g. IRS-1C WiFS or MERIS.

Figure 5.57: Nadir normalization.


CHAPTER 5. DESCRIPTION OF MODULES 107

5.5.3 Mosaicking
Mosaic a number of georectified scenes into one (in an efficient way...). Figure 5.58 shows the
parameter settings which can be chosen for this procedure.

Figure 5.58: Mosaicking Tool.

Inputs
• Input Files (first file on top): list of files to be mosaicked. The files are stacked in the order
of appearance (i.e the first file in the list is on top of the mosaicked output)
Buttons:
Add File(s): adds one or more new files
Remove Entry: removes the selected file(s)
Move: moves the file one position up (or rotates if already at top)
• Range: range in x and y direction to edge of pixels of the mosaicked product should be
entered. The coordinates refer to the pixel borders (edges) on either side of the image.
• Button From Files : reads the maximum extend of all selected files as of the list (make sure
to select the files in the list to be considered before pressing this button).
• Size of the pixels [m]: Pixel size of quadratic pixels
Note: the mosaicking uses a bilinear interpolation; no aggregation is done.
• Button Select Bands : Allows to select/deselect the spectral bands to be considered for
mosaicking. NOTE: this option si void, if the number of bands does not agree between
images. The number of currently selected bands is displayed beneath the button
CHAPTER 5. DESCRIPTION OF MODULES 108

• Cut: treatment of overlapping images, by


Edge Overlay: The mosaicking is such that the first file is in the list is strictly on top
Center Cropped : While mosaicking, the routine tries to find the middle of the overlap area
between the new image and all the images mosaicked so far as a cut line.
Layer Stacking: The files are stacked in band sequential order on top of each other. The first
image in the list rules the output dimensions. All bands are used in any case.

• Options:
Calculate Mosaicking Map: A file named mosmap.bsq is written in parallel to the output,
containing an integer map with numbers starting at 1 to n (number of input files) which
shows for each pixel the used input file.
Calculate Brightness Map: A file named bright.bsq is written which contains the relative
brightness for all mosaicked bands (for hyperspectral images, a subset of bands at 450, 600,
805, 1190, 2020nm is written)
Brightness Filter Size: Smoothing filter size in meters to use for relative brightness determi-
nation.

• Output File:
name of output file to be written.

Actions

Preview : the first of the selected bands is mosaicked at a resolution reduced by a factor of 2 and
the result is displayed.

Run Process : The mosaicking is performed.

Restrictions

This routines requires georeferenced data with:


- same coordinate system
- no rotation in ENVI header
- background coded with 0
- all files should have the same number of bands for mosaicking (except for layer stacking)
The input resolutions of the imagery may vary.

5.5.4 Empirical Deshading


This routine applies an empirical cloud deshading (i.e spatial brightness adjustment) of images or
image mosaics based on the relative brightness.

Inputs:

• Input File:
File to be corrected; typically a mosaicked output file, usually in reflectance units.

• Brightness File:
File containing smoothed brightness of the imagery, at least for the blue and the NIR spectral
band. The size and data type of the brightness map for up to 10 bands is the same as the
image; for more than 10 bands, a subset of 2 to 5 bands at [450, 600, 805, 1190, 2020] nm
CHAPTER 5. DESCRIPTION OF MODULES 109

Figure 5.59: Deshading/Brighness Adjustment Tool

wavelength are used for brightness calculation; bands in between get interpolated brightness.
This file can be created by the ATCOR mosaicking routine (see above) as side output.

• Shaded Areas Threshold:


relative brightness upper limit to image mean; i.e. only pixels darker than this factor from
image mean are corrected.

• Output File:
name of output file to be written.

Action: Run Runs the brightness adjustment (’deshading’).

Procedure: The routine reads the brightness in the blue spectral band and searches for the
maximum relative brightness for the same pixels in the near infrared spectral bands. These two
reference points are used to derive the coefficients for wavelength dependent correction. Using an
Angstrom function of form k · λ−α < 1, a wavelength dependent correction factor is then applied
to the pixels below threshold.

Restrictions: This routine is still in development ... please approach us with sample data if
results are not as expected.
CHAPTER 5. DESCRIPTION OF MODULES 110

5.6 Menu: Filter


The ”Filter” menu provides spectral filtering of single spectra (reflectance, emissivity, radiance)
provided as ASCII files, spectral filtering of image cubes, and spectral polishing.

Figure 5.60: Filter modules.

5.6.1 Resample a Spectrum


This program serves for the general purpose of resampling. It requires an ASCII file with two
columns as input. The first column is wavelength (nm or µm unit), the second is reflectance, or
emissivity, or something else, e.g. spectral radiance. The reflectance range can be 0 - 1 (the intrinsic
reflectance unit) or the percent range (0 - 100). Figure 5.61 shows the graphical user interface.
The input spectrum is high spectral resolution data. After specifying the first band of the sensor
the resampling is performed for all spectral bands, and the result is written to an output file, again
with two columns (wavelength and resampled spectrum).

Figure 5.61: Resampling of a (reflectance) spectrum.

5.6.2 Low pass filter a Spectrum


This program serves to prepare target reference spectra for IFCALI inflight calibration. Unwanted
spectral noise is removed by lowpass filter (i.e., spectral smoothing). It requires an ASCII file with
two columns as input. The first column is wavelength (nm or µm unit), the second is reflectance,
or emissivity, or something else, e.g. spectral radiance. The reflectance range can be 0 - 1 (the
CHAPTER 5. DESCRIPTION OF MODULES 111

intrinsic reflectance unit) or the percent range (0 - 100). Figure 5.62 shows the graphical user
interface. The input spectrum is high spectral resolution data. The result has the same format and
dimensions as the input file.

Figure 5.62: Low pass filtering of a (reflectance) spectrum.

5.6.3 Spectral Polishing: Statistical Filter


Remove spectral artifacts in high spectral resolution imaging spectroscopy data.

Inputs:

Input file name A hyperspectral image cube, usually the output of atmospheric correction ∗ atm.bsq

Sensor Spectral Response Defines the first band of the sensor response ∗ṙsp. This field may
be left empty - in that case, the wavelength information from the ENVI header is used if the
wavelengths tag is properly given. if no wavelength reference is there, a spectrally equidistant
succession of the spetral bands is assumed.
Note: the Savitzky-Golay filter is not wavelength-aware and uses always the assumption of
equidistant, constantly increasing bands.

Number of polishing bands on each side Adjacent bands to be used for calculation on each
side of the target band; e.g. factor 3 uses 7 bands for polishing (3 on each side plus central
band).

Smoothing Factor smoothing applied stand alone or in combination with the derivative filter:
0: no smoothing
1: slight smoothing (filter: 1/4/1)
2: moderate smoothing (filter: 1/2/1)
3: standard smoothing (filter: 1/1/1)
4 and more: standard smoothing with moving average

Polishing Filter Type Four options are available for statistical spectral polishing: Derivative
Filter: all spectral bands of the given window size are taken into account to calculate deriva-
tive used to reconstruct the value of the center band.
Neighbour Derivative: all spectral bands except for the center itself are taken into account to
calculate derivative used to reconstruct the value of the center band.
Lowpass Filter: Only the smoothing is performed, no derivatives are calculated.
CHAPTER 5. DESCRIPTION OF MODULES 112

Savitzky-Golay: Filter to perform a numerical polinomial fit of 4th degree through the selected
total window size.

Output:
A cube containing the spectrally filtered copy of the original image data cube is generated
(compare Paper Earsel, SIG-IS Workshop, Edinburgh, 2011).

Figure 5.63: Statistical spectral polishing.

5.6.4 Spectral Polishing: Radiometric Variation


A module that was originally developed for the airborne version of ATCOR is the spectral polishing.
The algorithm is only intended for hyperspectral imagery.

Figure 5.64: Radiometric spectral polishing.

Input to the spectral polishing program is the reflectance cube calculated with ATCOR. It em-
ploys the vegetation index (0 < N DV I < 0.33, N DV I = (ρN IR − ρRED )/(ρN IR + ρRED )) to
mask soil pixels. A soil spectrum is a slowly varying function of wavelength, therefore a spectral
smoothing will only remove spikes without disturbing the spectral shape. Then the average re-
flectance spectrum over all soil pixels is calculated and smoothed with a 5-channel filter except for
the atmospheric water vapor regions where a linear interpolation is performed. The ratio of the
filtered to the original soil spectrum is the spectral polishing function applied to all image pixels. If
CHAPTER 5. DESCRIPTION OF MODULES 113

”xxx atm.bsq” is the atmospherically corrected input image, then ”xxx atm polish.bsq” is the pol-
ished output reflectance cube, and the spectral polishing function is stored in ”xxx atm polish.dat”,
an ASCII file with two columns containing the center wavelength of each channel and the polishing
factor. Figure 5.64 shows the GUI panel.

5.6.5 Flat Field Polishing


This routine is to remove spectral artifacts from atmospherically corrected imaging spectroscopy
data. Average residual gains and offsets are calculated by comparison of assumed flat field data
values to the measured values for each spectral band to find a gain correction factor. The flat field
is searched automatically within an image as the spectrally least variable part of the image.

Figure 5.65: Flat field radiometric polishing.

Inputs:
Input file name (usually output of atmospheric correction atm.bsq), can be any kind of image.
Type of Correction Function:

• Gain and Offset: calculate average residual gain and offset for each pixel and apply them as
correction function

• Gain only: constrain the residual gain to an offset of 0; this is the typical situation.

Output:
A cube containing the spectrally filtered copy of the original image data cube is created.

5.6.6 Pushbroom Polishing / Destriping


This routine treats each detector pixel of a pushbroom imaging spectrometer separately and derives
gain and optional offset values in comparison to its direct neighbors. The routine may be used for
both, spectral polishing of residual gain/offset errors and for destriping of pushbroom imagery.

Inputs:

Input file name A hyperspectral image cube, usually the output of atmospheric correction ∗ atm.bsq

Interpolation Distance Number of pixels from center pixel, i.e., a factor of 2 uses 2 pixels on
each side for calculation of residual gains. The distance should be in a range of the width of
visible striping artefacts.
CHAPTER 5. DESCRIPTION OF MODULES 114

Figure 5.66: Pushbroom radiometric polishing.

Polishing Filter Type Three options are available for pushbroom spectral polishing: Spectral:
Polishing is done in spectral dimension only; one adjacent band on each spectral side is taken
for residual calculation.
Spatial: Only the spatial filter is applied; use this option for destriping of imagery.
2D Filter: Do both dimensions (spatial/spectral) simultaneously the filter size only applies
to the spatial dimension, however..

Type of Correction Function For each detector pixel, correction parameters are generated:
Gain and Offset: Calculate average residual gain and offset for each pixel and apply them as
correction function.
Gain Only: Constrain the residual gain to an offset of 0; this is the typical situation.

Output:
A cube containing the spectrally filtered copy of the original image data cube is created. As a
side output, a gain file is written (name: gain.bsq’), containing the following three layers: 1: offset
of linear recalibration offset function
2: gain of linear recalibration offset function
3: gain of linear recalibration offset function if function is constrained to zero offset
such that the corrected spectral band is: Lpolish = Lori − [Lof f s + gain ∗ Lori,smooth

5.6.7 Spectral Smile Interpolation


For sensors affected by ”spectral smile” the surface reflectance cube is calculated accounting for the
smile shift function in the column (across-track) direction of the detector array. The smile shift is
specified as a 4th-order polynomial function, i.e. the file ”smile poly ord4.dat” in the corresponding
sensor folder, see chapter 4.7. Due to the smile shift the wavelength values of a spectral channel
vary slightly in across-track direction. The ”smile interpolation” function allows the specification
of a common center wavelength for each channel. Then for each channel all pixel reflectances are
interpolated to this new reference wavelength. Since the smile shift between adjacent bands does
not vary significantly, a linear interpolation can be applied. If λj (i) denotes the center wavelength of
band i and column j, and ρj (i) the surface reflectance of a column j pixel, then the new interpolated
CHAPTER 5. DESCRIPTION OF MODULES 115

reflectance is
(new) (λref (i) − λj (i)) (ρj (i + 1) − ρj (i − 1))
ρj (i, λref (i)) = ρj (i) + (5.6)
λj (i + 1) − λj (i − 1)
where λref (i) is the user-defined reference center wavelength for band i. There are three options
for the reference wavelength grid:
1. use wavelength corresponding to the center of the detector array,

2. use average wavelength over all detector columns (per band),

3. use nominal wavelength specified in the (ENVI) header of the reflectance cube.
This tool is available in the interactive mode (main menu, then ”Filter”, then ”Spectral Smile
Interpolation (Image Cube)” and in the batch mode (”smile interp3 batch”, see chapter 6.3).

Figure 5.67: Spectral smile interpolation

This routine is used after smile-dependent atmospheric correction. It applies a linear interpolation
on the reflectance data in order to bring the spectral bands to a common reference in across track
direction. The inputs are as follows (see Fig. 5.67):

Inputs:
Input Image A hyperspectral image cube, usually the output of atmospheric correction in smile
mode ∗ atm.bsq

Smile polynomial file The file ’smile poly ord4.dat’ as of the sensor definition used for the smile-
aware atmospheric correction.
CHAPTER 5. DESCRIPTION OF MODULES 116

Options Three options for the spectral reference wavelength grid to be used for interpolation may
be selected:
center of detector array: The spectral position of the center pixel in across track direction of
the detector is taken as the reference wavelength for each spectral band.
average over all detector columns: For each spectral band, the average of all (smiled) center
wavelengths is calculated and used as the new reference wavelength.
nominal position (ENVI header) the nominal position as provided in the ENVI header file is
taken as the reference.

Output:
A cube containing the spectrally interpolated image data is generated and the ENVI header is
updated (for options 1 and 2).

5.6.8 Cast Shadow Border Removal


This routine is used after cast shadow correction in case the borders of the shadows show dark or
bright artifacts. It corrects the imagery by adjusting the brightness to the direct neighbor pixels.
Using the illumination file, all pixels at the cast shadow borders are first identified and a buffer
along the borders is calculated using the border width. Secondly, a brightness correction factor
is calculated for each pixel in the border lines using the relative brightness in comparison to its
neighbours. The pixels are then corrected using this relative difference in a multiplicative way.
The inputs are as follows (see Fig. 5.67):

Inputs:

Input File A hyperspectral image cube, usually the output of atmospheric correction ∗ atm.bsq

Illumination/Cast Shadow File illumination file containing a shadow mask which had been
applied to the image during atmospheric correction.

Options Two options for alternate processing are available (try those in case the artifacts are not
well removed):
adjust spectral mean: An average additional correction factor is applied to the border pixels
in order to correct for spectral variation of the brightness difference.
Interpolate Borders: The border pixels are interpolated from their neighbours, overwriting
the original values.
Shadow Border Width: the with of the border to be corrected/interpolated..

Output:
A cube containing the filtered image data is generated and the ENVI header is copied to the new
file.
CHAPTER 5. DESCRIPTION OF MODULES 117

Figure 5.68: Shadow border removal tool


CHAPTER 5. DESCRIPTION OF MODULES 118

5.7 Menu: Simulation


The ”Simulation” menu provides programs for the simulation of at-sensor radiance scenes based
on surface reflectance (or emissivity and temperature) images.

Figure 5.69: Simulation modules menu.

5.7.1 TOA/At-Sensor Radiance Cube


This routine calculates an At-Sensor Radiance Cube from an reflectance image cube. All parameters
used for the processing are generated from the ∗.inn file of the input cube. If the function is called,
the cube is opened and the ∗.inn file is read, which results in an at-sensor cube ∗ toarad.bsq . Note
that this routine does not consider adjacency effects and is a simple forward propagation based on
the given parameters and the given standard model.
No specific panel is displayed. The routine asks for the input reflectance image. All other infor-
mation is taken from the *.inn file. Please make sure that the reflectance image spectral definition
corresponds exactly to the chosen atmospheric library and sensor definition as of the *.inn file.

5.7.2 TOA/At-Sensor Thermal Radiance


This routine calculates an At-Sensor Thermal Radiance Cube from an emissivity/temperature cube
(where temperature is in the last band). All parameters used for the processing are generated from
the ∗.inn file of the input cube. If the function is called, the cube is opened and the ∗.inn file is
read, which results in an at-sensor cube ∗ toarad.bsq

5.7.3 At-Sensor Apparent Reflectance


This routine calculates an at-sensor apparent reflectance from a calibrated at-sensor radiance image
cube. This routines alculates for each image band the following output:

ρapp = (DN ∗ c1 + c0 ) ∗ π ∗ d2 /(E0 ∗ cos(θ0 )) (5.7)

where:
DN : stored data values
c1 : gain for conversion of DN to at sensor radiance
c0 : offset for conversion to at sensor radiance
d: relative sun-earth distance (average:d=1)
E0 : solar irradiance, top of atmosphere (NOT at aircraft altitude)
θ0 : solar zenith angle
CHAPTER 5. DESCRIPTION OF MODULES 119

Figure 5.70: Apparent Reflectance Calculation

Inputs:

• input file name

• calibration file name (∗.cal)

• solar radiation file (e0 solar ∗.spc)

• output file name

• scale factor (see below)

• date of the year, given exactly as ’day/month’, eg. 26/7 for July, 26th, used for sun-earth
distance calculation

• solar zenith angle (use ’Tools : Solar Zenith and Azimuth’ for its calculation)

Output: A cube containing the scaled apparent reflectance in [%] is stored. The data format is
driven by the scaling factor as follows:

• scale < 10 : byte

• scale >= 10 : integer

• scale >= 500: unsigned integer

• scale <= 1. : floating point (effective value, unit: [%]) ( wavelength reference and FWHM
are taken from the file e0 solar ∗.spc)

5.7.4 TOA/At-Sensor Spectra Simulation


This routine allows to calculate at sensor signals from spectral measurements of bottom of atmo-
sphere reflectance under consideration of irradiance measurements.
CHAPTER 5. DESCRIPTION OF MODULES 120

Figure 5.71: TOA radiance calculation from ground reference reflectance spectral library

Inputs:

• BOA Reflectance Spectra:


ENVI spectral library containing the bottom of atmosphere reflectance. All spectra in the
file are used for TOA Radiance calculation

• BOA iWhite Reference Radiance:


ENVI spectral library containing the irradiance on the ground in W/(m2 sr nm)

• Option: Use BOA irradiance data values directly: for TOA radiance calculation, one may
use the BOA irradiance instead of modeled irradiance.

Scene Specific Parameters:


The parameter may be read from an ATCOR *.inn file as far as they are available.

• Buttons:
Read Parameters from *.inn: opens the corresponding *.inn file and sets all parameters for
the simulation.
Write/Update *.inn file: reads the parameters from the GUI and updates the respective
parameters to a new/updated *.inn file.

• Sensor: current sensor definition (directory name)

• Atmosphere: current atmospheric file (for ATCOR-4: be aware to select the correct flight
alitude)

• Visibility: current visibility.

• Date, Solar Zenith, Azimuth, and Ground Altitude, should be entered. The values are read
from the *.inn file if available.
CHAPTER 5. DESCRIPTION OF MODULES 121

• Sensor View Zenith: this value is to be entered manually; zero degrees corresponds to nadir
view.

• TOA Radiance Output SLB File:


Output file containing the TOA radiance data for each spectrum in spectral library.

Actions: Upon availabilty of irradiance spectra, the atmospheric parameters may be inverted
from the irradiance spectra (first two actions):

Find Best Atmospheric Model searches for the applicable atmospheric file (i.e. aerosol model
and water vapor content)

Estimate Visibility searches for the best visibility fitting to the irradiance spectrum.

Calculate TOA Radiance Performs the calculation and creates the output library.

Plot TOA Radiance Starts the internal spectral library viewer for plotting the outputs.

Outputs: Output File: An ENVI spectral library file is written which contains all spectra as of
the input file transformed to at-sensor radiance. all relevant information is written to the ENVI
file header.
Note: Use the tool Simulation:Vicarious Validation (At-Sensor) for validation of the such created
spectral libraries in comparison to the ENVI at-sensor radiance imagery.

5.7.5 Vicarious Validation (At-Sensor)


This routine allows to validate imagery in comparison to simulated at-sensor radiance spectra.

Figure 5.72: TOA radiance validation against calibrated image spectra


CHAPTER 5. DESCRIPTION OF MODULES 122

Inputs:
• Validation Image: Calibrated at sensor radiance image (ATCOR input image) to be used for
cross validation
- using the button ’Show Image’ starts an image display of the currently selected image file.
• Sample Position: Coordinates of sample spectrum in image (may be either pixel coordinates
or geographic coordinates)
- using the ’Get’ button transfers the position coordinates from the ATCOR file viewer (after
’Push’ has been pressed there).
• Sample Diameter: diameter of square sample in pixels around the sample position (uneven
numbers). Statistics for the validation are taken from this sample. NOTE: the sample size
should be at least 3x3 clean pixels; this means that the total size of the target should be at
least 7x7 pixels (compare [?]).
• Adjacency Range: The adjacency range is given in image pixels. The default is the adjacency
range in km divided by the standard pixel size.
• TOA Radiance SLB: ENVI spectral library containing the tof of atmosphere radiance (as
created by the tool ’Simulation:TOA Radiance’)
- using the button ’Plot TOA Radiance’ allows to plot the currently selected file
• Parameters: sensor, atmosphere, visibility, solar zenith, and ground altitude are read from
slb ENVI header at first. If selecting an image file; the values are read from the *.inn file if
available.
• CAL file for TOA Validation: This file can be selected,specifically for analysis using the
’Validation Plot’ tool.
• Image Validation Output SAV File: Name of IDL save dump to be created containing all
validation information. In parallel, an ASCII *.txt file is created containing the relevant
data.

Actions:
Validate Calculates both the validation spectra including adjacency correction and writes an ascii
report of the calculations.
Validation Plot Creates a plot of the sample statistics and the corresponding reference spectrum,
scaled by the parameters from the currently selected *.cal file.
Write CAL File Lets you select a number of validation output files and will create a new *.cal
file by linear regression of image data to simulated data for all selected files.

Outputs: Output File: an idl save dump is written upon pressing the ’Validate’ button; in
parallel a validation report with all spectra is written named [out] eval.txt. The calibration reports
may be used for derivation of CAL file by linear regression.

5.7.6 Resample Image Cube


This routine allows to simulate a multispectral image from imaging spectroscopy data. A detailed
description of this routine is given in chapter 8.
CHAPTER 5. DESCRIPTION OF MODULES 123

Figure 5.73: Plot sample of validation against calibrated image spectra


CHAPTER 5. DESCRIPTION OF MODULES 124

5.8 Menu: Tools


The ”Tools” menu contains contains a collection of useful routines such as the calculation of the
solar zenith and azimuth angles, spectral classification, nadir normalization for wide field-of-view
imagery, adding of a synthetic blue channel for multispectral sensors with a blue band (e.g. SPOT)
which is done for the atmospherically corrected surface reflectance image, spectral calibration, con-
version of the monochromatic atmospheric database from one to another solar irradiance spectrum,
and BIL to BSQ conversion.

Figure 5.74: The tools menu.

5.8.1 Solar Zenith and Azimuth


The routine SOLAR GEOMETRY is used to calculate the zenith and azimuth angle for the image
location and acquisition time. All explanations concerning the definition of angles are included in
the panel (Fig. 5.75).

Figure 5.75: Calculation of sun angles.


CHAPTER 5. DESCRIPTION OF MODULES 125

5.8.2 Classification of Surface Reflectance Signatures


The spectral classification (SPECL) is a hierarchical classifier based on surface reflectance data
employing the Landsat Thematic Mapper (TM) wavelengths. It is not a land use classification,
but a classification into certain spectral categories, e.g. dark and bright bare soil, and different
vegetation classes, see figure 5.76. The following set of rules is used where b1, b2, b3, b4, b5 and b7
indicate the surface reflectance in the TM bands 0.48, 0.56, 0.66, 0.84, 1.65, 2.2 µm, respectively,
or the nearest corresponding channel:

• snow: b4/b3 ≤ 1.3 and b3 ≥ 0.2 and b5 ≤ 0.12

• cloud: b4 ≥ 0.25 and 0.85 ≤ b1/b4 ≤ 1.15 and b4/b5 ≥ 0.9 and b5 ≥ 0.2

• bright bare soil: b4 ≥ 0.15 and 1.3 ≤ b4/b3 ≤ 3.0

• dark bare soil: b4 ≥ 0.15 and 1.3 ≤ b4/b3 ≤ 3.0 and b2 ≤ 0.10

• average vegetation: b4/b3 ≥ 3.0 and (b2/b3 ≥ 0.8 or b3 ≤ 0.15) and 0.28 ≤ b4 ≤ 0.45

• bright vegetation: b4/b3 ≥ 3.0 and (b2/b3 ≥ 0.8 or b3 ≤ 0.15) and b4 ≥ 0.45

• dark vegetation: b4/b3 ≥ 3.0 and (b2/b3 ≥ 0.8 or b3 ≤ 0.15) and b3 ≤ 0.08 and b4 ≤ 0.28

• yellow vegetation: b4/b3 ≥ 2.0 and b2 ≥ b3 and b3 ≥ 0.08 and b4/b5 ≥ 1.5

• mix veg/soil: 2.0 ≤ b4/b3 ≤ 3.0 and 0.05 ≤ b3 ≤ 0.15 and b4 ≥ 0.15

• asphalt/dark sand: b4/b3 ≤ 1.6 and 0.05 ≤ b3 ≤ 0.20 and 0.05 ≤ b4 ≤ 0.20 and 0.05 ≤ b5 ≤
0.25 and b5/b4 ≥ 0.7

• sand/bare soil/cloud: b4/b3 ≤ 2.0 and b4 ≥ 0.15 and b5 ≥ 0.15

• bright sand/bare soil/cloud: b4/b3 ≤ 2.0 and b4 ≥ 0.15 and (b4 ≥ 0.25 or b5 ≥ 0.30)

• dry vegetation/soil: (1.7 ≤ b4/b3 ≤ 2.0 and b4 ≥ 0.25) or (1.4 ≤ b4/b3 ≤ 2.0 and b7/b5 ≤
0.83)

• sparse vegetation/soil: (1.4 ≤ b4/b3 ≤ 1.7 and b4 ≥ 0.25) or (1.4 ≤ b4/b3 ≤ 2.0 and
b7/b5 ≤ 0.83 and b5/b4 ≥ 1.2)

• turbid water: b4 ≤ 0.11 and b5 ≤ 0.05

• clear water: b4 ≤ 0.02 and b5 ≤ 0.02

• clear water over sand: b3 ≥ 0.02 and b3 ≥ b4 + 0.005 and b5 ≤ 0.02

Figures 5.77 and 5.78 show the panel of the SPECL program and a sample output.

5.8.3 SPECL for User Defined Sensors


This function is the same as described above in Section 5.8.2 and Figure 5.78. The only difference is
that the available sensors are the ones defined in the ’sensor’ directory of the ATCOR installation,
i.e., the user-defined sensors instead of the pre-defined ones.
CHAPTER 5. DESCRIPTION OF MODULES 126

Figure 5.76: Examples of reflectance spectra and associated classes.

Figure 5.77: SPECL: spectral classification of reflectance cube.

5.8.4 Add a Blue Spectral Channel


This routine (MAKEBLUE) adds a blue spectral channel for multispectral imagery not containing
a blue band. The band is calculated from empirical relationships from the green, red, and NIR
bands which ought to be present. The routine simply asks for an input multispectral image to be
processed.
NOTE: the input image should have at least 3 bands and the first three bands are assumed to be
the triple GREEN/RED/NIR.
CHAPTER 5. DESCRIPTION OF MODULES 127

Figure 5.78: Example of classification with SPECL.


Left: true color image of Landsat TM, right: result of classification.
CHAPTER 5. DESCRIPTION OF MODULES 128

5.8.5 Spectral Smile Detection


This routine uses sharp atmospheric absorption features and Fraunhofer lines for inflight smile (i.e.,
spectral across-track non-uniformity) detection. The calculation is done by correlation analysis of
a number of spectral bands in the vicinity of selected absorption features. The outputs may be
used for smile-aware atmospheric correction.
Initially, the smile characterization for each spectrometer channel is derived from laboratory mea-
surements. From such data, the wavelength shift with respect to the center pixel of the detector
array can be parametrized using a 4th order polynomial fit. However, in case of instrument changes
during the mission, a spectral re-calibration might be necessary from the image data or from on-
board calibration facilities using well-defined absorption features. Onboard spectral calibration
devices such as interference or rare earth filters would be well suited for this purpose. However,
such devices are often not available in sensor systems. Therefore, atmospheric gas absorption
features or solar Fraunhofer lines have to be taken as a reference from the imagery itself. The
processing steps are:

1. A calibrated image is averaged in along track direction, leading to a signature image of the
size of the detector array.

2. The surface reflectance is calculated (atmospheric correction) and smoothed.

3. The spectral bands within the spectral matching range are selected.

4. Spectral shifts with intervals between 0.01-0.05 nm are calculated and applied to the selected
spectral band response functions.

5. An appropriate pre-calculated fine-spectral resolution atmospheric LUT is selected which


serves for the calculation of at-sensor radiance values for the series of spectrally shifted re-
sponse functions using the surface reflectance spectrum from step (2).

6. The derived spectral signatures are then correlated to the observed column-averaged signal
in the image, such that the best fitting spectral shift ∆λj = ∆j can be found for each image
column j, i.e., the ∆j with the highest Pearson’s correlation coefficient is selected. This is
equivalent to minimizing the merit function

λk X
+5nm
2
χ (∆j ) = [LI (j, k) − LR (λk + ∆j , k)]2 , (5.8)
∆j =λk −5nm

where LI (j, k) is the average at-sensor radiance of the image for column j and channel k, and
LR (λk + ∆j , k) is the corresponding reference radiance for a wavelength shift ∆j within a 5
nm interval around λk . By using the continuum removed scaled radiances, the stability of
the routine is enhanced.

7. A 4th order polynomial is fitted through the calculated spectral points and the respective
polynomial parameters of eq. 4.1 are stored.

8. The polynomial parameters are interpolated and optionally extrapolated to all other bands
within the same detector or spectrometer unit. Optionally, the polynomial coefficients can
be set to zero in atmospheric absorption regions to expedite the processing.
CHAPTER 5. DESCRIPTION OF MODULES 129

The same approach is used for FWHM detection, with the difference that not the position of the
spectral bands is varied, but the FWHM of the spectral bands is scaled in a systematic way. Once
the coefficients have been determined, they are converted into the required file format and are
placed in the respective sensor folder for a subsequent fully automatic radiometric and atmospheric
processing. Fig. 5.79 shows the panel of the smile detection module.

Inputs:

Input file : calibrated ENVI image file. The file should be statistically as uniform as possible in
order to get valid averages.

Atmospheric Database File: non-resampled atmospheric database file most appropriate for the
selected image; take care of the flight altitude and aerosol model.

Sensor spectral response: First band of sensor spectral response file(s) ∗.rsp. The correspond-
ing pressure definition file (pressure.dat) is selected automatically from the same directory as
the ∗.rsp files, if available.

Output smile coefficients: file name of ASCII file which is written and contains the 4th order
polynomial coefficients. This file may be copied to the sensor definition as ’smile poly ord4.dat’
for use as smile definition with a sensor.

Detection resolution: finest spectral resolution used for correlation analysis - results will be
resolved by this resolution.

Search range: maximum total spectral range used for smile detection (ie., 20 nm is +- 10 nm
search distance). For FWHM detection, it is the maximum factor to be applied. A factor of
2, e.g. means to search between FWHM scaling from 0.5 to 2.

Band range: bands which shall be used for smile detection and for which the coefficients are
written to the output file.

Split band: First band of second detector for sensor having more than one detector (starting
numbering at 1). NOTE: for imagers with more than two detector it is recommended to
derive the smile separately for each detector to avoid artefacts in the transition range.

Visibility: horizontal visibility as of modtran conventions [km]

Solar Zenith: angle measured from zenith to sun

Mean Ground Elevation: Ground altitude in km.

Flight Altitude: in km a.s.l.

Feature wavelength: 17 selectable features used for smile detection. the per-band smile is inter-
polated from these feature wavelengths.

Interpolation type: interpolation used to expand the feature wavelength results to all spectral
bands

Extrapolation type: specifies how the bands outside of the selected features are treated. Repeat:
repeats the last value toward the borders. ’to zero’: gradually decrease to zero at border of
detector.
CHAPTER 5. DESCRIPTION OF MODULES 130

Actions:

Detect Smile The module will perform the smile detection calculation.

Detect FWHM The FWHM variations are calculated instead of smile variations by the same
technique.

Plot Smile Starts a plotting window to check the smile and lets you select suitable features for
calibration.

Save Report Saves an informational report about the smile detection.

Outputs:

An ASCII-file which may be used as smile (or FWHM) description file in the respective sensor
directory. Note that this file should be named ”smile poly ord4.dat” or ”smile poly ord4 fwhm.dat”
in order to be automatically recognized by ATCOR.
As a side output, an IDL save dump (∗.sav) is written in parallel which contains all used param-
eters and the effectively calculated smile results in array ”smileresult(4,ncols,17)”. Here the first
dimension (4) contains the center wavelength (nm), smile shift (nm), atmospheric transmittance,
and correlation coefficient. The second dimension (ncols) refers to the number of image columns,
and the last dimension (17) contains results for the 17 feature wavelengths. For example, the cen-
ter wavelengths for all across-track pixels and the 760 nm feature are stored in smileresult[0,*,5],
because this feature is the third one and IDL arrays start with index 0.

Figure 5.79: Spectral smile detection


CHAPTER 5. DESCRIPTION OF MODULES 131

5.8.6 Spectral Calibration (Atm. Absorption Features)

The program (SPECTRAL CAL) is only intended for hyperspectral sensors and employs atmo-
spheric absorption features to detect and remove possible wavelength calibration errors (see chapter
2.2). For this purpose, a certain number of target spectra have to be selected in the SPECTRA
module.
NOTE: Alternatively to this routine, the spectral calibration can be done by first using the spectral
smile detection routine (see section 5.8.5) and then applying the shift to the sensor as described in
section 5.2.4.
Input to the spectral calibration module are the DN spectra of selected fields saved as ASCII files in
the SPECTRA module by pressing the button ”Save last spectrum”. The files should be numbered
consecutively, starting with a name such as ”location target1”, without extension. The next target
has to be named ”location target2” etc. For each target field three files will generated, for example:

• ”location target1.dat” : contains surface reflectance spectrum,

• ”location target1.txt” : contains target coordinates, and processing parameters (visibility,


water vapor column, etc.),

• ”location target1 dn1.dat” : contains the DN spectrum.

For a given location (scene) up to 9 targets can be extracted and used for the spectral calibration.
The geometry, scene visibility and average water vapor content of the targets enter as parameters to
the spectral calibration, see Fig. 5.80. The water vapor content has to be averaged from the values
found in the ”location target*.txt” files. The first target DN file has to be selected by the user,
the remaining target files are automatically found provided the nomenclature with a consecutive
numbering is applied. The result of the spectral calibration are files with the spectral shifts per
spectrometer and the new center wavelengths of all channels. The spectral bandwidth of channels
is not modified.
The DN spectra will be employed in an optimization procedure that minimizes the spikes of the
derived surface reflectance spectra in the atmospheric absorption regions.
The first target DN file has to be entered at the top left button of the GUI panel (Figure 5.80).
The other target files are automatically searched and employed if the nomenclature of chapter 2.2 is
employed. Further input data are the sensor definition, the range of bands per spectrometer, solar
geometry and atmospheric parameters. Output is a file with the spectral channel center wavelength
shifts per spectrometer, and a new wavelength file containing the updated wavelengths for each
channel.
The results of the spectral shift are summarized in a file ”spectral calibration results*.txt” where
the wavelength shift is listed for each spectrometer and each target. The final shift is taken as
the average of all target wavelength shifts. In addition, a new wavelength file ”sensor new.wvl”
is created containing the channel center wavelengths and the FWHMs (bandwidth as full width
at half maximum). A copy of the original radiometric calibration file (e.g., ”xxx.cal”) is provided
for convenience (e.g., ”xxx new.cal”) which contains the original radiometric calibration coefficients
and the updated channel center wavelengths.
In case of originally non-Gaussian filter curves, the output FWHM values of ”sensor new.wvl”
represent the equivalent Gaussian FWHM values, even though the spectral re-calibration is based
on the original (non-Gaussian) filter curves. The corresponding sensor with the new spectral
calibration has to be added to the list of existing sensors (see chapter 4.5) to process imagery
CHAPTER 5. DESCRIPTION OF MODULES 132

Figure 5.80: SPECTRAL CAL.: spectral calibration

with the updated spectral calibration. In case of non-Gaussion filter curves, the original channel
response files (”band*.rsp”) should be copied to the new sensor directory applying the appropriate
wavelength shifts. For sensors with Gaussian filter curves the ’gauss rsp” module (see chapter 5)
can be applied to the ”sensor new.wvl” file to generate the corresponding ”band*.rsp” files. Note
that a change of the spectral calibration usually requires a radiometric re-calibration.

5.8.7 Calibration Coefficients with Regression


This routine employs the ”*.rdn” files obtained during the single-target calibration (the ”c1 option”
of ATCOR’s calibration module to create a calibration file by rlinear regression.

Figure 5.81: CAL REGRESS.: radiometric calibration with more than one target

So for n > 2 the single-target calibration is to be performed n times and the resulting ”*.rdn” files
(radiance versus digital number) are offered as input to the ”cal regress” program.
CHAPTER 5. DESCRIPTION OF MODULES 133

Inputs:

Number of calibration targets: A maximum of 9 calibration targets may be selected. The files
*.rdn should having been calculated beforehand and the need to be calculated consecutively,
e.g., calib1.rdn, calib2.rdn, ...

First *.rdn file: Name of the first *.rdn file of the series to be used for regression

Output Name” Name of the calibration output to be created.

Output: The output of this program is an ASCII file ”name.cal” with three columns (center
wavelength, c0 , c1 ) where ”name” is specified by the user.
Note: If several calibration targets are employed, care should be taken to select targets without
spectral intersections, since calibration values at intersection bands are not reliable. If intersections
of spectra cannot be avoided, a larger number of spectra should be used, if possible, to increase the
reliability of the calibration.
CHAPTER 5. DESCRIPTION OF MODULES 134

5.8.8 Convert High Res. Database (New Solar Irradiance)


The standard solar irradiance curve used with ATCOR is the Fontenla database (2011). However,
there’s some uncertainty about the solar irradiance and people may want to use ATCOR with
a different solar reference function. This module (CONVERT DB3) converts the complete high
resolution atmospheric database from the current definition to a new irradiance function. Normally,
the standard database is converted (this function does not apply to the thermal IR), but also the
specific CHRIS database may be selected. In the panel (see Fig. 5.82), the two databases may be
selected on the basis of the directory (f1) and the new reference function e0 solar∗.dat.

Figure 5.82: Convert monochromanic database to new solar reference function

5.8.9 Convert .atm for another Irradiance Spectrum


The conversion as described in module 5.8.8 can be applied to a sensor-specific atmospheric library
of a self-defined sensor using this function. In the panel as of Fig. 5.83, the sensor has first to
be entered and the new solar function e0 solar∗.dat is to be selected before the conversion may be
applied.

5.8.10 MTF, PSF, and effective GIFOV


A useful representation of the spatial resolution of a sensor is the transfer function, describable
in terms of a modulation transfer function (MTF) and a phase transfer function. The transfer
function describes how the system modifies the amplitude (MTF) and shifts the phase of the input
spatial frequencies. Usually, only the MTF is given as a figure-of-merit or its counterpart, the
point-spread-function (PSF). The MTF is the 2-D Fourier transform of the PSF [?].
CHAPTER 5. DESCRIPTION OF MODULES 135

Figure 5.83: Convert atmlib to new solar reference function

Fig. 5.84 presents the GUI for the MTF / PSF evaluation. The image is loaded in the left part.
The user should click with the left mouse button in the area where the MTF evaluation is intended.
This area will be shown in top middle part of the GUI. Then the MTF can be evaluated for a line
or an edge, yielding the line-spread function (LSF) or edge-spread function (ESF), respectively.
The user is responsible to select an appropriate feature by clicking the start and end points of the
line with the left and center mouse buttons, respectively.
After clicking ”Calculate MTF”, the MTF is plotted below for up to four fixed channels as well
as the effective GIFOV (Ground Instantanous Field-of-View) defined as one half of the reciprocal
of the spatial frequency at which the MTF is 0.5. The effective GIFOV is also called effective
instantaneous field-of-view EIFOV and it is specified in pixels. Low values of the EIFOV represent
a good capability at resolving high spatial frequencies. The slider ”Line averaging” can be adjusted
between 3 and 9 to evaluate up to 9 parallel lines (centered on the user-defined line) to average the
phase effect.
Results (MTF, LSF, DN profile, Effective GIFOV) for all bands can be saved as ENVI spectral
library files (”*.slb”). The ”Status” widget indicates the mode of calculation (LSF or ESF).
CHAPTER 5. DESCRIPTION OF MODULES 136

Figure 5.84: MTF and effective GIFOV.


CHAPTER 5. DESCRIPTION OF MODULES 137

5.9 Menu: Help


Finally, the ”Help” menu allows browsing of the ATCOR user manual, provides a link to the web
resources, contains the software update center, and displays license information.

Figure 5.85: The help menu.

5.9.1 Help Options


The options of the help menu are listed below:

Browse Manual Opens this manual in the default PDF display application of your machine.

Browse Tutorial Opens the ATCOR-3 tutorial in the default PDF display application of your
machine. The tutorial can be found in the ’docu’ directory of your ATCOR installation.

Web Resources Opens the html document atcor3 webresources.htm in the systems default ap-
plications for viewing HTML-documents.

About Provides basic information about the copyright and also displays the build-number of the
software (please provide the build-number for debugging purposes in case the ATCOR support
is contacted).

Check for Updates Connects to the ReSe Web server to check if a new build/release of the
software is available. The software update is downloaded automatically if available and may
be installed thereafter.

Install Components This is your software update center - atmospheric database files may be
downloaded and updated directly through this update tool upon availability.

Your License Provides information about the licensed features in your license key and also dis-
plays which license key is currently active.
Chapter 6

Batch Processing Reference

For most ATCOR modules a convenient graphical user interface is available, but batch jobs can
also be submitted. A detailed discussion of the interactive panel-driven modules is given in chapter
5.
Running ATCOR in batch mode can be done in two ways: either from the operating system console
directly or from within IDL. The latter provides a higher flexibility whereas the first is well suited
for integration of ATCOR in a processing environment.

6.1 Starting ATCOR from console


ATCOR can be started directly from a console or from a different processing environment using
the standard call to IDL run time environment. This call will show a splash screen when starting
IDL unless an IDL RT or a full IDL license is installed on the processing computer. RT licenses can
be acquired from exelisvis.com at a significantly reduced price than full IDL licenses. This makes
this method useful for operational processing with ATCOR.
The call in a windows environment is:

[idlpath]\idlrt.exe -rt="[atcorpath]atcor_3\bin\atcor.sav"
-args input options [output] [logfile] [elefile]

where [idlpath] is the path to the idl installation, typically something like ..\idl84\bin\bin.x86 64\
On a unix/macOSX system, the call syntax is as follows:

[idlpath]/idl -rt=".../bin/atcor.sav"
-args input options [output] [logfile] [elefile]

The [idlpath] in this case is something like ../exelis/idl84/bin/.

Arguments:
input: Input file to be processed or input reference file, respectively
options: Flags for processing options - syntax ’xxx-yy’;
xxx: sensor/process identifier (1-3 digits) see Table 6.1 below.
yy: dehazing flag (set to ’DH’ to make it work, optional)

138
CHAPTER 6. BATCH PROCESSING REFERENCE 139

output: Name of output file to be created (set to ’dum’ for default). This argument is disregarded
for Sentinel-2.

logfile: name of log file to be used or created (set to ’dum’ for default).

elefile: input elevation file for processing - alternatively, for flat processing the ground altitude
[km] can be given with a preceding ’+’ sign (e.g. +0.25 is ground altitude 250m).

Supported Options/Sensor: This table summarizes the shortcut identifiers for the supported
sensors:

Table 6.1: Command Line Batch Process Options

F atcor2 batch RE RapidEye


R atcor3 batch L5 Landsat 5
DH dehaze only L5T Landsat 5 Thermal
S2 Sentinel 2 L7 Landsat 7
S2M Sentinel 2, 20m only L7T Landsat 7 Thermal
SP SPOT 5/6/7 L8 Landsat 8 with Thermal
PLE Pleiades OLI Landsat 8 OLI only
DMC DMC

NOTE: files names other than the input files may be set to ’dum’ in order to process default file
names. After execution, the idl session quits and throws an error status of ’1’ if an error occurred
during processing.
ATTENTION: These routines are overwriting existing outputs.

EXAMPLE STATEMENT: On console, you can start a landsat8 with dehazing end-to-end
processing as follows:

[idlpath]\idlrt.exe -rt="[atcorpath]atcor_3\bin\atcor.sav"
-args C:\\your_path\LC81940272014200LGN00_B1.TIF
L8-DH dum C:\\your_path\landsat_process.log
C:\\your_path\yourdem_ele.bsq

6.2 Using the batch mode from within IDL


ATCOR can process scenes in batch mode. For large scenes the tiling option is also available in
batch mode which splits a big scene into a number of smaller sub-scenes, processes the sub-scenes,
and finally merges them into one file. A prerequite for the tiling is that enough IDL memory is
available to keep one image channel and the sub-scene channel in memory. Also note that a full
IDL developer license is required in order to make use of the batch commands on the IDL prompt.

The batch mode can be accessed after the processing parameters have been specified in the inter-
active graphical user interface (GUI) panel, i.e., after the SPECTRA module has been accessed or
after one of the image processing options has been selected. Thus, the GUI panel creates an ’*.inn’
file containing all input parameters.
CHAPTER 6. BATCH PROCESSING REFERENCE 140

The batch mode can be started after quitting the interactive session, using the same IDL window.
It can also be started in a new IDL session after typing ’atcor’ on the IDL command line. Then
continue with:

>atcor2 batch, input=’/data1/examples/example image.bsq’ (case of flat terrain) or


>atcor3 batch, input=’/data1/examples/example image.bsq’ (case of rugged terrain)

At this stage, all required input parameters are already available in the ’*.inn’ file, in this specific
case ’example image.inn’.

The submitted job is a ’quasi batch’ job, the corresponding IDL window is used for error and
status messages and it may not be closed during the run time of the job. A log file is created
during processing, e.g. ’example image atm.log’, which contains information about the job status.
It contains three message levels (I=Info, W=Warning, E=Error) followed by a two digit number
(between 0 and 99) and a space, e.g. ’W19 ’, followed by the appropriate information. These three
message levels can easily be parsed by a separate user program if desired. Other information in the
log file is marked with the hashmark symbol in the first column.

In the tiling mode the user has to specify the number of tiles in x=column direction (ntx) and in
y=line direction (nty), e.g.,

>atcor2 tile, input=’/data1/examples/example image.bsq’, ntx=3, nty=2

In this case the image is split into 3*2=6 tiles, each tile is processed separately, finally all tiles
are merged into one output file, and the sub-scenes are deleted. The maximum size of each tile
depends on the available memory for a specific machine because ATCOR performs most calcula-
tions in memory loading one or two complete bands of the scene. A typical tile size for modern
machines is 3000*3000 pixels = 9 Mpixels to 5000*5000 pixels = 25 Mpixels. The user has to try
and find out the appropiate tile size. As an example, with a 9 Mpixel tile size and a 30 Mpixel
scene the image has to be split into 4 sub-scenes. Assuming that the number of image columns and
lines is approximately the same, one would choose the keywords ’ntx=2, nty=2’ in this example.
Of course, processing of much smaller tiles is also possible, e.g., ’ntx=20, nty=10’, but this is not
recommended because of potential image border effects, i.e., larger visibility differences for the
small tiles might lead to seams at the tile borders.

The TIFF input data format is supported, however, channels in the TIFF file must have the in-
creasing band order, and the maximum number of bands should be less than 10. If all channels are
in one input TIFF file (example: ”image.tif”), the output TIFF after atmospheric correction will
also hold all channels (example: ”image atm.tif”).

An IDL routine called ’write atcor3 inn file’ is available to users who want to generate the ’*.inn’
file without the ATCOR GUI.

Note: :
On the IDL command line, the command ’atcor’ has to be typed first to load the ’atcor.sav’ file.
Then the ’atcor2 tile’ or ’atcor3 tile’ commands will execute the tile processing. A simple trick
can be used to start the ’atcor tile’ programs directly on the IDL command line without having to
type ’atcor’ first: just copy the ’atcor.sav’ file to ’atcor2 tile.sav’ and ’atcor3 tile.sav’. The same
CHAPTER 6. BATCH PROCESSING REFERENCE 141

can be done for ’atcor2 batch.sav’ and ’atcor3 batch.sav’. For the Linux/Unix operation systems
a symbolic link is sufficient, e.g., ln -s atcor.sav atcor2 batch.sav.
For Linux/Unix users with a full IDL license a batch job can be started directly from the shell,
e.g.: idl -e ”atcor2 batch, input=’/export/data/data7/demo data/tm essen.bsq’ ”

6.3 Batch modules, keyword-driven modules


Most of the modules are available in both modes (interactive and batch). If the ’atcor.sav’ file is
copied to ’atcor2 batch.sav’ and ’atcor3 batch.sav’, a batch job can be started immediately from
the IDL command line, otherwise ’atcor’ has to be typed first. Hereafter, a description of the batch
modules and keyword-driven modules is given.
In order to make the batch options available, you first have to type "atcor"on the IDL command
line, then the ATCOR GUI selection panel pops up. (alternatively, you may use the command
restore,"atcor.sav"). Disregard this panel and continue on the IDL command line with the
name of the batch job module where all the input parameters have to be specified via key words.
Current batch programs are:
• slopasp batch, input=filename, [ pixelsize=10.0, kernel=3, dem unit=0 ]
The ’filename’ should have the last four characters as ” ele” and the extension ”.bsq”. Two
output files (slope and aspect) are generated from the elevation file, e.g.,
”example DEM25m slp.bsq” and ”example DEM25m asp.bsq”. The values are coded in de-
grees. The keyword pixelsize is not required if this information is included in the map info
of the ENVI header. The keywords kernel and dem unit can be omitted if the default values
kernel=3, and dem unit=0 are used. The unit of pixelsize is ’meter’. For the elevation height
unit three options exist: dem unit=0 : height unit is ’meters’, =1 for ’dm’, =2 for ’cm’.
Note: Before running ATCOR with a DEM, please check the results of the slope image. We
often encounter severe horizontal and vertical striping in the slope image in case of low quality
DEMs or if coarse DEMs of 25 m have to be resampled to say 5 m. Additional appropriate
filtering is required in these cases! A simple way might be to try a larger kernel size, e.g.,
kernel=5 or kernel=7. A simple check on the derived DEM solar illumination file is also
performed at the start of ATCOR, see the discussion below.
A TIFF input elevation file is converted into the corresponding ENVI elevation file.
• skyview batch, input=filename, pixelsize=10.0, [dem unit=0, unders=unders, azi inc=azi inc,
ele inc=ele inc]
’filename’ is the full file name including the path, ’filename’ should have the last four char-
acters as ” ele” and the extension ”.bsq” to indicate a digital elevation file and to enable
an automatic processing, e.g., ”example DEM25m ele.bsq”. ’pixelsize’ is specified in meters,
’dem unit’ is the integer code for the DEM height unit (0 represents [m], 1 means [dm], 2
means [cm]). The option dem unit=0 is default and can be omitted. The keyword ”unders”
specifies the undersampling factor (in pixels) to reduce the execution time for very large files.
The default angular azimuth resolution is azi inc=10 degrees and the default elevation incre-
ment is ele inc=30 degrees. However, the recommended resolution is 10 degrees for azimuth
and 5 degrees for elevation. In case of large files, an undersampling factor > 1 can be specified
to reduce the execution time. Usually an undersampling factor of 3 is sufficient. A high an-
gular resolution is more important than a low undersampling factor. The output file replaces
the ending ” ele” with the ending ” sky”, e.g., ”example DEM25m sky.bsq”.
A TIFF input elevation file is converted into the corresponding ENVI elevation file.
CHAPTER 6. BATCH PROCESSING REFERENCE 142

• shadow batch, input=filename, pixelsize=10.0, solze=30.5, solaz=160.8, dem unit=0, The


keywords have the same meaning as for skyview batch, ’solze’ is the solar zenith angle [degr.],
and ’solaz’ is the solar azimuth angle [degr.]. In particular, ’filename’ should have the last
four characters as ” ele” and the ”.bsq” extension. The output file replaces the ending ” ele”
with the ending ” shd” e.g., ”example DEM25m zen31 azi161 shd.bsq”. The rounded zenith
and azimuth angles will be included in the ”*shd” file name. Note: The shadow and skyview
calculations can be omitted in gently undulated terrain. Example: for maximum slopes of
25◦ and a solar zenith angle of 40◦ no DEM shadow is possible. Also, the local trigonometric
sky view factor, employed if the ” sky.bsq” file is missing, is sufficiently accurate, compare
figure 10.5.
A TIFF input elevation file is converted into the corresponding ENVI elevation file.

• atcor2 batch, input=filename [, output=file, vis=vis, tiff2envi=tiff2envi] or


atcor2 tile, input=filename, ntx=3, nty=2 [, output=file, vis=vis, tiff2envi=tiff2envi]
The ”2” in atcor2 batch means the code for flat terrain, i.e. no DEM is employed. The ’file-
name’ must be fully qualified, i.e. it includes the path, e.g., ”/data2/project1/image1.bsq”.
The file should have the band sequential (BSQ) file structure. A corresponding ”*.inn” file,
e.g., ”/data2/project1/image1.ini” must be available that contains all processing parameters.
This file will be generated during the interactive session. It may be also be created by the
user, e.g. employing the program ”write atcor3 inn file.pro” that is available on request. The
default output file name without the output keyword specification is the input name with an
” atm.bsq” appended, e.g., ”/data2/project1/image1 atm.bsq”.
The keyword output can be used to specify the full output name, or only the output path,
the latter option is recommended. In that case, all output files are written to the specified
output directory, and the reflectance output file name is the name of the input file with
” atm.bsq” appended. Example: output=”/data4/project1/” then the output reflectance file
will be ”/data4/project1/image1 atm.bsq”.

The corresponding tile program atcor2 tile in this example is called to split the image into 3
sub-images in x direction, and 2 in y direction, compare chapter 5.4.12.
The optional keyword ’vis’ can be used to overwrite the visibility value in the ”.inn” file. For
a constant visibility per scene (npref=0 in the ”*.inn” file), the input ’vis’ value is the start
value that will be iterated as described in chapter 10.5.1. In case of a variable scene visibility
(npref=1) the ’vis’ parameter is ignored if the scene contains enough dark reference pixels. If
not, the program switches to the constant visibility mode and ’vis’ is used as a start value.

An optional keyword output can be used to define the output directory and name of the
output reflectance file. If the keyword specifies only the output path, which is recommended,
then all output files are written to the specified output directory, and the reflectance output
file name is the name of the input file with ” atm.bsq” appended.

The optional keyword ’vis’ can be used to overwrite the visibility value in the ”.inn” file. For
a constant visibility per scene (npref=0 in the ”*.inn” file), the input ’vis’ value is the start
value that will be iterated as described in chapter 10.5.1. In case of a variable scene visibility
(npref=1) the ’vis’ parameter is ignored if the scene contains enough dark reference pixels. If
not, the program switches to the constant visibility mode and ’vis’ is used as a start value.
A negative vis value means the value abs(vis) is used for processing even if it causes a large
CHAPTER 6. BATCH PROCESSING REFERENCE 143

percentage of negative reflectance pixels.

The optional keyword tiff2envi can be used if the input file has the TIFF format. tiff2envi=1
produces an automatic conversion of the input TIFF file (e.g., ”image1.tif”) into the corre-
sponding ENVI file (e.g., ”image1 envi.bsq”). This file is used as a temporary input file to
ATCOR and it will be automatically deleted when the ATCOR run is finished. Two output
surface reflectance files will be generated if tiff2envi=1, an ENVI file (”image1 envi atm.bsq”)
and a TIFF file (”image1 atm.tif”). The ENVI output is needed if the spectral classification
(SPECL) module is run, otherwise it may be deleted by the user.
The default for a TIFF input file is tiff2envi=0, i.e., the ENVI file conversion is switched off
and no intermediate files are created. This will save disk space and some file conversion time.
However, if the ”image1.ini” file specifies the de-hazing or de-shadowing option, then tiff2envi
is reset to 1 to enable the creation of of the needed additional intermediate ENVI files. For
non-TIFF files, the tiff2envi keyword is ignored.
If each input band is in a separate TIFF file, the files should be labeled consecutively, e.g.,
”image band1.tif”, ”image band2.tif”, etc. The output of ATCOR will be the corresponding
surface reflectance files ”image band1 atm.tif”, ”image band2 atm.tif”, etc.
A keyword ’tiff2envi’ can be specified as a parameter of the batch job. If not specified, the
default is ’tiff2envi=0’ which means no intermediate disk files will be created, only the final
”* atm.tif”. With the keyword ’tiff2envi=1’ the temporary file ”image envi.bsq” is automat-
ically created and it contains the input data in the ENVI bsq (band sequential) format. The
standard output name of the atmospheric correction is ”image envi atm.bsq”, and of course
”image atm.tif”. The ”image envi.bsq” is deleted after processing, but ”image envi atm.bsq”
is kept, because it is required for a run of the spectral classification (SPECL module). The
user has to delete this file manually if the SPECL module is not employed. The setting
’tiff2envi=0’ is automatically replaced with ’tiff2envi=1’ if the ”.inn” file specifies the de-
hazing or de-shadowing option, because these require additional disk files. In case of tiling
and a TIFF input file the program automatically switches to ’tiff2envi=1’ because the inter-
mediate tile images must have the ENVI bsq format.

• s2imp, input=filename
filename is the complete file name of the first S2 band ’*B01.jp2’

• atcor s2, input=filename [, i20m=i20m ]


This is a special mode of ATCOR tailored to Sentinel-2 data. The filename is the complete
file name of the ”*TOA rad 20m.bsq”. This ’atcor s2’ uses angular-dependent LUTs, while
the standard ATCOR employs the nadir-based LUTs, see chapter 9.8.5. Therefore, ’atcor s2’
has a longer execution time.
• atcor3 batch, input=filename [, output=file, vis=vis, tiff2envi=tiff2envi] or
atcor3 tile, input=filename, ntx=3, nty=2 [, output=file, vis=vis, tiff2envi=tiff2envi]
The ”3” in atcor3 batch means the code for rugged terrain, i.e. a DEM is employed as well as
other DEM related files, e.g., slope, aspect, skyview. Otherwise, the same explanations hold
as for the ”flat” terrain ATCOR.
The corresponding tile program atcor3 tile in this example is called to split the image into 3
sub-images in x direction, and 2 in y direction, compare chapter 5.4.12. The keywords output
and vis are described in atcor2 batch above.
CHAPTER 6. BATCH PROCESSING REFERENCE 144

• Note: optional keywords for atcor2 batch, atcor3 batch, atcor2 tile, atcor3 tile.
There are four keywords concerning spectral interpolation to overwrite the interpolation set-
tings in file ”preference parameters.dat”:

– i725=-1: no interpolation for 725/820 nm channels, i725=1: interpolation.


– i760=-1: no interpolation for 760 nm channels, i760=1: interpolation.
– i940=-1: no interpolation for 940 nm channels, i940=1: nonlinear interpolation, i940=2:
linear.
– i1400=-1: no interpolation for 1400/1900 nm channels, i1400=1: nonlinear interpolation,
i1400=2: linear.

• toarad, input=filename, [ pixelsize=pixelsize, sz=solar zenith, atmfile=atmfile, elev=elevation,


vis=visibility, adjrange=adjrange, scalef=scalef ]
The keywords in brackets are optional, the meaning of all keywords is described in chapter
8. Information on all missing keywords is taken from the corresponding ”.inn” file. If the
keyword elev is missing and the corresponding ”*.inn” file contains the DEM files (eleva-
tion, slope, aspect) then the simulation is performed for a rugged terrain, otherwise for a flat
terrain, compare chapter 8.

• cal regress, ntargets=4, outfile=’regression4’


This program uses the ”*.rdn” files to calculate a regression for the c0, c1 radiometric cali-
bration, see chapters 2.3 and 5.4.9. The above example is for the case of n=4 targets, and the
output file will be ”regression4.cal” in the directory of the ”*.rdn” files which are prompted
with a dialog pickfile panel. A graphical user interface for this program is available in the
”Tools” pull-down menu of ATCOR labeled ”Calibration Coefficients with Regression”.

• makeblue, input=filename
The program computes a synthetic blue channel for sensors without a blue spectral band. If
it is started from the the interactive panel (’Tools’) a dialog pickfile box pops up prompting
for the input file name. If ’makeblue’ is started on the IDL command line, the input file name
must be fully qualified, i.e., the path has to be included. The input has to be atmospherically
corrected data, i.e., an ”* atm.bsq” file, where the blue band is missing, e.g. imagery of
SPOT, IRS-1D, DMC. The output file contains a synthetic blue band as the first image
channel calculated from the green, red, and NIR bands on a pixel by pixel basis. The output
file name is ”* blue atm.bsq”. This product is a useful supplement to be able to create a true
color image of the scene.
The calculation of the surface reflectance in the synthetic blue band consists of three steps:

1. The blue band reflectance (index 1) is extrapolated from the green (index 2) and red
(index 3) band reflectance :
ρ1 = ρ2 + (ρ2 − ρ3 ) ∗ (λ2 − λ1 )/(λ3 − λ2 ) (6.1)
where the center wavelength of the blue band is taken as λ1 = 480 nm. This represents
the typical spectral behavior of soils and some artificial surfaces (asphalt, concrete).
2. The red and NIR (index 4) bands are employed to compute the ratio vegetation index
VI = ρ4 /ρ3 . Pixels with V I > 2.5 and ρ4 > 10% are defined as vegetation and the blue
band reflectance is calculated as :
ρ1 = ρ3 /2 (6.2)
CHAPTER 6. BATCH PROCESSING REFERENCE 145

3. Finally, water pixels are masked with the criterion ρ4 ≤ 7%, where the large threshold
of 7% is employed to account for potential turbid water bodies, and the blue band
reflectance is calculated as :
ρ1 = 1.2 ∗ ρ2 (6.3)
• decirrus, input=input [, dem=dem] This module performs the cirrus removal for the file input.
This means, the apparent cirrus band reflectance is calculated, and related to the apparent
reflectance at the visible bands, see 10.6.5. Finally, the cirrus-removed apparent reflectances
are converted into the corresponding DN values. If the optional keyword is set (dem=1) and
if a digital elevation file (’* ele.bsq’ ) exists in the folder of the input scene, then decirrus is
switched off for high mountains above 3000 m.
• dehaze, input=filename [, water=iw, ipm=ipm, ihm=ihm, keep=keep, dem=dem, ihaz = ihaz,
nocirrus = nocirrus, fraction haze = fh]

Here the filename is the name of the image (level 1 data, original DN, stored as ENVI bsq,
band-sequential) including the path. The sensor name is read from the scene ’.inn’ file, e.g.
sensor=’worldview2’. If keyword water=0 (or not keyword set) then only land pixels are
dehazed, with water=1 also water pixels will be dehazed. Keyword ”ipm” specifies the inter-
polation method:
ipm = 1 is default and uses bilinear interpolation for the bright areas (very fast)
ipm = 2 uses triangulation (very slow)
ihm = 0, 1, 2 specifies the dehazing option, ihm=1: standard dehazing, ihm=2: stronger
dehazing, ihm=0: both options are executed, the results contain the identifier ’dh1’ and
’dh2’, respectively. Afterward, the better result is renamed with ’dh’ and the inferior result
is deleted if keep=0 or if this keyword is not specified.

If ’scene.bsq’ is the name of the input image, then the output file name is ”scene dh bilin.bsq”,
and ”scene dh trian.bsq” for ipm=1, 2, respectively. The ’dh’ indicates the dehazing and the
interpolation method is also included. Additionally, a file ’* haze map.bsq’ is created contain-
ing the classes haze/land, haze/water, clear, water, cirrus classes (if a cirrus band exists) and
geocoded background. IF the keyword water=1 is specified, then the corresponding names
are ’dhw’, ’dh1w’ etc. Typing the name of the module without parameters will yield the list
and description of the parameters. This program can also be invoked from the ATCOR main
panel.

If a DEM file is in the folder of the input scene with the name ending ’ ele.bsq’ and if the key-
word dem=1 is set, then the haze and cirrus removal are switched off for mountains higher
than 3000 m. Keyword nocirrus=1 may be set to ignore the cirrus channel info. The default
is nocirrus=0, i.e. the cirrus channel is included and a joint cirrus / haze removal is performed.

If the keyword fraction haze is not specified, then fh=0.01 (1 percent of scene), i.e. the pro-
gram will not perform the dehazing, if the fraction of haze pixels is less than fw.

Several dehazing options exist if a cirrus channel is available.


1. The default is a joint cirrus / haze removal (keywords ihaz=0, nocirrus=0, i.e. both
keywords not set). The decirrus algorithm is run first (see the ’decirrus’ description),
CHAPTER 6. BATCH PROCESSING REFERENCE 146

followed by the dehaze. The ’decirrus’ handles the cirrus affected part of the scene,
and the dehaze handles the hazy (cirrus-free) part. In addition, the dehaze algorithm
also treats overcorrected cirrus areas to a certain extent and reduces the amount of
overcorrection. This option usually ranks best.
2. With ihaz=1 (and nocirrus=0) the dehazing is performed in cirrus affected regions and
(non-cirrus) hazy regions. Normally, without a cirrus band, cirrus clouds are labeled as
bright objects and the haze thickness map (HTM) in these regions has to be spatially
interpolated. However, with the cirrus band information, the calculated HTM values
can be retained to achieve a better haze removal, because the spatial interpolation is
avoided. This option usually ranks second.
3. With ihaz=1 and nocirrus=1 the dehazing is performed without the information of the
cirrus channel. This option ranks last.

• specl2 batch, input=filename, sensor=’xx’ or


specl2 tile, input=filename, sensor=’xx’, ntx=ntx, nty=nty
The spectral classification based on template reflectance spectra is also available in the
batch mode and with the tiling option. The ’xx’ is a keyword for the sensor type, e.g.,
’xx’=’landsat7’ for Landsat-7 ETM. The complete list of sensor keywords is shown when
typing specl2 batch on the IDL command line without the sensor specification. The ntx, nty
keywords have the meaning explained for the ATCOR tile programs above.

• smile interp3 batch, input=filename, fpoly=fpname, option=number [, silent=silent]


Purpose: The atmospheric correction accounts for the column-dependent smile shift as spec-
ified in the ”smile poly ord4.dat” of the corresponding sensor folder, but the image columns
of each band belong to slightly different wavelengths.
This function interpolates the pixel reflectance values for each band to a specified reference
wavelength. Three options exist for the reference wavelength grid:

1. use wavelength corresponding to the center of the detector array,


2. use average wavelength over all detector columns (per band),
3. use nominal wavelength specified in the (ENVI) header of the reflectance cube.

The new reference center wavelengths are included in the header of the output file. If the
input filename is ”/path1/image atm.bsq” the output name is ”/path1/image atm smcorr.bsq”
indicating the ”smile corrected” common wavelength grid.
Function parameters are: ”filename” is the full name of the surface reflectance file, ”fpname”
is the full name of ”smile poly ord4.dat”, i.e., including the path, ’number’ is the above option
number (1 - 3), and if the keyword ’silent’ is set the progress about the band processing is
not issued to the command line.
This module is also available in the interactive mode (see main menu, ’Filter’, ”Spectral Smile
Interpolation (Image Cube)”, chapter 5.6).

• hyperion tif envi, tifname


Here, ’tifname’ is the complete name of the first band of the Hyperion scene (each band is a
separate ’*.TIF’) All 242 Hyperion TIF files are layer-stacked into one ENVI BSQ file. The
output file name has the extension ’.bsq’. This module can also be invoked from the main
ATCOR menu with ’File’, ’Import’, ’Hyperion Image (TIF)’.
CHAPTER 6. BATCH PROCESSING REFERENCE 147

• reslut batch, sensor=’xxx’, [aero=aero, h1s=h1s, h2s=h2s, ith=ith ]


Here ’xxx’ is the sensor name corresponding to the ’../atcor3/sensor/xxx/’ folder. The key-
word aero can have the values ’rura’, ’urba’, mari’ or ’dese’. If not specified aero=’rura’ is
the default. For the processing of thermal band LUTs the keyword ith=1 has to be set.
¯
• at derpolish, infile, outfile, nbin, respfile *.rsp, smooth .̄., /lowpass, /adj
Derivative polishing routine.

PARAMETERS:
infile: file of reflectances to be filtered
outfile: name of output file to be created
nbin: number of adjacent bands to use for filtering (nbin=1

KEYWORDS:
respfile: response file used for wavelength reference (default: ENVI header values) lowpass:
perform lowpass filtering only
smooth: smooth the outputs by a lowpass filter of size ’smooth’ after derivative filtering
adj: use only adjacent bands (excluding current) fro derivatives

• at evalcali, filelist, outcal, /gainonly


Write calibration output based on vicarious validation results.
PARAMETERS:
filelist: list of ASCII files used to derive calibration file.
outcal: name of *.cal file to be written.
KEYWORDS:
/gainonly: only get gain and no offset in cal file

• at evaluate, ifile, geopos, slbfile, output, selspc = selspc, calfile = calfile, zen = zen, vis = vis,
gndalt = gndalt, adj = adj, atmfile = atmfile, sample = sample, dark = dark, group = group
Perform at-sensor radiance evaluation of spectra based on at sensor radiance spectral library.
PARAMETERS:
ifile: input image file
geopos: geometric position of spectrum sample center
slbfile: file of toa radiance spectra corresponding to sample
output: name of output save and txt file

KEYWORDS:
selspc: index of selected spectrum from within SLB (starting at 0)
zen: sensor zenith angle
vis: visibility
gndalt: ground altitude
calfile: calibration file for scaling of image
adj: range of adjacency window (pixels)
atmfile: atmfile used for validation
sample: size of sample window (diameter in pixels,uneven numbers only)
/dark: exclude bright pixels of sample (for water/sun glint)
CHAPTER 6. BATCH PROCESSING REFERENCE 148

OUTPUT:
variables in save file:
sdev: standard deviation of sample spectrum
avgspc: average spectrum from image sample
corspc: corrected spectrum for adjacency from image
n spc: number of sampled spectra in image
sdevsm: standard deviation of adjacency sample
avgspcsm: average spectrum of adjacency window
mspc: slb spectra
mspc Scl: slb spectra scaled to at sensor using calfile
selspc: currently selected spectrum index
q: q factor for adjacency correction

As a further output a text file with the spectra is created ( eval.txt).

• at evaluate batch, ifile, slbfile, output, selspc = selspc, calfile = calfile, vis = vis, gndalt =
gndalt, adj = adj, at3=at3, sample = sample
Perform at-sensor radiance evaluation of spectra based on ground reference spectral library.
PARAMETERS:
ifile: input image file
slbfile: file of BOA reflectance spectra corresponding to sample; should contain additionaly
ENVI header tags POS X and POS Y containing coordinates of sample spectrum
output: name of output save and txt file

KEYWORDS:
selspc: index of selected spectrum from within SLB (starting at 0)
zen: sensor zenith angle
vis: visibility
gndalt: ground altitude
calfile: calibration file for scaling of image
adj: range of adjacency window (pixels)
atmfile: atmfile used for validation
sample: size of sample window (diameter in pixels,uneven numbers only)
/dark: exclude bright pixels of sample (for water/sun glint)

• at flatpoli,infile, outfile, gainfile,[/zero offset]


Spectral polishing using an extended flat field approach..

PARAMETERS:
infile: file of reflectances to be filtered
outfile: name of output file to be created
gainfile: optional output file containing gains and offsets (will be stored)

KEYWORDS:
zero offset: apply linear function through zero (no offset)

• at impgeogr, infile, cord, resol, thresh = thresh, /s bilin, expand = .., /interp, /autoutm,
/altioff, outfile = , /overwrite, logfile = ..
CHAPTER 6. BATCH PROCESSING REFERENCE 149

Program to convert an ENVI image or GEOTIFF in geographic coordinates to metric system.


PARAMETERS:
infile: input file in geographic Lat/Lon format (ENVI or TIFF)
cord: Projection name (e.g. ’WGS 1984 UTM Zone 1N’)
resol: horizontal/vertical resolution of output image

KEYWORDS: /interp: interpolate the missing values (see keywords below, default by trian-
gulation)
thresh: threshold value above which pixels should be interpolated (default: -1)
/s bilin: use fast nereast bilinear resampling (note: s bilin and expand can not be used at the
same time)
/expand=..: use fast nearest neighbor expansion by the given amount of pixels
outfile: name of ENVI file to be written
/altioff: apply z datum offset for DEM data.
/autoutm: convert to UTM data using the default UTM zone for the given longlat location.

• at prepele, infile, demfile, ofile, [kernelsize= .., /fillzero, log=.., /slopasp, /skyview ]
Program to resize and prepare a DEM and all its layers for ATCOR processing..

PARAMETERS:
infile: ENVI formatted BSQ file (to be processed with ATCOR)
demfile: ENVI DEM covering the area of ifile (same coordinate system, can be different
resolution/extent)
ofile: name of primary elevation file

KEYWORDS:
kernelsize: size of kernel to calculate slope/aspect (default: 5)
fillzero: fill in zero values at edges of image (shrink image)
slopasp: set to calculate slope/aspect files
skyview: set to calculate skyview factor file

• at pushpoli, infile, outfile [, gainfile, spatial= .. , /nospectral , /zero offset]


Spectral polishing and post-calibration/destriping on the basis of pixel wise deviations from
local average.

PARAMETERS:
infile: file of reflectances to be filtered
outfile: name of output file to be created
gainfile: optional output file containing gains and offsets (will be stored)

KEYWORDS:
spatial: use the spatial dimensions with a filter size of the keyword for filtering
nospectral: don’t apply spectral interpolation (by default, spectral interpolation with 3 bands
is used to get systematic offsets)
zero offset: apply linear function through zero (no offset)

• at rdglobdem, globdem, longrange, latrange, cord, outdem, log = log, psize = psize, /overwrite
CHAPTER 6. BATCH PROCESSING REFERENCE 150

PARAMETERS:
globdem: input Lon/Lat DEM
longrange: range in longitude direction; pixel edges
latrange: range in latitude direction; pixel edges
cord: coordinate structure (use cord=ll getcord(projname) to get this structure.
outdem: name of dem to be written

KEYWORDS:
psize: pixel size in meters of output

• at rhoapp, infile, calfile, e0solar [,outfile, scale= .., zen=.., date=..]


Apparent reflectance calculation.

PARAMETERS:
calfile: ATCOR calibration file to be used for conversion of the cube
e0solar: File containing the solar irradiance for the sensor (atcor file)
outfile: name of output

KEYWORDS:
scale: scale for processing (same convention as for ATCOR, scale=1.0 is floating point output)
zen: solar zenith angle (default: 0 degrees), in degrees
date: date as two-elemt array [day,month]

• at shadowdetect, infile, calfile, e0solar [outfile, solangles= .., slopefile= .., /skyview, min= ..,
/all layers , /pixfilter , range= ..,
Image based shadow detection/classification.

PARAMETERS:
infile: file to be analysed
calfile: calibration file for current input file
e0solar: solar irradiance file for current input
outfile: output file of the processing

KEYWORDS:
castshadow: if keyword is set, an existing cast shadow file is provided in order to find the
shadows through this keyword.
slopefile: use slope and aspect and include them in the illumination.
solangles: solar angles [zenith/azimuth]; only required for slopefile option
skyview: calculate additional skyview layer (based on illumination) requires keyword solangles
and slopefile being set
range: range of index (default 0.5-1.0)
min: minimum value of output (default:0)
pixfilter: set to filter single pixels from dark areas (to avoid artifacts in full cast shadows)
all layers: write all layers instead of the illumination file only.

• at shadowfilter, infile, ilufile, outfile[, smfact .̄., /interp,/meanadjust, min.̄.


Filter dark/bright borders of shadows after cast shadow correction.
CHAPTER 6. BATCH PROCESSING REFERENCE 151

PARAMETERS:
reflfile: file to be filtered (reflectance file)
ilufile: illumination file containing a shadow mask which had been applied to the image.
outfile: output file of the processing

KEYWORDS:
smfact: width of shadows to be corrected
interp: shadow borders are replaced by interpolations (instead of brigthness adjustment)
meanadjust: The mean brightness across all spectral bands is adjusted (not only band wise)
min: minimum threshold for border pixel detection (default: 0.02)

• at scalefwhm, sensorin, sensout dir, fwhmdat, meanshift=..

• at shiftresp, sensorin, sensout dir, smiledat, meanshift=..


Apply FWHM or smile detection results to a sensor.

PARAMETERS:
sensorin: input sensor definition file sensor*.dat
sensout dir: output sensor name; to be created, path to directory in sensor directory of atcor
installation
fwhmdat/smiledat: files smile poly ord4.dat to be applied to sensor

• at shadowvisibility, infile, skyviewfile, ilufile, elefile = elefile, outfile = outfile, tilesize = ..,
tiledist = .., refwvl = .., /at3, /getvis, vis = vis, log = logfile
Derive aerosol distribution from image using the SHAOT method.
PARAMETERS:
infile: input file for visibiilty determination; the input file should be provided together with
*inn file containing all parameters
skyviewfile: file containing skyview factor
ilufile: file to be used to identifiy shaded areas (as created with at shadowdetect)

KEYWORDS:
elefile: elevation file (default: ground altitude from inn)
outfile: output aot550 file name (default: infile aot550.bsq, and infile visindex.bsq will be
created)
visindex: optional name of visindex file to be written (if keyword outfile is set)
tilesize: default 400 pixels (tile size for calculation of moving window)
tiledist: default 200 pixels (distance between tiles, default tilesize/2)
refwvl: reference wavelength for AOT cacluation (default 550 nm)
/at3: use atcor 3 formats
/getvis: calculates one value for the whole image - tilesize gets irrelevant here
vis: side output of visibility if /getvis keyword is set.
log: log file name
/savedump: only save parameters without creating the aot/visindex file

• at fwhmdetect, incube, dbfile, respfile, resol, outfile, featureflags=[..], vis=.., zen=.., ele=..,alti=..,chlist=..,
results=.., /spline,zeroborder=[0/1/2],range=..,splitband=..,/overwrite
CHAPTER 6. BATCH PROCESSING REFERENCE 152

• at smiledetect, incube, dbfile, respfile, resol, outfile, featureflags=[..], vis=.., zen=.., ele=..,alti=..,chlist=..,
results=.., /spline,zeroborder=[0/1/2],range=..,splitband=..,/overwrite
Smile detection routine.

PARAMETERS:
incube: input data cube
dbfile: raw database file to be used for convolution (no height interpolation)
respfile: response file (e.g., band001.rsp)
resol: internal resolution for the calculation
outfile: name of output file for smile coefficients

KEYWORDS:
featureflags: bytarr(n feat), 15 feature regions, featureflags[i] = 1 if feature is set, else 0;
vis: visibility [km]
zen: solar zenith angle [deg]; zenith at 0 deg.
ele: average ground elevation [km]
alti: flight altitude elevation [km] for pressure compensation
chlist: list of bands which are used for smile detection and for interpolation of the results
numbering starting at 0.
results: write idl save dump of all results in a file named *.sav together with the regular
output
spline = 1, spline channel interpolation, =0 linear channel interpolation of smile coefficients
zeroborder : 2 set smile coefficients to 0 at spectral borders
(first, last channel) 1 repeat smile coefficients outside of interpolated values
range : search range, default =20 nm
splitband: splitchannel index between two detectors (starting at 0) - first band of second
detector. overwrite: silently overwrites the older output

• at smoothdem, infile, dist, outfile, /median


DEM smoothing routine.

PARAMETERS:
infile: input data cube (single band ENVI image)
dist: size of smoothing filter
outfile: name of output file

KEYWORDS:
median: use median filter instead of default low pass filter.

• bil 2 bsq, infile[, outfile]

• bip 2 bsq, infile[, outfile]


Conversion of ENVI band interleaved by line (BIL) or by pixel (BIP) to ATCOR standard
band sequential storage order (BSQ).
PARAMETERS:
infile: input data cube in BIL or BIP format (ENVI image)
outfile: name of output file to be created (optional; default * img.bsq).
CHAPTER 6. BATCH PROCESSING REFERENCE 153

• env mosaic, filelist, outfile, [psize, xr, yr, [/brightness, /middle , /mosmap, background = ..,
chlist = .., /overwrite]]
Create a mosaic of a series of images.
PARAMETERS:
filelist: list of files to mosaic
outfile: name of output file to be created
psize: pixel size of output
xr: range in x dimensions (edges of pixels, two elements [xmin,xmax])
yr: range in y dimensions (edges of pixels, two elements [ymin,ymax])

KEYWORDS:
chlist: list of bands to mosaic (starting at zero 0).
background: value of background pixels (in and out)
overwrite: overwrites the output without asking...
middle: search for cutline in the middle of the overlap area
mosmap: write mosaicking map instead of the mosaicked file, indicating the file numbers.
brightness: calculate brightness map; this may also be the smoothing factor

If yr is not set correctly, the full extent is taken for both xr and yr. If psize is not set, the
minimum pixel size of all images is used.

• env mosshades, envifile, brightnessfile, outfile, [thresh=.., /horizontal,/vertical,/overwrite]


Correct large scale shadowing/cloud shadow effect in envi mosaics.
PARAMETERS:
envfile: mosaiced envifile to be corrected
brightnessfile: brightnessfile to be used for correction; created by env mosaic,/brightness
outfile: corrected file

KEYWORDS:
horizontal: horizontal flight strips, ie. vertical averages are normalized (by default vertical
strips are assumed)
vertical : vertical flight lines (N-S), horizontal averages are done.
thresh: threshold value for correction (maximum percentage of 1)
overwrite: overwrite the output

• multires, sensor=sensor, psens=psens, pspec=pspec


Resampling of multiple spectra stored as separate ASCII files (’*.dat’) in the path pspec. The
spectral channel response functions (’*.rsp’) are stored in the path psens, and the keyword
sensor specifies the sensor name. The ASCII files (’*.dat’) contain 2 columns: wavelength
(µm or nm), spectral value. Empty lines (in between or at the end) are not allowed. The
spectrum can have any unit (radiance, reflectance, emissivity, ...)
Example:
multires, sensor=’xxx’, psens=’/data7/sensor/xxx/’, pspec=’/data7/spectra/’
The resampled spectra are written to a new folder ’/data7/spectra/xxx/’ .

• multires slb, sensor=sensor, psens=psens, slbfile=slbfile


Same as multires, but all input spectra are stored in a single ENVI spectral library file (.slb)
and the keyword slbfile specifies this file (with path).
CHAPTER 6. BATCH PROCESSING REFERENCE 154

Example:
multires slb, sensor=’xxx’, slbfile=’/data7/spectra/field1.slb’
The resampled spectra are written to file ’/data7/spectra/field1 xxx.slb’

• spect xx, input=input, xc=xc, yc=yc, box=box, spnam=spnam


Extraction of a reflectance spectrum from a Level-1 image (DN image), file name=input.
The spectrum is taken from the center coordinates xc, yc, and averaged over a square box
of box*box pixels. The name of the spectrum is specified with the keyword spnam. The
corresponding ’*.inn’ file must exist and all parameters for the calculation of the surface re-
flectance are taken from this file. If box is an even number it is replaced with the next higher
odd number to uniquely define the box center. If box is not specified then box=1 is taken.

NOTE: The above spect xx is a symbolic placeholder. There are four implementations (flat
and rugged terrain, satellite and airborne ATCOR)

– spect a2 : satellite version, flat terrain


– spect a3 : satellite version, rugged terrain
– spect 4f : airborne version, flat terrain
– spect 4r : airborne version, rugged terrain

So an example of invoking this feature is:


spect 4r, input=’/data1/mission2/scene15.bsq’, xc=500, yc=600, box=3, spname=’target15 n1’

Two ASCII output files will be created in the folder ’/data1/mission2/’ :


- ’target15 n1.dat’ : the surface reflectance spectrum, 2 columns: wavelength, reflectance (%)
- ’target15 n1.rdn’ : 4 columns: wavelength, at-sensor radiance, DN, standard dev(DN).
Radiance is in (mW cm−2 sr−1 µm−1 ). The standard deviation indicates the spatial uniformity
within the box.

• angles=sun(month=..,day=.., hour=..,minute=..,lat=..,lon=..)
Calculate solar position from parameters; the keyword are self-explanatory. The output
’angles’ is an array containing [zen,azi,doy], Zenith angle and azimuth angle in degrees and
day of the year as a number.

6.4 Meta File Reader

Reading of the sensor meta data is supported for most of the pre-defined sensors. The
prerequisites are that the radiometric calibration offset/gain values are included in the file
and that one meta file exists for each scene (a multiple image meta file is not supported).
The meta file reader extracts the required information for an ATCOR run and creates two
files:

– metafile.cal : contains the radiometric calibration for each band.


CHAPTER 6. BATCH PROCESSING REFERENCE 155

– metafile.inn : contains all input parameters for the ATCOR run. Note: as the meta file
reader does not know the average scene elevation, the default elevation is set to 0 (sea
level) and the visibility will be calculated from the scene (i.e. parameter npref = 1 in
the .inn file). However, these defaults can be modified using the keywords parameters
given below. The default atmosphere is US Standard. In rugged terrain, the topography
files (elevation, slope, aspect) are also needed on lines 8 - 10 of the ’*.inn’ file. In this
case the file has to be modified subsequently.

The image scene and the meta file have to be stored in the same folder. If the scene is named
’scene.bsq’ or ’scene.tif ’ then the ’metafile.inn’ has to be renamed into ’scene.inn’ before
starting the ATCOR run. Reading of the meta file is invoked with the following command,
where ’ext’ is the extension of the meta file name (e.g., ’txt’, ’xml’, ’IMD’).

– read meta dmc, input=’/folder/metafile.ext’ (DMC)


– read meta kompsat3, input=’/folder/metafile.ext’ (Kompsat-3)
– read meta landsat tm, input=’/folder/metafile.ext’ (Landsat-4/5 TM)
– read meta landsat etm, input=’/folder/metafile.ext’ (Landsat-7 ETM).
Note: calibration values are taken for the thermal band ’61’ (low gain). If band ’62’
(high gain) will be used, then the parameters c0 62, c1 62 should be appended after the
input file specification. These will contain the corresponding offset and gain values to
be updated in the ’*.cal’ file.
– read meta landsat oli, input=’/folder/metafile.ext’ (Landsat-8 OLI)
– read meta landsat oli pan, input=’/folder/metafile.ext’ (Landsat-8 OLI panchromatic)
– read meta pleiades, input=’/folder/metafile.ext’ (Pleiades)
– read meta rapideye, input=’/folder/metafile.ext’ (RapidEye)
– read meta spot5, input=’/folder/metafile.ext’, 4 (SPOT-4)
– read meta spot5, input=’/folder/metafile.ext’, 5 (SPOT-5)
– read meta spot6, input=’/folder/metafile.ext’ (SPOT-6)
– read meta theos, input=’/folder/metafile.ext’, 2 (Formosat)
– read meta theos, input=’/folder/metafile.ext’, 3 (Theos)
– read meta wv2, input=’/folder/metafile.ext’, 1 (QuickBird)
– read meta wv2, input=’/folder/metafile.ext’, 2 (Worldview-2: 8, 4 bands or pan)

In several cases, the format for different sensors is very similar, so they are distinguished by
a sensor identification number. Example ”read meta wv2, input=’...’, 1” invokes QuickBird,
while the number ’2’ invokes Worldview-2. For all programs, the following optional keywords
can be used:

– ele=0.5 : average scene elevation (km), default: ele=0


– vis=40 : visibility (km), default: vis=23
– adj=0 : adjacency range (km), default: adj=1
Chapter 7

Value Added Products

As a ”by-product” of atmospheric correction a number of useful quantities can readily be calculated.


The first group of value added products include vegetation indices (based on surface reflectance
instead of at-sensor radiance), simple parametrizations of the leaf area index, and wavelength-
integrated reflectance (albedo). The second group comprises quantities relevant for surface energy
balance investigations which are a useful supplement for studies in landscape ecology and related
fields, e.g., as input for regional modeling of evapotranspiration. These include global radiation on
the ground, absorbed solar radiation, net radiation, and heat fluxes. Emphasis is put on simple
models based on the reflectance / temperature cube derived during the atmospheric correction.
No additional data (with the exception of air temperature) is taken into account. All value added
products are written to a file with up to 11 bands. The file structure is band sequential. If the
input file name is ”example.bsq”, the output reflectance file name is ”example atm.bsq”, and the
value added file name is ”example atm flx.bsq”, the ’flx’ indicating the most important part of the
calculation, i.e., the radiation and heat fluxes.

7.1 LAI, FPAR, Albedo


Many vegetation indices have been introduced in the literature. Only two are presented here,
because these are often used for simple parametrizations of the leaf area index (LAI), the fraction
of absorbed photosynthetically active radiation (FPAR), and surface energy fluxes (Baret and
Guyot 1991, Choudury 1994). The normalized difference vegetation index (NDVI) is defined as
ρ850 − ρ650
N DV I = (7.1)
ρ850 + ρ650
where ρ650 and ρ850 are surface reflectance values in the red (650 nm) and NIR (850 nm) region,
respectively. The soil-adjusted vegetation index (SAVI) is defined as (Huete 1988, Baret and Guyot
1991, with L=0.5) :
(ρ850 − ρ650 ) ∗ 1.5
SAV I = (7.2)
(ρ850 + ρ650 + 0.5)
The leaf area index (LAI) can often be approximated with an empirical three-parameter relationship
employing a vegetation index (VI=SAVI or VI=NDVI)

V I = a0 − a1 exp(−a2 LAI) (7.3)

156
CHAPTER 7. VALUE ADDED PRODUCTS 157

Solving for LAI we obtain


1 a0 − V I
LAI = − ln( ) (7.4)
a2 a1
Sample sets of parameters are a0 =0.82, a1 =0.78, a2 =0.6 (cotton with varied soil types), a0 =0.68,
a1 =0.50, a2 =0.55 (corn), and a0 =0.72, a1 =0.61, a2 =0.65 (soybean) with VI=SAVI (Choudury et
al. 1994).
Note: Since it is difficult to take into account the parameters for different fields and different sea-
sons it is suggested to use a fixed set of these three parameters for multitemporal studies. Then,
the absolute values of LAI may not be correct, but the seasonal trend can be captured.

Plants absorb solar radiation mainly in the 0.4 - 0.7 µm region, also called PAR region (photo-
synthetically active radiation, ASRAR 1989). The absorbed photosynthetically active radiation
is called APAR, and the fraction of absorbed photosynthetically active radiation is abbreviated
as FPAR. These terms are associated with the green phytomass and crop productivity. A three-
parameter model can be employed to approxiate APAR and FPAR (Asrar et al. 1984, Asrar 1989,
Wiegand et al, 1990, 1991).

F P AR = C[1 − A exp(−B LAI)] (7.5)

Typical values are C=1, A=1, B=0.4. Again, since it is difficult to account for the crop- and
seasonal dependence of these parameters, a constant set may be used for multitemporal datasets
to get the typical FPAR course as a function of time.

The wavelength-integrated surface reflectance (in a strict sense the hemispherical - directional
reflectance) weighted with the global flux on the ground Eg is used as a substitute for the surface
albedo (bi-hemispherical reflectance). It is calculated as :
2.5µm
R
ρ(λ)Eg (λ)dλ
0.3µm
a= 2.5µm
(7.6)
R
Eg (λ)dλ
0.3µm

Since most satellite sensors cover only part of the 0.3 - 2.5 µm region the following assumptions
are being made for extrapolation. Extrapolation for the 0.30-0.40 µm region:

• ρ0.3−0.4µm = 0.8 ρ0.45−0.50µm , if blue a band (0.45-0.50 µm) exists.

• ρ0.3−0.4µm = 0.8 ρ0.52−0.58µm , green band, no blue band available.

Extrapolation for the 0.40-0.45 µm region:

• ρ0.4−0.45µm = 0.9 ρ0.45−0.50µm , if a blue band (0.45-0.50 µm) exists.

• ρ0.4−0.52µm = 0.9 ρ0.52−0.58µm , green band, no blue band available.

The reflectance reduction factors in the blue part of the spectrum account for the decrease of
surface reflection for most land covers (soils, vegetation). The extrapolation to longer wavelengths
is computed as:

• If a 1.6 µm band exists


CHAPTER 7. VALUE ADDED PRODUCTS 158

– ρ2.0−2.5µm = 0.5 ρ1.6µm , if ρ850 /ρ650 > 3 (vegetation)


– ρ2.0−2.5µm = ρ1.6µm , else

• If no bands at 1.6 µm and 2.2 µm are available the contribution for these regions is estimated
as :

– ρ1.5−1.8µm = 0.50 ρ0.85µm , if ρ850 /ρ650 > 3 (vegetation)


– ρ2.0−2.5µm = 0.25 ρ0.85µm , if ρ850 /ρ650 > 3
– ρ1.5−1.8µm = ρ0.85µm , (else)
– ρ2.0−2.5µm = ρ0.85µm , (else)

At least three bands in the green, red, and near-infrared are required to derive the albedo product.
Wavelength gap regions are supplemented with interpolation. The contribution of the 2.5 - 3.0 µm
spectral region can be neglected, since the atmosphere is almost completely opaque and absorbs all
solar radiation. The output ” flx” file contains the channels SAVI, LAI, FPAR, and albedo coded
as 16 bit integer with the following scale factors:
• SAVI: range 0-1000, scale factor 1000, e.g., scaled SAVI=500 corresponds to SAVI=0.5 .

• LAI : range 0-10,000, scale factor 1000, e.g., scaled LAI=5000 corresponds to LAI=5.0 .

• FPAR: range 0-1000, scale factor 1000, e.g., scaled FPAR=500 corresponds to FPAR=0.5 .

• Albedo: range 0-1000, scale factor 10, e.g., scaled albedo=500 corresponds to albedo=50% .
The next section presents a simplified treatment of the radiation and heat fluxes in the energy
balance.

7.2 Surface energy balance


Surface energy balance is an essential part of climatology. The energy balance equation applicable
to most land surfaces can be written as (Asrar 1989) :
Rn = G + H + LE (7.7)
where, Rn is the net radiant energy absorbed by the surface. The net energy is dissipated by
conduction into the ground (G), convection to the atmosphere (H) and available as latent heat of
evaporation (LE). The amount of energy employed in photosynthesis in case of vegetated surfaces
is usually small compared to the other terms. Therefore, it is neglected here.
The terms on the right hand side of equation (7.7) are called heat fluxes. The soil or ground heat
flux (G) typically ranges from 10% to 50% of net radiation. Convection to the atmosphere is called
sensible heat flux (H). It may warm or cool the surface depending on whether the air is warmer or
cooler than the surface. The energy available to evaporate water from the surface (LE) is usually
obtained as the residual to balance the net radiation with the dissipation terms. Net radiation is
expressed as the sum of three radiation components:

Rn = Rsolar + Ratm − Rsurf ace (7.8)

where Rsolar is the absorbed shortwave solar radiation (0.3 - 3 µm, or 0.3 - 2.5 µm), Ratm is the
longwave radiation (3 - 14 µm) emitted from the atmosphere toward the surface, and Rsurf ace is
the longwave radiation emitted from the surface into the atmosphere. Downwelling radiation is
CHAPTER 7. VALUE ADDED PRODUCTS 159

counted with a positive sign, the upwelling thermal surface radiation has a negative sign. The
absorbed solar radiation can be calculated as :
2.5µm
Z
Rsolar = {1 − ρ(λ)} Eg (λ) dλ (7.9)
0.3µm

where ρ(λ) is the ground reflectance, 1 − ρ(λ) is the absorbed fraction of radiation, and Eg (λ) is the
global radiation (direct and diffuse solar flux) on the ground. The numerical calculation of equation
(7.9) is based on the same assumptions regarding the extrapolation of bands and interpolation of
gap regions as discussed in chapter 7.1 dealing with the surface albedo. If the satellite imagery
contains no thermal band(s) from which a map of ground temperature can be derived, then Rsolar
is the only surface energy component that can be evaluated. In case of flat terrain with spatially
varying visibility conditions or rugged terrain imagery, a map of the global radiation is included as
an additional value added channel.
2.5µm
Z
Eg = Eg (λ) dλ (7.10)
0.3µm

For flat terrain imagery with constant atmospheric conditions the global radiation is a scalar quan-
tity and its value can be found in the ”*log” file accompanying each output reflectance file. For
rugged terrain imagery, the global radiation accounts for the slope/aspect orientation of a DEM
surface element.

With thermal bands a ground temperature or at least a ground brightness temperature image can
be derived. Then the emitted surface radiation is calculated as

Rsurf ace = s σ Ts4 (7.11)

where s is the surface emissivity, σ = 5.669 ×10−8 W m−2 K −4 is the Stefan-Boltzmann constant,
and Ts is the kinetic surface temperature. For sensors with a single thermal band such as Landsat
TM an assumption has to be make about the surface emissivity to obtain the surface temperature.
Usually, s is selected in the range 0.95 - 1, and the corresponding temperature is a brightness
temperature. A choice of s = 0.97 or s = 0.98 is often used for spectral bands in the 10 - 12
µm region. It introduces an acceptable small temperature error of about 1-2◦ C for surfaces in the
emissivity range 0.95 - 1. Examples are vegetated or partially vegetated fields ( = 0.96 − 0.99),
agricultural soil ( = 0.95 − 0.97), water ( = 0.98), and asphalt / concrete ( = 0.95 − 0.96).
Emissivities of various surfaces are documented in the literature (Buettner and Kern 1965, Wolfe
and Zissis 1985, Sutherland 1986, Salisbury and D’Aria 1992).

The atmospheric longwave radiation Ratm emitted from the atmosphere toward the ground can be
written as
Ratm = a σ Ta4 (7.12)
where a is the air emissivity, and Ta is the air temperature at screen height (2 m above ground),
sometimes 50 m above ground are recommended. For cloud-free conditions, Brutsaert’s (1975)
equation can be used to predict the effective air emissivity :
pwv 1/7
a = 1.24 { } (7.13)
Ta
CHAPTER 7. VALUE ADDED PRODUCTS 160

Here, pwv is the water vapor partial pressure (millibars = hPa), and Ta is the air temperature (K).
Figure 7.1 shows pwv as a function of air temperature for relative humidities of 20 - 100%. The
partial pressure is computed as :

pwv = RH es / 100 (7.14)

where RH is the relative humidity in per cent, and es is the water vapor partial pressure in saturated
air (Murray 1967) :
a(Ta − 273.16)
es (Ta ) = es0 exp{ } (7.15)
Ta − b
The constants are a = 17.26939, b = 35.86, and es0 = es (273.16K) = 6.1078 hP a. An alternative
to equation (7.13) is the following approximation (Idso and Jackson 1969) which does not explicitly
include the water vapor and holds for average humidity conditions, compare Figure 7.2.

a = 1 − 0.261 exp{−7.77 × 10−4 (273 − Ta )2 } (7.16)

Figure 7.1: Water vapor partial pressure as a function of air temperature and humidity. Relative humidi-
ties are 20% to 100% with a 10% increment, bottom to top curves, respectively (eq. 7.14).

The calculation of the heat fluxes G, H, and LE on the right hand side of equation 7.7 requires
different models for vegetated and man-made surfaces. For vegetated or partially vegetated surfaces,
we employ a simple parametrization with the SAVI and scaled NDVI indices (Choudury 1994,
Carlson et al. 1995) :

G = 0.4 Rn (SAV Im − SAV I)/SAV Im (7.17)

where SAV Im = 0.814 represents full vegetation cover. The sensible heat flux is computed as :

H = B (Ts − Ta )n (7.18)

B = 286 (0.0109 + 0.051 N DV I ∗ ) (7.19)


CHAPTER 7. VALUE ADDED PRODUCTS 161

Figure 7.2: Air emissivity after Brutsaert (eq. 7.13) and Idso/Jackson (eq. 7.16).

n = 1.067 − 0.372 N DV I ∗ (7.20)


ρ850 − ρ650
N DV I ∗ = (7.21)
0.75 ∗ (ρ850 − ρ650 )

Equation (7.18) corresponds to equation (1a) of Carlson et al. (1995), because G is neglected there,
and so Rn − G represents the energy left for evapotranspiration. The factor 286 in equation (7.19)
converts the unit (cm/day) into (W m−2 ). N DV I ∗ is the scaled NDVI ranging between 0 and
1, and truncated at 1 if necessary. Equation (7.21) corresponds to equation (3) of Carlson et al.
(1995) with N DV I0 = 0 (bare soil) and N DV Is = 0.75 (full vegetation cover). The latent heat
flux LE is computed as the residual:
LE = Rn − G − H (7.22)
A different heat flux model is employed for urban areas with man-made surfaces (asphalt, concrete,
roofs, etc.). These are defined here with the reflectance criteria
ρ650 ≥ 0.10 and ρ850 ≥ 0.10 and ρ650 > ρ850 ∗ 0.7 (7.23)
representing low vegetation indices with N DV I < 0.176. This simple spectral definition is not
unambiguous, it might also apply to soils. For urban areas the latent heat is usually very small,
and the fluxes G and H dominate. Therefore, the terms G, LE, and H are approximated by the
following three equations (Parlow 1998):
G = 0.4 Rn (7.24)

LE = 0.15 (Rn − G) (7.25)

H = Rn − G − LE (7.26)

For low vegetation indices (SAV I < 0.1) the ground heat flux G from equation (7.17), i.e., the
vegetation model, agrees well with G from equation (7.24), i.e., the urban model. However, major
CHAPTER 7. VALUE ADDED PRODUCTS 162

differences exist for the LE and H terms, see table 7.1. Parameters for this table are: Eg =
800, Rn = 600, Ratm + Rsurf ace = −100 W m−2 , Ts = 30◦ C, and Ta = 20◦ C. The (veg) and
(urb) indicate the heat fluxes derived from the vegetation and urban model, respectively. For the
urban surfaces (asphalt, concrete) the G(veg), H(veg) and LE(veg) values are given in brackets
for comparison, but the corresponding ”urban” heat fluxes are valid because the ”urban” criterion
(equations 7.23, ρ650 ≥ 0.10, ρ850 ≥ 0.10, and ρ650 > ρ850 ∗ 0.7) applies. The last row repeats the
concrete case for Rsolar = 800 ∗ (1 − 0.36) = 512, Rn = Rsolar + Ratm + Rsurf ace = 512 − 100 =
412 W m−2 , a realistic reduced Rn value (compared to the asphalt where Eg = 800, Rsolar =
800 ∗ (1 − 0.12) = 700, Rn = 700 − 100 = 600 W m−2 ).

surface ρ650 ρ850 NDVI G(veg) H(veg) LE(veg) G(urb) H(urb) LE(urb)
full veget. 0.05 0.40 0.78 77 87 435 - - -
partial veget. 0.10 0.20 0.33 185 76 338 - - -
dark asphalt 0.11 0.13 0.09 (228) (50) (322) 240 306 54
bright concrete 0.35 0.40 0.07 (222) (48) (330) 240 306 54
bright concrete (*) 0.35 0.40 0.07 - - - 164 210 37

Table 7.1: Heat fluxes for the vegetation and urban model. All fluxes in [W m−2 ].

All radiation and heat fluxes are calculated in units of W m−2 . They represent instantaneous flux
values. For applications, where daily (24 h) LE values are required the following equation can be
used for unit conversion:
cm 1
LE [ ]= LE [W m−2 ] (7.27)
day 286
The latent heat flux LE is frequently called evapotranspiration (ET). Although LE and ET are used
interchangeably the unit (cm/day) or (mm/day) is mostly employed for ET. For water surfaces
the distribution of net radiation into G, LE, and H is difficult to determine, because it depends on
several other parameters. Therefore, G and H are set to zero here, and so LE equals Rn .

Spatial maps (files) of air temperature and air emissivity can also be included in the processing.
Usually, isolated point-like measurements of air temperature are available from meteorological sta-
tions. These have to be interpolated to generate a spatial map coregistered to the image prior
to applying the ATCOR model. Data in the file containing the air temperature must have the
Celsius unit, data of the air emissivity file must range between 0 and 1. Future improvements
to the ATCOR model will include an air temperature map derived from the image (”triangle” or
”trapezoidal” method employing the thermal band surface temperature and NDVI, Carlson et al.
1995; Moran et al. 1994).

In case of mountainous terrain, the air temperature Ta (z0 ) and water vapor partial pressure pwv (z0 )
at a reference elevation z0 have to be specified. The height dependence of air temperature is
then obtained with linear extrapolation employing a user-specified adiabatic temperature gradient
∂T /∂z:
∂T
Ta (z) = Ta (z0 ) + (z0 − z) (7.28)
∂z
where ∂T /∂z is typically in the range 0.65 - 0.9 (Celsius / 100 m). The water vapor partial pressure
is extrapolated exponentially according to
pwv (z) = pwv (z0 ) 10−(z−z0 )/zs (7.29)
CHAPTER 7. VALUE ADDED PRODUCTS 163

where zs is the water vapor scale height (default 6.3 km). The list of all output channels of the
value added ”* flx.bsq” file is :

1. Soil adjusted vegetation index (SAVI), scaled with factor 1000,

2. Leaf area index (LAI), scaled with 1000,

3. Fraction of photosynthetically active radiation FPAR, scaled with 1000,

4. Surface albedo (integrated reflectance from 0.3-2.5 µm), per cent * 10,

5. Absorbed solar radiation flux Rsolar [W m−2 ],

6. Global radiation Eg [W m−2 ], omitted for constant visibility in flat terrain because it is a
scalar which is put into the ”*log” file .
The next channels are only available in case of at least one thermal band:

7. Thermal air-surface flux difference Rtherm = Ratm − Rsurf ace [W m−2 ],

8. Ground heat flux G [W m−2 ],

9. Sensible heat flux H [W m−2 ],

10. Latent heat LE [W m−2 ],

11. Net radiation Rn [W m−2 ].


Chapter 8

Sensor simulation of
hyper/multispectral imagery

After atmospheric correction the surface reflectance and temperature/emissivity cubes can be used
to simulate new products which might be of interest:

• at-sensor radiance cubes in the solar region (0.4 - 2.5 µm) for different solar geometries and
atmospheric conditions,

• at-sensor radiance cubes in the thermal region (8 - 14 µm) for different atmospheric conditions,
e.g. for satellite sensor studies,

• resampling of the surface reflectance cube to an existing or new multispectral sensor,

• resampling of the surface emissivity cube to an existing or new multispectral sensor.

This is a convenient way to simulate realistic data for a spaceborne version of an airborne instru-
ment, to obtain radiance data under differenct atmsopheric conditions, or to compare hyperspectral
(hs) data with broad-band multispectral (ms) data. As a restriction, the TOA (top-of-atmosphere)
or at-sensor radiance calculated with the ”TOARAD” program assumes a nadir view. The ”hs2ms”
(hyperspectral-to-multispectral) program requires the hs and ms center wavelengths and the ms
channel filter curves for resampling. In addition, noise of the ms sensor can be included as Gaussian
noise with a specified amplitude, either as noise-equivalent radiance (NER) or as noise-equivalent
reflectance (N E∆ρ). The hs contribution to a certain ms band is weighted with the value of the
ms response curve at the corresponding hs wavelength, compare Fig. 8.1.
After summing all contributions the result is normalized with the sum of the hs filter values
ni
P (k) (i) (k)
Lhs Rms (λhs )
k=1
Lms (i) = ni (8.1)
P (i) (k)
Rms (λhs )
k=1

(i)
where L denotes at-sensor (or TOA) radiance, Rms the ms response function of channel i, and ni is
the number of hs channels covered by the i-th ms filter function. A similar equation is used for the
resampling of surface reflectance. The weight factors wk for each hs channel are calculated with

164
CHAPTER 8. SENSOR SIMULATION OF HYPER/MULTISPECTRAL IMAGERY 165

Figure 8.1: Weight factors of hyperspectral bands.


(i)
The solid curve shows the response function Rms of a ms channel,
(j)
and the dashed lines indicate the hs center wavelengths λhs .

eq. 8.2, and they are documented in the corresponding ”.log” file created by program ”HS2MS”.

(i) (k)
Rms (λhs )
wk (i) = P
ni (8.2)
(i) (j)
Rms (λhs )
j=1

Fig. 8.2 describes the sequence of processing for the sensor simulation in the solar region. After
atmospheric correction with ATCOR the ”image atm.bsq” contains the surface reflectance cube.
Program ”TOARAD” then calculates the at-sensor radiance for a different solar geometry, or at-
mospheric parameters. All parameters not specified as keywords (see list of keywords below) are
taken from the ”image.inn” file created by ATCOR.

The program ”HS2MS” can be started to resample the radiance cube to a ms image by specifying
the ms sensor (i.e., channel filter functions) and the ms noise equivalent radiance (NER). NER =
0 is allowed, so the resampled image product will only include the noise of the hs scene, which will
be reduced due to the inherent integration over several hs bands. A channel-constant NER or a
file with channel-dependent NER values may also be employed.
Figure 8.3 shows the GUI panel of program ”HS2MS”. Although the input image will usually be
a hyperspectral scene with n > 50 channels and the output a multispectral scene with m << n
channels, this program can also be employed for the case of a multispectral input image with
n < 10 channels and a panchromatic sensor with m=1 band. The program supports the four cases
of resampling mentioned above, i.e., solar or thermal at-sensor radiance, surface reflectance, or
emissivity.

The processing of hyperspectral thermal data is currently not supported by the satellite version
of ATCOR because of the lack of commercial sensors with these channels. However, this part is
already implemented in the airborne ATCOR. A detailed description of the keywords of program
”toarad” follows.
CHAPTER 8. SENSOR SIMULATION OF HYPER/MULTISPECTRAL IMAGERY 166

Figure 8.2: Sensor simulation in the solar region.

Keywords for the batch program ”toarad”

On the IDL command line, program names can be written in lower case letters, so as an example
”toarad” instead of ”TOARAD” is used synonymously in this context. If ”toarad” is submitted as
a batch job, the following keywords can be specified:
• toarad, input=filename, [ pixelsize=pixelsize, sz=solar zenith, atmfile=atmfile, elev=elevation,
vis=visibility, adjrange=adjrange, scalef=scalef ]

The input file name must include the path, and the keywords in brackets indicate optional pa-
rameters. If a keyword is set, it will overwrite the corresponding parameter from the ”.inn” file,
compare chapters 6.3 and 9.4. To perform a TOA/at-sensor radiance simulation for a given scene,
the user has to resample files from the monochromatic atmospheric database:
• for the altitude 99,000 m that serves as ”flight” altitude for space sensors, see chapter 4.6.
After running ATCOR for a certain scene and sensor, a surface reflectance cube is obtained which
is input to the TOA/at-sensor simulation that can be performed for a flat or a mountainous terrain.
A detailed description of the keywords of ”toarad” follows:
CHAPTER 8. SENSOR SIMULATION OF HYPER/MULTISPECTRAL IMAGERY 167

Figure 8.3: Graphical user interface of program ”HS2MS”.

• input=’/data1/image atm.bsq’, the ’ atm.bsq’ indicates a surface reflectance file which is the
output of an ATCOR run. The input file to ATCOR was ’/data1/image.bsq’, and toarad
extracts some information from the corresponding file ’/data1/image.inn’, for example the
sensor name. The output file name is ’/data1/image toarad.bsq’.

• atmfile=’h99000 wv29 rura’, this is an example of an atmospheric look-up-table file with a


rural aerosol and a water vapor column of 2.9 gcm−2 , see chapter 9.1. If the keyword atmfile
is not specified, then ’h99000 wv10 rura’ will be taken.

• elev=500, an example of a ground elevation at 500 m above sea level. If elev is not specified,
then elev=0 is assumed. However, if the keyword elev is not specified and the ’/data1/image.inn’
file contains file names for the DEM elevation, slope, and aspect, then the DEM files are taken,
and the TOA calculation is performed for a rugged terrain. If the keyword elev is specified
the simulation is always performed for a flat terrain regardless of any possible DEM file names
in the ’*.inn’ file.

• sz=35.5, an example of a solar zenith angle of 35.5◦ .

• vis=25, an example of a visibility of 25 km.

• pixelsz=4.5, an example of a pixelsize of 4.5 m .


CHAPTER 8. SENSOR SIMULATION OF HYPER/MULTISPECTRAL IMAGERY 168

• adjrange=500, an example of an adjacency range of 500 m.

• scalef=10,000, scale factor for the TOA radiance. The default is scalef=1.0 which provides
the output file as float data of TOA radiance in units of [mW cm−2 sr−1 µm−1 ]. If scalef > 1,
e.g. scalef=10,000, the output TOA radiance is stored as 16 bit unsigned integer multiplied
with the scale factor. The advantage is a smaller output file (compared to the 32 bit float),
the drawback is that radiances will be truncated at 65,000 which might happen for bright
surfaces (e.g., snow, vegetation in the NIR) with scalef=10,000, see Figure 8.4. Therefore, the
easiest way to avoid scale problems is to use the default scalef=1.0 and have a float radiance
output cube.

Figure 8.4: TOA radiances for three albedos and a solar zenith angle of 30◦ .
MODTRAN calculation for a mid-latitude summer atmosphere, rural aerosol, visibility 15 km,
ground elevation 500 m above sea level.

For convenience, a ”*.log” and an ”*.ini” file are created for the documentation of the processing
parameters, e.g., ’/data1/image toarad.ini’. In addition, the corresponding sensor calibration file
will be created. Example: sensor=’casi96’, scalef=1000, then file ’casi96 scalef1000.cal’ will be
created on the ’../atcor4/sensor/casi96/ directory with the radiometric calibration coefficient c1 =
0.001 for each band.
Chapter 9

Implementation Reference and Sensor


Specifics

This chapter discusses miscellaneous topics associated with the current implementation of ATCOR.
First the user is acquainted with the structure and handling of the atmospheric database. Second,
the supported input/output file types are given. The next item discusses the preference parameters,
e.g. the definition of thresholds employed for the masking of cloud and water areas, and options for
interpolating certain spectral regions. Then the parameters of the ”*.inn” file are described which
is employed for the interactive and batch processing. Last but not least a section on problems and
tips is included.

9.1 The Monochromatic atmospheric database


This section presents the technical details of the atmospheric database.

To be capable of handling typical hyperspectral sensors with arbitrary spectral bands in the so-
lar and thermal spectral regions a large database of atmospheric LUTs was compiled with the
MODTRAN 5 R (version5.4.0) radiative transfer code in 2016, which uses resampled HITRAN2013
files. The database is called ”monochromatic” because of its high spectral resolution, compare
figure 9.1. After resampling with the spectral response functions of any sensor a typical size of the
sensor-specific database is 10 MB. Chapter 9.1.4 contains a description of the resampling program
RESLUT.

9.1.1 Visible / Near Infrared region


In the solar spectral region (0.34 - 2.54 µm) MODTRAN R was run with different wavenumber
spacings to achieve a wavelength grid spacing of approximately 0.4 nm (except for the 1400 nm and
1800 nm regions). This required the use of MODTRAN ’s R ”p1 2008” database (i.e., 0.1 cm−1 )
in the 2.1 - 2.5 µm region. In addition, different RT algorithms were used: in atmospheric window
regions the scaled DISORT algorithm with 8 streams (SD-8) was employed, in absorption regions
the more accurate SD-8 with the correlated k algorithm was selected [?]. Since the wavenumber
grid is not equidistant in wavelength, the LUTs were resampled with an equidistant 0.4 nm grid of
Gaussian filter functions of FWHM=0.4 nm to speed up subsequent calculations. So the new LUT
database should be sufficient for instruments with bandwidths > 2 nm covering the solar spectral
region from 340 to 2540 nm.

169
CHAPTER 9. IMPLEMENTATION REFERENCE AND SENSOR SPECIFICS 170

The ”standard” database is calculated for nadir viewing instruments. An off-nadir database with
the incidence angles 0◦ - 30◦ (in steps of 10◦ ) is available upon request. It is intended for future
hyperspectral space sensors such as EnMAP.
A separate ”CHRIS/Proba” database is included in the distribution containing calculations for the
tilt angles 0◦ , 35◦ , and 55◦ for seven equidistantly spaced relative azimuth angles (0, 30, ... 180◦ ).
CHRIS data acquisition is usually close (within ±2◦ ) to this set of tilt angles, and interpolation
is automatically performed. While the standard database is named ”atm database”, the CHRIS
database is named ”atm database chris” and it is automatically accessed if the letters ”chris”
or ”CHRIS” are part of the user-defined sensor name, e.g., ”chris mode5”. While the standard
database uses a 0.4 nm wavelength grid, the CHRIS database employs a 1 nm grid.

9.1.2 Thermal region


The thermal high-resolution database employs a spectral sampling distance of SSD=0.4 cm−1 for
the wavelength region 7 - 10 µm, i.e. corresponding to a wavelength SSD=2 - 4 nm, and SSD=0.3
cm−1 for the wavelength region 10 - 14.9 µm, i.e. corresponding to a wavelength SSD=3 - 5.5
nm. A triangular weight function is used with a spectral bandwidth of twice the SSD. The Isaacs’s
2-stream method is employed including the correlated k algorithm. The Isaacs’s algorithm is much
faster than DISORT, and yields the same results for our cases in the thermal region. All files
(”*.bt7”) are calculated for view or scan angles from 0◦ (nadir) to 40◦ off-nadir with a 5◦ increment
to enable an accurate interpolation.

Figure 9.1: Monochromatic atmospheric database.

The database comprises calculations performed for a satellite altitude of 700 km, but for consis-
tency with the airborne ATCOR the symbolic height ’99,000’ is used in the file names. For off-nadir
geometries, the earth incidence angle of the satellite view is used for the MODTRAN runs to make
the results independent of the satellite orbit altitude. MODTRAN ’s R mid-latitude summer atmo-
sphere was used for the air pressure and temperature height profiles at six water vapor columns
(W=0.4, 1.0, 2.0, 2.9, 4.0, and 5.0 cm or or g cm−2 , (sea level-to-space values) and different aerosol
types. These represent dry to humid atmospheric conditions [?, ?]. They are needed for the water
vapor retrieval to create interpolated / extrapolated values for the range W=0.3 - 5.5 cm. In spec-
tral regions where water vapor absorbs, the accuracy of the surface reflectance retrieval depends on
the number of water vapor grid points and the interpolation method (full range of W or sub-interval
pertaining to a pixel [?]). The CO2 mixing ratio of the atmosphere is set at 400 ppmv, the default
ozone column is fixed at 330 DU (Dobson Units, equivalent to the former 0.33 atm-cm) for a ground
at sea level. However, there is a separate ozone database covering the range 200 - 500 DU, with
extrapolation in the range 100 - 600 DU. It is automatically included, if the scene ozone column
is specified in the ’*.inn’ file [61]. The aerosol types rural, urban, maritime, and desert have been
CHAPTER 9. IMPLEMENTATION REFERENCE AND SENSOR SPECIFICS 171

provided in the database.

These files have to be resampled with the sensor-specific channel filter curves. The file names for
the solar region include the altitude, the aerosol type, and the water vapor content. They have the
extension ”.atm”. Example: ”h99000 wv04 rura.atm” represents a file with the symbolic altitude
99,000 m, water vapor column 0.4 cm, and the rural aerosol.
Each ”*.atm” file contains the look-up tables for the visibility range 5 - 120 km, solar zenith angles
0 - 70◦ , and ground elevations 0 - 4000 m (increment 500 m).

The files ”phasefct*.bin” in the ”../atcor/bin” directory contain the path radiance as a function of
the scattering angle for the standard multispectral instruments with tilt capability (up to 50◦ off-
nadir), e.g. Worldview, Planet Labs, TripleSat, Pleiades, SPOT, Ikonos. A small field-of-view is
assumed for all (hyperspectral or multispectral) instruments, i.e., the specified tilt / incidence angle
and solar zenith angle holds for the whole scene.

9.1.3 Database update with solar irradiance


In the solar region any high spectral resolution database of LUTs is based on the specification of an
extraterrestrial spectral solar irradiance, because the values of path radiance, direct and diffuse solar
fluxes depend on solar irradiance. Other quantities (direct and diffuse atmospheric transmittances
and spherical albedo) are independent of the solar spectrum. ATCOR’s standard atmospheric
database is calculated for a certain irradiance E1 (λ), and the corresponding file ’e0 solar xxx.dat’
is included in the directory ’atm database’.

Beginning with the ATCOR-2011 release there is an option to switch from one extraterrestrial solar
irradiance source E1 (λ) to another one E2 (λ). The delivered high spectral resolution database of
atmospheric LUTs is based on the Fontenla-2011 solar irradiance spectrum (Fontenla et al. 2009,
2011 [8, 9]). It represents the solar irradiance for a quiet or ”low activity” sun and is recommended
as the standard spectrum. The original 0.1cm−1 resolution spectrum is convolved with Gaussian
filter functions (FWHM=0.4 nm) and mapped on an equidistant 0.4 nm grid. The file name of
this spectrum E1 (λ) is ’e0 solar fonten2011 04nm.dat’. If R1 denotes the set of quantities (path
radiance, direct, diffuse solar flux) based on E1 (λ), then the new set R2 with the irradiance spectrum
E2 (λ) is calculated as:

R2 (λ) = R1 (λ) E2 (λ)/E1 (λ) (9.1)

Figure 9.2 presents a schematic sketch of this conversion. The folder ’sun irradiance’ contains a
number of solar irradiance files that can be selected. The folder of the atmospheric database DB1
pertaining to E1 (λ) includes the corresponding irradiance file (e.g. ’e0 solar fontan2011 04nm.dat’ )
and the calculated new database DB2 includes the E2 (λ) file (e.g., ’e0 solar kurucz2005 04nm.dat’ ).
The standard or ”active” database is named ’atm database’, while the new database includes 10
characters from the E2 file name, e.g. ’atm database kurucz2005’.

The ATCOR ”tools” panel contains the program to convert from one to another spectral irradi-
ance database (see Figure 9.3). It enables an update of the ”monochromatic” atmospheric database
without the need to repeat the time-comsuming MODTRAN 5 R computations (involving the cor-
related k algorithm in some spectral regions). The user can also provide additional solar irradiance
files to the ’sun irradiance’ folder provided the spectral range, increment, and irradiance unit agree
CHAPTER 9. IMPLEMENTATION REFERENCE AND SENSOR SPECIFICS 172

Figure 9.2: Solar irradiance database.

with the template spectra.

Attention: ATCOR will always work with files in the ”active” folder ’atm database’, therefore the
old ’atm database’ has to be renamed (or deleted) and the folder with the new database has to
be renamed as ’atm database’ before applying the sensor-specific resampling program (RESLUT).
Since each ’atm database’ folder contains its corresponding solar irradiance spectrum a unique
identification is always possible. In addition, the directory of the sensor-specific ”*.atm” files
contains an ASCII file named ’irrad source.txt’ identifying the solar irradiance file.

9.1.4 Sensor-specific atmospheric database


This sensor-specific database is created by resampling the files of the monochromatic database with
the sensor’s spectral response functions employing program RESLUT, see figure 9.4. An aerosol
subset or all aerosol files from the monochromatic database can be selected. All water vapor files
belonging to the selected aerosol type (e.g. wv04, wv10, wv20, wv29, wv40, wv50) will be resam-
pled for hyperspectral or user-defined sensors. The folder with the ”.atm” files also contains a file
”irrad source.txt” identyfying the underlying solar irradiance spectrum.

In addition, a file of the resampled extraterrestrial solar irradiance, e.g., ”e0 solar hyperion.spc”,
will be created in the corresponding sensor folder, e.g., ”../sensor/hyperion/”.

9.1.5 Resample sensor-specific atmospheric LUTs with another solar irradiance


It is also possible to resample existing sensor-specific LUTs (”.atm” files) with another solar irra-
diance spectrum. Input is a sensor from the ”atcor/sensor/” folder (example name ’xxx’) with the
corresponding spectral response files (”.rsp”) and a high-resolution solar irradiance file from the
”atcor/sun irradiance/” directory (example: ’e0 solar kurucz2005 04nm.dat’).

Output is a new sensor subdirectory (example: ”sensor/xxx kurucz2005/”) where the first 10 char-
acters of the ’e0 solar kurucz2005 04nm’ (starting after the ’e0 solar ’) are appended to the input
sensor name. The contents of the input ’atcor/sensor/xxx/’ are copied to the output directory,
’e0 solar xxx.spc’ is deleted (in the output directory) and replaced by the new ’e0 solar xxx kurucz2005.spc’.
CHAPTER 9. IMPLEMENTATION REFERENCE AND SENSOR SPECIFICS 173

Figure 9.3: User interface to convert database from one to another solar irradiance.

A comparison of ’e0 solar xxx.spc’ with ’e0 solar xxx kurucz2005.spc’ shows the influence of the
change of the irradiance spectrum. In addition, a new ’atm lib/xxx kurucz2005/’ is created where
all the LUTs ’.atm’ from the input ’atm lib/xxx/’ are replaced with the resampled selected irra-
diance spectrum. This new folder also contains a file ””irrad source.txt” identifying the selected
irradiance source.

9.2 Supported I/O file types


The input image to ATCOR must have the band sequential (BSQ) ENVI format or the TIFF
format. Some restrictions apply to the TIFF format as detailed below. Several data types exist for
the encoding. The following data types of an input image are supported:

• byte, or unsigned 8 bit integer, ENVI data type = 1;

• signed 16 bit integer, ENVI data type = 2;

• unsigned 16 bit integer, ENVI data type = 12;

• signed 32 bit long integer, ENVI data type = 3;

• float (32 bit), ENVI data type = 4.


CHAPTER 9. IMPLEMENTATION REFERENCE AND SENSOR SPECIFICS 174

Figure 9.4: GUI panels of the satellite version of program RESLUT.

9.2.1 Side inputs


Before running the main processor, certain files have to be provided (the DEM derived files are not
required for a flat terrain):

Parameter file extension: *inn


This file is written automatically while using the graphical user interface. It may also be
written externally for use in batch processing. See Section 9.3 for a detailed description.

Elevation file (DEM) extension: [dem] ele.bsq


Elevation file containing the digital terrain model used for processing.
Format: single band ENVI file in either integer, unsigned integer, or floating point format.
Default unit: meters.

Slope file extension: [dem] slp.bsq


Slope angle for each image pixel.
Format: single band ENVI file byte or 16-bit integer or float data type. Unit: degrees.

Aspect file extension: [dem] asp.bsq


Aspect angle for each image pixel with respect to north.
Format: single band ENVI file 16-bit integer or float data type. Unit: degrees.

Skyview factor file extension: [dem] sky.bsq


Skyview Factor
Format: single band ENVI file byte data type. Unit: % (percentage 0-100)

Cast shadow mask extension: [dem+angles] shd.bsq


Shadow flag (0: cast shadow, 2: no shadow, 1: border region) for each image pixel.
Format: single band ENVI file byte data type.

Illumination file extension: [image] ilu.bsq


External Illumination file, Format: ENVI floating point data file - external illumination files
CHAPTER 9. IMPLEMENTATION REFERENCE AND SENSOR SPECIFICS 175

are only read if they are in floating point format and if they are in the same size as the
imagery. Contents: a value of zero is a complete cast shadow whereas a value of 1 is in
full illumination, corresponding to the definition of the cos(β) of the incidence angle, where
β = 0 deg is a 90 degree incidence direction.

Calibration file extension: [sensor].cal


Calibration file, containing wavelength, c0 and c1 for each spectral band for conversion of
image data to calibrated radiance L = c0 + c1 ∗ DN , units mW/(cm2 sr µm)
Format: 3 column ASCII, one header row

Response Function extension: [bandxxx].rsp


Spectral response function for one spectral band with wavelength reference and relative re-
sponse
Format: 2 column ASCII, no header This file is only requested for user-defined sensors, not
for the standard sensors.

Sensor Description extension: sensor [type].dat


Sensor description file as created by the Function ’File:New Sensor’ Format: ASCII. This file
is only requested for user-defined sensors, not for the standard sensors.

Solar Reference extension: e0 solar [type].dat


Solar reference function for the sensor as created when compiling the atmospheric LUT for a
sensor. Format: ASCII, three columns: center wavelength, bandwidth, extraterrestrial solar
irradiance.

9.2.2 Main output


The default output image data type is byte if the input is byte data. Then a scale factor s=4 is
employed, i.e., the per cent reflectance value of each pixel is multiplied with s=4 and rounded to
byte. As an example, a surface reflectance value of 20.2% will be coded as 81. However, the user
can modify the scale factor (on ATCOR’s main panel). A value of s=10 to s=100 causes the output
file to be coded as signed 16 bit integer, i.e., with two bytes per pixel. The specification s=1.0
produces a float output image, i.e., with 4 bytes per pixel.
Attention: The float output could be used for testing on small images. For large files and an input
data type of 2 bytes per pixel the output float image would require twice the disk space of the
input image.

The default output data type is signed 16 bit integer for all integer (and float) input data employing
the scale factor s=100. The scale factor is always included in the output ENVI header file.

Note: Any positive value of the scale factor s is accompanied with a truncation of surface reflectance
values at 0 in the output cube. So a negative reflectance, e.g., caused by a wrong choice of vis-
ibility or inaccurate radiometric calibration, will be reset to zero in the output image. In the
”SPECTRA” module no truncation is applied. If a user wants the output reflectance cube without
zero-truncation, the scale factor s should be specified with a negative value, e.g., s=-1 will provide
a float output surface reflectance retaining negative reflectance values, s=-100 will provide a 16 bit
integer output file. The byte scale (−10 < s < −1 and output data range 0-255) cannot be used to
represent negative values. The negative scale factor should only be used for test purposes, since the
results do not make a physical sense, and some further processing options or modules are excluded
in this case, e.g. the value added calculation of surface energy balance components, the automatic
CHAPTER 9. IMPLEMENTATION REFERENCE AND SENSOR SPECIFICS 176

spectral classification (SPECL), or the BRDF corrections.

Note: The TIFF format is also allowed for the input file. However, some restrictions apply in this
case, compare chapter 6.3.

• All bands in one TIFF file: the channels in the file must have the ascending band order and
the maximum number of channels is 9.

• Each band in a separate file: file names must include the band numbers, e.g., ”image band1.tif”,
”image band2.tif”, etc. Again, the maximum number of bands is restricted to 9. The first
band is specified to ATCOR and all bands will be processed automatically.

• An optional keyword tiff2envi exists for the ATCOR batch and tiling modes that produces an
automatic conversion of the input TIFF file (e.g., ”image.tif”) into the corresponding ENVI
file (e.g., ”image envi.bsq”). This file is used as a temporary input file to ATCOR and it will
be automatically deleted when the ATCOR run is finished. Two output surface reflectance
files will be generated if tiff2envi=1, an ENVI file (”image envi atm.bsq”) and a TIFF file
(”image atm.tif”). The ENVI output is needed if the spectral classification (SPECL) module
is run, otherwise it may be deleted by the user.
In the interactive ATCOR mode with GUI panels, the default for a TIFF input file is
tiff2envi=1, i.e., a corresponding input ENVI bsq (band sequential) file is created. In the
batch mode, the default for a TIFF input file is tiff2envi=0, i.e., the ENVI file conversion is
switched off and no intermediate files are created. This will save disk space and some file con-
version time. However, if the ”image.ini” file specifies the de-hazing or de-shadowing option,
then tiff2envi is reset to 1 to enable the creation of of the needed additional intermediate
ENVI files. For non-TIFF files, the tiff2envi keyword is ignored.

Summary of output data types :

• byte (default surface reflectance scale factor = 4.0)

• 16 bit signed integer (scale factor ≥ 10.0, typically 10 or 100)

• float (scale factor = 1.0)

• The corresponding negative scale factors (except byte case) provide an output reflectance
cube allowing negative surface reflectance values (only recommended in a test phase).

9.2.3 Side outputs


A number of side outputs is written by default after successful execution whereas some outputs are
optional (marked with an ’*’).

Log file Name: [outputname].log


Standard log file containing all necessary information about the data processing.
Format: ASCII

Error log file Name: atcor error.log


An error log file is written whenever an uncaught error occurred. Please send this file to the
software supplier in case of malfunction.
Format: ASCII
CHAPTER 9. IMPLEMENTATION REFERENCE AND SENSOR SPECIFICS 177

Aerosol optical thickness* Name: [outputname] atm aot.bsq


Aerosol optical thickness map (scale facor 1,000).
Format: 1 channel, binary, 16-bit signed integer

DDV classification* Name: [outputname] atm ddv.bsq


Classification of dark dense vegetation, cast shadows, and water pixels map used for aerosol
retrieval.
Format: 1-band ENVI byte file containing the three classes

Visibility index* Name: [outputname] atm visindex.bsq


Index of Visibility used for atmospheric correction (if variable aerosol distribution has been
selected as processing option).
Format: 1-band ENVI byte file containing the indices

Water vapor* Name: [outputname] wv.bsq


Columnar amount of water vapor calculated from image
Format: ENVI single band file, 16-bit signed integer; unit: cm (i.e., g/cm2)*1,000, i.e. scale
factor 1,000.

Illumination Name: [outputname] ilu.bsq


Illumination file created during processing (in case no external floating * ilu has been pro-
vided).
Format: Scaled illumination in byte format from 0 to 100%, single band.

Haze/cloud/water* Name: [outputname] out hcw.bsq


Haze, cloud, and water mask.
Format: ENVI byte image; classes.

Fractional shadow* Name: [outputname] fshd.bsq


Fractional cloud/building shadow (optional)
Format: ENVI Integer image; Scaled shadow between 0 and 1000.

Diffuse irradiance* Name: [outputname] edif.bsq


Diffuse irradiance component, 1 band, 16-bit signed integer, unit (W m−2 nm−1 ).

Direct irradiance* Name: [outputname] edir.bsq


Direct irradiance component, 1 band, 16-bit signed integer, unit (W m−2 nm−1 ).

Global irradiance* Name: [outputname] eglo.bsq


Global irradiance (sum of edir and edif).
1 band, 16-bit signed integer, unit (W m−2 nm−1 ).

Value Added Vegetation* Name: [outputname] atm flx.bsq


Multi Layer file containing side outputs for vegetation, i.e. flux, fapar, savi, etc..
Format: ENVI signed 16-bit integer with scale factors as specified in the header.

9.3 Preference parameters for ATCOR


The preference parameters are now located in a user specific HOME directory ”∼/.idl/rese/atcor3/”,
so multiple users of the same license can retain their personal preference settings. The path
of the last input image is saved separately for the flat and rugged terrain versions of ATCOR,
CHAPTER 9. IMPLEMENTATION REFERENCE AND SENSOR SPECIFICS 178

i.e., ”preference atcor2 path.txt”, and ”preference atcor3 path.txt”. In addition, the file ”prefer-
ence parameters.dat” contains a number of default parameters that can be adjusted to scene prop-
erties. This file contains the parameters with a short description.

line 1 A choice to set the water vapor values for water pixels:
1 = average water vapor value of land pixels is assigned to water pixels,
Option available for iwv model = 1 and iwv model = 2, see section 9.4.
2 = line average of water vapor of land pixels is assigned to water pixels.
Option only available with iwv model = 1, see the job control parameter section 9.4.
line 2 A cloud reflectance threshold Tc (%) in the blue-green region to define a cloud mask.
Pixels belong to the cloud mask if :
(a1) ρ∗ (blue) > Tc or (a2) ρ∗ (green) > Tc (asterisk: apparent reflectance)
Typical values for Tc range from 15 - 35% .
If the cloud reflectance threshold is too high, clouds will be included in the haze mask.
This will reduce the performance of the haze removal algorithm.
line 3 A surface reflectance threshold ρw1 (%) for water in the NIR band.
Pixels belong to the water mask if ρ(N IR) < ρw1 , for details see chapter 10.2.
line 4 A surface reflectance threshold ρw2 for water in the 1600 nm region (if band exists).
Pixels belong to the water mask if ρ(N IR) < ρw1 and ρ1600 < ρw2 .
The defaults ρw1 = 5% and ρw2 = 3% allow some margin for turbid water.
line 5 interpolate bands in 760 nm oxygen region (0=no, 1=yes)
line 6 interpolate bands in 725 / 825 nm water region (0=no, 1=yes)
line 7 interpolate bands in 940 /1130 nm water region (0=no, 1=nonlinear, 2=linear)
line 8 smooth water vapor map (box 50m*50m) (0=no, 1=yes)
The water vapor map is calculated on a pixel-by-pixel basis, a moderate spatial
smoothing (50m*50m or at least 3*3 pixels) reduces the noisy appearance.
line 9 interpolate bands in 1400/1900 nm nm water region (0=no, 1=yes)
line 10 cut-off limit for max. surface reflectance (default 150%)
line 11 ” out hcw.bsq” file (haze/cloud/water/land) (0=no, 1=yes, 2=hcw + quality file)
line 12 water vapor threshold to switch off the cirrus algorithm, unit [cm]
line 13 define saturation with factor b: DN (saturated) ≥ b DN (max), b=0.9 to 1.
line 14 include non-linear influence of vegetation in water vapor calculation (yes/no)
Only for water vapor retrieval with regressein (iwv model=2)
line 15 start/stop wavelengths for interpolation in the 940 nm region
line 16 start/stop wavelengths for interpolation in the 1130 nm region
line 17 start/stop wavelengths for interpolation in the 1400 nm region
line 18 start/stop wavelengths for interpolation in the 1900 nm region
line 19 haze/sun glint over water: (apparent) NIR reflectance T1 (clear), T2 (haze)
line 20 reduce over/under-correction in cast shadow (0=no, 1=yes)
line 21 adapt path radiance for blue bands (visib > 0, no DDV pixels) (0=no, 1=yes)

Note on the non-linear influence of vegetation in water vapor calculations:


This option applies to the APDA-regression algorithm and only if the 940 nm region is selected
for the water vapor retrieval. The retrieval is based on a linear interpolation across the absorption
region, and errors can occur due to the non-linear behavior of the reflectance of vegetated surfaces
in this region. A simple empirical correction to the water vapor map W is applied using the NDVI
CHAPTER 9. IMPLEMENTATION REFERENCE AND SENSOR SPECIFICS 179

calculated with the apparent reflectances in the red/NIR channels:

W (new) = W (old) − 0.1 (N DV I/0.7) (cm) (9.2)

The correction is only performed for pixels with N DV I ≥ 0.25 and values N DV I > 0.7 are reset
to 0.7.

Note on cut-off limit for surface reflectance


The default limit is set to a high value (150% reflectance) to avoid a truncation in spectra of high
reflectance surfaces, e.g. snow and/or surfaces with specular reflectance. The previous default
cut-off (before 2012) was set to 90%.

Note on factor b:
Factor b is a relative saturation factor applied to the maximum radiometric encoding, e.g. for 8
bit data and b=1 all pixels with DN=255 will be marked as saturated in the ” out hcw.bsq” file
(color coding: red). Setting b=0.9 implies pixels with DN > 230 will be considered as saturated
or in the non-linear radiometric range close to saturation. This factor is only used for 8 and 16 bit
(signed or unsigned) data, not for float or 32 bit data.

Note on the cloud mask:


The criterion (a1) or (a2) is also coupled with the conditions:
ρ∗ (N IR)/ρ∗ (red) < 2 and ρ∗ (N IR)/ρ∗ (SW IR1) > 1 and N DSI < 0.7,
where NDSI is the normalized difference snow index. A quality or probability mask for clouds
is generated with the above three conditions and different apparent reflectance thresholds Tc in
the blue/green spectral region. For Tc = 15% we define a low probability cloud, Tc = 25% a
medium probability, and Tc = 35% a high probability cloud. The result is put into a cloud map
file named ”image quality.bsq” if the input scene is named ”image.bsq”. The cloud mask in the
”image out hcw.bsq” file is based on the user-defined threshold Tc (in the preference parameter
file) and the above three conditions.

The band interpolation options are only intended for hyperspectral imagery. Linear interpolation
is employed in the 760, 725, and 825 nm regions. Non-linear interpolation as a function of the veg-
etation index is applied in the 940 and 1130 nm parts of the spectrum to account for the leaf water
content in plants. nterpolation in the strong atmospheric water vapor absorption regions around
1400 nm and 1900 nm is recommended because of the low signal and large influence of sensor noise.
However, interpolation can be disabled if required, i.e., for test purposes. If enabled, non-linear
interpolation is performed in the 1400 / 1900 nm regions by fitting the surface reflectance curves
with a hull of a template vegetation or soil spectrum. All interpolated channels are marked with
an ’*’ in the ENVI header of the output reflectance cube.

Haze or sunglint removal over water: the default apparent reflectance thresholds in the NIR chan-
nel for clear water and haze are T1 (clear) = 0.04 (or 4%) and T2 (haze) = 0.12 (or 12%), respec-
tively. Pixels with values less than T1 (clear) are defined as clear water, pixels with values between
the thresholds T1 (clear) and T2 (haze) are assigned as haze (or sun glint). A lower value (i.e.,
T1 (clear) < 0.04) can be can be specified, but might cause a wrong classification of bright coastal
water (sandy bottoms and bleached coral waters). If the threshold T1 (clear) is too high, haze pixels
might erroneously be put into the clear water category.
CHAPTER 9. IMPLEMENTATION REFERENCE AND SENSOR SPECIFICS 180

Cast shadow areas (mountainous terrain): these may contain over- and/or undercorrected pixels
during the standard empirical BRDF correction. A reduction of these pixels is tried with the
following steps:

• bright pixels in the NIR with DN > DN (mean) − σ, σ=standard deviation, are removed
from the list of shadow pixels.

• a 7 x 7 pixel convolution filter is being applied to the shadow mask.

• a transition region shadow/sunlit is introduced.

• already dark pixels (DN < DN (mean) − σ in the NIR) are not reduced in brightness during
BRDF correction. The threshold is evaluated for a NIR channel, but the non-reduction of
brightness (reflectance) is applied to all channels.

Note on ”adapt path radiance for blue bands”


This flag is set to 1 (enabled) as a default. It is only used if the option of constant scene visibility
is selected, and if the visibility in the ”*.inn” file is positive. Then the program might change the
input visibility if negative reflectance pixels (in the red and NIR bands) occur, while a negative
visibility in the ”*.inn” file will not be changed even in case of negative surface reflectance values.
Therefore, if this flag is set and the constant (positive) visibility is selected, the following steps are
executed:

• Iteratively increase the visibility in the shortest wavelength blue band (up to vis=120 km),
if negative surface reflectance pixels occur.

• Re-scale the path radiance using the shortest blue band and the red band (0.66 µm) as tie
bands, using exponential interpolation.

• If no negative surface reflectance pixels occur (in the shortest blue band, for the selected
input visibility) then search for dark pixels with (N DV I > 0.4, ρ(N IR) > 0.1).

• If the percentage of dark pixels is less than 4% of the scene, then terminate, else continue:

• Calculate the surface reflectance ρ(blue) and ρ(red) for these dark pixels.

• If ρ(blue, average) > ρ(red, average) then increase the visibility iteratively (until vis=120
km).

• Re-scale the path radiance with the final visibility using the shortest blue band and the red
band (0.66 µm) as tie bands, using exponential interpolation.

9.4 Job control parameters of the ”inn” file


If the file name of the input image is ”example image.bsq” then a file ”example image.inn” is created
during the interactive ATCOR session. When all image processing parameters have been defined
by the user this ”inn” file is written to the directory of the corresponding image. When the image
is re-loaded during a later session, or when a batch job is submitted, all input parameters are read
from this file. It is suggested not to edit this file, because it might create inconsistent input data.
The file might contain empty lines when input is not required for a specific case. The IDL routine
for writing this file is available on request for users who want to run ATCOR batch jobs without
CHAPTER 9. IMPLEMENTATION REFERENCE AND SENSOR SPECIFICS 181

employing the interactive GUI panels. The contents of an ”inn” file are:

line 1 :
20/08/1989 Date (dd/mm/year) i.e., 20/08/1989 occupies the first 10 columns.

line 2 :
100.0 ; scale factor reflectance (0-100% range)

The default reflectance scale factor in the output file is s=100 for 16 bit data and s=4 for 8 bit
data, i.e. a reflectance value of say 21.75% is coded as 2175 and 87 for s=100 and s=4, respectively.
For 8 bit input data and s=4 reflectance values above 63.75% are truncated at 255. If higher values
are expected, a scale factor of s=100 should be selected. For s=1 the output file will be coded as
32 bit (float) data requiring twice the disk storage as for s=100. With s > 0, negative reflectance
values are truncated to 0. With s=-100 or s=-1 the negative values are not truncated. This option
may sometimes be useful to identify areas in the scene where overcorrection exists. This is usually
caused by a too low visibility or in shadow areas.

line 3 :
5.0 ; pixel size [m]

line 4 :
landsat4 5, Landsat-4/5 TM,
sub-directory ”../atcor2+3/cal/landsat4 5”, sensor text as defined in ”../atcor2+3/bin/sensor.dat”

line 5 :
1.0 ; gain setting
Any positive value is accepted, this gain setting g is used to replace the c1 in the corresponding
”.cal” file with c1 /g, where g is the same for all channels.

line 6 :
calfile ; calibration file name

line 7 :
0.9500, 0 ; iemiss, dem unit (surface emissivity, DEM height unit)

iemiss = surface emissivity option or value, disregarded if no thermal band exists.

iemiss = 0 invokes  = 0.98 to be consistent with the definition of earlier ATCOR versions.
Since iemiss=1 is reserved for the cover-dependent emissivity setting below, =1.0 has to be ap-
proximated as iemiss=0.999 or iemiss=0.9999.
In case of multiple thermal bands this  holds for the thermal band itemp band employed for the
surface temperature evaluation, see chapter 4.6.

iemiss = 1 : fixed values of surface emissivity = 0.98 (water), 0.97 (vegetation), 0.96 (soil).
iemiss = 2 : same as iemiss=3, (the iemiss=2 option of ATCOR4 is not supported here).
iemiss = 3 : NEM or ANEM method, requires multiple thermal bands, see chapter 10.1.5.
iemiss = 4 : ISAC method, requires multiple thermal bands, see chapter 10.1.5.
iemiss = 5 : both NEM and ISAC, but ISAC is currently only supported for flat terrain imagery.
CHAPTER 9. IMPLEMENTATION REFERENCE AND SENSOR SPECIFICS 182

dem unit : 0 = [m], 1 = [dm], 2 = [cm] DEM height unit

line 8 :
fele ; DEM elevation file name (empty line for a flat terrain calculation)

line 9 :
fslp ; DEM slope file name (empty line for a flat terrain calculation)

line 10 :
fasp ; DEM aspect file name (empty line for a flat terrain calculation)

line 11 :
fsky ; DEM skyview file name (empty line for a flat terrain calculation)

line 12 :
fshd ; DEM cast shadow file name (empty line for a flat terrain calculation, rugged terrain: empty
if calculated ”on-the-fly”)

line 13 :
atmfile ; atmospheric LUT file name (reflective region)

• If the automatic aerosol type retrieval is intended for batch jobs, the usual aerosol identifier in
the file name (e.g. ’rura’) has to be replaced with ’auto’. Example: file name (without path) is
’aamsrura.atm’, replace it with ’aamsauto.atm’. The program then uses all aerosol types for
the ’ms’ = mid-latitude summer atmosphere in the aerosol type estimate, and selects the one
with the closest match, compare chapter 10.5.2. In the example of the ’ms’ case four aerosol
types (rural, urban, maritime, desert) are checked. In case of the ’tr’ = tropical atmosphere,
only three aerosol types (rural, urban, maritime) will be found in the atmospheric library.
The automatic aerosol type retrieval requires the parameter npref=1 (variable visibility, see
line 20 below). If npref=0, it is reset to npref=1.
In the interactive mode the user can just press the ’Aerosol Type’ button on ATCOR’s main
panel to execute the aerosol type retrieval, irrespective of the ’*.atm’ name in the ’.inn’ file.

line 14 :
temfile ; atmospheric LUT file name (thermal region, empty if no thermal band)

line 15 :
1.0 ; adjacency range [km]

line 16 :
35.0 ; visibility [km]

line 17 :
0.7 ; mean ground elevation ([km asl] not used in case of rugged terrain, where elevation file applies

line 18 :
33.0, 178.0 ; solar zenith, solar azimuth angle [degr.]
CHAPTER 9. IMPLEMENTATION REFERENCE AND SENSOR SPECIFICS 183

line 19 :
10.0, 150.0 ; off-nadir sensor (earth) incidence angle , sensor view azimuth angle [degr.]
For nadir-looking sensors the tilt / incidence angle is zero and the view azimuth is an arbitrary value.

line 20 :
0, 0, 1, 0, 0, 0, 1 ; npref, iwaterwv, ihaze, iwat shd, ksolflux, ishadow, icl shadow
seven parameters controlling the processing options:
npref = 0 : constant visibility
npref = 1 : variable visibility, based on dark reference areas in the scene
npref =-1 : variable visibility for each sub-image during batch job with tiling
iwaterwv = 0 : no water vapor correction or no water vapor bands available
iwaterwv = 1 : water vapor correction using bands in the 940 nm region
iwaterwv = 2 : water vapor correction using bands in the 1130 nm region
iwaterwv = 3 : 940 and 1130 nm bands are employed

• Haze removal with the HOT method is enabled by setting the parameter ihaze>0, no haze
removal is specified with ihaze=0. Separate parameter values define haze removal over land,
haze/sunglint removal over water, and the combination. Some criteria exist to check whether
the haze/land removal is likely to yield good results. The haze/land algorithm is switched
off if those criteria are not passed (ihaze=1 ). However, as these criteria might fail in certain
cases, there is the option of setting ihaze=-1 which enforces the haze removal disregarding
the termination criteria. The parameter ihaze enables the HOT haze removal. Better results
are usually obtained with the HTM method to be used as a preprocessing step, see chapter
10.6.2.

ihaze =0 : no haze correction


ihaze =1 : haze/land correction, might be switched off if quality check criteria are not passed
ihaze =2 : haze over water removal (requires clear water pixels)
ihaze =3 : haze/land and haze/water removal
ihaze =4 : sun glint removal over water
ihaze =-1 : haze/land correction is executed disregarding quality checks
ihaze =-2 : is treated as ihaze=2
ihaze =-3 : haze/land removal is forced, haze/water removal needs clear water pixels

Haze removal is performed for the visible bands, sun glint removal for all bands.

iwat shd = 0 : water pixels are excluded from de-shadowing (land), default
iwat shd = 1 : water pixels are included in de-shadowing (land)
The option iwat shd = 1 might be useful if the internal water classification based on purely spectral
critera fails, and dark land pixels are classified as water (which is excluded from de-shadowing).
So this flag is only used if the de-shadowing option is set and if no external water map is supplied.
Example: scene is ”image1.bsq”, and a file ”image1 water map.bsq” or ”image1 hcw.bsq” exist in
the same folder, then the flag iwat shd is ignored because an external water map always has the
first priority.

ksolflux = 0 : file with value added channels not calculated


CHAPTER 9. IMPLEMENTATION REFERENCE AND SENSOR SPECIFICS 184

ksolflux = 1 : value added channels are calculated (*.flx file)

ishadow = 0 and fshd=” (empty string): no DEM cast shadow map is used
ishadow = 0 and fshd=”valid file name”: pre-calculated DEM cast shadow file is used
ishadow = 1 : DEM cast shadow mask is calculated ”on-the-fly”
The pre-calculated map avoids repeated on-the-fly calculations.

icl shadow = 0 : no cloud/building shadow correction


icl shadow > 0 : cloud/building shadow correction is performed
= 1 : de-shadowed output as DN image corresponding to input DN scene
= 2 : de-shadowed output as surface reflectance image
= 3 : de-shadowed output as surface reflectance and DN image
If a float ’* ilu.bsq’ file exists in the scene folder, then the de-shadowing is performed with this
file, i.e. the matched filter algorithm is not applied. Otherwise this ’* ilu.bsq’ has to be renamed
(temporarily) if the matched filter method shall be executed.
line 21 :
0, 0.5, 0.5 : itriang, ratio red swir, ratio blu red
itriang = 0 : average vis. index of reference areas is employed for non-reference pixels
itriang = 1 : triangular interpolation of visibility index of reference areas

ratio red swir : ratio of surface reflectance of red to 2.2 µm band for the reference pixels
If no 2.2 µm band exists, but a 1.6 µm band, the ratio holds for the red-to-1.6 µm band.
If only VNIR bands exist (400 - 1000 nm) the ratio holds for the red-to-NIR band.
ratio blu red : ratio of surface reflectance of blue band to red band for the reference pixels.

line 22 :
0, 65.0, 0.25 ; ibrdf, beta thr, thr g, parameters for BRDF correction in rugged terrain
For a flat terrain, these parameters are not used.

• ibrdf = 0 : no empirical BRDF correction (or flat terrain)

• ibrdf = 1 : correction with cosine of local solar zenith angle (eq. 10.127 with b=1)

• ibrdf = 2 : correction with sqrt(cos) of local solar zenith angle (eq. 10.127 with b=1/2)

• ibrdf = 11 : correction with cosine of local solar zenith angle (eq. 10.127 with b=1), for
soil/sand. Vegetation: eq. 10.127 with exponent b=3/4 and b=1/3 for λ < 720 nm and λ >
720 nm, respectively, i.e., option (a) in the BRDF panel, see Figure 5.47 (”weak” correction),

• ibrdf = 12 : correction with cosine of local solar zenith angle (eq. 10.127 with b=1), for
soil/sand. Vegetation: eq. 10.127 with exponent b=3/4 and b=1 for λ < 720 nm and
λ > 720 nm, respectively, i.e., option (b) in the BRDF panel, see Figure 5.47 (”strong”
correction),

• ibrdf = 21 : correction with sqrt(cos) of local solar zenith angle (eq. 10.127 with b=1/2),
for soil/sand. Vegetation: eq. 10.127 with exponent b=3/4 and b=1/3 for λ < 720 nm
and λ > 720 nm, respectively, i.e., option (a) in the BRDF panel, see Figure 5.47 (”weak”
correction). This is the recommended standard yielding good results in most cases.
CHAPTER 9. IMPLEMENTATION REFERENCE AND SENSOR SPECIFICS 185

• ibrdf = 22 : correction with sqrt(cos) of local solar zenith angle (eq. 10.127 with b=1/2), for
soil/sand. Vegetation: eq. 10.127 with exponent b=3/4 and b=1 for λ < 720 nm and λ > 720
nm, respectively, i.e., option (b) in the BRDF panel, see Figure 5.47 (”strong” correction).

• beta thr : threshold local solar illumination angle βT where BRDF correction starts. If
beta thr=0 (and ibrdf > 0) then the angle βT is calculated in ATCOR depending on the
solar zenith angle and its value can be found in the corresponding ”* atm.log” file.

• thr g : g, lower boundary of BRDF correction factor, see chapter 10.7.2, eq. (10.127, 10.128).

line 23 :
1, 0.820, 0.780, 0.600 ; lai model, a0 vi, a1 vi, a2 vi
Parameters for the LAI model to be used if ksolflux > 0, see chapter 7

line 24 :
0.900, 0.950, 0.380 ; c fpar, a fpar, b fpar
parameters for the fpar model to be used if ksolflux > 0, see chapter 7

line 25 :
20.0, 0.83 ; air temperature (C), air emissivity, see chapter 7
Parameters for the net flux calculation (used for flat terrain, ignored for rugged terrain)

line 26 :
20.0, 0.50, 0.65, 15.0, 6.3 ; t air, z0 ref, tgradient, p wv, zh pwv, see chapter 7
t air : air temperature (Celsius) at elevation z0 ref
z0 ref : reference elevation for t air [km asl]
tgradient : air temperature gradients (Celsius per 100 m height)
p wv : ([mb or hPa], default, water vapor partial pressure at z0 ref)
zh pwv : ([km], scale height of water vapor, exponential decrease falls to 1/e value)
Parameters for the net flux calculation (rugged terrain, ksolflux > 0)
These are dummy values (not used) if ksolflux=0, or for a flat terrain.

line 27 :
2, 2 ; ihot mask, ihot dynr , parameters for haze correction
ihot mask = 1 : small area haze mask
ihot mask = 2 : large area haze mask
ihot dynr = 1 : thin to medium haze levels are corrected
ihot dynr = 2 : thin to thick haze levels are corrected

line 28 :
2, -0.500, 0.12, 0.08, 1 ; iclshad mask, thr shad, phi unscl max, phi scl min, istretch type
Parameters for correction of cloud/building shadow effects, if icl shadow > 0
Default values are put in this line even if icl shadow=0
iclshad mask = 1,2,3 : small, medium, large cloud shadow mask
thr shad = -0.500 : threshold for core shadow areas, -999 means threshold is calculated from image
histogram
phi unscl max : max of unscaled shadow function Φmax , see chapters 2.4, 10.6.6.
phi scl min : min of scaled shadow function Φ∗min , see chapters 2.4, 10.6.6.
istretch type: 1=linear stretching, 2=exponential stretching of Φ into Φ∗ .
CHAPTER 9. IMPLEMENTATION REFERENCE AND SENSOR SPECIFICS 186

line 29 :
ch940(1:6) vector with 6 channel numbers for the 940 nm water vapor retrieval
ch940(1) : left window channel (850 - 890 nm)
ch940(2) : right window channel (850 - 890 nm)
ch940(3) : left absorption channel (920 - 970 nm)
ch940(4) : right absorption channel (920 - 970 nm)
ch940(5) : left window channel (1000 - 1040 nm)
ch940(6) : right window channel (1000 - 1040 nm)
The left and right channel numbers for each window or absorption region may be the same. Put
in a zero channel number if not applicable. If the 820 nm water vapor region is selected the vector
ch940 holds the corresponding window and absorption channels for this region.

line 30 :
ch1130(1:6) vector with 6 channel numbers for the 1130 nm water vapor retrieval
ch1130(1) : left window channel (1050 - 1090 nm)
ch1130(2) : right window channel (1050 - 1090 nm)
ch1130(3) : left absorption channel (1110 - 1155 nm)
ch1130(4) : right absorption channel (1110 - 1155 nm)
ch1130(5) : left window channel (1200 - 1250 nm)
ch1130(6) : right window channel (1200 - 1250 nm)
The left and right channel numbers for each window or absorption region may be the same. Put
in a zero channel number if not applicable.

line 31 :
chth w1, chth a1, chth a2, chth w2 bands for thermal water vapor retrieval (10 - 12 µm)
chth w1 : left window channel (SWCVR method, see chapter 10.1.5)
chth w2 : right window channel
chth a1 : left absorption channel
chth a2 : right absorption channel

line 32 :
e water, e veget, e soil, e sand surface emissivities (adjusted NEM, channel with Tmax)

line 33 :
0 iwv model (water vapor retrieval: 1=no band regression, 2=band regression)
The choice iwv model = 0 indicates the water vapor retrieval is disabled. Option 1 means the water
vapor retrieval is performed for the selected bands, and in case of several measurement bands the
one with the smallest standard deviation is selected (per 940 and 1130 nm region). Finally, if both
regions are active, the average of the water vapor maps of both regions is taken. Option 2 employs
a linear regression of bands which yields better results for the water vapor map if the data is noisy
or not accurately calibrated. If iwv model = 2 and channels in the 940 nm and 1130 nm regions
are specified, then only the 940 nm region is evaluated with a linear regression of bands. If the
regression is intended for the 1130 nm region, then the 940 nm channels (all channels in line 29)
have to be specified as 0.

line 34 :
0 icirrus ozone flag for cirrus removal (0=disabled, 1=enabled, -1=forced)
CHAPTER 9. IMPLEMENTATION REFERENCE AND SENSOR SPECIFICS 187

ozone is the ozone content (DU = Dobson Units), ozone=331 if not specified.
The value icirrus = -1 enforces cirrus detection and removal, i.e., termination criteria are ignored.

line 35 :
0 irrad0 flag for solar flux on ground (0=disabled, 1=enabled)
For irrad0=2 the surface reflected (leaving) radiance is calculated additionally.
For a flat terrain, ASCII spectra of the direct, diffuse, and global flux on the ground are provided in
the folder of the input scene, see chapter 10.1.4. In case of a flat terrain the global (i.e. direct plus
diffuse) flux image is calculated. For a rugged terrain the images of the direct and diffuse fluxes are
calculated. Note: as the flux files have to use a float encoding (32bits/pixel) the file size is twice
or four times the size of the input scene for a 16bit/pixel and 8bit/pixel input scene, respectively.

Lines 36 - 39 are optional and specify the solar and view angle at the imge corners in case of wide
field-of-view scenes for upper left (UL), upper right (UR), lower left (LL) and lower right (LR).
line 36 :
UL UR LL LR solar zenith angles (degrees)

line 37 :
UL UR LL LR solar azimuth angles (degrees)

line 38 :
UL UR LL LR view zenith angles (degrees)

line 39 :
UL UR LL LR view azimuth angles (degrees)

Notice concerning visibility iterations:


ATCOR will automatically iterate the initial visibility (parameter visib set in the ’.inn’ file) if the
number of negative reflectance pixels is larger than 1% of the scene for the red band (around 650
nm, vegetation is checked here) or the NIR band (around 850 nm, water is checked here). The
specified visibility is always kept if the visibility is set to a negative value, i.e., visib=-20 means the
program performs the calculation with visib=20 km and does not iterate even if a large number of
negative reflectance pixels occurs.

If the parameter npref is set to 1 the program computes the visibility map based on dark reference
pixels in the scene and npref=1 overwrites the initial value of the visib parameter. With npref=1
the program still iterates the average visibility of the visibility map by checking for water pixels
in the NIR band unless the specified visib is negative. A constant scene visibility is employed for
npref=0. In case of scene tiling and npref=0 or npref=1 the iterated visibility obtained for sub-
scene 1 is also applied to all other sub-scenes to avoid brightness steps for the merged sub-scenes
caused by potentially different visibilities.
Attention : If scene tiling has to be performed and the aerosol map is requested for each sub-
image then specify npref=-1, but this could cause different average visibilities in the sub-scenes
and potentially brightness steps at the sub-scene borders.

9.5 Problems and Hints


Some often encountered problems and tips to come around are listed here.
CHAPTER 9. IMPLEMENTATION REFERENCE AND SENSOR SPECIFICS 188

• Distinction of haze and cloud, when can the haze removal algorithm be applied ?
Ground surface information under haze areas can still be recognized in the 600-900 nm region,
but the brightness contrast is low. The haze removal is only applied for channels in the 400 -
800 nm region. However, for cloud areas no ground information can be observed. If in doubt
whether a certain area should be assessed as haze or cloud covered, take a look at the scene
in the NIR (around 850 nm) channel: if surface features can be seen in this area, the haze
algorithm might be applied. If not, the area is cloud covered and a haze removal run will not
be successful.

• The cloud mask is not appropiate.


The cloud mask might contain too few pixels: then decrease the cloud reflectance threshold
in the ../atcor/preferences/preference parameters.dat file. The default threshold is 25% re-
flectance in the blue-green spectrum. The opposite case can also happen: if the cloud mask
comprises too many pixels the threshold has to be raised.

• The haze mask is not appropiate.


This problem may be connected with the setting of the cloud threshold. If the cloud threshold
is too high, cloud pixels are counted as haze, and the results of the haze removal are bad
because the haze algorithm is applied to clouds.

• The water mask is not appropiate.


This might lead to problems for the haze removal as well as the cloud/building shadow re-
moval, i.e., water is erroneously counted as land and included in the land mask. Enable
the output of a haze/cloud/water map, compare Fig. 4.15, to check the water mask. Read
chapter 4.8. If necessary, modify the NIR/SWIR1 reflectance thresholds for water, an in-
crease/decrease of the thresholds will increase/decrease the number of water pixels.

• Rugged terrain: the slope and illumination maps show strong horizontal and vertical stripes.
Strong artifacts in the DEM files will immediately be visible in the atmospherically / topo-
graphically corrected surface reflectance image. This problem frequently occurs for resampled
DEMs, e.g. the original DEM resolution is 30 m, which is resampled to a 5 m pixel size. Ar-
tifacts will be enhanced, especially if the stepsize of the original DEM (height resolution) is
coded as integer. Float data would have smoother transitions. A simple way to get better
results is the use of a larger kernel size for the slope/aspect calculation, e.g., kernel=5 or
kernel=7 instead of the default kernel=3 (pixels), but this approach causes a reduction of the
high frequency spatial information.
Attention: in addition to using float data before resampling, it is recommended to calcu-
late the slope/aspect maps on the original (coarse spatial resolution) data, followed by the
high-resolution resampling step for all DEM files (elevation, slope, aspect). Do not employ
the sequence of resampling the elevation, followed by a slope/aspect calculation of the high-
resolution elevation map, because this approach enhances artifacts!
Steps to reduce slope/aspect striping:

1. FLOAT(ELEVATION file) (if it is stored as integer)


2. Calculate SLOPE (and also ASPECT) with a low pass filter of 5x5 pixels
3. Resize SLOPE (ASPECT) file: factor 4 larger
4. Apply a lowpass filter (7x7 pixels)
5. Resize with factor 0.25 using nearest neigbor to obtain the original size.
CHAPTER 9. IMPLEMENTATION REFERENCE AND SENSOR SPECIFICS 189

Note that the function DEM Smoothing (chap. 5.3.10) allows an efficient DEM smoothing.

• Landsat and ASTER thermal band processing.


The thermal band(s) are sensitive to the atmospheric water vapor column. However, the
thermal band atmospheric LUTs (US-standard, mid-latitude summer, tropical etc) only pro-
vide a discrete set of water vapor columns (u), see chapter A. If the nearest u value from this
set deviates more than 0.2-0.3 cm from measured data (e.g. radiosonde profile) the user may
generate a new thermal LUT with a water vapor column u as a linear combination of two
existing LUTS with water vapor contents u1 and u2 : u = w1 u1 + (1 − w1 ) u2 . Example:
u = 2.4 cm, u1 = 2.08 cm (subarctic summer), u2 = 2.92 cm (mid-latitude summer), then
w1 = (u2 − u)/(u2 − u1 ) = 0.619. This manipulation can be performed in the SPECTRA
module after pressing the button ”Mixing of Atmospheres”. There, the user has to select two
existing atmospheric files, defines the weight w1 , and assigns a file name to the new mixed
LUTs. This file can be loaded from the main ATCOR panel.
If no atmospheric water vapor information is available, but lake temperature measurements
exist, the user can define an appropriate temperature offset k0 to match the satellite-derived
temperature and the water body temperature. The corresponding panel (”Surface Radiance
to Temperature Conversion”) pops up when the SPECTRA module or the image processing
options are entered.

9.6 Supported sensors without import function


ATCOR facilitates the import of sensors often processed by our customers, see the next section.
The import reads the satellite data provider-specific meta file, extracts the required data for the
ATCOR input and radiometric calibration (the ’*.inn’ and ’*.cal’ files), and starts the atmospheric
correction.
For a number of sensors there is a ’Read Sensor Meta Data’ (see chapter 9.8) extracting the required
information for the ’*.inn’ and ’*.cal’ files without initiating the atmospheric correction. However,
there are also sensors supported by ATCOR with no import or meta data reader function. This
may be due to the fact that very few customers process imagery of this sensor, due to missing infor-
mation (e.g. about the radiometric calibration), or due to frequent changes in the meta data format.

Depending on customer requirement we usually support a new sensor very quickly, first without
import/ meta file reader, and then it is the customer obligation to provide the required information
for the ATCOR processing. Therefore, the latest list of supported sensors can be found by starting
ATCOR and checking the sensor list. The manual is only updated once a year and may not contain
the full list of sensors.

But we can include the import function for a certain sensor on request, if the data provider delivers
a meta file with the required information.

9.7 Import for standard sensors


For selected standard sensors there is an import module which reads the meta file information and
converts the native format (geotiff: ’.tif’, ’*.TIF’; and jpeg2000: ’.jp2’, ’.JP2’) into an ENVI band
sequential (’bsq’) format. It is available with a GUI (Graphical User Interface) on ATCOR’s main
panel (use ’File’, ’Import’). Currently, the following sensors are supported:
CHAPTER 9. IMPLEMENTATION REFERENCE AND SENSOR SPECIFICS 190

• Landsat-4/5, Landsat-7, Landsat-8

• Sentinel-2

• DMC (Disaster Monitoring Constellation)

• RapidEye

• SPOT-4 to SPOT-7

• Planet (4 bands, GeoTIFF)

• Pleiades

• Worldview-2

The import function creates:

• an ENVI bsq file with all channels

• the radiometric calibration file (’.cal’)

• the input parameter file (’.inn’)

Then ATCOR can be started in case of a flat terrain. For a rugged terrain, the user has to supply
the DEM file and resample it for the respective scene (use ’Topographic’, ’DEM Preparation’ on the
main panel of ATCOR). The corresponding topographic files (elevation ’* ele.bsq’, slope ’* slp.bsq’,
aspect ’* asp.bsq’, and the optional skyview ’* sky.bsq’) then have to be included in the ’.inn’ file
using the ATCOR3 GUI.

The other possibility is a fully automatic batch processing. For a rugged terrain, the user has to
provide the DEM file. Input to the batch processor is the file name of the input scene (’.tif’, ’.jp2’,
or ’.bsq’) and optionally the DEM file name. If the DEM file is specified, it is resampled to fit
the scene, and the corresponding topographic files are calculated. If the DEM file is specified then
ATCOR-3 is invoked else ATCOR-2. The sensor-specific modules for batch processing are:

• dmc batch for DMC

• landsat5 batch (also applies to Landsat4 TM), landsat7 batch, landsat8 batch

• pla batch for Planet (4 bands)

• ple batch for Pleiades

• re batch for RapidEye

• spot batch for SPOT-4 to SPOT-7 (the SPOT mission ID is taken from the metafile)

• s2 batch for Sentinel2

• wv2 batch for Worldview-2

• pla batch for Planet Labs 4-bands (16 bit data)

• triple batch for TripleSat


CHAPTER 9. IMPLEMENTATION REFERENCE AND SENSOR SPECIFICS 191

When typing the name of the batch module without any parameter, the optional keywords are
displayed, e.g. the average scene ground elevation ’gndele’ (default gndele=0, i.e., sea level) or ’dh’
for dehazing. If the dehazing keyword is set, then the haze removal is performed as the first step
(with the original DN scene) followed by atmospheric correction.

The Landsat batch modules with all parameters are:


• landsat5 batch, filename [, demfile, gndele=gndele, thermal=thermal, dh=dh, ntx=ntx, nty=nty]
’demfile’ is the optional DEM (elevation) file overlapping the scene (tif or bsq file). It will
be resized and resampled to match the scene. If demfile is not specified, then a flat terrain
is assumed. In this case, the scene-average ground elevation can be specified (km), e.g. gn-
dele=0.58. If demfile and gndele are not specified, then gndele = 0 is assumed (sea level).
’filename’ is the Landsat-5 ’* B1.TIF’ (also works for Landsat-4 data).
If the keyword thermal=1 or /thermal is not specified, then the thermal band is excluded.
Setting keyword dh=1 includes a dehazing prior to the ATCOR run. The keywords ntx, nty
can be used for tiling a very large scene into ntx*nty tiles during processing. Finally all tiles
are merged.

• landsat7 batch, filename [, demfile, gndele=gndele, thermal=thermal, dh=dh, ntx=ntx, nty=nty]


This is similar to the landsat5 batch. If keyword thermal=1 is set, the low gain thermal band
B61 is taken.
• landsat8 batch, filename [, demfile, gndele=gndele, oli=oli, dh=dh, ntx=ntx, nty=nty]
This is similar to the landsat7 batch, filename. If keyword oli=1 is set, then the thermal
TIRS bands are not included.
The Sentinel-2 batch module with its parameters is:
• s2 batch, filename [, demfile, gndele=gndele, dh=dh, i20m=i20m
The parameters are similar to the previous module, but filename is the ’*B01.jp2’, i.e. the file
name of the first Sentinel-2 band in the ’*GRANULE*IMG DATA’ folder. A 13-band TOA
radiance cube is calculated (all bands at 20 m) and a 4-band TOA radiance cube with the
original 10m bands. If keyword i20m=1 is set, then atmospheric correction is only performed
for the 20 m bands.
This module provides:
– layer-stacked ENVI TOA reflectance cubes at 20 m and 10 m.
– layer-stacked ENVI TOA radiance cubes at 20 m and 10 m.
– reading of the meta data, creating the ’*.inn’ and ’*.cal’ files for ATCOR.
– optional dehazing prior to atmospheric correction (keyword dh=1)..
– atmospheric correction.
The SPOT batch module supports SPOT-4 to SPOT-7 imagery:
• spot batch, filename [, demfile, gndele=gndele, dh=dh, ntx=ntx, nty=nty]
The parameters are similar to the ones described above. The input filename can have a TIF
or JP2 (JPEG2000) or ENVI band sequential (bsq) format.
The remaining batch modules (DMC, RapidEye, Worldview-2) have the same parameters as for
SPOT.
CHAPTER 9. IMPLEMENTATION REFERENCE AND SENSOR SPECIFICS 192

9.8 Metadata files (geometry and calibration)


This section explains how the geometry and calibration information of various sensor-specific meta-
data files has to be interpreted for use in ATCOR. Besides the atmospheric LUTs for the nadir view,
there are files for off-nadir view geometries covering incidence angles from 0◦ to 50◦ (increment 10◦ )
and relative azimuth angles from 0◦ (backscatter) to 180◦ (forward scatter) with an increment of
30◦ , the ”phase fct*.bin” files in the ATCOR directory. A corresponding incidence/azimuth angle
interpolation of the LUTs is automatically done.

The meta data for a selected number of pre-defined multispectral sensors can also be read from the
ATCOR main panel: ’File’, ’Read Sensor Meta Data’, which creates the corresponding ”.cal” and
”.inn” files, using some default atmospheric parameters for the latter file and setting the average
scene elevation at sea level. These can later be updated in the corresponding widgets of the ATCOR
panel. The meta file reader can also be invoked as a batch job, see chapter 6.4.

9.8.1 Import Landsat Data


Landsat-4 and Landsat-5
After unzipping the downloaded file, a set of seven TIF files is generated. An ”import” module
is available to create a corresponding layer-stacked ENVI bsq file. It can be invoked on the IDL
command line as a batch job:
landsat5 envi, tifname, [thermal=1]
Here, tifname is the complete file name of the first band ’*B1.TIF’. If the keyword ”thermal=1”
is not included, then the thermal band 6 is not included in the layer-stacked bsq file. The same
command also works for Landsat-4 TM data. One can also use ATCOR’s GUI with the sequence:
’File’, Import’, ’Landsat-4/5’ to obtain the layer-stacked ENVI bsq file. In addition, the required
’*.inn’ and ’*.cal’ files are created.

Landsat-7
For Landsat-7 ETM+ the corresponding batch module is invoked as
landsat7 envi, tifname, [thermal=1]
and the corresponding GUI sequence is ’File’, Import’, ’Landsat-7’.

Landsat-8
For Landsat-8 there are two separate batch modules, one for OLI, and one for the combination OLI
+ TIRS:
• l8 oli envi, tifname
Here, ’tifname’ is the complete name of the first band of the Landat-8 ’*.TIF’ files including
the folder. Example: l8 oli envi, ’/data1/scene B1.TIF’.
Then a layer-stacked ENVI .bsq file for the OLI bands is created (8 channels, without panchro-
matic), named ’/data1/scene OLI.bsq’.
• landsat8 envi, tifname [, oli=1]
Here, ’tifname’ is the complete name of the first band of the Landat-8 ’*.TIF’ files including
the folder. Example: landsat8 envi, ’/data1/scene B1.TIF’.
Then a layer-stacked ENVI .bsq file for the OLI+TIRS bands is created (10 channels, with-
out panchromatic), named ’/data1/scene OLI TIRS.bsq’. If the keyword oli=1 is set, then
only the 8 OLI bands (without panchromatic) are processed, and the output file name is
’/data1/scene OLI.bsq’.
CHAPTER 9. IMPLEMENTATION REFERENCE AND SENSOR SPECIFICS 193

One can also use the GUI sequence ’File’, ’Import’, ’Landsat-8 OLI’ or ’Landsat-8 OLI+TIRS’.
This ’Import’ also creates the required ’*.cal’ and ’*.inn’ files for the ATCOR processing.

9.8.2 Landsat-5 TM, Landsat-7 ETM+


The usual source of Landsat data is a download from the USGS website (glovis.usgs.gov). A scene
should be downloaded with its meta file (’* MTL.txt’). In former years there was the NLABS
processing system, which was replaced with the LPGS processing starting on December 8, 2008,
see the comprehensive article [?]. The meta file reader of ATCOR only supports LPGS processed
data.

The meta file contains the min/max radiance for each band, e.g., Lmax band1 = 191.6, Lmin band1
= -6.2, and the corresponding max/min digital numbers (Qmax, Qmin). The general equations to
convert the digital number DN into an at-sensor radiance are
L = B + G · DN (9.3)
 Lmax − Lmin 
B = Lmin − Qmin (9.4)
Qmax − Qmin
Lmax − Lmin
G= (9.5)
Qmax − Qmin

where B = bias, G = gain, and Qmin=1, Qmax=255 for the LPGS processing (the former NLAPS
used Qmin=0, Qmax=255). The radiance unit in the meta file is W m−2 sr−1 µm−1 . Since ATCOR
employs the unit mW cm−2 sr−1 µm−1 , the meta file reader multiplies the B and G values with the
factor 0.1 for the unit conversion in the ’*.cal’ file, i.e. c0 = 0.1 * B, and c1 = 0.1 * G.

For the ETM+ thermal band two files are included per scene, e.g. ”xxx nn61.tif” and ”xxx nn62.tif”,
the ”61” indicates the low gain, the ”62” indicates the high gain data. To be compatible with
Landsat-5 TM only one thermal band should be layer-stacked for ATCOR and placed at the band
6 position. The meta file reader generates the ’*.cal’ file for the ’61’ case, but the offset, gain values
(c0 , c1 ) for the ’62’ case are also given in the panel. Either one can be selected for ATCOR, but
an update (editing) of the radiometric calibration ”.cal” file is nessary for ’62’.

The module ’Read Sensor Meta File’ (ATCOR main panel, entry below ’File’) reads the USGS
LPGS meta file and extracts the necessary data for the ”.cal” and ”.inn” files. The panchromatic
band 8 is not included in the multispectral band list, again to be compatible with Landsat-5 TM.
This band has to be treated separately.

Notice: the standard negative offset values can lead to negative surface reflectances for dark targets,
therefore in these cases the magnitude of the negative offset has to be decreased, typically by a
factor 2 (ETM bands 1-4).

Note concerning Landsat-4/5 TM and non-LPGS / non-NLAPS processing :


Different formats existed in the past, depending on the international Landsat processing station
and year of processing. For this data, the radiometric calibration is varying as a function of the
day after launch, compare references [?], [?]. A file cal gain table kamstrup hansen.dat is available
on the directory ”../atcor/cal/landsat4 5” containing the gain=c1 values for 1985-2005 for bands
CHAPTER 9. IMPLEMENTATION REFERENCE AND SENSOR SPECIFICS 194

1-4 calculated with the regression equation of [?]. Other publications deviate 10 - 20% from the
Kamstrup-Hansen c1 values. However, the historical Landsat archive was re-processed with LPGS,
and it is recommended to use only this source.

9.8.3 Landsat-8
The meta data file ’*MTL.txt’ is similar to the one for Landsat-7 ETM+. However, the encoding
is 12 bits/pixel, therefore, the previous Qmax=65535 and Qmin=1 in equation 9.4. Data for the
different spectral bands is delivered as TIF files, one file per band. Band B8 is the panchromatic
band, which should not be included in the multispectral (MS) set of OLI/TIRS bands for ATCOR.
Band B9 is the cirrus band (1.38 µm), B6 is the 1.6 µm (SWIR1) channel, and B7 (is the 2.2 µm
(SWIR2) channel.
See chapter 9.8.1 how to import Landsat-8 data for ATCOR. In case of processing OLI + TIRS
data, the output of ATCOR will have 9 bands, where band 9 is the surface temperature calculated
with the split-window method (see below) and assuming an emissivity of 0.98 for the thermal bands.

9.8.4 Landsat-8 TIRS


Landsat-8 has the TIRS sensor with two thermal channels (B10, B11 with center wavelengths near
10.9, 12.1 µm, respectively). The pixel size of the data is resampled to 30 m to match the pixel
size of the OLI data. ATCOR allows the calculation of the surface temperature using the split-
window technique in combination or separately from the OLI bands. The B10, B11 data (digital
number DN) is first converted into TOA radiance L using the calibration in the meta file, i.e.
L = c0 + c1 DN . Next the TOA radiance L is converted into (TOA) blackbody temperature (see
http://landsat.usgs.gov/Landsat8 Using Product.php )
k2
Tbb = (9.6)
ln(k1 /L + 1)
where k1 , k2 for B10, B11 are included in the meta file. The employed split-window equation for
the approximate calculation of the surface temperature Ts is:

Ts = Tbb10 + 2 (Tbb10 − Tbb11 ) + 1 + Tof f set (9.7)

where Tof f set is an optional user-specified offset which is 0 if not specified. The equation (with
Tof f set = 0) holds for a surface emissivity of 0.98 in both TIRS bands, which is typical for vegetation.
Figure 9.5 shows the corresponding surface temperature error for the mid-latitude summer (MS)
and US standard atmospheres with the ground at sea level and 0.5 km above sea level. The sea
level air temperatures for the MS and US atmospheres are 294 K and 288 K, respectively. The three
curves correspond to surface temperatures 10 K below and above air temperature and same as air
temperature. The shaded areas indicate a typical range of humidity (water vapor) conditions. The
surface temperature error in the shaded regions is smaller than 0.5 K (US) and 1 K (MS). For the
MS atmosphere and water vapor columns ranging from 0.5 - 2.5 cm the error is also smaller than
0.5 K.
The surface temperature calculation independently of the OLI bands is available from the main AT-
COR GUI (’Atm. Correction’, ’Landsat-8 TIRS: surface temperature’). An optional user-specified
temperature offset can be added to match ground measurements if such data is available (e.g. lake
temperature). The calculation can also be performed in the batch mode using the command:
CHAPTER 9. IMPLEMENTATION REFERENCE AND SENSOR SPECIFICS 195

Figure 9.5: Surface temperature error depending on water vapor column (emissivity=0.98).

• tirs temp, input=’/data1/LC81920272013135LGN01 B10.TIF’

or with the offset option (example offset=-1.2 K)

• tirs temp, input=’/data1/LC81920272013135LGN01 B10.TIF’, offset=-1.2

Figure 9.6 shows the corresponding surface temperature error for the same atmospheric conditions,
but with the spectral emissivity of water. A temperature offset Tof f set = −1 has to be specified to
obtain temperature retrieval errors smaller than 0.5 K. The reason is that the spectral emissivity
of water (see Fig. 9.7) is not constant in the thermal spectral region.
The last case presents the surface temperature error for a constant emissivity of 0.95 in the spectral
region of B10 and B11, typical for asphalt, see Fig. 9.8. Here, a temperature offset of 2 K in equation
9.7 is required to keep errors smaller than 1 K in most cases in the shaded areas. Higher errors are
encountered for H=0 (sea level) if the surface temperature is 10 K below the air temperature.
CHAPTER 9. IMPLEMENTATION REFERENCE AND SENSOR SPECIFICS 196

Figure 9.6: Surface temperature error depending on water vapor column (water surface).

Figure 9.7: Spectral emissivity of water. Symbols mark the TIRS channel center wavelengths.
CHAPTER 9. IMPLEMENTATION REFERENCE AND SENSOR SPECIFICS 197

Figure 9.8: Surface temperature error depending on water vapor column (emissivity=0.95).
CHAPTER 9. IMPLEMENTATION REFERENCE AND SENSOR SPECIFICS 198

9.8.5 Import Sentinel-2


Sentinel-2 (S2) data is provided as JPEG2000 files, one file for each band. The bands represent
scaled TOA reflectance data. Since the bands have different spatial resolution (10 m, 20 m, 60 m)
the ’Import of S2’ creates two products in the folder of the JPEG2000 files:
• a 13-band ENVI BSQ file, where all bands are resampled to 20 m (”*TOA rad 20m.bsq”).
• a 4-band ENVI BSQ file with only the 10 m bands (B2, B3, B4, B8, ”TOA rad 10m.bsq”)
The original scaled TOA reflectance data is converted into scaled TOA radiance and the corre-
sponding ’*.inn’ and ’*.cal’ files are calculated. The information for the ’*.inn’ is taken from the
corresponding meta files. The TOA reflectance cubes (13 bands: ”*TOA rho 20m.bsq”, and 4
bands:”*TOA rho 10m.bsq”) are kept, but ATCOR needs only the radiance cubes.

The ’Import Sentinel-2’ can be started from the GUI (’File’, ’Import’, ’Sentinel-2’) or as a batch job
”s2imp, input=filename”, where filename is the complete file name of the first S2 band ’*B01.jp2’.
Note :
• There is a special version of ATCOR for running S2 data as batch job: ’atcor s2’. It is invoked
with ”atcor s2, input=file” where file is the complete file name of the ”*TOA rad 20m.bsq”.
This ’atcor s2’ uses angular-dependent LUTs, while the standard ATCOR employs the nadir-
based LUTs. Therefore, ’atcor s2’ has a longer execution time. A Sentinel-2 scene consists
of ’granules’, each granule has a size of 110 km × 110 km. In most cases, the variation of the
solar zenith angle and view angle per granule is smaller than 4◦ . In the angular dependent
’atcor s2’ the granule is divided into small cells of 30 km × 30 km, corresponding to angular
changes of less than 1◦ . For each cell the corresponding angular dependent radiative transfer
functions are updated from the pre-compiled atmospheric LUTs.
• Additionally, ’atcor s2’ accepts the DEM files if they are located in the scene folder, so they
do not have to be included in the ”scene.inn”.
• Also ’atcor s2’ automatically processes the 20m and 10m cubes. If a user wants to process
only the 20m cube, then the keyword ’i20m=1’ should be specified, i.e. ”atcor s2, input=file,
i20m=1”.
• If no DEM files are specified, ’atcor s2’ assumes a flat terrain with the ground elevation
(in km) specified in the ”*.inn” or with the keyword gndele. Typing atcor s2 on the IDL
command line will give the list of parameters and keywords.
• The batch program ’s2 batch’ combines the ’Import Sentinel-2’ and ’atcor s2’ steps in one
module, if the input file is the ’*B01.jp2’ of the selected granule. Typing ’s2 batch’ on the
IDL command line will yield the list of all parameters and keywords.
• A DEM (Digital Elevation Model) file name can be specified as second input parameter to
’s2 batch’ either as .TIF’ or ’.bsq’ file. The area should completely cover the area of the
specified granule. The file will be resampled and cut to the appropiate size of the 20m and
10m cubes. In addition, the required DEM slope, aspect and skyview files will be calculated.
However, the program ’atcor s2’ already requires resampled DEM files. It is sufficient to
places these into the granule folder, keeping the standard nomenclature, i.e. the elevation
file for ”scene.bsq” should be named ”scene ele.bsq” (and ”* slp.bsq”, ”* asp.bsq”). It is not
necessary to include these DEM file names in the ’*.inn’ file. But the ”normal” ATCOR3
requires that the DEM file names are specified in the ’*.inn’.
CHAPTER 9. IMPLEMENTATION REFERENCE AND SENSOR SPECIFICS 199

So there are two ways to process Sentinel-2 data:

• step 1: ’Import Sentinel-2’ converts the jp2 TOA reflectance files into a 20m layer-stacked
file and a 10m layer-stacked ENVI bsq containing TOA radiance.

• step 2: The TOA radiance files are processed with ’atcor s2’ (batch) or the GUI ”Sentinel-2
(angular dependent ATCOR)”

• steps 1 and 2 combined: ’s2 batch’

The per-granule processing can cause brightness steps in the mosaicked product. This can be
avoided by using the average visibility (aerosol optical thickness) obtained for one granule (’mas-
ter’ granule) for the other granules: reset the parameter visibility (line 16 of the ’*.inn’ file) to the
negative value of the visibility of the ’master’ granule, which is given in the corresponding ’*.log’
file (line with ’Average Visibility’).
Another possibility is to mosaic up to 4 granules of the ’* rad 20m.bsq’ files before running
’s2 batch’, ’atcor s2’, ’atcor2 batch’, or ’atcor3 batch’. This is possible with the Linux/MAC OS,
but not with Windows because of different memory handling techniques. It is not possible with
the 10m cubes, because of the huge memory requirements.

9.8.6 SPOT-1 to SPOT-5


The metadata is specified in two files, a VOL LIST.PDF and a METADATA.DIM. The first file
is intended for a quick overview, the second file contains the complete set of specifications. The
absolute calibration gains for each band can be taken from either file and should be put into the
corresponding ”.cal” file as they are. In theh METADATA.DIM i file the calibration gains are named
PHYSICAL GAIN. The SPOT unit is 1/ W m−2 sr−1 µm−1 , but it is automatically converted
into the ATCOR radiance unit. The standard offset values are zero. Occasionally however, for
SPOT-4/5 data a slightly negative offset has to be introduced for band 4 (1.6 µm) in cases when
the scene water reflectance is too high (it should be close to zero).

The geometry of data acquisition is described in the the METADATA.DIM file. The solar geometry
is specified with the solar elevation and azimuth angle. The sensor view geometry is defined by the
incidence angle θI at the earth’s surface, see Fig. 9.9. Sensor view angle and incidence angle are
related by the equation:
h RE i
θV = arcsin sin(θI ) 180/π (9.8)
RE + h
where RE = 6371 (km) is the earth radius and h=832 (km) is the SPOT orbit altitude. Exam-
ple: incidence angles of 5◦ , 10◦ , 20◦ , 30◦ correspond to view angles of 4.4◦ , 8.8◦ , 17.6◦ , and 26.2◦ ,
respectively. Conversely, if the tilt angle is given, equation 9.8 can be solved for the incidence angle.

In addition to the tilt / incidence angle the view direction with respect to the flight path is specified.
Nearly all SPOT data (99.9%) is recorded in the descending node, i.e., flying from the north pole
to the equator (indicated by a negative value of the velocity vector for the Z component in the
METADATA.DIM). Then a positive incidence (tilt) angle in METADATA.DIM means the tilt
direction is left of the flight direction (”east” for the descending node). This is indicated by an ”L”
in the incidence angle in VOL LIST.PDF, e.g. incidence angle L20.6 degree. A negative incidence
angle means the sensor is pointing to the ”west” (coded as R=right in the VOL LIST.PDF, e.g.
incidence angle R20.6 degree). For ATCOR the satellite azimuth as seen from the recorded image
CHAPTER 9. IMPLEMENTATION REFERENCE AND SENSOR SPECIFICS 200

Figure 9.9: SPOT orbit geometry.

has to be specified. If α denotes the scene orientation angle with respect to north (see Fig. 9.10)
then the satellite azimuth angle φV as viewed from the scene center is :
• φV = α + 270◦ if tilt/incidence angle is positive (L=left case, ”east”)
• φV = α + 90◦ if tilt/incidence angle is negative (R=right case, ”west”)

Figure 9.10: Solar and view geometry.

Attention:

• Tricky: The orientation angle is specified in the VOL LIST.PDF, but does not show if the
METADATA.DIM is viewed with an XML browser. However, it is included in the META-
DATA.DIM and can be found when the file is opened with an editor. On the other hand,
the view angle is not included in the VOL LIST.PDF, but is displayed with an XML browser
applied to METADATA.DIM .
CHAPTER 9. IMPLEMENTATION REFERENCE AND SENSOR SPECIFICS 201

• SPOT-4/5 imagery is usually delivered in the DIMAP format, a tif file with the band sequence
3/2/1/4, NIR/Red/Green and 1.6 µm. The wavelength increasing sequence has to be created
before offering the file to ATCOR.

Attention:
Old SPOT-2 imagery are usually distributed in the CAP format. For this old format the SPOT
leader file and the voldir.pdf indicate: ”L - instrument looks to west” and ”R - instrument looks
to east”. This is a header coding error, it is just vice versa, so interpret L = east, R = west.

9.8.7 SPOT-6, SPOT-7


SPOT-6/-7 has 4 multispectral VNIR bands (blue, green, red, NIR) with a spatial resolution of 6
m, and a panchromatic band (450-745 nm) with a 1.5 m resolution. The meta data file is in the
’*.XML’ format. It is suggested to use the ’Read Sensor Meta Data’ button to extract the necessary
information in the ’.inn’ and ’.cal’ file. If the scene is named ’scene xxx.bsq’ then the ’xxx.inn’ file
generated by the meta file reader has to be renamed as ’scene xxx.inn’ before starting ATCOR.

9.8.8 ALOS AVNIR-2


The ALOS satellite has a sun-synchronous orbit of 690 km and among other instruments carries the
AVNIR-2 optical payload. AVNIR-2 has four spectral channels (blue, green, red, NIR) with a nadir
resolution of 10 m. The instrument has a ±44◦ across-track tilt capability. Different metafiles are
available, one is in the DIMAP format. It contains the relevant geometric and radiometric parame-
ters. The convention for the tilt and orientation angles is similar to SPOT, compare Fig. 9.10, i.e.,
a tilt left (with respect to flight direction) is coded as ’L’ (tilt angle > 0), a tilt right is coded as ’R’
(tilt angle < 0). The radiometric calibration coefficients are given in the unit mW m−2 sr−1 nm−1 ,
thus they have to be multiplied with 0.1 to convert them into the unit mW cm−2 sr−1 µm−1 used
by ATCOR.

9.8.9 Ikonos
Ikonos metadata files look like ”po 3964 metadata.txt” where the po indicates the project order
and the following number the project number. The meta data include the geographic coordinates
and the solar elevation and azimuth angles. The sensor can tilt into any direction, and the satellite
geometry as viewed from the scene center is specified with :

• Nominal Collection Azimuth : absolute azimuth view angle, e.g.. east = 90◦ .

• Nominal Collection Elevation.

ATCOR’s incidence angle can be calculated from equation 9.8 with the Ikonos orbit altitude 680
km. The tilt angle is close to the ”incidence=90-elevation”, see Table 9.1.
Ikonos offers a radiometric calibration L = DN / calcoef where calcoef is specified in the in-band ra-
diance unit mW cm−2 sr−1 , see http://www.spaceimaging.com/products/ikonos/spectral.htm. For
post 22 February 2001 scenes with 11 bit data calcoef is specified as 728, 727, 949, and 843
(blue, green, red, NIR band, respectively). These values have to be converted into c1 = 1 /
(calcoef*bandwidth) and are stored in the ”ikonos 2001 std.cal” standard calibration file.
CHAPTER 9. IMPLEMENTATION REFERENCE AND SENSOR SPECIFICS 202

elevation (degree) incidence (degree) tilt (degree)


90 0 0.0
85 5 4.5
80 10 9.0
75 15 13.5
70 20 18.0
65 25 22.4
60 30 26.9
55 35 31.2

Table 9.1: Elevation and tilt angles for Ikonos.

9.8.10 Quickbird
The metadata files are named ”*.IMD”. They contain the geographic coordinates. The ”sunEl” and
”sunAz” keywords (or ”meanSunEl” and ”meanSunAz”) specify the solar elevation and azimuth
angle, respectively. Similar to Ikonos, the sensor can tilt into any direction. The satellite geometry
as viewed from the scene center is specified with ”satEl” or ”meanSatEl” (satellite elevation angle),
and ”satAz” or ”meanSatAz” (absolute azimuth angle). ATCOR’s incidence angle corresponds to
incidence = 90 - satEl . Quickbird’s orbit altitude 450 km. Depending on the processing date, the
tilt angle may also be given in the ”.IMD” file, then it is named ”offNadirViewAngle” or ”meanOff-
NadirViewAngle”. Then the incidence angle can be obtained by solving equation 9.8 for θI .

The Quickbird sensor uses the radiance unit W m−2 sr−1 (in-band radiance) which can be con-
verted into a spectral (band-average) radiance employing the effective bandwidth of each channel,
specified as ∆λ = 0.068, 0.099, 0.071, and 0.114 µm for the blue, green, red, and NIR band,
respectively (reference [?] from http://www.digitalglobe.com). The calibration is different for com-
pressed 8-bit data and the original 11-bit data. ATCOR contains a template for an 8 bit .cal file
(”quickb 8bit std.cal”) and an 11 bit file (”quickb 16bit std.cal”). However, it is recommended to
use only the 11 bit data for ATCOR. The ”.IMD” metadata file contains the absolute calibration
factor (absCalFactor) for each multispectral channel in the unit W m−2 sr−1 . Depending on pro-
cessing date, the ”effectiveBandwidth” = ∆λ (µm unit) is also included. The nominal offset is c0
= 0 in each channel, and the ATCOR gain c1 has to be specified in the unit W cm−2 sr−1 µm−1
which requires the following conversion equation for Quickbird:
absCalF actor ∗ 0.1
• c1 = ∆λ .

Therefore, the template calibration file has to be updated, i.e., copied to a new file name, and edited
according to the absCalFactor of the scene IMD file and the above spectral bandwidth values ∆λ.

9.8.11 IRS-1C/1D Liss


The metadata file contains the geographic coordinates as well as the solar elevation and azimuth
angles. It also includes the radiometric calibration coefficients, the bias B = Lmin and gain G =
Lmax in the ATCOR radiance unit mW cm−2 sr−1 µm−1 . The radiometric coefficients for ATCOR’s
”.cal” file have to be calculated as

• c0 = Lmin, and c1 = (Lmax − Lmin)/255.


CHAPTER 9. IMPLEMENTATION REFERENCE AND SENSOR SPECIFICS 203

9.8.12 IRS-P6
The IRS-P6 platform carries three optical sensors: the AWiFS (advanced wide-field-of-view sensor),
the Liss-3, and the Liss-4. AWiFS (60 m resolution) and Liss-3 (20 m) have the same spectral bands
(green, red, NIR, and SWIR1 at 1.6 µm), the LISS-4 (red band) serves as the high-resolution camera
(5 m). Similar to the IRS-1C/1D, the radiometric calibration coefficients are included in the meta
file: the bias B = Lmin and gain G = Lmax are specified in the unit mW cm−2 sr−1 µm−1 , and the
nominal value of Lmin is zero. For each sensor (AWiFS, Liss-3, Liss-4) the calibration coefficients
seem to be constant with time, i.e., independent of the scene, based on laboratory calibration. The
radiometric coefficients for ATCOR’s ”.cal” file have to be calculated as
• c0 = Lmin, and c1 = (Lmax − Lmin)/b.
where b=1023 for AWiFS (10 bit data encoding), and b=255 for Liss-3 and Liss-4 (8 bit encoding).
The analysis of a couple of scenes showed that a non-zero bias c0 is required to obtain reasonable
surface reflectance spectra. Therefore, typical average bias values are included in the standard
”*.cal” file for each sensor. A fine tuning of the calibration coefficients may be necessary to obtain
better agreement between scene-derived surface reflectance spectra and library or ground measured
spectra.

9.8.13 ASTER
ASTER has 9 reflective and 5 thermal bands. ATCOR calculates surface reflectance and a surface
(brightness) temperature (from band 13). ASTER has four gain settings (high=H, normal=N,
and low1=L1, low2=L2) for the reflective bands. Table 9.2 contains the c1 values for the different
reflective bands and gain settings in the ATCOR radiance unit mW cm−2 sr−1 µm−1 . It was taken
from the ASTER user’s guide ([?]). The thermal band 13 has a calibration gain of c1=5.693E-4.

band high gain normal gain low gain 1 low gain 2


1 0.0676 0.1688 0.225 N/A
2 0.0708 0.1415 0.189 N/A
3 0.0423 0.0862 0.115 N/A
4 0.01087 0.02174 0.0290 0.0290
5 0.00348 0.00696 0.00925 0.0409
6 0.00313 0.00625 0.00830 0.0390
7 0.00299 0.00597 0.00795 0.0332
8 0.00209 0.00417 0.00556 0.0245
9 0.00159 0.00318 0.00424 0.0265

Table 9.2: Radiometric coefficients c1 for ASTER.

9.8.14 DMC (Disaster Monitoring Constellation)


DMC is a constellation of several orbiting satellites with an optical payload intended for rapid
disaster monitoring. All DMC sensors have three spectral bands (green, red, NIR) with a spatial
resolution of 32 m and a swath of 600 km. The metadata file (*.dim and *.htm formats) pertaining
to each scene contains the solar geometry and the radiometric calibration coefficients. The bias
and gain specified in the metadata are defined as:
L = bias + DN/gain (9.9)
CHAPTER 9. IMPLEMENTATION REFERENCE AND SENSOR SPECIFICS 204

using the radiance unit W m−2 sr−1 µm−1 . Since ATCOR uses the radiance unit mW cm−2 sr−1 µm−1
and the equation

L = c0 + c1 DN (9.10)

the calibration coefficients have to be calculated as :

c0 = 0.1 ∗ bias (9.11)

c1 = 0.1/gain (9.12)

Note: analysis of some DMC data from 2007 indicates that the specified bias in the NIR band is
too high, and better results are obtained if bias(NIR) = 0 is employed.

9.8.15 RapidEye
The RapidEye constellation consists of 5 identical instruments in different orbits enabling a high
temporal revisit time for any area. The sensor has 5 multispectral bands covering the blue to NIR
region, with the specialty of a red-edge band (at 710 nm, bandwidth 40 nm). In addition, the
instruments can be tilted in the across-track direction. The nadir spatial resolution is 6.5 m. The
.xml metafile contains information on the solar elevation angle (”illuminationElevationAngle”), so-
lar azimuth (”illuminationAzimuthAngle)”, and the view geometry, i.e. the ”IncidenceAngle” and
the view azimuth (”azimuthAngle”). Over the years, different formats of the meta file were issued.

9.8.16 GeoEye-1
GeoEye-1 provides optical data with four multispectral channels in the 480 - 840 nm region with
a spatial resolution of about 1.7 m. In addition, panchromatic data with a resolution of about 0.5
m is available. The radiometric encoding is 11 bits per pixel. The metafile for each scene contains
the radiometric offset and gain values. These values are given in the same unit as used by ATCOR
(i.e. mW cm−2 sr−1 µm−1 ), so they can be directly taken, i.e.,

c1 = Gain (9.13)

The Offset = c0 is usually zero.

9.8.17 WorldView-2
WorldView-2 provides optical data with 8 multispectral channels in the VNIR region (428 - 923 nm)
at a spatial resolution of 1.8 m (nadir) with a dynamic range of 11 bits per pixel. The instrument
has selectable radiometric gain factors (”absCalFactor”) specified in the metafile (*.IMD). The
offset c0 is zero for all channels and the gain c1 for ATCOR has to be calculated as:

c1 = 0.1 AbsCalF actor / F W HM (9.14)

where FWHM is the effective bandwidth (”effectiveBandwidth” in µm) as specified in the metafile.
Although the bandwidth is constant per channel, the gain c1 might have to be updated, because
the absCalFactor can vary from scene to scene. Additionally, panchromatic images with a 0.5 m
resolution are available.
CHAPTER 9. IMPLEMENTATION REFERENCE AND SENSOR SPECIFICS 205

9.8.18 THEOS
THEOS is a satellite mission of Thailand, containing a multispectral and a panchromatic instru-
ment. The multispectral sensor has 4 channels in the visible/near infrared, similar to the first 4
bands of Landsat-5 TM, but the spatial resolution is 15 m and swath 90 km. The orbit altitude
is 826 km. The panchromatic instrument has a spectral filter curve similar to Landsat-7 ETM+
panchromatic, but the spatial resolution is 2 m and swath. The data encoding is 8 bits/pixel, the
sensor has adjustable gain settings documented in the metafile for each scene. The gain factor ’g’
is given in the unit 1/(W m−2 sr−1 µm−1 ) and it has to be converted into the gain c1 for ATCOR
according to

c1 = 0.1 /g (9.15)

where the factor 0.1 accounts for the unit (mW cm−2 sr−1 µm−1 ). The offset c0 is zero for all
channels. The metafile specifies the satellite incidence angle used for the ’*.inn’ file of ATCOR.
which can be used to calculate the off-nadir viewing angle The satellite view direction is specified
in the parameter ’satellite azimuth’.
The meta data can also be read using the ATCOR main panel: ’File’, ’Read Sensor Meta Data’,
which creates the corresponding ”.cal” and ”.inn” files, using some default values for the latter file.

9.8.19 Pleiades
The multispectral Pleiades sensor has four bands (blue, green, red, NIR) with a spatial resolution of
2 m. Pleiades-1 was launched on December 16, 2011. The mean orbit altitude is 694 km, the swath
is 20 km, the tilt angle up to 50◦ . Data encoding is 12 bits/pixel, and the sensor has adjustable
gain settings documented in the metafile for each scene. The radiometric bias and gain are defined
as L = bias + DN /gain with the radiance unit (W m−2 sr−1 µm−1 ), therefore the corresponding
ATCOR offset c0 and slope c1 values are

c0 = 0.1 · bias (9.16)

However, the nomianl bias is 0.

c1 = 0.1/gain (9.17)

Attention: Pleiades imagery is usually distributed with the band sequence (red, green, blue, NIR)
and for ATCOR the band sequence should be re-arranaged as (blue, green, red, NIR). This is
automatically done for the batch processing with module ’ple batch’.

9.8.20 Planet Labs, TripleSat


These sensors are also supported, i.e. their metafiles are read in the ATCOR GUI (’File, ’Read
Sensor Meta Data’), and a batch processing is also possible using the commands ’pla batch’ and
’triple batch’, respectively. Since we support new sensors usually shortly after a successful launch,
the complete list of sensors is always displayed in the ATCOR GUI, but the ATCOR manual
description (updated once per year) might be incomplete.
Chapter 10

Theoretical Background

Standard books on optical remote sensing contain an extensive presentation on sensors, spectral
signatures, and atmospheric effects where the interested reader is referred to (Slater 1980 [?], Asrar
1989 [?], Schowengerdt 2007 [?]). This chapter contains a description of the concepts and equations
employed for the atmospheric correction.
We start with the basic equations in the solar and thermal spectral region for clear sky conditions
(standard case), then move on to non-standard conditions comprising bidirectional reflectance
(BRDF) effects, hazy scenes, and a treatment of shadow areas caused by clouds or buildings. Stan-
dard atmospheric conditions include the option of a constant visibility (aerosol optical thickness)
and water vapor content per scene, as well as the retrieval of a visibility and water vapor map
if the required spectral bands are available for the specific sensor. Water vapor correction on a
pixel-by-pixel basis is usually necessary for hyperspectral imagery.
The section on the non-standard conditions contains a short discussion on empirical correction
methods for bidirectional effects. It continues with the description of a statistical haze removal
method. The third section presents a technique to compensate shadow effects, i.e. cloud or building
shadow areas are masked and de-shadowed. Then, an overview is presented of all major processing
steps involved in the atmospheric correction.
After atmospheric correction, the surface reflectance cube can be used for classification. A simple
automatic method is included here based on template reflectance spectra of different surface covers.
Finally, the accuracy of the atmospheric correction is discussed.

Before going into details, a brief overview of the main processing steps during atmospheric cor-
rection is described in the next two flow charts. Figure 10.1 contains a compact summary of the
main processing elements: after reading the sensor-specific LUTs a masking and preclassification is
conducted to obtain land, water, haze, cloud, and shadow areas. Then an optional haze or cirrus re-
moval is conducted followed by an optional shadow removal. The next step calculates the visibility
or aerosol optical thickness map using the dense dark vegetation (DDV) method. This is followed
by an update of the aerosol model (path radiance behavior in the blue to red bands) if a blue band
exists and the update option (ratio blu red > 0) is enabled. Otherwise the selected aerosol model
is not changed. After calculation of the water vapor map the iterative surface reflectance retrieval
is conducted accounting for adjacency and spherical albedo effects. After atmospheric correction,
a spectral polishing (for hyperspectral instruments) and BRDF correction might be performed.

The visibility/ AOT(550 nm) retrieval flow chart describes the case with a SWIR band at 2.2 µm.
It starts with a low reflectance threshold T1=0.05 and performs the masking in this SWIR band to
obtain the darkest pixels, excluding water. If the number of reference pixels is less than 2% of the

206
CHAPTER 10. THEORETICAL BACKGROUND 207

Figure 10.1: Main processing steps during atmospheric correction.

scene pixels then the threshold T1 is increased until threshold T2 = 0.12 is reached. If not enough
reference pixels are found then a constant VIS=23 km is used otherwise the visibility for each ref-
erence pixel is determined as the intersection of modeled and measured radiance in the red channel.

Then the red and NIR channels are checked concerning negative reflectance pixels (mainly water,
shadow). If the percentage of negative reflectance pixels is higher than 1% of the scene pixels, then
the visibility is iteratively increased up to 120 km, and these ’negative’ areas are stored in a mask
containing the respective visibility index.
The visibility index ’vi’ is closely related to the total optical thickness δ at 550 nm, δ = 0.185 +
0.006 ∗ vi. It is used for a fast indexing of arrays depending on visibility to avoid time-consuming
interpolation.
Since dark reference pixels might be close to ’negative’ areas (in most cases from the NIR band), the
visibility index of the reference pixels viref is updated to obtain a smooth visibility/AOT transition

viref = viref + 0.5 · (vineg − viref ) (10.1)

where vineg is the average visibility index from the ’negative’ areas (NIR band). Of course, equa-
tion 10.1 is only applied to reference pixels with viref > vineg . A visibility index map is created
inserting the visibility index of the reference pixels as well as the visibility index of the red and NIR
band ’negative’ areas. The non-reference (and non ’negative’ area) pixels are assigned the average
of the reference pixel visibility index. Alternatively, triangular interpolation can be applied. The
final step is a spatial low pass filter (3 km × 3 km) of the visibility index and AOT(550nm) maps
to smooth small-scale fluctuations and noise.
CHAPTER 10. THEORETICAL BACKGROUND 208

Figure 10.2: Visibility / AOT retrieval using dark reference pixels.

If the aerosol type (rural, urban, maritime, desert) is not fixed by the user, i.e., if the ’auto’ aerosol
is selected in the ’*.inn’ file, then the flow chart is executed for these four types, and the type
closest to the scene-estimated type is used, see chapter 10.5.2 for more details.
CHAPTER 10. THEORETICAL BACKGROUND 209

Figure 10.3: Radiation components, illumination and viewing geometry.

10.1 Basics on radiative transfer


This chapter presents the basic concepts and the terminology. The full set of equations is docu-
mented here as implemented in ATCOR. We start with the radiative transfer equation in the solar
spectral region (0.4 - 2.5 µm) for a flat terrain under clear sky conditions. First, the equation
for an infinite plane of uniform reflectance is presented. Then the case of a small uniform surface
embedded in a large homogeneous background of different reflectance is discussed. We continue
with the rugged terrain, and finally discuss the equations for the thermal spectral region (8-14 µm).

10.1.1 Solar spectral region


For a cloud-free sky and a uniform ground of reflectance ρ, the radiance signal received at the
sensor consists of scattered solar radiation and ground reflected radiation. The scattered radiation
component is also called path radiance. It depends on the solar and viewing geometry as sketched
in Fig. 10.3. In case of a flat terrain, the at–sensor radiance L can be written as (Asrar 1989,
chapter 9):

ρ Eg (0)
L = Lp (Θv , Θs , φ) + τv (Θv ) (10.2)
π 1 − ρr s

L at-sensor radiance for surface reflectance ρ ;


Lp path radiance ;
τv total ground-to-sensor atmospheric transmittance, sum of
direct τdir and diffuse τdif transmittance;
Eg global flux on a horizontal surface, sum of direct (Edir ) and
diffuse (Edif ) flux, Eg (0) is calculated for a ground surface
with ρ = 0 ;
ρr large scale reference background reflectance determining
the effective global flux (ρr =0.15 is used for ATCOR) ;
CHAPTER 10. THEORETICAL BACKGROUND 210

s spherical albedo of the atmosphere, accounts for atmospheric


backscattering to the ground.

The geometry is described by the angles Θv (view zenith), and Θs , φ (solar zenith and relative
azimuth angles), compare figure 10.3. Since ρ and ρr are not known for image data and can vary
within a scene, equation (10.2) has to be solved for ρ iteratively, compare equations (10.10 - 10.16).
In a strict sense, the reflectance ρ used here should be called hemispherical-directional reflectance
factor (HDRF), because most surfaces show an anisotropic reflectance behavior characterized by
the bidirectional reflectance distribution function (BRDF, Nicodemus 1970, Slater, 1985). The
ground is illuminated hemispherically by the direct and diffuse solar flux and the reflected radia-
tion is recorded from a certain direction, i.e., hemispherical input radiation, directional reflected
radiation. Since the reflected radiation is always measured in a small cone, the term hemispherical-
conical reflectance factor HCRF is also used, but for small instantaneous field-of-view sensors,
”directional” is a sufficiently accurate geometrical description. However, for simplicity we will use
the abbreviation reflectance in this manual.

In spectral regions dominated by scattering effects, the terms of equation (10.2) are calculated
with the scaled DISORT option (discrete ordinate radiative transfer [?]), in regions with strong
atmospheric absorption the more accurate correlated k algorithm is used in combination with
DISORT [?]. The results are stored in look-up tables (LUT). Since MODTRAN calculates the
path radiance including the diffuse reflected ground radiation in the form

τdif Eg (0) ρ/π


Lpath (ρ) = Lpath (0) + = Lpath (0) + τdif Eg (ρ) ρ/π (10.3)
1 − ρs
two MODTRAN runs with surface reflectance ρ = 0 and ρr = 0.15 are required to calculate the
diffuse ground-to-sensor transmittance τdif and spherical albedo s from equation (10.3)
[Lpath (ρr ) − Lpath (0)] π
τdif = (10.4)
ρr Eg (ρr )

Eg (ρ = 0)
Eg (ρr ) = (10.5)
1 − ρr s

Eg (0)
s = [1 − ]/ρr (10.6)
Eg (ρr )

For image data, the pixel reflectance ρ may differ from the background reflectance ρ̄ . In this case
the signal at the sensor consists of three components as sketched in Fig. 10.4:
• component 1: scattered radiance, path radiance,

• component 2: radiation reflected from pixel under consideration,

• component 3: radiation reflected from the neighborhood and scattered into the viewing di-
rection (”adjacency” effect).
Only component 2 contains information on the surface properties of the pixel, the other components
have to be removed during the atmospheric correction. As detailed in [56] the adjacency radia-
tion L3 consists of two components (atmospheric backscattering and volume scattering) which are
combined into one component in Fig. 10.4.
CHAPTER 10. THEORETICAL BACKGROUND 211

Figure 10.4: Schematic sketch of solar radiation components in flat terrain.

The radiometric calibration assigns to each digital number (DN) the corresponding at-sensor radi-
ance L

L(k) = c0 (k) + c1 (k)DN (k) (10.7)

where k indicates the channel number, and c0 , c1 are the calibration coefficients (offset and slope).
For sensors with adjustable gain settings the equation is

L(k) = c0 (k) + c1 (k)DN (k)/g(k) (10.8)

where g(k) is the gain setting in channel k. The atmospheric correction has to be performed itera-
tively, since the surface reflectance and large-scale (0.5-1 km neighborhood) background reflectance
are not known. So three steps are employed in the ground reflectance calculation:
Step 1: The influence of the neighborhood (adjacency effect) is neglected and the surface reflectance
is obtained from
π[d2 (c0 + c1 DN ) − Lp ]
ρ(1) = (10.9)
τv Eg (ρr = 0.15)

where the spectral band index is omitted for clarity. The factor d2 takes into account the sun-to-
earth distance (d is in astronomical units) since the LUTs with path radiance and global flux are
calculated for d=1 in ATCOR.
Step 2: The second step calculates the average surface reflectance in a large neigborhood of each
pixel (range R = 1 km)
N
1 X (1)
ρ̄ = 2
ρi,j (10.10)
N i,j=1

where N corresponds to the number of pixels for the selected range R of the adjacency effect [?], [56].
The exact choice of R is not critical since the adjacency influence is a second-order effect. Instead
of the range-independent weighting in eq. (10.10), a range-dependent function can be selected with
an exponential decrease of the weighting coefficients [?]. The range-dependent case requires more
CHAPTER 10. THEORETICAL BACKGROUND 212

execution time, of course. Except for special geometries, the difference between both approaches
is small, because the average reflectance in a large neighborhood usually does not vary much and
the influence is a second-order effect.

ρ(2) (x, y) = ρ(1) (x, y) + q{ρ(1) − ρ̄(x, y)} (10.11)

The function q indicates the strength of the adjacency effect. It is the ratio of the diffuse to direct
ground-to-sensor transmittance. The range-dependent version of eq. (10.11) is:
ZR
(2) (1) (1)
ρ (x, y) = ρ (x, y) + q{ρ (x, y) − ρ(1) (r)A(r)exp(−r/rs )dr} (10.12)
0

Here, R is the range where the intensity of the adjacency effect has dropped to the 10% level
(i.e. r=R=2.3x rs , where rs is a scale range, typically rs =0.2-0.4 km, R=0.5-1 km), ρ(r) is the
reflectance at range r from the (x,y) position and A(r) is the area of a circular zone from r to r+dr.
Now we approximate the circular regions by square regions to obtain the discrete version of eq.
(10.12) with exponentially decreasing weighting coefficients wi :
nR
X
(2) (1) (1)
ρ (x, y) = ρ (x, y) + q{ρ (x, y) − ρ̄i wi } (10.13)
i=1

Zri Zri
1
wi = n R
Wi and Wi = A(r)exp(−r)dr ≈ (2r)2 exp(−r)dr (10.14)
P
Wi ri−1 ri−1
i=1

ATCOR supports up to nR =5 regions. Since the sequence of moving digital low pass filters works
with square filters of size 2ri * 2ri , the area A(r) is approximated as the corresponding square
region A(r) = (2r)2 .
Step 3: it includes the spherical albedo effect on the global flux that was initially calculated with
the reference background reflectance ρr = 0.15 and is finally adapted to the scene-dependent value
ρ̄ by correcting with the difference ρ̄ − ρr :

ρ(3) (x, y) = ρ(2) (x, y)[1 − (ρ̄(x, y) − ρr )s] (10.15)

Radiation components in rugged terrain :


Figure 10.5 shows a sketch of the radiation components in a rugged terrain [?]. Compared to
the flat terrain one additional component is taken into account in the ATCOR model. It is an
approximation of the terrain reflected radiation. It is obtained by weighting the reflected radiation
in a 0.5 - 1 km surrounding of a pixel with the terrain view factor. The terrain view factor is
Vterrain (x, y) = 1 − Vsky (x, y) , and the sky view factor Vsky (x, y) is calculated from the DEM as
explained below. The sky view factor is normalized to 1 for a flat terrain.
The reflectance is calculated iteratively. The first step neglects the adjacency effect and starts with
(0)
a fixed terrain reflectance of ρ̄terrain = 0.1 [?] :

π [d2 (c0 + c1 DN (x, y)) − Lp (z, Θv , φ)]


ρ(i) (x, y) = i) (i−1)
(10.16)
τv (z, Θv )[b(x, y)Es τs (z)cosβ(x, y) + Ed∗ (x, y, z) + Et (z, ρr )ρ̄terrain Vterrain (x, y)]
The terms are defined as :
CHAPTER 10. THEORETICAL BACKGROUND 213

Figure 10.5: Radiation components in rugged terrain, sky view factor.


Left: schematic sketch of radiation components in rugged terrain; 1 : path radiance; 2 : pixel
reflected radiance; 3 : adjacency radiance; 4 : reflected terrain radiance. Right: sky and terrain
view factor.

x, y horizontal coordinates, corresponding to the georeferenced pixel positions;


z vertical coordinate, containing the elevation information from the DEM;
DN(x,y) digital number of georeferenced pixel;
Lp (z, θv , φ) path radiance, dependent on elevation and viewing geometry;
τv (z, Θv ) ground-to-sensor view angle transmittance, direct plus diffuse components;
τs (z) Sun-to-ground beam (direct) transmittance;
β(x, y) angle between the solar ray and the surface normal (illumination angle);
b(x,y) binary factor: b=1 if pixel receives direct solar beam, otherwise b=0;
Es extraterrestrial solar irradiance (earth-sun distance d=1 astronomical unit);
Ed∗ (x, y, z) diffuse solar flux on an inclined plane (see equation 10.19);
Eg (z) global flux (direct plus diffuse solar flux on a horizontal surf. at elevation z);
Et (z) radiation incident upon adjacent slopes;
(0)
ρterrain = 0.1, initial value of average terrain reflectance;
(i)
ρ̄terrain (x, y) locally varying average terrain reflectance, calculated iteratively (i=1,2,3);
Vterrain (x, y) terrain view factor (range 0-1).
The solar and DEM geometry is shown in figure 10.6 as well as the three solar radiation components
CHAPTER 10. THEORETICAL BACKGROUND 214

taken into account for rugged terrain: direct and circumsolar irradiance, and diffuse hemispherical
sky flux. It can be shown that these three components are equivalent to the direct and diffuse solar
flux components in flat terrain. In case of a shadow pixel the direct and circumsolar components
are set to zero, i.e. the binary factor b=0.

The next step iterates eq. 10.16 averaging the reflected terrain radiation over a square box of 1.0
× 1.0 km. If equation (10.16) is used with Et = Eg then three iterations are usually sufficient to be
independent of the start value of the terrain reflectance [?]. However, for highly reflective surfaces,
e.g. snow, and high terrain view factors, more than three iterations are necessary, and a faster
(i)
convergence of ρ̄terrain can be achieved with a geometric series for the terrain reflected radiation
Et as proposed in [69] :

(i) ρ̄(i−1) Vterrain


Et = Eg (10.17)
1 − ρ̄(i−1) V̄terrain
If Θs , Θn , φs , φn denote solar zenith angle, terrain slope, solar azimuth and topographic azimuth,
respectively, the illumination angle β can be obtained from the DEM slope and aspect angles and
the solar geometry:

cosβ(x, y) = cosΘs cosΘn (x, y) + sinΘs sinΘn (x, y)cos{φs − φn (x, y)} (10.18)

The illumination image cosβ(x, y) is calculated within ATCOR and stored as a separate map. The
diffuse solar flux on an inclined plane is calculated with Hay’s model (Hay and McKay 1985, also
see Richter 1998 for the enhancement with the binary factor b):

Ed∗ (x, y, z) = Ed (z)[bτs (z)cosβ(x, y)/cosΘs + {1 − bτs (z)}Vsky (x, y)] (10.19)

The sky view factor can be computed from local information as Vsky (x, y) = cos2 (Θn (x, y)/2)
based on the local DEM slope angle Θn . ATCOR uses the horizon algorithm that provides a more
accurate value of the sky view factor by considering the terrain neighborhood of each pixel (Dozier
et al. 1981). Vsky and Vterrain are related by :

Vsky (x, y) = 1 − Vterrain (x, y) (10.20)

In mountainous terrain the equations 10.10 to 10.14 are replaced with the at-sensor radiance L
instead of the surface reflectance, because it yields better results for cast shadow areas, i.e. these
equations are rewritten as:
N
1 X
L̄ = 2 Li,j (10.21)
N i,j=1

L(2) (x, y) = L(x, y) + q{L(x, y) − L̄(x, y)} (10.22)


nR
X
L(2) (x, y) = L(x, y) + q{L(x, y) − L̄i wi } (10.23)
i=1

The last step accounts for the spherical albedo effect (eq. 10.15).
CHAPTER 10. THEORETICAL BACKGROUND 215

Figure 10.6: Solar illumination geometry and radiation components.

10.1.2 Illumination based shadow detection and correciton


For high resolution imagery, the correction of cast shadows and illumination on the basis of a surface
model does not lead to useful results as the surface representation with respect to the radiometry
is never accurate enough. Severe over- and under-correction artifacts are observed due to these
inaccuracies in the resulting images.
The detection and correction of cast shadows has been widely studied, specifically for space borne
high resolution instruments [?, ?]. An index-based method for cast shadow detection has been
implemented for the ATCOR case [?]. It produces a continuous shadow field and relies on the fact
that all areas in cast shadows are illuminated by diffuse irradiance only. The diffuse illumination
is caused by scattering and thus exhibits very specific spectral characteristics if compared to the
direct irradiance. Specifically, the signal in the blue spectral band is significantly higher in cast
shadow areas than in directly illuminated areas. For the shadow quantification, the brightness in
CHAPTER 10. THEORETICAL BACKGROUND 216

the NIR spectral band is first calculated using the solar illumination. Secondly, two blue indices
have been defined as the band ratios green/blue and red/blue, respectively. These three measures
are combined such that a value equivalent to the illumination between 0 and 1 is created (0 being
a cast shadow area).

Figure 10.7: Combination of illumination map (left) with cast shadow fraction (middle) into continuous
illumination field (right).

Shadows over land


The shadow fraction fsh parameter is now to be calculated from this red-to-blue spectral feature.
The respective apparent reflectance values are used as input. They are simply named ρb , ρg , ρr , and
ρn for the blue, green, red, and NIR spectral bands, respectively. In a first step, the ratio between
the red and the blue spectral band is calculated. This index increases with the portion of direct illu-
mination: low index values show shadow areas whereas high values are directly illuminated pixels.
The blue apparent reflectance is corrected to account for the influence of chlorophyll absorption,
using the positive difference in apparent reflectance between NIR and red (ρn − ρr )>0 . Setting
the minimum of this correction factor to zero inhibits its unintended application to non-vegetated
pixels.
ρr + kn · (ρn − ρr )>0
ish = . (10.24)
ρb
The factor kn is used to weight the vegetation correction factor and is to be found empirically. It is
derived by minimizing the variation of ish as of Eq. 10.24 depending on surface cover types, using
the spectra of the above-mentioned simulated data set. An optimal value of kn = 0.1 has been
found from this analysis.
When calculating the index from Eq. 10.24 for various aerosol amounts, a systematic decrease of
the index value with increasing aerosol amounts is observed. This can be accounted for by using
dark object signatures in the blue, which are mainly ruled by aerosol scattering. The dark signature
ρb,dark for the blue band, is found from the image by using the average apparent reflectance of the
darkest pixels in the image from 0.1% of all image pixels (this percentile is increased to 1% for
small images). Relating these dark object signatures, an aerosol-amount-dependent trend can be
found and applied to the index as a normalization function such that the shading index for land
surfaces may be written as:
ρr + kn · (ρn − ρr )>0 1
ilsh = · b·ρ
. (10.25)
ρb a · e b,dark
The parameters a and b from the correction function are found by an exponential fit between
ρb,dark and the raw index ish on all spectra of the simulated data set, on three sensor altitudes
CHAPTER 10. THEORETICAL BACKGROUND 217

(2km, 5km, and satellite level). Values of a = 1.58 and b = −0.04 have been found leading to the
lowest variation of ilsh with respect to the visibility. The relative deviation from mean of the index
derived from the full set of reference spectra as described above with the full variation of visibilities
could be reduced from 32% to 14% by applying this correction. Applying Eq. 10.25 with optimized
correction parameters to the simulated data leads to a more stable average index.

Shadows over water


The above index is applicable for most land situations, but it can not be used to derive shadows over
water bodies. Specific methods have to be developed to find shaded areas over water in order to
exclude false alarms in water. Using the red-blue ratio does not allow for a good shadow detection
over water. The blue appearance of water reflectances is interfering with the aerosol signatures in
this wavelength range and needs to be accounted for. It has been found that an extrapolation of
the signatures in the green-red bands towards the blue spectral range is a good alternative to find a
shadow-sensitive index for water bodies. A corresponding index is calculated as a relation between
an extrapolated blue signature to the measured blue apparent reflectance, while both parameters
are corrected by subtracting the blue dark objects signature:
ρb,ext − ρb,dark,ext
iwsh,0 = , (10.26)
ρb − ρb,dark,ext

where
ρr − ρg
ρb,ext = ρg − · (λg − λb ). (10.27)
λr − λg

The dark object signature for the blue band can not be taken from the blue band directly as the
natural blue reflectance of water may be quite high. Therefore, this signature ρb,dark,ext is estimated
as a weighted combination between the blue dark signature and the red dark signature as:

ρb,dark,ext = 0.8 · ρr,dark + 0.2 · ρb,dark (10.28)

It has been found that the index depends mainly on flight altitude rather than on aerosol optical
thickness, which may be explained by the relation between atmospheric path radiance and diffuse
ground irradiance which changes with altitude. An exponential decrease of the index value with
flight altitude h has been derived from the simulated data set which can be used for a height-
dependent index equation as:

iwsh,0
iwsh = . (10.29)
a · e−bh
The values of the exponential function are derived from the simulated data as a = 1.18 and
b = −0.4 km−1 . The flight altitude h is given in km.

Shadow Index Combination


The indices can be combined based on a land/water mask. The water mask is derived by a
classification rule which uses the following threshold values: [(ρn < (ρnir,dark + 1%) AND (ρr − ρb <
−3%) AND (ρn − ρr < 3%)] OR [(2 · ρg > (ρr + ρn ) + 4%) AND (ρn < 7%)]. Using a transition
range of 1% for each reflectance threshold, a smooth weighting factor w between water (w = 0)
and land surfaces (w = 1) is derived. Offsets are applied to both indices to place them in a range
CHAPTER 10. THEORETICAL BACKGROUND 218

between 0 and 1 such that i0lsh = (ilsh − 0.3) > 0 < 1 and i0wsh = (iwsh − 0.6) > 0. The two re-scaled
indices are then combined into one layer for later use in image analysis:
ish = w · i0lsh + (1 − w)i0wsh . (10.30)
The parameter ish is finally scaled to a shadow fraction fsh between 0 (full cast shadow) and 1 (no
cast shadow) using a lower limit for full cast shadow areas and an upper limit for full illumination.
It has been found that the lower limit of ish has to be set to values between 0.3 and 0.55. This
threshold depends on the instrument spectral response, the radiometric calibration accuracy of the
instrument, but also on the average flight altitude.
In desert areas where no water is expected, the detection of shadows on water is not useful and may
lead to erroneous results. Therefore, a simplified mode without the second index is applied in such
situations by setting the parameter w to one. A sample of the whole cast shadow detection process
is illustrated in Figure 10.8. The indices for land and water are calculated and then combined into
one fractional shadow value using the water mask. Application of a final threshold leads to the
cast shadow mask.

Figure 10.8: Derivation of cast shadow mask from original image by calculating land index, water index,
water mask, a combination of both and applying a threshold of 0.33 to the output. The indices (in blue) are
linearly scaled between 0.2 and 0.6 in this sample.

For topographic correction in the ATCOR software, the direct illumination on an image pixel is
scaled by the cosine of the local solar incidence angle cos(β) which is typically derived from digital
elevation data. As the image derived shadow fraction fsh is also related to the direct illumination,
it can be combined with the incidence angle in an illumination factor filu as the smaller value of
both factors per image pixel:
filu = min [fsh ; cos(β)] . (10.31)
This fractional illumination factor may now be used for correction of illumination effects in the
atmospheric compensation routine, for cast shadow correction, but also for aerosol detection as
described hereafter.

Skyview Factor Estimate


The skyview factor Vsky describes the relative amount of the unobstructed sky hemisphere. This
factor is highly variable on small scales, e.g., in vicinity of forest borders. The skyview factor is
approximated from the cast shadow fraction such that all areas in complete cast shadows get a
reduced skyview factor as:
θs θs
Vsky = (1 − + fshad ) · 100% < Vsky,geom , (10.32)
180◦ 180◦
where θs is the solar zenith angle and the geometrical skyview factor Vsky,geom had been calculated
based solely on the digital terrain model.
CHAPTER 10. THEORETICAL BACKGROUND 219

Application in ATCOR Workflow


In ATCOR-4, the local illumination angle ϕ is first calculated on the basis of the terrain model using
an efficient vector algebra based method. The topographically and shadow corrected reflectance
ρtopo is then retrieved from the atmospherically corrected ground leaving excitance (Mg , derived
from first order atmospheric compensation) using the atmospherically transmitted direct irradiance
Edir,t , the diffuse illumination field Edif,t , and the terrain illumination Eter , and the shadow fraction
fshad , as:

Mg
ρtopo = , (10.33)
fshad Edir,t cos(ϕ) + ρ0 Edif,t + Edif,t ((1 − τs )Vsky + τs fshad cos(ϕ)
/ cos(θs )

The local illumination factor cos(ϕ) is now enhanced by the cast shadow fraction, such that shaded
areas are corrected accounting for direct and circumsolar irradiance.

Figure 10.9: Effect of combined topographic / cast shadow correction: left: original RGB image; right:
corrected image (data source: Leica ADS, central Switzerland 2008, courtesy of swisstopo).

After cast shadow correction, the border pixels of the shadows are often under/overcorrected, which
is visible as black or bright borders in the cast shadow areas. A filter has to be applied to remove
this artifact (compare Fig. 10.10). A simple approach to this problem is an interpolation of all
border pixels. However, a considerable data loss may be the result of such a process. Thus a more
sophisticated approach is required. As the border pixels are usually isolated, a filter approach has
been used which compares the pixel brightness ρi,j to the brightness of its direct neighbors ρprox
in a 3x3 or 5x5 box, respectively. The brightness of the shadow border pixel is then adjusted by
the relative brightness difference of the whole spectrum such that:
ρprox
ρf ilt,i,j = ρi,j . (10.34)
ρi,j

This method proved to successfully remove shadow borders for high resolution imagery and an
urban environment. However, for terrain shadows on a larger scale, the border pixels are not such
clearly isolated and often can not be corrected using this method, or only after increasing the size
of the border pixel filter significantly.
The updated processing leads to improved terrain correction as displayed in Fig.10.9. Advantages
of this method are:
CHAPTER 10. THEORETICAL BACKGROUND 220

Figure 10.10: Effect of cast shadow correction (middle) and shadow border removal (right) for building
shadows.

• terrain and forest cast shadows are corrected,

• water and cast shadows are discerned (in most cases),

• operational usability has been proven on large ADS data sets, and

• a consistent physically based method applicable to photogrammetry and imaging spectroscopy


is implemented.

10.1.3 Integrated Radiometric Correction (IRC)


The IRC method was published by Kobayashi and Sanga-Ngoie [22, 23] to provide a combined
atmospheric and topographic correction. The algorithm is briefly outlined here, more details can
be found in the original papers.

The first step is the orthorectification of the scene using a digital elevation model (DEM). Then
the slope and aspect maps are calculated. The next step is the calculation of the sky view factor,
see chapter 10.1.1. The original paper uses the simple equation based solely on the slope angle, but
with ATCOR a more accurate calculation based on a ray tracing can also be used in case of a steep
terrain. Then the following quantities are computed (keeping the original notation of Kobayashi in
most cases):

(π + 2θs )
h0 = (10.35)

Here θs is the solar zenith angle in radian. IF s denotes the slope map (in radian) then the simple
version of the skyview is obtained with

h = 1 − s/π (10.36)

The cosine of the local solar zenith (illumination angle β) is given in eq. 10.18. Then the surface
radiance for each channel Ls is calculated by subtracting the path radiance Lp from the at-sensor
radiance L:

Ls (x, y) = L(x, y) − Lp (x, y, z) (10.37)

In the ATCOR version of the IRC algorithm the path radiance varies spatially, particularly due to
the DEM height variation, while a constant value (per channel) is used in the original IRC paper.
CHAPTER 10. THEORETICAL BACKGROUND 221

Then a regression analysis (per channel) of Ls versus cosβ is applied to calculate the slope m and
intercept b. After defining C = m/b the topographic correction map A is calculated:
cosθs + C/h0
A(x, y) = (10.38)
cosβ(x, y) + C h(x, y)/h0
Finally, the surface reflectance ρ is computed according to:
π Ls (x, y, z) A(x, y)
ρ(x, y) = (10.39)
T (x, y, z) {Edir (x, y, z) cosθs + Edif (x, y, z)}
where T is the total ground-to-sensor transmittance, and Edir , Edif are the direct irradiance and
diffuse solar flux on the ground, respectively.

So the ATCOR version of IRC contains some improvements with respect to the original method:
the path radiance varies spatially, mainly caused by terrain height variations, possibly also due to
visibility variations, and the sky view factor can be provided from a ray tracing analysis instead of
the local slope angle.

Note: the IRC method usually performs well. However, due to the statistical evaluation of the
regression analysis unphysically large (> 1 reflectance unit) or small ( < 0) surface reflectance
values might happen for some pixels, usually in areas with topographic shadow or low local sun
elevations.

10.1.4 Spectral solar flux, reflected surface radiance


The spectral solar fluxes on the ground can be calculated by setting the parameter irrad0 = 1 in
the .inn file or using the graphical user interface. The fluxes depend on solar geometry, terrain
elevation, topography, and atmospheric conditions. All fluxes and the surface reflected radiance of
this section are evaluated for the current earth-sun distance. For a flat terrain, ATCOR provides
spectra of the direct, diffuse, and global flux for the selected visibility / water vapor. In case of
variable visibility / water vapor the spectra are calculated for the average scene visibility / water
vapor. The direct flux is just the beam irradiance on the ground times the cosine of the local solar
zenith angle. The diffuse flux spectrum Edif is evaluated for a surface reflectance of ρ = 0, and the
global flux for ρ = 0.15, i.e., Eg = (Edir + Edif (0))/(1 − s · 0.15), where s is the spherical albedo.
The spectral band index is omitted for brevity. For a flat terrain these fluxes are provided in the
directory of the input file (e.g. ’scene.bsq’ ):

• the direct spectral flux on the ground: ’scene edir.dat’

• the diffuse spectral flux on the ground: ’scene edif.dat’ for surface reflectance ρ = 0.

• the global spectral flux on the ground: ’scene eglo.dat’ for a typical average surface reflectance
ρ = 0.15.

These spectra will already give a realistic description for a flat terrain, but they lack the dependence
on the spectral reflectance variations in the scene. Therefore, an image of the global flux is also
provided that accounts for the spatial reflectance and visibility / water vapor patterns (VIS, named
’scene eglobal.bsq’ :)
Edir (V IS(x, y)) + Edif (ρ = 0, V IS(x, y))
Eg (x, y) = (10.40)
1 − s(x, y) ρ̄(x, y)
CHAPTER 10. THEORETICAL BACKGROUND 222

Here, ρ̄ indicates a spatial averaging with a filter size corresponding to the specified adjacency
range. The unit of the global flux is mW cm−2 µm−1 and it is stored as float data (32 bits/pixel).
Therefore, its file size will be twice or four times the size of the input scene if the scene is encoded
as 16bit/pixel and 8bits/pixel, respectively.

For a rugged terrain, images of the direct and diffuse fluxes will be calculated using the available
DEM information on height (z), slope and aspect (i.e. local solar illumination angle β), and
atmospheric conditions (visibility / water vapor VIS). The direct flux on the ground is :
Edir (x, y) = b(x, y) E0 Tsun (V IS(x, y, z)) cosβ(x, y) (10.41)
where E0 , Tsun are extraterrestrial solar irradiance and sun-to-ground transmittance, respectively,
and b is the topographic shadow mask (0=shadow, 1=sunlit pixel).

The diffuse flux in mountainous terrain accounts for the adjacency effect and multiple reflection
effects from the surrounding topography. Using the terrain view factor Vt from the last section
and the effective terrain reflectance ρt = Vt (x, y) ρ̄(x, y) and ρ̄t = V̄t (x, y) ρ̄(x, y) the diffuse flux is
approximated as:
Edif (x, y) = Edif,f lat {b Tsun (x, y, z) cosβ/cosθs + [1 − b(x, y) Tsun (x, y, z)] Vsky (x, y)}
+ {Edir,f lat (x, y, z) + Edif,f lat (x, y, z)} ρt (x, y) / (1 − ρ̄t (x, y)) (10.42)
The first line describes the anisotropic and isotropic components of the diffuse flux, the second line
accounts for multiple terrain reflection effects.

Related quantities to the global spectral solar flux on the ground are the wavelength-integrated
global flux and the absorbed solar flux (W m−2 ). These play a role in the surface energy balance
and they are available as part of the value added channels, see chapter 7.2, equations 7.9, 7.10.

Surface reflected radiance

The ground reflected (or ground leaving) radiance per band can be obtained in addition to the
spectral solar fluxes by setting the parameter irrad0=2. It is calculated corresponding to the
surface reflectance cube ρ(x, y), named ’scene surfrad.bsq’. For a flat terrain it is:
L(surf, x, y) = E(global) ρ(x, y) / π (10.43)
In case of a mountainous terrrain the direct and diffuse reflected radiation maps from the equations
10.41 and 10.42 are used:
L(surf, dir, x, y) = (Edir + Edif )ρ(x, y) / π (10.44)
Again, the same output file name is used (’scene surfrad.bsq’ ).

10.1.5 Thermal spectral region


Similar to the solar region, there are three radiation components: thermal path radiance (L1 ), i.e.,
photons emitted by the atmospheric layers, emitted surface radiance (L2 ), and reflected radiance
(L3 ). The short form of the radiance equation in the thermal region can be written as [?] :
L = Lp + τ ε LBB (T ) + τ (1 − ε) F/π (10.45)
where
CHAPTER 10. THEORETICAL BACKGROUND 223

Figure 10.11: Radiation components in the thermal region.


L1 = LP , L2 = τ  LBB (T ), L3 = τ (1 − ) F/π .

L at-sensor radiance,
L1 = LP thermal path radiance,
τ ground-to-sensor atmospheric transmittance,
ε surface emissivity,
T surface temperature,
LBB blackbody radiance at temperature T, weighted with the channel’s filter curve,
F thermal downwelling flux on the ground.

The second term on the right-hand side of equation (10.45) is emitted surface radiance reaching
the sensor, the third term is the atmospheric radiance reflected at the surface and attenuated by
the surface-to-sensor path. The spectral band index, elevation, and angular dependence is omitted
for brevity.

The LBB (T ) term is Planck’s blackbody radiance B(λ, T ) weighted with the spectral channel
response function R(λ):
λ
R2
B(λ, T )R(λ)dλ
λ1
LBB (T ) = λ
(10.46)
R2
R(λ)dλ
λ1

For a discrete temperature interval T = (T1 , T2 ) and increment (e.g. T1 = 200 K, T2 = 350 K,
increment 1 K) equation (10.46) is solved numerically. Temperature and radiance are then approx-
imated by an exponential fit function function with channel dependent coefficients a1 , a2 :
a1
LBB = (10.47)
exp(a2 /T − 1)
a2
T = (10.48)
ln(a1 /LBB + 1)
CHAPTER 10. THEORETICAL BACKGROUND 224

For convenience, an offset a0 is introduced with default a0 = 0. The offset term can be used to
adjust a temperature bias in a scene. Example: if scene temperatures are too low by 3K they can
be raised by setting a0 = 3.
a2
T = a0 + (10.49)
ln(a1 /LBB + 1)
Remark:
The computer implementation of the channel-resampled radiance equations is coded to minimize
spectral resampling effects [?], [?].

Temperature / emissivity separation

For a sensor with n thermal channels there are n equations of (10.45) with n+1 unknowns, namely
the n surface emissivities plus a surface temperature. So, the system of equations (10.45) is always
underdetermined. Several possibilities exist to address this problem (Gillespie et al. 1986, 1998
[?, ?]). Five options are offered by the satellite version of ATCOR:

• a constant emissivity (default =0.98 independent of surface cover type, 10-12 µm region) for
sensors with a single thermal channel. For user-defined sensors with multiple thermal bands
the parameter itemp band described in chapter 4.6.1 defines the channel employed for the
surface temperature calculation.

• fixed emissivity values assigned for 3 classes for the selected surface temperature band (pa-
rameter itemp band described in chapter 4.6.1): (soil)=0.96, (vegetation)=0.97, else =0.98
(water and undefined class). The assignment to the vegetation / soil class is performed on-
the-fly in memory employing the vegetation index (red and NIR bands required), and the
3-class emissivity map is available (file ’image atm emi3.bsq’, compare chapter 4.5). In the
airborne ATCOR version [?] a pre-classification with more emissivity classes can be used as
already suggested in [?].

• for multispectral thermal bands the normalized emissivity method (NEM) or adjusted NEM
are also implemented. In the NEM [?], the surface temperature is calculated for all chan-
nels with a constant user-defined emissivity, and for each pixel the channel with the highest
temperature is finally selected. In the adjusted NEM (ANEM) [84] the assigned emissivity
is surface cover dependent. Here, we define four surface cover classes (water, vegetation,
soil/dry vegetation, sand/asphalt) based on the following criteria:

– vegetation: ρnir /ρred > 2 and ρnir > 0.20 .

– soil/dry vegetation: ρnir /ρred ≥ 1.4 and ρnir /ρred < 2.0 and ρred > 0.09 .

– sand/asphalt : ρnir /ρred < 1.4 and ρred > 0.09.

– water : ρnir < 0.05 and ρ1.6µm < 0.03 .

To each class the user can assign an emissivity valid for the channel with the highest temper-
ature. There is only one common emissivity class in case of night data or data from purely
CHAPTER 10. THEORETICAL BACKGROUND 225

thermal channels.
The ANEM method provides accurate channel emissivities and surface temperatures if the
classes are assigned correctly and the emissivity value assigned to the channel with the max-
imum temperature is close to the actual channel emissivity. Maximum surface emissivities
usually lie in the 10.5 - 13 µm region. After calculating the surface temperature, the emis-
sivities for all channels are computed.

• the ASTER TES algorithm is available for sensors with at least 5 channels in the thermal
interval (λx , λy ) with λx −F W HMx /2 ≥ 8.08 µm and λy +F W HMy /2 ≤ 13.0 µm to exclude
channels in strong absorption regions. The TES algorithm implemented here consists of 3
major parts (Gillespie et al. 1998 [?]):

– the NEM algorithm described above.


– the ratio module:
It calculates relative emissivities βi (channel i) by ratioing the NEM emissivity values εi
to their average:
n εi
βi = i=n (i = 1, n) (10.50)
P
εi
i=1

Here n is the number of channels in the allowed thermal interval.


– maximum minimum distance (MMD module) :
The maximum and minimum values of the relative emissivities (β spectrum) are calcu-
lated to find the spectral contrast:
M M D = max(β) − min(β) (10.51)
Then an empirical relationship is used to predict the actual emissivities εi from the
MMD employing a regression with laboratory or field emissivity spectra:
εmin = a + b M M Dc (10.52)
For small values M M D < 0.03 (e.g. water, vegetation) the value εmin is set to 0.983.
The 3 parameters (a, b, c) of the regression can be specified by the user, the default
values are taken from [?], i.e., a=0.994, b=-0.687, c=0.737 . The final step calculates
the actual emissivities using the β spectrum and εmin :
εmin
εi = β i (i = 1, n) (10.53)
min(β)
• for thermal band imagery with at least 5 channels the ISAC (In-Scene Atmospheric Com-
pensation) method is available. A detailed description is given by Young et al. [76]. The
method does not require ancillary meteorological data or atmospheric modeling. It neglects
the downwelling thermal flux and employs the equation

L = Lp + τ ε LBB (T ) = Lp + τ Lsurf ace (10.54)

This approximation is justified for pixels with a high emissivity close to 1, i.e. ”blackbody”
pixels. First, the highest brightness temperature Tmaxsensor for each pixel in each channel is

computed based on the at-sensor radiance L converted into brightness temperature. In the
current implementation, only channels in the spectral region 8 - 13 µm are employed for
the maximum brightness temperature search, because the spectral regions λ < 8 µm and
CHAPTER 10. THEORETICAL BACKGROUND 226

λ > 13 µm are strongly affected by atmospheric water vapor absorption. Next, a reference
channel is defined where most pixels with maximum brightness temperature occur. Only
those blackbody pixels are retained which have the maximum brightness temperature in this
reference channel (”most hits” method). For these selected blackbody pixels the scatterplot
of measured at-sensor radiance L versus blackbody radiance corresponding to LBB (Tmax sensor )

is computed for each channel. This means the surface radiance of eq. 10.54 is approximated
as Lsurf ace = LBB (Tmaxsensor ). The final step is a least squares regression of the scatterplot

data L versus Lsurf ace , yielding the intercept (path radiance Lp ) and slope (transmittance
τ ) of eq. 10.54. Care has to be taken to apply the regression only to the points near the
top edge of all cluster points, but allow some margin, so the fitting line is allowed to sink
by an amount of the sensor noise equivalent spectral radiance (NESR). The quality of the
regression is significantly increased by allowing only those pixels in the scatterplot that had
their maximum temperatures in the reference channel.

Two comments: first, because of the involved assumptions, the obtained intercept is not
the physical path radiance, and the slope not the physical atmospheric transmittance. Both
quantities may be negative in some channels, therefore they are referred to as unscaled path
(u)
radiance Lp and unscaled transmittance τ (u) . They might be rescaled to proper atmospheric
path radiance and transmittance spectra, e.g. using a radiative transfer code. Second: the
ISAC method requires an adequate spread in surface temperatures in the scene, and surface
temperatures higher than the atmospheric radiation temperature. So, results for night-time
imagery will likely be degraded.

The compensated unscaled surface radiance spectrum is calculated as


(u)
(u) L(λ) − Lp (λ)
Lsurf ace (λ) = (10.55)
τ (u) (λ)

and the unscaled ISAC surface emissivity can be obtained with


(u)
isac (λ) = Lsurf ace (λ) / LBB (λ, Tref ) (10.56)

where Tref is the brightness temperature image in the reference channel. The compensated
(u)
surface radiance spectrum Lsurf ace (λ) can be converted into the equivalent compensated
brightness temperature spectrum where most of the atmospheric absorption features are
removed. Both the compensated surface radiance and compensated brightness temperature
are spectrally consistent with the data and represent the best estimate for the spectral shape.
The emissivity spectrum isac (λ) may exceed the value 1 in certain channels if the maximum
brightness temperature of a pixel does not occur in the selected reference channel. However, a
common reference channel is needed in this method to obtain a consistent pixel-independent
(u)
spectrum of unscaled path radiance Lp and transmittance τ (u) .
Split-window covariance-variance ratio SWCVR

The method derives the water vapor map from thermal band imagery [85, 86, 87]. The water vapor
content W can be retrieved as a function of the ratio Rj,i of transmittances τi , τj in two thermal
bands i and j:
W = a + b Rj,i (10.57)
CHAPTER 10. THEORETICAL BACKGROUND 227

with
N
(Ti,k − T̄i ) (Tj,k − T̄j )
P
j τj k=1
Rj,i = = N
(10.58)
i τi
(Ti,k − T̄i )2
P
k=1

where N is the number of pixels in a moving window box centered at pixel k, T̄i is the average
brightness temperature in this box, and  is the land surface emissivity. Equation 10.58 is the
ratio of covariance to variance accounting for the abbreviation SWCVR. The two selected channels
should be in the 10.5 - 12.5 µm region, where the emissivity of most land surfaces changes only
slightly, yielding an emissivity ratio j /i close to 1 yielding Rj,i = τj /τi . Then the parameters ”a”
and ”b” in eq. 10.57 can be calculated from a regression of channel transmittances versus water
vapor content using the pre-calculated LUTs. The moving averaging window box is selected at 100
m × 100 m. The method requires moderate to high temperature contrasts in the moving window,
otherwise results are not reliable. Therefore, it is preferable to retrieve the water vapor map from
channels in the solar reflective region if possible.

10.2 Masks for haze, cloud, water, snow


A useful first step before executing an atmospheric correction is the calculation of a pixel map for
haze, cloud, water snow, etc. Such a pre-classification has a long history in atmospheric correction
methods [?, ?, ?, ?, ?, ?, ?]. It is also employed as part of NASA’s automatic processing chain for
MODIS [?] using the classes land, water, snow/ice, cloud, shadow, thin cirrus, sun glint, etc. A
similar approach is taken here.
The calculation is done ”on-the-fly” and if the scene is named ”scene.bsq”, then the corresponding
map is named ”scene out hcw.bsq”. There is also the possibility to provide this information from
an external source: if a file ””scene hcw.bsq” exists in the same folder as the ”scene.bsq” then this
information is taken and the internal ATCOR calculations for this map are skipped. In this case,
the coding of the surface types has to agree with the ATCOR class label definition, of course, see
Table 10.1. This file is written if the corresponding flag is set to 1, see chapter 9.3 and figure 5.12
in chapter 4.

Depending on the available spectral channels, it may not be possible to assign certain classes. Table
10.1 contains one class for cloud (over land, meaning water cloud), whereas the low optical thick-
ness cloud is put into the thin and medium thickness haze class. Thin and medium haze can often
be corrected successfully. Of course, there is no clear distinction between thick haze and cloud.
We take a pragmatic view, and if the haze removal is successful in areas with thick haze, then
these pixels can be included in the haze mask. Since this is not clear at the beginning, it might
be necessary to run the program twice, with and without haze removal. A check of the results will
reveal whether the haze removal was successful. ATCOR contains a number of criteria to assess
the probability of a successful haze removal, and will switch off the haze option if the chances are
not good. This automatic haze termination works in most cases, but a success cannot always be
guaranteed. There are 5 cirrus classes: thin, medium, thick, cirrus cloud, thick cirrus cloud. The
two cirrus cloud classes are merged with the (normal) cloud class for the surface reflectance retrieval
during the treatment of the adjacency effect: here the reflectance of the cloud pixels is replaced
with the average reflectance of the non-cloud pixels to avoid an overestimation of the adjacency
effect. The classes are currently defined with the following criteria:
CHAPTER 10. THEORETICAL BACKGROUND 228

label class
0 geocoded background
1 shadow
2 thin cirrus over water
3 medium cirrus over water
4 thick cirrus over water
5 land
6 saturated (blue/green band)
7 snow / ice
8 thin cirrus over land
9 medium cirrus over land
10 thick cirrus over land
11 thin haze over land
12 medium haze over land
13 thin haze over water
14 medium haze over water
15 cloud over land
16 cloud over water
17 water
18 cirrus cloud
19 cirrus cloud thick

Table 10.1: Class labels in the hcw file.

Water class:

The following TOA reflectance thresholds are employed for water:


ρ∗ (red) < 0.20 and ρ∗ (green) > ρ∗ (red)
ρ∗ (N IR) < TN IR and ρ∗SW IR1 < TSW IR1 and N DV I < 0.1 (10.59)
where TN IR = max(0.07, Twater,N IR ) and Twater,N IR is the user-defined threshold (in the ’prefer-
ence parameters.dat’, see chapter 9.3). Similarly, TSW IR1 = max(0.05, Twater,SW IR1 ) and Twater,SW IR1
is the user-defined threshold in the ’preference parameters.dat’.
Note: this requires a positive value of Twater,N IR , Twater,SW IR1 . If these thresholds are negative,
then the following criteria are employed:
ρ∗ (red) < 0.20 and ρ∗ (N IR) < |Twater,N IR | and N DV I < 0.1 (10.60)
The relations 10.60 are applied for sensors without a SWIR band.
ρ∗ (red) < 0.20 and ρ∗SW IR1 < |Twater,SW IR1 | + 0.01 and N DV I < 0.1 (10.61)
The relations 10.61 are applied for sensors with a SWIR1 (1.6 µm) band.

Saturated pixels:

These pixels fulfill the criterion


DN (blue) ≥ Tsaturation (10.62)
CHAPTER 10. THEORETICAL BACKGROUND 229

where DN (blue) is the digital number in a blue band (around 470 nm) and the threshold Tsaturation
is defined in the preference parameter file. If a blue band does not exist, a green band (around 550
m) is used as a substitute. If a green band also does not exist, a red band (around 650 nm) is used.
Tsaturation = b · encoding, default b=1.0, e.g. 1.0*255=255 for 8 bit sensors with encoding=255.
A lower value, e.g. b=0.98, might be used because nonlinear effects might already occur ot lower
radiance levels. This would provide some safety margin and indicate situations near saturation.
Setting b=0.98 for an 8-bit sensor means that pixels exceeding DN = 0.98*255=250 will be marked
as (nearly) saturated. For a 32 bit encoding (integer or float) no saturation threshold is defined.
As saturation usually occurs in the blue-to-red part of the spectrum, channels in this region are
checked and assigned to the class ’saturated’, false color coded red in the ”* out hcw.bsq” file.
However, the ”* atm.log” file contains the percentage of saturated pixels for each channel.

Cloud over land:

Pixels must satisfy the conditions:

ρ∗ (blue) > Tc and ρ∗ (red) > 0.15 and ρ∗ (N IR) / ρ∗ (red) < 2
and ρ∗ (N IR) > 0.8 ρ∗ (red) and ρ∗ (N IR) / ρ∗ (SW IR1) > 1
and N DSI < 0.7 or DN (blue) > Tsaturation (10.63)

where ρ∗ (blue) is the apparent reflectance in a blue band, Tc is the cloud threshold as defined in
the preference parameter file, and DN (blue) is the corresponding digital number. If no blue band
is available, a green band (around 550 nm) is taken as a substitute. If no green band exists, a red
band (around 650 nm) is taken. NDSI is the normalized difference snow index:
ρ∗ (green) − ρ∗ (SW IR1)
N DSI = (10.64)
ρ∗ (green) + ρ∗ (SW IR1)
Note that saturated pixels in visible bands are automatically counted as cloud although they might
be something else (e.g., snow, or a specular reflection from a surface). If a thermal band exists, the
following cloud criterion must also be fulfilled:

(1 − ρ∗ (SW IR1)) Tbb < 225 (Kelvin) and exclude Tbb > 300 (Kelvin) (10.65)

where Tbb is the at-sensor blackbody temperature in the selected thermal band.

Cloud over water:

The following criteria have to be fulfilled:

0.20 < ρ∗ (blue) < 0.40 , ρ∗ (green) < ρ∗ (blue)


ρ∗ (N IR) < ρ∗ (green) , ρ∗ (SW IR1) < 0.15 , N DSI < 0.2 (10.66)

For optically thick clouds it is not possible to distinguish clouds over water from clouds over land
if only spectral criteria are used.

Cloud shadow:

Pixels must satisfy the conditions:

ρ∗ (red) < 0.06 , ρ∗ (N IR) > ρ∗ (red) + 0.04 , 0.02 < ρ∗ (SW IR1) < 0.08 (10.67)
CHAPTER 10. THEORETICAL BACKGROUND 230

and they should not belong to the water class. This may also include building shadow pixels.

Snow / ice:

Pixels must satisfy the conditions:

ρ∗ (blue) > 0.22 and N DSI > 0.6 and DN (blue) < Tsaturation (10.68)

The condition DN (blue) < Tsaturation means that saturated pixels in the blue spectral band are not
included in the snow mask, instead they are put into the cloud class. If no blue band exists, a green
band (around 550 nm) is taken. However, if the blue or green band is saturated and N DSI > 0.7
then this pixel is assigned to the snow class because of the very high probability. If a green band
and a SWIR2 band (around 2.2 µm) exist the following relationships are used:

DN (blue) < Tsaturation and ( (ρ∗ (blue) > 0.22 , N DSI > 0.6)
∗ ∗ ∗
or (ρ (green) > 0.22 , N DSI > 0.25 , ρ (SW IR2)/ρ (green) < 0.5 ) ) (10.69)

Again, if the blue or green band is saturated and N DSI > 0.7 then the snow class is assigned.

Cirrus over land and water:

The apparent cirrus reflectance is calculated in the cirrus band (1.38 µm). Cirrus classes are defined
according to the apparent reflectance. Thin cirrus over land is calculated with

1.0% < ρ∗ (cirrus) < 1.5% (10.70)

employing the percent reflectance unit. Medium thickness cirrus is calculated as

1.5% ≥ ρ∗ (cirrus) < 2.5% (10.71)

and the thick cirrus class consists of pixels with

2.5% ≥ ρ∗ (cirrus) < 4.0% (10.72)

The same definition is used for cirrus over water if the land/water distinction is still possible based
on the selected spectral criteria.

Still higher apparent reflectance values are defined as ’cirrus cloud’ if

4.0% ≥ ρ∗ (cirrus) < 5.0% (10.73)

and ’thick cirrus cloud’ if

ρ∗ (cirrus) ≥ 5.0% (10.74)

and no distinction concerning land/water is made for the last two classes.
Cirrus detection is switched off in the following cases:

• no water vapor map available: if DEM height ¿ 2000 m

• water vapor map W available: if W ¡ 1 cm or W ¡ Twv where Twv is the water vapor threshold
specified in the file preference parameters.dat
CHAPTER 10. THEORETICAL BACKGROUND 231

Haze over land: see chapter 10.6.3

The the mean of the tasseled cap transformation (TC) is calculated. Clear pixels are those with
T C < mean(T C) and ρ∗ (blue) < Tc (cloud over land threshold) and ρ∗ (N IR) > Twater (N IR)
(water reflectance threshold, defined in ”preference parameters.dat”). Next, the mean and stan-
dard deviation σ of the HOT transformation (HOT = Haze Optimized Transform) are calculated.
Pixels are assigned to the compact haze mask if HOT > mean(HOT ), and to the large haze mask
if HOT > mean(HOT ) − 0.5 σ(HOT ). Then the HOT histogram of all haze pixels is calculated.
Pixels with values less than 40% of the cumulative histogram are assigned to thin-medium haze,
pixels with higher values to medium-thick haze. This distinction is arbitrary and has no effect on
the subsequent processing.

Haze over water:

Pixels must belong to the water mask, and the NIR apparent reflectance ρ∗ (N IR) must be greater
than the NIR clear water threshold Tclearw aterN IR defined in the preference parameter file (chapter
9.3). Thin haze over water is defined as:

Tclearw aterN IR ≥ ρ∗ (N IR) ≥ 0.06 (10.75)

Medium haze over water is defined as:

0.06 < ρ∗ (N IR) ≤ T2 (10.76)

where T2 (default=0.12) is another editable parameter in the preference file. The method of haze
removal over water is described in chapter 10.6.4. The same technique is also employed to remove
sun glint.

10.3 Quality layers


The previous section defined a coarse pixel classification which is useful for an atmospheric cor-
rection. In addition, it supports an assessment of the quality of the processing. For example, a
large error in the radiometric calibration could cause a scene classification with all pixels labeled
as water. In this case, a user can immediately identify the problem. Of course, a more detailed
assessment is possible with an analysis of the reflectance spectra. Nevertheless, the classification
map (land, water, haze, cloud, etc) is a useful product and the quality of the atmospheric correction
may depend on the correct class assignment, at least for some classes.

The previous (haze, cloud, water, land) pixel classifyer is a binary decision: a pixel belongs to a
certain class or not. In reality the decision is typically not unique and a class assignment has only a
certain probability. As the absolute probability of a class assignment is very difficult to assess, we
use a simple 1-parameter equation to estimate a relative probability (0 - 100%). Currently there
are three quality layers: cloud, water, and snow/ice.

Cloud probability:
If a pixel belongs to the cloud class then the TOA reflectance of the red band is used together with a
CHAPTER 10. THEORETICAL BACKGROUND 232

linear scaling between the two reflectance thresholds Tc1 = 0.15, Tc2 = 0.35 and the corresponding
probabilities p1=60% and p2=100%:

ρ∗ (red) − Tc1
p(cloud) = p1 + (p2 − p1) ∗ (10.77)
Tc2 − Tc1
Probabilities higher than 100 are truncated to 100, values lower than 30 are reset to 30.

Water probability:
If a pixel belongs to the water class then the NDVI is used together with a linear scaling between
the two NDVI thresholds Tw1 = −0.30, Tw2 = 0.10 and the corresponding probabilities p1=60%
and p2=100%:
N DV I − Tw1
p(water) = p1 + (p2 − p1) ∗ (10.78)
Tw2 − Tw1
Probabilities higher than 100 are truncated to 100, values lower than 30 are reset to 30.

Snow /ice probability:


If a pixel belongs to the snow/ice class then the NDSI is used together with a linear scaling between
the two NDVI thresholds Ts1 = 0.70, Ts2 = 0.25 and the corresponding probabilities p1=60% and
p2=100%:
N DSI − Ts1
p(snow) = p1 + (p2 − p1) ∗ (10.79)
Ts2 − Ts1
Probabilities higher than 100 are truncated to 100, values lower than 30 are reset to 30.

10.4 Quality confidence layer


A quality confidence layer map (’scene atm qcl.bsq’) for a file ’scene.bsq’ is available indicating
the overall relative quality of the surface reflectance product. The values range from 0 - 100, with
100 the best quality. The quality depends on the aerosol optical thickness at 550 nm (AOT550)
and the solar zenith angle (SZA). In mountainous terrain, the local SZA is used. Figure 10.12
presents the functions Q(SZA) and Q(AOT550). The final quality confidence value is the product
Q = Q(SZA) * Q(AOT550). No quality confidence file will be written for a flat terrain scene and
constant visibility, because SZA and AOT550 do not vary (at least for small FOV imagery).

10.5 Standard atmospheric conditions


Standard conditions comprise scenes taken under a clear sky atmosphere. This means the visibility
(aerosol optical thickness) can be assumed as constant over a scene, or it might vary within a
certain range (excluding haze) and a visibility map can be calculated. It also includes situations
with constant or spatially varying water vapor column contents.

10.5.1 Constant visibility (aerosol) and atmospheric water vapor


This is the easiest case for atmospheric correction. Still, it can often be applied if homogeneous
atmospheric conditions exist. These might be encountered for small area scenes, i.e., high spatial
resolution imagery. If the sensor has no channels in atmospheric water vapor regions, results of
CHAPTER 10. THEORETICAL BACKGROUND 233

Figure 10.12: Quality confidence Q(SZA) and Q(AOT550).

atmospheric correction are not sensitive with respect to the selected water vapor content, and a
climatological value (e.g., midlatitude summer, US standard, or tropical water vapor profile) is
usually sufficient. For hyperspectral instruments, the processing has to include the image-derived
pixel-by-pixel water vapor map.

The program performs a check whether the specified visibility leads to negative reflectance pixels
for dark surfaces in the red band (660 nm, vegetation) and NIR band (850 nm, water). If this
is the case, the visibility is iteratively increased (up to VIS=120 km) to reduce the percentage of
negative reflectance pixels below 1% of the scene pixels. During an interactive ATCOR session
the user is notified, and can continue with the recommended visibility update or with the initial
visibility. During batch mode operation the program continues with the updated visibility (if the
input visibility in the .inn file is positive). For a negative visibility (in the ’*.inn’ file) no visibility
iterations are performed. A corresponding notice on the final visibility is given in the ”*atm.log”
output file. The set of visibility grid point is given in Table 10.2.

The iteration capability is most important for low visibility start values.

10.5.2 Aerosol retrieval and visibility map


If a sensor has the appropriate spectral bands the aerosol type and visibility or optical thickness
of the atmosphere can be derived, provided the scene contains reference areas of known reflectance
behavior (Kaufman and Sendra 1988, Kaufman et al. 1997). The minimum requirements are spec-
CHAPTER 10. THEORETICAL BACKGROUND 234

visibility [km] vis. increment [km]


5 3
8 3
11 3
14 3
17 3
20 3
23 3
26 4
30 5
35 5
40 5
50 10
60 10
70 10
80 20
100 20
120 max VIS=120 km

Table 10.2: Visibility iterations on negative reflectance pixels (red, NIR bands).

tral bands in the red and near IR. If the scene contains dense dark vegetation (DDV, coniferous
type) the reflectance values in the red band can be obtained from a correlation with the SWIR band
reflectance as detailed below. The visibility of each reference pixel can then be calculated in the
red band as the intersection of the modeled at-sensor radiance curve with the measured radiance,
see figure 10.13.

The measured radiance for a reference pixel of digital number DN is L = c0 + c1 DN , which is


a constant value indicated by the dashed line in figure 10.13. The curve indicates the modeled
radiance. It employs the reflectance of the reference surface (e.g., ρref = 0.02) and uses values
of path radiance, atmospheric transmittance, and global flux for the current solar and viewing
geometry stored in precalculated LUTs.

Automatic masking of reference areas (1.6 or 2.2 µm band required, or at least red/NIR bands)

If the sensor has a SWIR band (at 1.6 or 2.2 µm), then the scene can be searched for dark pixels in
this band and a correlation of the SWIR reflectance with the reflectance in the red and blue band
can be employed to estimate the visibility automatically (Kaufman et al. 1997). For this purpose,
we use a modified version of the original idea for the following algorithm.
If a SWIR band exists the SWIR reflectance is calculated assuming a visibility of 23 km (instead of
the original version of top of atmosphere reflectance). Then, water pixels are excluded by employing
only those pixels with SWIR reflectance values above 1% and an NDVI > 0.1. For the 2.2 µm band
the upper threshold of the reflectance of the dark pixels is selected as 5%. If the number of reference
pixels is less then 1% of the image pixels, then the upper threshold is increased to 10% or finally
12%. If a 1.6 µm band exists, but no 2.2 µm band, the corresponding upper thresholds are selected
as 10% and 15%, or finally 18%, respectively. The reflectance ratios for the red (near 0.66 µ) and
CHAPTER 10. THEORETICAL BACKGROUND 235

Figure 10.13: Schematic sketch of visibility determination with reference pixel.

blue (near 0.48 µm) band are then calculated as :

ρred = 0.5 ρ2.2 and ρ0.48 = 0.5 ρ0.66 + 0.005 (10.80)

ρred = 0.25 ρ1.6 and ρ0.48 = 0.5 ρ0.66 + 0.005 (10.81)

The offset 0.005 for the blue band yields a better correlation with ground measurements than a
zero offset ([24]. Therefore, it is included starting with the 2013 release of ATCOR.

This situation is sketched in figure 10.14. The correlation factor of 0.5 between the 2.2 µm and the
red region is not a universal constant, but may typically vary between 0.4 and 0.6. The correlation
actually also works for dark soils. So the dark pixels may also include soil areas. For narrow band
hyperspectral sensors a band close to 2.13 µm is used instead of a 2.20 µm band.
The red band is then used to calculate the visibility (compare figure 10.13) as the intersection of
the measured radiance with the simulated visibility-dependent at-sensor radiance curve. Since the
same visibility is employed for the blue spectral band this provides an opportunity to adjust the
spectral behavior of the path radiance (which is essentially the aerosol path radiance, since the
Rayleigh path radiance is known) in the blue spectral region.

Lupdate
p,blue = Lblue − τblue ρblue Eg,blue /π (10.82)

Deep blue channels

For most multispectral sensors a blue channel in the 470 - 490 nm region was the shortest wave-
length channel in the past. However, with the availability of Worldview-2 and Landsat-8 OLI
and hyperspectral data there is often a need to adjust the path radiance in the deep blue region
< 470 nm, because the limited set of discrete aerosol models might not be adequate. Therefore,
an empirical approach is taken: the DDV surface reflectance at 400 nm is set to 0.6 times the
CHAPTER 10. THEORETICAL BACKGROUND 236

Figure 10.14: Correlation of reflectance in different spectral regions.

reflectance of the standard blue (480 nm) channel and the reflectance for channels in between is
linearly interpolated:
ρddv ddv
0.400 = 0.6 ρ0.480 (10.83)

ρddv ddv
0.480 − ρ0.400
ρddv (λ) = ρddv
0.400 + (λ − 0.400) (10.84)
0.480 − 0.400
Multispectral sensors usually have only one or two channels in the 400 - 470 nm region. In case of
hyperspectral instruments, the channels closest to 410 nm and 440 nm are selected as tie channels
to calculate the corresponding path radiance, and exponential interpolation is used to obtain the
path radiances for the remaining bands in the 400 - 480 nm region.

The question of an automatic aerosol type calculation is addressed next. It is restricted to the
available number of aerosol models, and uses path radiance ratios of the 0.66, 0. 48 µm channels
derived from the scene DDV pixels and the corresponding path radiance in the MODTRAN LUTs.

Aerosol type estimation

After calculation of the scene path radiance in the blue (0.48 µm) and red (0.66 µm) region (as
total minus reflected radiance, using the average values obtained for the dark reference pixels)
the ratio of Lp (blue, scene) to Lp (red, scene) can be compared to the corresponding ratio for the
MODTRAN standard aerosols (rural, urban, maritime, desert) :
Lp (blue, scene)/Lp (red, scene)
dp = (10.85)
Lp (blue, M ODT RAN )/Lp (red, M ODT RAN )
The aerosol type for which the double ratio (dp ) is closest to 1 is the best approximation for
the scene. It approximates the corresponding MODTRAN aerosol type. However, some fine
tuning is subsequently performed to be able to modify the wavelength behavior of the path ra-
diance compared to the standard aerosol types. If Lp (blue, scene) deviates more than 5% from
Lp (blue, M ODT RAN ) then Lp (blue, scene) is used as the valid path radiance. In addition, the
path radiance for any other bands in the blue to red region is linearly re-scaled with the factor
CHAPTER 10. THEORETICAL BACKGROUND 237

Lp (blue, scene)/Lp (blue, M ODT RAN ), see Figure 10.15. Here, the path radiance in the red band
is used as a fixed tie point. For wavelengths greater than 700 nm a posssible typical 10% differ-
ence in path radiance between the selected aerosol type (after fine tuning) and the actual aerosol is
usually not important, because path radiance contributes only a small fraction to the total radiance.

If the sensor has no blue spectral band, but a green band, than the green band is substituted and
for the dense dark vegetation the surface reflectance relationship is used:
ρ(green) = 1.3 ρ(red) (10.86)
Now eq. 10.82 is again employed for the green band instead of the blue band to calculate the path
radiance, the best match to a MODTRAN aerosol type, and possibly a fine tuning of the path
radiance.

Figure 10.15: Rescaling of the path radiance with the blue and red band.
After subtraction of the reflected radiance from the total radiance in the blue band the remaining
signal is the updated path radiance in the blue band. The path radiance of bands in the blue to
red region is then rescaled with interpolation.

Aerosol retrieval for VNIR sensors

If no SWIR bands exist, but at least a red band (around 660 nm) and a NIR band (around 850 nm)
a different approach has to be taken, see reference [?] for details. It starts with the assumption of
average clear atmospheric conditions (visibility VIS=23 km) to calculate the surface reflectance in
the red and NIR bands which is appropriate for situations of clear atmospheres (VIS = 15 - 40 km).
The second step derives a mask of dark vegetation pixels using the ratio vegetation index rvi of
the red and near-infrared surface reflectance, rvi = ρnir /ρred , and multiple reflectance thresholds:
• The mask pixels have to fulfill: rvi ≥ 3 and ρnir ≥ 0.10 and ρnir ≤ 0.25 and ρred ≤ 0.04 .
Water pixels are automatically excluded from this mask because of the ρnir ≥ 0.10 condition, and
soil pixels are excluded with the combination of all four conditions. If the percentage of reference
pixels is smaller than 2% of the scene the search is iterated with VIS=60 km (covering the very
clear conditions of visibility = 40 - 60 km). Again, if the percentage is smaller than 2%, the search
is iterated with VIS=10 km to cover higher aerosol loadings (VIS = 8 - 15 km). Each visibility
iteration is supplemented with an iteration of the threshold ρred which is decreased in steps of 0.005
down to ρred = 0.025 to include only the darkest vegetation pixels (see [?] for details). Currently,
CHAPTER 10. THEORETICAL BACKGROUND 238

the algorithm terminates if less than 2% reference pixels are found after these two iterations. In this
case, the user has to employ the constant visibility option specifying the value of the visibility for
the scene. During batch mode operation the program takes the specified visibility (from the ”.inn”
file). Then a check for negative reflectance pixels is performed with dark pixels in the red band
(660 nm, vegetation) and the NIR band (850 nm, water), and the visibility is iteratively increased
(up to VIS=60 km) to reduce the percentage of negative reflectance pixels below 1% of the scene
pixels. A corresponding notice is given in the ”*atm.log” output file.
The third step calculates the surface reflectance in the red band as a fraction α of the NIR band
reflectance:

ρred = α ∗ ρnir = 0.1 ∗ ρnir (10.87)

Similar to the empirical SWIR relationships the coefficient α = 0.1 is an average empirical value
yielding results in close agreement with the SWIR method in many cases. However, deviations
from the nominal value α = 0.1 can vary about 30% depending on biome. Before the final step of
atmospheric correction takes place the visibility of non-reference pixels in the scene can be set to
the average value of the reference pixels or a spatial interpolation can be applied.

If the percentage of dark reference pixels with eq. 10.87 is less than 2% and if a blue spectral band
exists, then the atmospherically resistent vegetation index (ARVI) is employed to include somewhat
brighter pixels as reference areas. The ARVI is defined as :
ρ∗N IR − ρ∗rb
ARV I = (10.88)
ρ∗N IR + ρ∗rb
The asterisk in ρ∗ indicates a TOA reflectance with the Rayleigh contribution already subtracted,
and

ρ∗rb = ρ∗red + 1.3 (ρ∗red − ρ∗blue ) (10.89)

If A1 , A2 are the lower and upper ARVI thresholds (A2 = 0.9 is fixed) then additional dark reference
pixels are searched which fulfill A1 < ARV I < A2 . The inital value is A1 = 0.8, and it is iteratively
decreased to A1 = 0.64 until at least 2% of these additional reference pixels are found or the
iteration terminates. We use the following simple empirical equation for the surface reflectance in
the red band:
ARV I − A2
ρred = 0.01 + 0.03 (10.90)
A1 − A2
In reality, this relationship is dependent on biome, season, and geography [63]. Corresponding
maps have been developed for the MERIS sensor, using a coarse reolution of about 3 km x 3 km,
but these are not appropriate for high spatial resolution instruments. Finally, the dark reference
pixels from both VNIR approaches (eq. 10.87 and 10.90 are combined.

Visibility and aerosol optical thickness

The visibility calculated for each reference pixel (range 5 - 190 km in ATCOR) is converted into
an integer, called visibility index vi, with range 0-182. The visibility index is closely related to the
total optical thickness δ at 550 nm, the equidistant optical thickness spacing is 0.006 for a ground
at sea level, and smaller for increasing elevations.

δ = 0.185 + 0.006 ∗ vi (10.91)


CHAPTER 10. THEORETICAL BACKGROUND 239

It is easy to calculate the aerosol optical thickness (AOT) from a known total optical thickness by
subtracting the Rayleigh optical thickness and a very small trace gas optical thickness, compare
Fig. 2.1 in chapter 2.
With the MODTRAN code the AOT (at 550 nm) can be calculated from a given visibility VIS
(km) as

AOT = exp (a(z) + b(z) ln(V IS)) (10.92)

where z is the surface elevation, and a(z), b(z) are coefficients obtained from a linear regression of
ln(AOT ) versus ln(V IS).

Figure 10.16: Optical thickness as a function of visibility and visibility index.


CHAPTER 10. THEORETICAL BACKGROUND 240

10.5.3 Water vapor retrieval


A water vapor retrieval can be included after the aerosol retrieval because the aerosol retrieval
does not use water vapor sensitive spectral bands, but the water vapor algorithm (employing bands
around 820 nm, 940 nm, or 1130 nm) depends on aerosol properties. The water vapor retrieval
over land is performed with the APDA (atmospheric precorrected differential absorption) algorithm
[65]. In its simplest form, the technique uses three channels, one in the atmospheric water vapor
absorption region around 820 nm, 940 nm, or 1130 nm (the ”measurement” channel), the others
in the neighboring window regions (”reference” channels). The depth of the absorption feature is
a measure of the water vapor column content, see figure 10.17.
In case of three bands the standard method calculates the water vapor dependent APDA ratio as :
L2 (ρ2 , u) − L2,p (u)
RAP DA (ρ, u) = (10.93)
w1 (L1 (ρ1 ) − L1,p ) + w3 (L3 (ρ3 ) − L3,p )
where the index 1 and 3 indicates window channels (e.g. in the 850-890 nm region and 1010-1050
nm region), respectively. Index 2 indicates a channel in the absorption region (e.g., 910-950 nm).
L and Lp are the total at-sensor radiance and path radiance, respectively. The symbol u indicates
the water vapor column. The weight factors are determined from
w1 = (λ3 − λ2 )/(λ3 − λ1 ) and w3 = (λ2 − λ1 )/(λ3 − λ1 ) (10.94)

Figure 10.17: Reference and measurement channels for the water vapor method. The at-sensor radiance
is converted into an at-sensor reflectance.

The problem is the estimation of the surface reflectance ρ2 in the absorption band (eq. 10.93). The
technique tries to estimate the reflectance ρ2 with a linear interpolation of the surface reflectance
values in the window channels (ch. 1, 3) that are not or only slightly influenced by the water vapor
content: Therefore, the reflectance ρ2 is calculated as
ρ2 = w1 ρ1 + w3 ρ3 (10.95)
Then equation (10.93) can be written as
ρ2 τ2 (u)Eg2 (u) τ2 (u)Eg2 (u)
RAP DA (u) = = (10.96)
ρ2 τ2 (u = 0)Eg2 (u = 0) τ2 (u = 0)Eg2 (u = 0)
CHAPTER 10. THEORETICAL BACKGROUND 241

where Eg2 (u) is the global flux on the ground for the measurement channel (index 2). ATCOR
employs 4 to 5 water vapor columns (u=0.4, 1.0, 2.0, 2.9, 4.0 cm, sea-level-to space geometry) to
calculate an exponential fit function

RAP DA (u) = exp(−α + β u) (10.97)

which can be solved for the water vapor column u , see Fig. 10.18, where the diamonds in the
figure mark the calculated water vapor grid points (u= 0.4, 1.0, 2.0, 2.9 cm) :
α + lnRAP DA 2
u=( ) (10.98)
β

Figure 10.18: APDA ratio with an exponential fit function for the water vapor.

Equations (10.93, 10.95 to 10.98) are iterated, starting with u=1.0 cm, calculating RAP DA , up-
dating u, Li,p (u), ρ1 , ρ3 and repeating the cycle. A minimum of two channels (one reference, one
measurement channel) is required. The advanced APDA method can take into account multiple
absorption channels in the 810-820 nm, 910-960 nm and 1110-1150 nm regions. Two water vapor
retrieval algorithms are available in ATCOR (compare chapter 9.4, parameter iwv model = 1, 2):

1. The water vapor maps with the smallest standard deviation in the 940 nm and 1130 nm region
are selected. Finally, if both regions are available, the average of these two water vapor maps
is taken (parameter iwv model=1 in the ”.inn” file).

2. A linear regression ratio (LIRR) is applied to multiple bands (parameter iwv model=2). This
water vapor map might be more accurate, because the regression reduces sensor noise and
may partially compensate calibration problems in lucky cases. Although the water vapor map
might be less noisy, the retrieved surface reflectance spectrum will always retain any channel
calibration problems.

Remarks:
CHAPTER 10. THEORETICAL BACKGROUND 242

1. The APDA algorithm is relatively fast. Its disadvantage is that it is not stable numerically for
very low reflectance targets (water, shadow regions). The transmittance slope ratio method
[?] might work better in these cases, so it is an interesting alternative water vapor algorithm.
However, since the required processing time is much higher than for the APDA method, it is
currently not implemented in the ATCOR environment. In addition, the method requires data
with a very accurate spectral and radiometric calibration, otherwise its potential advantage
will be lost.

2. Five water vapor grid points at 0.4, 1.0, 2.0, 2.9, and 4.0 cm are sufficient to cover the 0.5 -
5.0 cm range with an accuracy of about 5-10 % [?].

10.6 Non-standard conditions


The non-standard situations refer to scenes with a substantial amount of haze and shadow areas.
The non-standard atmospheric conditions treat the haze removal and de-shadowing employing spec-
tral and statistical algorithms. Although bidirectional surface reflectance effects are independent of
the atmospheric conditions, the subject is included here, because the isotropic reflector is used for
the standard conditions. We present some methods of BRDF correction in flat and rugged terrain.

10.6.1 Haze removal


In many cases of satellite imagery the scene contains haze and cloud areas. The optical thickness
of cloud areas is so high that the ground surfaces cannot be seen, whereas in hazy regions some
information from the ground is still recognizable. In ATCOR the scene is partitioned into clear,
hazy, and cloud regions. Here we will treat the low altitude boundary layer (0 - 3 km) haze as
opposed to high altitude cirrus. Thin boundary layer haze can be detected with broad-band mul-
tispectral instruments, while a detection of thin cirrus requires specific narrow bands around 1.38
µm or 1.88 µm, compare chapter 10.6.5. As a first approximation, haze is an additive component
to the radiance signal at the sensor. It can be estimated and removed as described below. Cloud
areas have to be masked to exclude them from haze areas and to enable a successful haze removal.
The treatment of cloud shadow regions is discussed in chapter 10.6.6.

Two de-hazing algorithms are available: the first one is based on the HTM (Haze Thickness Map)
[27], the second employs the HOT (Haze Optimized Transform) [?]. The first method can be
submitted from a GUI (graphical user interface) or as a batch job and performs the de-hazing on
the original digital number (DN) data. This is an optional pre-processing step to ATCOR. An
atmospheric correction can be performed as an independent next step to obtain surface reflectance
data. The second method performs a de-hazing embedded in ATCOR, so it is always combined
with the atmospheric correction. It is available in the GUI and batch modes.

In most cases the HTM method provides better results. The HTM dehaze is performed for channels
in the 0.4 - 2.5 µm region, while the HOT algorithm is restricted to the visible channels..

10.6.2 Haze removal with HTM


This method automatically detects and removes haze and cirrus in medium and high spatial resolu-
tion multispectral images. The dark-object subtraction algorithm is further developed to calculate
a haze thickness map (HTM). The haze thickness is computed for each spectral band excluding
CHAPTER 10. THEORETICAL BACKGROUND 243

very bright object, because these can be misinterpreted as hazy areas. The haze thickness for these
bright object pixels is appoximated by a spatial interpolation. The first step is the search for dark
pixels using a small local nonoverlapping window box (w=3 x 3 pixels) for the calculation of the
haze thickness map (HTM). For this purpopse a blue spectral channel is employed, because it is
most sensitive to haze. If no blue band exists, the green band is taken. The next step calculates
an additional HTM map with a moderately large window size (e.g. w= 21 x 21 pixels). It is used
to label haze and haze-free regions by thresholding this HTM map. The third step calculates the
correlation of the band-specific HTM(λ) maps, and re-scales these maps in the interval (1,0.1) for
λ = (λblue , 2.2µm). More details can be found in the reference papers [27, 28]. If the remotely
sensed image contains a cirrus band, then a combined haze/cirrus correction is performed [28].

The initial HTM method [27] contained an image segmentation method to exclude bright objects.
Since this is rather time-consuming, it is replaced (since 2016) with the following three criteria
using the statistics of the TOA reflectance in the blue ρ∗b , red ρ∗r , and NIR ρ∗n bands:
ρ∗b ≥ ρ̄∗b + 2 σb ∧ ρ∗r ≥ ρ̄∗r + 2 σr ∧ ρ∗n ≥ 0.10 (10.99)
where σ is the standard deviation.

In addition, a classification map (water, cloud, haze, cirrus, bright, snow) is provided and integrated
into the dehazing/decirrus module.

Starting with the 2018 release the dehaze pre-processing module also supports hyperspectral im-
agery. In this case 11 reference wavelengths are defined (0.440, 0.480, 0.560, 0.660, 0.740, 0.850,
1.000, 1.090, 1.640, 2.200, 2.400 µm), and the band-specific HTM is calculated for the nearest hy-
perspectral center wavelength. HTM maps for the other channels are obtained with interpolation
or extrapolation, which is sufficient, because the band-dependent HTM maps change slowly with
wavelength.

The HTM module contains a number of keywords, the list can be obtained by just typing ’dehaze’
on the IDL command line. If the keyword water is set to 1, then dehazing is also performed
for water pixels. But it is switched off, if overcorrection occurs. For this purpose, atmospheric
correction is conducted (red band, water pixels) using a visibility of 40 km, i.e. AOT(550 nm) =
0.20, and if more than 30% of the water pixels have a surface reflectance < 0.01 then the dehaze
over water is switched off. Some other features are:
• The accuracy of the dehaze map to classify water pixels is improved if DEM data (slope)
is available. If the file name of the scene is ’scene.bsq’ or ’scene.tif’, then the elevation and
slope files should be ’scene ele.bsq’ and ’scene slp.bsq’. Other file names are also accepted, if
they are specified in the ’scene.inn’. Water pixels are first classified with spectral criteria, in
addition the DEM slope must be smaller than 3◦ .
• Sentinel-2 cube of the 10m data: the cirrus information of the 20m/60m data is used.
• Sentinel-2 cube of the 10m data: the DEM slope map of the 20m slope (resampled to 10m)
is used.

10.6.3 Haze removal with HOT


The second haze removal algorithm (HOT = Haze Optimized Transform) runs fully automatic. It
is a combination of the improved methods [?], [?] and consists of five major steps :
CHAPTER 10. THEORETICAL BACKGROUND 244

1. Masking of clear and hazy areas with the tasseled cap haze transformation [?].

T C = x1 ∗ BLU E + x2 ∗ RED (10.100)

where BLUE, RED, x1 , and x2 are the blue band, red band, and weighting coefficients,
respectively. The clear area pixels are taken as those pixels where TC is less than the mean
value of TC.

2. Calculation of the regression between the blue and red band for clear areas (”clear line” slope
angle α), see figure 10.19. If no blue band exists, but a green spectral band, then the green
band is used as a substitute.

3. Haze areas are orthogonal to the ”clear line”, i.e., a haze optimized transform (HOT) can be
defined as (Zhang et al. 2002):

HOT = BLU E ∗ sinα − RED ∗ cosα (10.101)

4. Calculation of the histogram of HOT for the haze areas.

5. For bands below 800 nm the histograms are calculated for each HOT level j. The haze signal
∆ to be subtracted is computed as the DN corresponding to HOT(level j) minus the DN
corresponding to the 2% lower histogram threshold of the HOT(haze areas). The de-hazed
new digital number is (see figure 10.19):

DN (new) = DN − ∆ (10.102)

Figure 10.19: Haze removal method. Left: regression between red and blue band for clear areas. Right:
calculation of Delta=∆ as a function of the HOT haze level (example Landsat TM band 1).

So the haze removal is performed before the surface reflectance calculation. Two options are
available: the use of a large area haze mask (eq. 10.103), which is superior in most cases, or a
compact smaller area haze mask (eq. 10.104).
HOT > mean(HOT ) − 0.5 ∗ stdev(HOT ) (10.103)

HOT > mean(HOT ) (10.104)


CHAPTER 10. THEORETICAL BACKGROUND 245

In addition, the user can select between haze removal of ”thin / medium haze” or ”thin to moder-
ately thick haze”, the last option is superior in most cases.

The algorithm only works for land pixels, so the near infrared band (NIR) is used to exclude water
pixels. The current implementation provides a mask for haze-over-land (see the ’* out hcw.bsq’
file). The haze-over-water mask is treated in the next section.

Figure 10.20 shows an example of a subset of an Ikonos scene of Dresden where the haze removal
algorithm was applied. More images with the results of the haze removal method are shown on
ATCOR’s web page, http://www.rese.ch .

Figure 10.20: Subset of Ikonos image of Dresden, 18 August 2002. Space


c Imaging Europe 2002. Left:
original scene, right: after haze removal. Color coding: RGB=4/2/1 (NIR/Green/Blue bands)

10.6.4 Haze or sun glint removal over water


The haze removal over water uses a near infrared (NIR) band to estimate the spatial distribution of
haze. The principal method is described in [?]. We use a modified version of this approach without
an interactive definition of haze polygons. First, the water pixels are masked either using spectral
criteria or taking an external water map. If the scene is named ”scene1.bsq” the external map must
be named ”scene1 water map.bsq”, a 1-channel 8-bit/pixel or 16-bit/pixel file where water is coded
with an arbitrary positive number. The external map is automatically taken if it is placed in the
same folder as the scene. The second step is the definition of clear water pixels using the apparent
reflectance in the NIR band. Pixels are labeled as clear if
ρ∗ (N IR) < T1 (clear) clear pixels (10.105)
The default value is T1 (clear) = 0.04 (i.e. 4%). The value is one of the editable preference
parameters (see chapter 9.3). Thin haze over water is defined as:
T1 (clear) ≤ ρ∗ (N IR) ≤ 0.06 thin haze (10.106)
Medium haze over water is defined as:
0.06 < ρ∗ (N IR) ≤ T2 (haze) medium haze (10.107)
CHAPTER 10. THEORETICAL BACKGROUND 246

The default value is T2 (haze) = 0.12 (i.e. 12%). This value is also one of the editable preference
parameters. The third step is a linear regression between haze pixels in the NIR band and each
other (reflective) band. The regression is iterated with only those pixels deviating less than half
a standard deviation from the average. If αj and βj denote offset and slope of the regression line,
respectively, the de-hazed pixel for each channel j can be calculated as

DN (corrected, j) = DN (original, j) − (αj + βj DNN IR − DN (clear, j)) (10.108)

where DN (clear, j) is the average of all clear water pixels in channel j. The same technique is also
employed to remove sun glint. The main problem is the specification of the clear water threshold.
If the threshold is too low, clear water pixels are included in the haze mask, if it is set too high haze
or sun glint pixels will be included in the clear pixel class. There is no unique solution, because
sandy bottoms over shallow water can have a similar spectral reflectance behavior as haze, so the
clear water threshold is scene-dependent. In addition, the upper threshold defining haze (or sun
glint) might be scene-dependent. However, the default values usually provide good results and a
solid basis for a possible iteration of these two parameters.
Figure 10.21 presents an example of haze removal over water with the two default values of
T1 (clear) = 0.04 and T2 (haze) = 0.12. The de-hazing over water is successful to a large ex-
tent, however, some artifacts appear close to the land border (image center) where haze pixels over
water are classified as land or cloud. This is due to a simple spectral classification of the land /
water mask, an external water map would lead to better results.

Figure 10.21: Haze removal over water, ALOS-AVNIR2 true color image, northern Germany, 16 April
2007. Left: part of original scene, right: after haze removal.
CHAPTER 10. THEORETICAL BACKGROUND 247

10.6.5 Cirrus removal


On the first glance, images contaminated by cirrus appear similar to hazy scenes discussed in the
previous section. However, haze usually occurs in the lower troposphere (0-3 km) while cirrus clouds
exist in the upper troposphere and lower stratosphere (8 - 16 km). The effect of boundary layer
haze can be observed in the visible region, but seldom in longer wavelength channels > 850 nm.
However, cirrus also affects the NIR and SWIR spectral regions. Thin cirrus clouds are difficult
to detect with broad-band multispectral satellite sensors in the atmospheric window regions, espe-
cially over land, because land scenes are spatially inhomogeneous and this type of cloud is partially
transparent. On the other hand, water vapor dominates in the lower troposphere and usually 90%
or more of the atmospheric water vapor column is located in the 0 - 5 km altitude layer. Therefore,
if a narrow spectral band is selected in a spectral region of very strong water vapor absorption, e.g.,
around 1.38 µm or 1.88 µm, the ground reflected signal will be totally absorbed, but the scattered
cirrus signal will be received at a satellite sensor or a sensor in a high-altitude aircraft (e.g., 20 km
AVIRIS scenes).

So a narrow channel at 1.38 µm is able to detect cirrus clouds, and if a correlation of the cirrus
signal at this wavelength and other wavelengths in the VNIR and SWIR region can be found, then
the cirrus contribution can be removed from the radiance signal to obtain a cirrus-corrected scene.
The basic ideas of cirrus correction were presented in several papers ([10], [12], [13], [60]). The
algorithm differs for water and land pixels. For water, a scatterplot of the 1.38 µm versus the 1.24
µm channel is used, for land the band-correlation is determined from a scatterplot of the 1.38 µm
versus a red channel (around 0.66 µm). To obtain a high sensitivity, only vegetation pixels are
taken because they have a low reflectance in the red spectral region, so the cirrus contribution is
easily traced. The scatterplot is computed in terms of the apparent (TOA or at-sensor) reflectance
of ρ1.38 versus ρred where the apparent reflectance is defined as:
πL
ρ∗ = (10.109)
Es cosθs
where L is the recorded radiance signal, Es the extraterrestrial solar irradiance for the selected
band, and θs is the solar zenith angle. Following [10] the method can be described by the following
set of equations:

Tc (λ) ρ(λ)
ρ∗ (λ) = ρc (λ) + (10.110)
1 − sc (λ) ρ(λ)

Here, ρc is the reflectance of the cirrus cloud, Tc the two-way transmittance (direct plus diffuse)
through the cloud, ρ the reflectance of the ”virtual” surface (land or water surface including all
effects of molecular and aerosol scattering below the cirrus), and sc is the cloud base reflectance of
upward radiation. Eq. 10.110 can be simplified, because of sc ρ << 1, yielding

ρ∗ (λ) = ρc (λ) + Tc (λ) ρ(λ) (10.111)

With the assumption that the cirrus reflectance ρc (λ) is linearly related to the cirrus reflectance at
1.38 µm in the 0.4 - 1.0 µm spectrum (small variation of single scattering properties of ice crystals,
and single scattering albedo close to 1) we obtain

ρ∗ (λ) = ρc (1.38µm) / γ 0.4 < λ < 1.0 µm (10.112)


CHAPTER 10. THEORETICAL BACKGROUND 248

where γ is an empirical parameter that can be derived from the scene scatterplot of ρ1.38 versus
ρred (land) or ρ1.24 (water). It depends on the scene content, cirrus cloud height, and solar and
viewing angles [12, 60]. Substituting eq. 10.112 into eq. 10.111 yields

Tc (λ) ρ(λ) = ρ∗ (λ) − ρc (1.38µm) / γ (10.113)

Neglecting the cirrus transmittance Tc (i.e., setting Tc = 1), we obtain the ”cirrus path radiance
corrected” apparent reflectance image (index ’cc’):
ρ∗cc (λ) = ρ∗ (λ) − ρc (1.38µm) / γ (10.114)
As the cirrus is almost on top of the atmosphere we have ρc (1.38µm) = ρ∗c (1.38µm) and the ap-
parent cirrus reflectance can be calculated with eq. 10.109.

Note
The calculation of gamma with the scatterplot of the TOA reflectance of the red/cirrus bands
is the standard method. The drawback is that the slope is not always well defined. Therefore,
a numerically more stable method is used: the value of γ is calculated iteratively in the typical
range (0.6 to 1.0) with an increment of 0.05. We define a cirrus class with ρ∗c (1.38) > 0.02 (or
ρ∗c (1.38) > 0.014 if less than 10,000 pixels in this class), and a non-cirrus class with ρ∗c (1.38) < 0.008,
or ρ∗c (1.38) < 0.010 or ρ∗c (1.38) < 0.011 if not enough pixels. Then the mean value of the DN of
3 bands (around 440, 480, 550 nm) is computed for the cirrus-free areas DNf ree (i), i=1, 2, 3.
It is also computed for the areas in the cirrus class as a function of γj , i.e. after cirrus removal
DNdecirrus (γj , i) with equation (10.114). Finally, the value of γj is selected which minimizes the
difference ∆(γj ) :
3
X
∆(γj ) = M in { | DNf ree (i) − DNdecirrus (γj , i) | } (10.115)
i=1

A similar approach is used for the SWIR bands: γ is varied in the range 1 - 2 (values are larger
in the SWIR than in the VNIR), increment 0.05, until the absolute difference between the mean
of |ρ∗ (SW IR, cirrus) − ρ∗c (1.38, cirrus)/γ| and ρ∗ (SW IR, no − cirrus) is less than 3%. If this
criterion fails, then the former criterion γ(SW IR) = 2 γ(V N IR) is used [60].

Cirrus removal can be conducted as the first step during atmospheric correction, followed by the
aerosol, water vapor, and surface reflectance retrievals. If the average water vapor column W of a
scene is less than some threshold (default W=0.6 cm) then the cirrus removal algorithm is switched
off, to avoid a misinterpretation of bright surfaces as cirrus in the 1.38 µm channel. Normally, at-
mospheric water vapor completely absorbs surface features in the 1.38 µm channel, but the channel
might become partly transparent to surface features for very low water vapor values. This water
vapor threshold can be set by the user, see chapter 9.3.

The file ’xxx out hcw.bsq’ (haze, cloud, water) corresponding to a scene ’xxx.bsq’ contains five cir-
rus classes (thin, medium, thick, cirrus cloud, thick cirrus cloud) for visualization, see chapter 4.8,
but the cirrus removal is independent of the class labeling.

The cirrus and (boundary layer) haze removal options in the ATCOR parameter setting (”*.inn”)
are exclusive, i.e., only one of them can be selected per ATCOR run. However, the preprocessing
batch module dehaze or the ATCOR GUI (’ATCOR’, ’Haze(HTM)+Cirrus removal’) can perform
a combined haze/cirrus removal [28] (without aerosol, water vapor, surface reflectance retrievals).
Thereafter, the ATCOR run obviously should not use the haze/cirrus removal a second time.
CHAPTER 10. THEORETICAL BACKGROUND 249

10.6.6 De-shadowing with matched filter


Remotely sensed optical imagery of the Earth’s surface is often contaminated with cloud and cloud
shadow areas. Surface information under cloud covered regions cannot be retrieved with optical
sensors, because the signal contains no radiation component being reflected from the ground. In
shadow areas, however, the ground-reflected solar radiance is always a small non-zero signal, be-
cause the total radiation signal at the sensor contains a direct (beam) and a diffuse (reflected
skylight) component. Even if the direct solar beam is completely blocked in shadow regions, the
reflected diffuse flux will remain, see Figure (10.22). Therefore, an estimate of the fraction of direct
solar irradiance for a fully or partially shadowed pixel can be the basis of a compensation process
called de-shadowing or shadow removal. The method can be applied to shadow areas cast by clouds
or buildings.

This section describes a de-shadowing method based on the matched filter approach, which is com-
plementary to the scene-based method described in section 10.1.2.

The proposed de-shadowing technique works for multispectral and hyperspectral imagery over land
acquired by satellite / airborne sensors. The method requires a channel in the visible and at least
one spectral band in the near-infrared (0.8-1 µm) region, but performs much better if bands in the
short-wave infrared region (around 1.6 and 2.2 µm) are available as well. The algorithm consists of
these major components: (i) the calculation of the covariance matrix and zero-reflectance matched
filter vector, (ii) the derivation of the unscaled and scaled shadow function, (iii) a histogram thresh-
olding of the unscaled shadow function to define the core shadow areas, (iv) a region growing to
include the surroundings of the core shadow areas for a smooth shadow/clear transition, and (v)
the de-shadowing of the pixels in the final shadow mask. Details are published in [?].

Figure 10.22: Sketch of a cloud shadow geometry.

The method starts with a calculation of the surface reflectance image cube ρi = ρ(λi ), where
three spectral bands around λi = 0.85, 1.6, and 2.2 µm are selected. These bands from the near
and shortwave infrared region are very sensitive to cloud shadow effects, because the direct part
of the downwelling solar radiation flux at the ground level is typically 80% or more of the total
downwelling flux. Channels in the blue-to-red region (0.4-0.7 µm) are not used for the detection of
shadow regions because they receive a much larger diffuse radiation component, making them less
CHAPTER 10. THEORETICAL BACKGROUND 250

sensitive to partial shadow effects. Instead, visible channels serve to define a potential cloud mask.

The surface reflectance is first computed with the assumption of full solar illumination, i.e., the
global flux on the ground consists of the direct (Edir ) and diffuse (Edif ) component. If DN
denotes the digital number of a pixel, LP the path radiance, and τ the atmospheric transmittance
(ground-to-sensor) the surface reflectance can be obtained as:
π(d2 {c0 (i) + c1 (i)DNi (x, y)} − Lp,i )
ρi (x, y) = (10.116)
τi {Edir,i + Edif,i }
Here, d is the Earth-Sun distance at the image acquisition time in astronomical units, c0 and c1
are the radiometric calibration coefficients (offset and slope) to convert the digital number into the
corresponding at-sensor radiance L, i.e., L = c0 + c1 DN , and i is the channel index.

The proposed de-shadowing algorithm consists of a sequence of eight processing steps as sketched
in Fig. 10.23. It starts with the atmospheric correction. The next step is the masking of water
bodies and cloud areas with simple spectral criteria as detailed below. Water pixels have to be
excluded as far as possible to avoid their assignment as shadow pixels.
Step 3 calculates the covariance matrix C(ρ) where ρ is the surface reflectance vector comprising
only the non-water and non-cloud pixels. For each pixel, this vector holds the reflectance values
in the 3 selected channels (around 0.85, 1.6, 2.2 µm). The matched filter is a vector tuned to a
certain target reflectance spectrum ρt to be detected [?] :
C −1 (ρt − ρ̄)
Vmf = (10.117)
(ρt − ρ̄)T C −1 (ρt − ρ̄)

Figure 10.23: Flow chart of processing steps during de-shadowing.

Here, ρ̄ is the scene-average spectrum, without the water/cloud pixels. Selecting ρt = 0 for a
shadow target yields a special simplified form of the matched filter, where the ’sh’ index symbolizes
shadow:
C −1 ρ̄
Vsh = − T −1 (10.118)
ρ̄ C ρ̄
CHAPTER 10. THEORETICAL BACKGROUND 251

The shadow matched filter vector is then applied to the non-water/non-cloud part of the scene
and yields the still un-normalized values φ that are a relative measure of the fractional direct
illumination, also called unscaled shadow function here:
T
Φ(x, y) = Vsh (ρ(x, y) − ρ̄) (10.119)

The matched filter calculates a minimum RMS shadow target abundance for the entire (non-
water/non-cloud) scene. Therefore, the values of Φ are positive and negative numbers. The arbi-
trary, image-depending range of Φ has to be rescaled to the physical range from 0 to 1, where 0
indicates no direct illumination (full shadow), and 1 means full direct illumination. The histogram
of Φ is used to rescale the image data. Fig. 10.24 shows a schematic sketch of such a histogram with
a smaller peak (at Φ2 ) representing the shadow pixels and the main peak (at Φmax ) representing
the majority of the fully illuminated areas. The statistical assumption is used that full direct solar
illumination is already obtained for pixels with Φ(x, y) = Φmax . Then the values Φ are linearly
mapped from the unscaled (Φmin , Φmax ) interval onto the physically scaled (0,1) interval, where
the scaled shadow function is named Φ∗ :
Φ − Φmin
Φ∗ = if Φ ≤ Φmax (10.120)
Φmax − Φmin

Φ=1 if Φ > Φmax (10.121)

The smallest value of the scaled shadow function is Φ∗min = 0, which means no direct illumination.
However, to avoid overcorrection and to cope with scenes containing merely partial shadow areas, it
is advisable to set Φ∗min at a small positive value. This value of Φ∗min , i.e., the minimum fractional
direct illumination (deepest shadow in a scene, typically ranging between 0.05 and 0.10) is scene-
dependent, see the detailed discussion below.

Figure 10.24: Normalized histogram of unscaled shadow function.

In principle, the de-shadowing could now be performed with the physically scaled function Φ∗ ,
which represents the fraction of the direct illumination for each pixel in the ρ vector, i.e., the
complete scene without cloud and water pixels. However, since the matched filter is not a perfect
shadow transformation, it is much better to restrict its application to the potential, most-likely
CHAPTER 10. THEORETICAL BACKGROUND 252

shadow areas. This is an important processing step to reduce the number of mis-classifications
or false-alarms. If omitted it will cause strange ’shadow’ pixels scattered all over the image. An
example can be found in the central part of Fig. 10.25 where the standard shadow map contains a
lot of artifact shadow areas.

Figure 10.25: Cloud shadow maps of a HyMap scene.


Left: surface reflectance image of HyMap at Chinchon, Spain, 12 July 2003. Colour coding:
RGB=878, 646, 462 nm channels. Center: standard shadow map showing a lot of artifact shadow
areas (grey patches) which do not appear with the core shadow approach (right part). Right:
improved cloud shadow map derived from core shadow regions.

Therefore, the proposed method tries to find the core shadow areas in a scene, and subsequently
expands the core regions to obtain the final mask that includes a smooth shadow/clear transition.
The physically scaled shadow function Φ∗ is then applied only to the pixels in the final mask.

The histogram of the unscaled shadow function Φ can be employed to separate regions of low
values of Φ from the moderate-to-high values, compare Fig. 10.24. A threshold ΦT can be set in
the vicinity of the local histogram minimum (Φ1 ) and the core shadow mask is defined by those
pixels with Φ(x, y) < ΦT . The details of the choice of ΦT are discussed below. As always with
thresholding, some arbitrariness is involved in the final selection.
Once the core shadow mask has been defined, it is expanded to include the surrounding shadow
/ clear transition zone of 100 m width. De-shadowing with the scaled shadow function Φ∗ is then
exclusively applied to the pixels in this final mask. This means the direct solar flux (Edir term in
CHAPTER 10. THEORETICAL BACKGROUND 253

eq. 10.116) has to be multiplied with Φ∗ (x, y):


π(d2 {c0 (i) + c1 (i)DNi (x, y)} − Lp,i )
ρi (x, y) = (10.122)
τi {Edir,i Φ∗ (x, y) + Edif,i }
In equations (10.116, 10.122) the aerosol optical thickness or visibility required for the atmospheric
terms (path radiance, transmittance, direct and diffuse flux) can be derived from the image pro-
vided the necessary bands in the visible and shortwave infrared region exist and the scene contains
dark reference areas [?]. Otherwise, the user has to specify an estimated visibility. The second
important atmospheric parameter is the water vapour column. For instruments with bands in
the atmospheric water vapour regions this information can be derived from the image data [65],
otherwise an estimate has to be provided by the user. In summary, three channels (around 0.85,
1.6, and 2.2 µm) are used to define a matched filter vector with three elements per pixel. For
each image pixel the surface reflectance in these three channels and the scene-average reflectance of
these channels are calculated to obtain the unscaled shadow function, and finally the scaled shadow
function. The same shadow function is employed to de-shadow the imagery not only in the initial
three channels but for all channels of the sensor (eq. 10.122).

Details of the method:

One of the most important parameters is the available number of spectral channels during the
covariance matrix and matched filter part of the algorithm. The minimum requirement is a band
in the near-infrared region (0.8 - 1.0 µm). The performance usually increases significantly if two
additional bands (at 1.6 µm and at 2.2 µm) are available, i.e., a Landsat TM type of multispectral
sensor. Even for hyperspectral imagery these three bands (around 0.85, 1.6, 2.2 µm) are sufficient
for the matched filter calculation. The usage of a hundred bands would not be helpful, but only
cause numerical problems during the inversion of the covariance matrix (eq. 10.118).
Spectral channels from the visible region are merely employed for the masking of cloud regions, not
for the matched filter part, because water, vegetation, dark soils, and shadowed pixels all range
within a few percent reflectance. In addition, the visible region is not very sensitive to partial
shadow effects, because of its larger fraction of diffuse radiation component as compared to wave-
lengths longer than 0.8 µm.

The distinction of water bodies from cloud shadow areas may be difficult or impossible if it is based
merely on spectral reflectance shape and amplitude information. Water bodies should be excluded
as far as possible to improve the performance of the de-shadowing algorithm. Currently, water and
cloud pixels are masked with the spectral criteria defined in the file ’preference parameters.dat’,
see chapter9.3, e.g.,
ρ(0.85µm) ≤ 5% and ρ(1.6µm) ≤ 3% (water) (10.123)

ρ(0.48µm) ≥ 25% and ρ(1.6µm) ≥ 25% (cloud) (10.124)

If no channel in the blue region is available, a channel in the green (0.5-0.6 µm) or red part of the
spectrum (0.6-0.68 µm) could be used as a substitute. Both criteria do not uniquely define the
corresponding class. The water criteria allow some margin for turbid water in the NIR region. The
more restrictive criterion ρ(0.85 µm) < 3% would perform better for clear water bodies. However,
it would fail for moderately turbid or muddy waters. Other common water classification criteria
such as average reflectance over all bands ρ̄ ≤ 3% or ρ(0.4 − 0.6µm) < 6% may also fail. So one has
to compromise and tolerate a certain amount of misclassification for a fully automatic algorithm.
CHAPTER 10. THEORETICAL BACKGROUND 254

The scaled shadow map Φ∗ (x, y) is written to an output file.

The histogram of the unscaled shadow function Φ (Fig. 10.24) typically has a main peak at Φmax , a
smaller secondary peak (at Φ2 ) due to shadow pixels, and a local minimum (at Φ1 ). The secondary
peak can be determined by level-slicing the normalized histogram. We arbitrarily define a threshold
ΦT as the intersection of this slice line at the level of h(Φ2 ) with the normalized histogram h(Φ)
for Φ1 < Φ < Φmax . The approach with a main peak and a smaller secondary peak is restricted to
cases where the percentage of shadow pixels in the scene is less than about 25%. This applies to the
fully automatic processing mode. If the secondary peak at Φ2 is not clearly defined numerically,
i.e., no local minimum found at Φ1 , or histogram difference h(Φ2 ) − h(Φ1 ) < 0.03, then ΦT is
defined as the intersection of the slice level 0.10 with h(Φ) for Φ < Φmax . More flexibility exists in
the interactive mode, see chapter 2.4, figure 5.41.

Masking of the core shadow areas with Φ < ΦT (Fig. 10.24) is critical like any thresholding process:
a large threshold could potentially include non-shadow areas, a low threshold could miss shadow
areas. The current automatic algorithm has the three user-selectable options of a small, medium,
or large core shadow mask corresponding to thresholds set at ΦT − 0.1, ΦT , and ΦT + 0.1, respec-
tively. The default value for the fully automatic algorithm is the medium-size mask. In addition,
an interactive mode for adjusting the threshold is also available.

A second tunable parameter is the minimum fractional direct illumination Φ∗min , also called depth
of shadow. Theoretically, it can be zero, i.e., a completely shadowed pixel receiving only diffuse
solar illumination. However, a too low estimate close to zero will boost the surface reflectance,
especially for channels in the 1.5 - 2.5 µm region (eq. 10.122), since the diffuse solar radiation term
Edif is very small. Therefore, small positive values of Φ∗min are recommended. The range of Φ∗min
is typically from 0.05 to 0.1, with the default set at Φ∗min = 0.08. The third tunable parameter is
Φmax providing the range of stretching of the unscaled shadow function into the scaled function.
The default of Φmax is the location of the maximum of the histogram of Φ, but it could be set at
a greater value if the corrected image is too dark in the expanded shadow regions, which indicates
the histogram maximum does not represent fully illuminated areas.

The advantage of the presented method is its fast processing performance, because it relies exclu-
sively on spectral calculations and avoids time-consuming geometric cloud/shadow pattern consid-
erations. The drawback is that useful geometric information is neglected.

In some cases it is useful to have the de-shadowed digital number (DN) image in addition to the
surface reflectance product. This facilitates a comparison with the originally recorded DN imagery.
The conversion from reflectance to the corresponding at-sensor radiance is performed with eq.
(10.2). Then eq. (10.7) is employed to compute the de-shadowed DN image for channel k:

L(k) − c0 (k)
DN (k) = (10.125)
c1 (k)

Figure 10.26 shows an example of de-shadowing. More images with the results of the de-shadowing
method can be found on ATCOR’s web page, http://www.rese.ch or http://www.op.dlr.de/atcor .
CHAPTER 10. THEORETICAL BACKGROUND 255

Figure 10.26: De-shadowing of a Landsat-7 ETM+ scene.


Subset of a Landsat-7 ETM+ scene from Kenia, 10 April 2001. Color coding: RGB = bands
4/2/1 (830, 560, 480 nm). Left: original scene, right: after de-shadowing.

10.7 Correction of BRDF effects


The bottom of atmosphere reflectance as retrieved after standard ATCOR atmospheric compen-
sation is highly variable due to the influence of the bidirectional reflectance distribution function
(BRDF, [?]). The observed reflectance value may deviate from the average spectral albedo by up
to 30%, specifically for vegetation and man made surfaces.
ATCOR offers three different methods of correcting BRDF effects: The first method is mainly
intended for flat terrain and normalizes the off-nadir reflectance values to the corresponding nadir
values.
The second method is exclusively dedicated to rugged terrain imagery and corrects for BRDF effects
due to the variability of the solar incidence angle. The reflectance values of areas with low local
solar elevation angles, i.e.. large local solar zenith angles, are often overcorrected by the assumption
of isotropically reflecting surfaces. The method reduces these high, overcorrected values depending
on the illumination and/or viewing angles.
The third method corrects the observation BRDF effects by fitting a physical BRDF model to a
number of images and surface cover classes in order to obtain a generic BRDF correction function.
This function is used to calculate a per-pixel anisotropy factor which corrects for the deviation
from an averaged spectral albedo.
In some cases of rugged terrain imagery it is useful to apply both, incidence and observation angle
correction methods of BRDF correction.

10.7.1 Nadir normalization method


A simple algorithm was implemented as part of the ATCOR package to normalize the scan angle
dependent brightness values to the nadir value. It is recommended to apply the method to imagery
CHAPTER 10. THEORETICAL BACKGROUND 256

after atmospheric correction, i.e., to reflectance data. However, if only the across-track illumination
gradients shall be removed without any further atmospheric correction, the algorithm can also be
applied to radiance (DN) data. In this case, the brightness gradient may be caused by a combination
of surface BRDF and atmospheric BRDF (left/right asymmetry in path radiance).
The algorithm is intended for large field-of view sensors (minimum FOV=20o ). It computes the
column means with a certain angular sampling interval (1o or 3o ). The input image may be
geocoded, or not. If it is not geocoded the total field-of-view FOV corresponds to the number n
of across-track image pixels per line. If geocoded, the scan angle for each pixel must be provided
in a separate file (” sca”). It contains the scan angle in degree scaled with a factor of 100, and
coded with 16 bits per pixel. This definition is taken from the airborne ATCOR/PARGE interface
(Schläpfer and Richter 2002). Scan angles on the right hand side with respect to flight heading are
defined as negative, those on the left side as positive, e.g., a value of -2930 represents a scan angle
of 29.3◦ on the right side.
The nadir region is defined here as the ±3o scan angle range. Usually, a 3o angular sampling
interval, from +3o to +FOV/2 on the left side and -3o to -FOV/2 on the right side, is adequate,
except for geometries close to the hot spot geometry. In the latter case, a 1o sampling interval can
be selected.
If b̄nadir denotes the averaged brightness value for the nadir region, i.e., reflectance or radiance,
then the nadir normalized brightness value of a pixel with column number j is calculated as:
b̄nadir
bnorm (j) = b(j) (10.126)
f2 (j)
where the function f2 is obtained with three processing steps:

• The first step is the averaging over each interval (3◦ or 1◦ ). It yields a function f1 with m+1
grid points for the m off-nadir intervals plus the nadir interval.

• Two cases are distinguished now: if the image is not geocoded, an interpolation from function
f1 (m + 1) to a function f2 (ncols) is performed where ncols is the number of column pixels
of the image. If the image is geocoded, an interpolation from the 3◦ grid to the 1◦ grid is
performed (no hot spot case).

• The third step is a filter with a moving average window applied to the f2 function. The
following cases are distinguished: if the image is not geocoded the window is 9 pixels (without
hot spot) and 3 pixels (with hot spot option). If the image is geocoded, the moving window
extends over a 5◦ angular interval (no hot spot) and over a 3◦ interval (with hot spot option).

Figure 10.27 shows part of a HyMap image (acquired 3 June 1999, Barrax, Spain, 12:09 UTC)
containing the hot spot geometry. The solar azimuth was 181o and the sensor scan line azimuth
was 179o , almost exactly pointing into the solar azimuth. The left image shows HyMap band 30 at
868 nm after atmospheric correction. The right image is the result after nadir normalization with a
1o sampling interval. In this example, the column means were calculated globally, i.e. surface cover
independent. The algorithm also contains an option to compute the column means separately for
4 surface covers. It can currently only be selected if the input imagery is reflectance data and not
geocoded. The processing time is much larger than for the global, cover-independent method. The
four surface classes are:

• bright vegetation (ratio vegetation index NIR/RED > 10);


CHAPTER 10. THEORETICAL BACKGROUND 257

• medium/dark vegetation (6 < ratio vegetation index < 10);

• dry vegetation or mixed vegetation/soil (3 < vegetation index < 6);

• soil (vegetation index < 3).

The reflectance of off-nadir water pixels (criterion: near infrared reflectance < 5 %) is not modified.

Figure 10.27: Nadir normalization of an image with hot-spot geometry.


Left: reflectance image without BRDF correction. Right: after empirical BRDF correction.

10.7.2 Empirical incidence BRDF correction in rugged terrain


For many surface covers the reflectance increases with increasing solar zenith and / or viewing
angle [50]. Scenes in mountainous regions often exihibit a large variation of terrain slopes, and
thus bidirectional brightness variations for a certain surface cover, e.g., meadow or forest. This
behavior cannot adequately be eliminated with the Lambertian assumption of equation (10.16).
This equation leads to overcorrected reflectance values in faintly illuminated areas (having small
values of cosβ).

Background
Several approaches have been pursuit to solve this problem in the past :

• an empirical coefficient C is calculated based on a regression of brightness values and the


local ilumination angle derived from the DEM. The coefficient depends on scene content and
wavelength ([41], [48]).

• the sun-canopy-sensor (SCS) geometry is employed in forested terrain instead of the solely
terrain-based geometry [?].

• the SCS method is coupled with the C-correction [?].

These approaches produced good results on sample scenes with uniform cover types presented in
the above papers. When applying the methods to a wider range of areas, some of the practical
problems are:
CHAPTER 10. THEORETICAL BACKGROUND 258

• mountainous scenes often contain a number of different covers, e.g., deciduous forest, conif-
erous forest, mixed forest, shrubs, meadow, rocks, etc.

• the computation of the C coefficients for different surface covers would require a pre - classi-
fication.

• the correlation obtained for the C coefficients is often less than 0.7, yielding unreliable results
with this method.
These remarks are supported by reference [48]. These authors applied different correction ap-
proaches to a TM scene containing different cover types and noted that there is no optimum
method for all cover types. A drawback of the Minnaert and empirical C-methods is that they do
do not distinguish between the direct and diffuse solar illumination as opposed to the physically
based approach of ATCOR. Nevertheless, the latter approach also cannot avoid problems in faintly
illuminated areas.

Correction method
The methods described in the above section are supplemented by an empirical method with three
adjustable parameters (βT , b, and g) as explained below. This approach was tested on different
rugged terrain scenes with vegetated and arid landscapes and usually yields satisfactory results. It
reduces overcorrected reflectance values starting at a threshold local solar zenith angle βT greater
than the scene’s solar zenith angle Θs . Equation (10.127) defines the implemented basic geometric
correction function which depends on the local solar incidence angle (solar illumination βi ) and
the threshold angle βT . The exponent b ( = 1/3, 1/2, 3/4, or 1) is the second parameter and can
be selected by the user. Some guidelines on the choice of b are are discussed below. The third
adjustable parameter is the lower bound g of the correction function, see Figure 10.28.

G = {cosβi /cosβT }b ≥g (10.127)

The threshold illumination angle βT should have some margin to the solar zenith angle to retain
the original natural variation of pixels with illumination angles close to the solar zenith angle. The
threshold angle can be specified by the user and the following empirical rules are recommended:
• if θs < 35 : βT = θs + 25◦

• if 35 ≤ θs ≤ 45 : βT = θs + 20◦

• if 45 < θs ≤ 50 : βT = θs + 15◦

• if 50 < θs ≤ 60 : βT = θs + 10◦

• if θs > 60 : βT = max([70, θs + 5◦ ])
These rules are automatically applied if βT = 0, e.g., during batch processing.
The geometric function G needs a lower bound g to prevent a too strong reduction of reflectance
values. Values of G greater than 1 are set to 1, and values less than the boundary g are reset
to g. This means the processing works in the geometric regime from βT to 90◦ and the updated
reflectance is:
ρg = ρL G, (10.128)
where ρL is the isotropic (Lambert) value.
CHAPTER 10. THEORETICAL BACKGROUND 259

Figure 10.28: Geometric functions for empirical BRDF correction. Left: Functions G eq. (10.127) for
different values of the exponent b. Right: Functions G of eq. (10.127) for b=1 and different start values of
βT . The lower cut-off value is g=0.2.

Figure 10.28 shows a graphical presentation of equation (10.127). The left part displays the function
G for different values of the exponent b. For b=1 the decrease with βi is strong with a constant
gradient. For smaller values of b the decrease with βi is moderate initially, but the gradient increases
with larger βi . Currently, different functions G for soil/sand and vegetation can be selected in
ATCOR (compare the graphical user interface of Figure 5.47). The function G for soil / sand is
applied with a wavelength - independent exponent b. After testing a large number of vegetated
mountainous scenes two vegetation modes were finally selected because of their good performance:
1. b=0.75 for channels with λ < 720 nm and b=0.33 for λ > 720 nm (”weak” correction),

2. b=0.75 (λ < 720 nm) and b=1 (λ > 720 nm), (”strong” correction).
In most of the tested cases, the first mode was appropriate. A simple criterion (vegetation index
ρ850nm /ρ660nm > 3) is used to distinguish soil/sand and vegetation.
The right part of Figure 10.28 shows the effect of shifting the threshold illumination angle βT . For
larger values of βT the decline of function G starts later with a larger gradient, and the lower bound
g is met at slightly higher values of βi . In most cases, g=0.2 to 0.25 is adequate, in extreme cases
of overcorrection g=0.1 should be applied.

Practical considerations
The angle βT can actually be calculated from the imagery as demonstrated by the following ex-
ample. When processing the scene with ATCOR the map of local solar zenith angles is stored in
a separate file ”*ilu”. If the output file after atmospheric / topographic correction contains bright
overcorrected areas this file should be linked to the ”*ilu” file using any available standard image
processing software. The ”*ilu” file contains the illumination map βi scaled as byte data:
ilu = 100 ∗ cosβi
βi = arccos(ilu/100) (10.129)
(10.130)
CHAPTER 10. THEORETICAL BACKGROUND 260

Let us assume an example:


A pixel in a dark area of the ”*ilu” image has the value ilu=32, i.e., βi = 71◦ . The overcorrected
reflectance value be ρL = 80% and this value shall be reduced to 40%, a value typical for the flat-
terrain neighborhood. Then the threshold angle has to be specified such that cosβi /cosβT = 0.5
(with exponent b=1 in equation (10.127), in this case βT = 50◦ . So, if the desired reflectance
reduction factor is G then the required threshold angle can be calculated from eq. (10.127 with
b=1):
cosβ ilu
βT = arccos( ) = arccos (10.131)
G 100G
In many cases a separate treatment of BRDF effects for soil/rock and vegetation provides better
results. For this purpose, two modes of BRDF correction are available for vegetation, compare the
graphical user interface of Figure5.47. The first mode is superior in most cases.
Reference [58] contains a comparison of different topographic correction methods for several Landsat-
TM, ETM+, and SPOT-5 scenes from different areas. The proposed empirical ATCOR approach
performed best in most of these cases, but no method ranked first in all cases.

10.7.3 BRDF effect correction (BREFCOR)


A generic BRDF effects correction routine (BREFCOR, [?])) has been included in ATCOR. The
idea is to apply a scaling of the volume scattering and the geometric scattering component within
a well accepted BRDF model. A fuzzy surface cover index of the complete image image is used
for this purpose, which covers all surface types from water to asphalt and concrete, soils, sparse
vegetation and dense vegetation.
The Ross-Li-sparce reciprocal BRDF model has been selected as basis for the correction of re-
flectance anisotropy [19]. This model is mainly developed for vegetation, but we use it in a scaled
way for all kind of surfaces. Literature mainly related to MODIS atmospheric correction routines
showed the superior performance of this model if compared to others. However, for high spatial
resolution instruments also other models may be applicable.

Selected BRDF kernels


The BRDF correction scheme is based on the Ross-Thick Li-Sparse Model (RTLS), potentially
enhanced by the Hot-Spot function as proposed by Maignan et al. [26]. For the correction, a
formulation of the model for the Bidirectional Reflectance Factor (BRF) is used. The BRF is well
suited for correction of the HDRF, as both quantities are defined as 1.0 for a 100% reflecting target
at the same observation geometry, and as only the second dimension (observation direction) relative
variation of the BRF is used for the correction. The generic RTLS-equation of the BRF for each
pixel and spectral band is given as:

ρBRF = ρiso + fvol Kvol + fgeo Kgeo , (10.132)

where ρiso is the isotropic reflectance defined at nadir for both illumination and observation angle.
The kernel factors fvol and fgeo are weighting coefficients for the respective kernels. They depend
on the ground coverage BRDF, whereas the kernels are fixed functions which define a fully bi-
directional reflectance property. The kernels have been selected according to the findings of BRDF
CHAPTER 10. THEORETICAL BACKGROUND 261

literature [72]. For the volume scattering, the Ross-Thick kernel is modified to include the hot-spot
extension by Maignan, i.e.:
4 1 π 1
  
Kvol = − ζ cos ζ + sin ζ − , (10.133)
3π cos θi + cos θr 2 3
where ζ = arccos(cos θi cos θr + sin θi sin θr cos φ) .
The angle θi is the incident solar zenith angle, θr is the observation zenith angle, and φ is the
relative azimuth angle φ = φi − φr (i.e., the difference between incidence and observation azimuth).
The extension of this volumetric kernel by Maignan is given as:
1 1
  
Kvol = Kvol + 1+ . (10.134)
3 1 + ζ/1.5o

The reciprocal Li-Sparse kernel is used for the geometric part. It is defined as:

1 1 1 1 1 1 + cos ζ
   
Kgeo = (t − sin t cos t) + − + + , (10.135)
π cos θi cos θr cos θi cos θr 2 cos θi cos θr
where √ 
tan2 θi +tan2 θr −2 tan θi tan θr cos φ+(tan θi tan θr cos φ)2
t = arccos 1
+ 1
.
cos θi cos θr

10.7.4 BRDF cover index


A continuous BRDF cover index (BCI) function is used for characterization of the surface. It is
calculated on the HDRF of four standard bands: blue at 460nm, green at 550nm, red at 670 nm,
and near infrared at 840nm. This reduced selection of spectral bands makes the index applicable
for most current optical remote sensing systems. The BCI function characterizes the image based
on intrinsic BRDF properties from strong forward scatterers (water) to neutral targets (asphalt) to
backward scatterers (soils and vegetation types). The index implementation is using the normalized
difference vegetation index (NDVI) as a first input for vegetation density quantification due to its
known relation to the leave area index (LAI), which has a significant influence on the BRDF [25].
The NDVI is increased in Equation (10.136) by a value of up to 0.5 using the fact that dense
agricultural vegetation shows higher green reflectance than dense forests; i.e., the NDVI is increased
by Cf orest for dense forests having a green reflectance in a range below 7%. In a further step, the
BCI is decreased for soils by Csoils using the effect that soils show a relatively low blue at-sensor
radiance. A last adaption Cwater is made for water such that clear water areas are always set to a
minimum value:

BCI = (N DV I + Cf orest − Csoils − Cwater ) > −1.2. (10.136)

Note: the ”>” -sign denotes a maximum operator between the left and the right side of the term.
The three correction functions in Equation 10.136 are given as follows, first for forests using the
absolute HDRF value in the green ρgreen :

0.5    
Cf orest = · [0.07 − ρgreen ]0.04
0.00 · [N DV I − 0.55]0.20
0.00 . (10.137)
0.04 · 0.2
The upper and lower values at the square brackets indicate a truncation at these values. The upper
values could be adapted for better representation of biome types. For surface covers having a BCI
CHAPTER 10. THEORETICAL BACKGROUND 262

below 0.1 (i.e., mostly soils), a reduction factor is found from the relation between blue and red
HDRF as:
ρblue  1.00

Csoils = [1 − 10 · (N DV I + Cf orest )]0.00 . (10.138)
ρred
This factor accounts for the variability of non-vegetated areas in the visible. Finally, a summand
to account for water is added, starting with BCI soil = N DV I + Cf orest − Csoils . It takes into
account the relatively higher reflectance of water in the green spectral band in relation to the blue
for discrimination to other surface targets such as shadows and dark asphalt:
ρgreen
  
Cwater = − 0.8 > 0 · (−3 ((BCIsoil + 0.5) < 0)) . (10.139)
2ρblue
The range of the final BCI function is defined between values of -1.20 and 1.50. The BCI-index
calculated in each image pixel can then be used for BRDF model calibration and subsequently for
image correction.

Model calibration
For the calibration of the model, the BCI is divided into a number of 4-6 discrete classes. The
evaluation has shown that increasing the number of classes often leads to worse fitting results and
less stable BRDF correction whereas keeping the number of classes small is more stable. A second
outcome was that it is hardly feasible to define generic class limits for any kind of data acquisition
and sensor. The calibration follows the scheme shown in Figure 10.29.
Differences in limits can be attributed to the fact that the higher resolution images allows for a more
accurate and statistically more relevant calibration of the model whereas for lower resolution, the
number of classes should be reduced. The classes can be denominated as: water, artificial materials,
soils, sparse vegetation, grassland, and forests. For each of the classes, the optimum kernel weights
are calculated and stored for each image of a campaign. All weights are then averaged while bad
fitting classes (with relative errors greater than 10%) are excluded from averaging. No BRDF
correction is applied for classes without any fitting parameters (i.e. if less than 3 bands out of 4
within the class could be calibrated). The averaged model is stored for later application to the
imagery.

Image correction
Finally, the derived BRDF model calibration data are to be applied to the image data. For applica-
tion on the imagery, the BCI has to be calculated from each image and is used to get a continuous
correction function.
The image processing procedure is following the below steps (compare Figure 10.30):

• calculate the BCI from image,

• calculate the scene-specific angular kernels subsets,

• interpolate the calibration data from BCI levels to a continuous BRDF model,

• calculate an anisotropy map by scaling the kernels using the BCI, the scan angles (observation
zenith and azimuth angle), and the interpolated BRDF model, and

• apply the anisotropy map on a per-pixel basis.


CHAPTER 10. THEORETICAL BACKGROUND 263

HDRF images RTLS model


(calibration set) (option Maignan)

BCI-calculation RTLS-kernels

BCI-levels f_vol variation:


(-1 to 3)
f_geo variation:
(-0.25 to 0.75)
level analysis -
fit polynomial 5 deg

image-based HDRF combinations in


functions for each HDRF-LUT
class (cross track)

best fit of absolute


deviation from mean
RMS

f_vol/f_geo/f_iso for
each band / BCI level

exclude outliers, bad fits


and incomplete levels

level averages
over all scenes

parameter set for


correction

Figure 10.29: BRDF model calibration scheme

The anisotropy factor is derived as relation of the directional model for each pixel to the same
model averaged over all angles (i.e., to a good approximation of the spectral albedo BHR).

ρiso + fgeo Kgeo,θi ,θr ,φ + fvol Kvol,θi ,θr ,φ ρBRF


AN IF = ≈ . (10.140)
ρiso + fgeo Kgeo + fvol Kvol ρBHR

The bihemispherical reflectance is described by the two hemispherical averages Kgeo and Kvol
weighted by the respective factors and added to the constant isotropic reflectance ρiso . Alter-
natively, the anisotropy with respect to nadir BRF would be an option as done in earlier BRDF
research [45]. This option is currently not supported in BREFCOR, as the BHR is the more generic
spectral albedo definition for surface object characterization.
The corrected bihemispherical reflectance is finally calculated as ρBHR = ρAN
HDRF
IF , where ρHDRF is
the bottom of atmosphere (directional) reflectance after standard ATCOR-4 atmospheric compen-
sation, as described above.
CHAPTER 10. THEORETICAL BACKGROUND 264

HDRF image
image meta data calibrated model
(ATCOR output)

BRDF cover index derive model interpolate model


(BCI) kernel subset to BCI range

scan angle file calculate model weighting factors


(zenith/azimuth) for each pixel

combine into
relative anisotropy map (ANIF)

multiplicative BRDF correction

corrected image
(spectral albedo, BHR)

Figure 10.30: Image correction scheme.

Sample result
The BREFCOR correction is most appropriate for wide FOV sensors, i.e., with FOV values larger
than approx. 20 degrees, typically found for airborne imagery. For satellite imagery, the BREF-
COR correction is typically applied for mosaicking a number of images, acquired in the same area
at varying illumination and sensor observation angle conditions. A sample result for RapidEye
imagery is displayed in Figure 10.31. The image is a chessboard of a false-color composite of two
scenes acquired with a relative observation angle difference, where the first had a observation zenith
of 1.4◦ and a solar zenith of 18.7◦ , whereas the second scene was 8 days later and had angles of
14.7◦ and 14.3◦ , respectively. The lower image is the correction result based on the calibrated
Ross-Li-sparse BRDF model. Some of the BRDF effects can be removed by this method as long
as the image statistics are sufficient. However, not all effects can be fully removed - this could also
be attributed to changing atmospheric conditions between the two dates.

10.8 Summary of atmospheric correction steps


Although the case of a flat terrain could be treated as a special case of a rugged terrain with the
same elevation everywhere this is not an efficient solution, because the rugged terrain algorithm
runs 3 to 4 times slower than the flat terrain code. Therefore, the coding is done in separate
modules as discussed below.
CHAPTER 10. THEORETICAL BACKGROUND 265

Figure 10.31: BREFCOR mosaic correction: Top: uncorrected, Bottom: corrected (RapidEye chessboard
image mosaic, (c) DLR).

10.8.1 Algorithm for flat terrain


The complete sequence of processing for sensors with water vapor bands and a short wave IR band
(1.6 or 2.2 µm region) consists of the following steps:
• masking of haze, cloud, water, and clear pixels

• haze removal or cirrus removal

• de-shadowing

• masking of reference pixels

• calculation of visibility, visibility index, and aerosol optical thickness for reference pixels. For
an efficient faster processing, the float visibility range 5 - 190 km is converted into a discrete
integer visibility index (vi), ranging from 0 - 182, where the vi increment 1 corresponds to
CHAPTER 10. THEORETICAL BACKGROUND 266

an aerosol optical thickness increment (at 550 nm) of 0.002. The lowest vi = 0 corresponds
to visibility = 190 km, and vi = 182 to visibility = 5 km. The visibility / visibility index of
the non-reference pixels can be defined as the average of the reference pixels or or a spatial
(triangular) interpolation can be employed to fill the gaps. Then a moving low pass window
with a box size of 3 km×3 km (or the minimum of ncols/2 and nlines/2, ncols=image columns,
nlines=lines) is applied to smooth sensor noise and small scale variations of the spectral
correlation coefficient of the DDV reference pixels. Finally, the aerosol optical thickness
(AOT at 550 nm) is calculated with eq. 10.92. The visibility index and AOT(550nm) maps
are stored as separate files. The visibility calculation based on the reference pixels has to
account for the adjacency effect, because reference areas are embedded in non-reference areas,
see the sketch below. Since the weighting fraction of reference to non-reference area within
the adjacency range is not known for each pixel, the visibility calculation is performed with
an average adjacency weighting factor of 0.5 q :

Figure 10.32: Weighting of q function for reference pixels.

Ladj.cor = c0 + c1 DN + 0.5q(DN − DNav,clear ) (10.141)

L(V IS) = Lp + τ ρref Eg /π = Ladj.cor (10.142)

Next the visibility is converted into the nearest visibility index vi (range 0-182), compare Fig. 10.16,
to store the visibility index map as byte data. Spatial interpolation is performed to fill the gaps
for non-reference pixels or the average vi value can be taken to close the gaps. A moving average
window of 3 km × 3 km is employed to reduce the influence of noise. The cloud / building shadow
map is stored separately (”fshd.bsq” file, containing the fraction of direct solar irradiance per pixel,
scaled with the factor 1000). The scaled value 1000 indicates full solar irradiance, smaller values a
corresponding fractional value.
• an update of the path radiance in the blue-to-red spectral region is performed, if required,
provided a blue spectral band exists.
• water vapor retrieval using the previously calculated visibility map. If the scene contains
no reference areas the user has to specify a constant visibility that enters the water vapor
calculation.
• reflectance spectrum retrieval with pixel-based water vapor and visibility map. Iterations
for adjacency effect and spherical albedo are included. For the adjacency correction, the
reflectance of cloud pixels is replaced with the scene average reflectance to avoid an overcor-
rection of the adjacency effect.
• temperature / emissivity retrieval if thermal bands exist.
CHAPTER 10. THEORETICAL BACKGROUND 267

10.8.2 Algorithm for rugged terrain


The algorithm for rugged terrain basically consists of the same processing step as in the flat terrain,
but every step has to take into account some or all DEM information:
• During the calculation of the visibility index map the DEM information (elevation, slope,
aspect, skyview factor) is taken into account.

• The retrieval of the water vapor map has to include the terrain elevation.

• The empirical BRDF correction is based on the local illumination map (local solar zenith
angle) derived from the slope, aspect and shadow channels.

• The retrieval of the spectral reflectance cube consists of the steps

1. three iterations for terrain reflectance,


2. empirical BRDF correction depending on illumination map, if enabled,
3. adjacency correction, including proper treatment of cloud areas,
4. spherical albedo correction.

• The retrieval of surface temperature and emissivity includes the maps of visibility index, water
vapor (if water vapor bands exist), elevation, and scan angle. No slope/aspect correction is
performed in the thermal region.

10.9 Accuracy of the method


There is not a single figure that can be given to summarize the accuracy for all situations, because
the radiometric accuracy of the method depends on several factors: the calibration accuracy of
the sensor, the quality of geometric co-registration of the spectral bands, the algorithm for ortho-
rectification relying on auxiliary information such as attitude and GPS/DGPS, the accuracy of the
radiative transfer code (MODTRAN 5), the correct choice of atmospheric input parameters, the
terrain type (flat or rugged), and the surface cover.

Solar region:
In the solar region (wavelength < 2.5 µm), assuming a flat terrain, and avoiding the specular and
backscattering regions, an accuracy of the retrieved surface reflectance of ±2% (for reflectance <
10%) and ±4% reflectance units (for reflectance > 40%) can be achieved [?]. For rugged terrain, the
most important parameter is an adequate spatial resolution of the DEM or DSM (digital surface
model) and the exact ortho-rectification of the imagery. It would be desirable to have a DEM of a
quarter of the sensor’s spatial resolution or at least the resolution of the sensor’s footprint which
is seldom available [?]. Even in the latter case, errors in the matching of imagery and DEM can
lead to large relative reflectance errors exceeding 100% for critical geometries (principal plane, e.g.
a mountain ridge with half a pixel offset between imagery and DEM [?]). Thus, the quality of the
required DEM will limit the final accuracy of the geo-atmospheric image product in many cases.
For a flat terrain and larger off-nadir view angles, BRDF effects may have to be accounted for, and
the appropriate surface-cover dependent BRDF model will influence the accuracy.

Thermal region:
In the thermal wavelength region beyond 8 µm, the surface temperature retrieval additionally
depends on the correct choice of the surface emissivity. In the ATCOR model the emissivity in one
CHAPTER 10. THEORETICAL BACKGROUND 268

thermal band is based on a classification of the reflective bands if the sensor collects co-registered
reflective and thermal band data. Depending on the surface cover classification (vegetation, soil,
sand, asphalt, water, etc.), a typical emissivity value is assigned to each class [?]. If the deviation
of the true surface emissivity to the assumed emissivity is less than 0.02 (a typical error margin),
then the temperatures will be accurate to about 1-1.5 K. A rule of thumb is a surface temperature
error of about 0.5-0.8 K per 0.01 emissivity error if the surface temperature is much higher than
the boundary layer air temperature [?]. An accuracy of 1-2 K can be achieved if the emissivity
estimate is better than 2% [84].
Bibliography

[1] Berk, A., Anderson, G.P., Acharya, P.K., ”MODTRAN5.3.2 User’s Manual”, Spectral Sciences
Inc., Burlington MA, Air Force Research Laboratory, Hanscom MA (2013).

[2] Berk, A., Hawes, F., v.d.Bosch, J., and Anderson, G.P., ”MODTRAN5.4.0 User’s Manual”,
Spectral Sciences Inc., Burlington MA, Air Force Research Laboratory, Hanscom MA (2016).

[3] Comanicio, D., and Meer, P., ”Mean shift: a robust approach toward feature space analysis”,
IEEE Trans. Pattern Anal. Mach. Intell., Vol. 24, 603-619 (2002).

[4] Corripio, J. G., ”Vectorial algebra algorithms for calculating terrain parameters from DEMs
and the position of the sun for solar radiation modelling in mountainous terrain”, Int. J.
Geographical Information Science, Vol. 17, 1-23 (2003).

[5] Crist, E. P., and Cicone, R. C., ”A physically-based transformation of Thematic Mapper data
- the Tasseled Cap”, IEEE Trans. Geosci. Remote Sensing, Vol. GE-22, 256-263 (1984).

[6] Dozier,J, Bruno, J., and Downey, P., ”A faster solution to the horizon problem”, Computers
and Geosciences, Vol. 7,.145-151 (1981).

[7] Dell’Endice, F., Nieke, J., Schläpfer, D., and Itten, K. I., ”Scene-based method for spatial
misregistration detection in hyperspectral imagery”, Applied Optics, Vol. 46, 2803-2816 (2007).

[8] Fontenla, J. M., Curdt, W and Haberreiter, M., Harder J., and Tian, H.,”Semiempirical Models
of the Solar Atmosphere. III. Set of Non-LTE Models for Far-Ultraviolet/Extreme-Ultraviolet
Irradiance Computation The Astrophysical Journal, 707:482-502 (2009).

[9] Fontenla, J. M., Harder, J., Livingston, W., Snow, M., and Woods, T., ”High-resolution solar
spectral irradiance from extreme ultraviolett to far infrared”, J. Geophys. Res., Vol. 116,
D20108, 31pp., (2011).

[10] Gao, B.-C., Kaufman, Y.J., Han, W., and Wiscombe, W.J., ”Correction of thin cirrus path
radiances in the 0.4 - 1.9 µm spectral region using the sensitive 1.375 µm cirrus detecting
channel”, J. Geophys. Res., Vol. 103, D24, 32,169-32,176 (1998).

[11] B.-C. Gao and A. F. H. Goetz, ”Column atmospheric water vapor and vegetation liquid wa-
ter retrievals from airborne imaging spectrometer data”, J. Geophys. Research Vol. 95, D4,
pp.3549-3564, (1990).

[12] Gao,B.-C., Yang, P., Han, W., Li, R.-R., and Wiscombe, W. J., ”An algorithm using visible
and 1.38 µm channels to retrieve cirrus cloud reflectances from aircraft and satellite data”,
IEEE TGRS, Vol. 40, 1659-1668, (2002).

269
References 270

[13] Gao, B.-C., Meyer, K., and Yang, P., ”A new concept on remote sensing of cirrus optical depth
and effective ice particle size using strong water vapor absorption channels near 1.38 and 1.88
µm”, IEEE Trans. Geosci. Remote Sens., Vol. 42, 1891-1899 (2004).

[14] Guanter, L., Richter, R., and Moreno, J., ”Spectral calibration of hyperspectral imagery using
atmospheric absorption features”, Applied Optics, Vol. 45, 2360-2370 (2006).

[15] Guanter, L., Richter, R., Kaufmann, H., ”On the application of the MODTRAN4 atmospheric
radiative transfer code to optical remote sensing”, Int. J. Remote Sensing, Vol. 30, 1407-1424
(2009).

[16] Hay, J. E., and McKay, D. C., ”Estimating solar irradiance on inclined surfaces: a review and
assessment of methodologies”, Int. J. Solar Energy, Vol. 3, 203-240 (1985).

[17] Hueni, A., Schläpfer, D., Jehle, M., and Schaepman, M., ”Impacts of dichroic prism coatings on
radiometry of the airborne imaging spectrometer APEX”, Applied Optics, Vol. 53, 5344-5352
(2014).

[18] Hagolle, O., Huc, M., Pascual, D. V., and Dedieu, G., ”A multi-temporal and multi-spectral
method to estimate aerosol optical thickness over land, for the atmospheric correction of
FormoSat-2, Landsat, Vens, and Sentinel-2 images”, Remote Sensing, Vol. 7, 2668-2691 (2015)

[19] Hu B., Lucht W., Li X., and Strahler A.H., ”Validation of kernel-driven semiempirical models
for the surface bidirectional reflectance distribution function of land surfaces”, Remote Sens.
Environ., Vol. 62, no. 3, pp. 201-214, (1997).

[20] Irish, R., Barker, J. L., Goward, S. N., and Arvidson, T., ”Characterization of the Landsat-7
ETM + Automated Cloud-Cover Assessment (ACCA) algorithm”, Photogrammetric Engineer-
ing and Remote Sensing,, Vol. 72, 11791188 (2006).

[21] Kaufman, Y. J., et al. ”The MODIS 2.1 µm channel - correlation with visible reflectance for
use in remote sensing of aerosol”, IEEE Transactions on Geoscience and Remote Sensing, Vol.
35, 1286-1298 (1997).

[22] Kobayashi, S., and Sanga-Ngoie, K., ”The integrated radiometric correction of optical remote
sensing imageries” Int. J. Remote Sensing, Vol. 29, 5957-5985 (2008).

[23] Kobayashi, S., and Sanga-Ngoie, K., ”A comparative study of radiometric correction methods
for optical remote sensing imagery: the IRC vs. other image-based C-correction methods”,
Int. J. Remote Sensing, Vol. 30, 285-314 (2009).

[24] Levy, R.C. et al., ”Algorithm for remote sensing of troposheric aerosol over dark targets from
MODIS: collections 005 and 051, Revision 2; Feb 2009” (2009).

[25] Luo. Y., ”Surface bidirectional reflectance and albedo properties derived using a land cover-
based approach with Moderate Resolution Imaging Spectroradiometer observations”, J. Geo-
phys. Res., vol. 110, no. 1, p. D01106, (2005).

[26] Maignan F., Br¡8e¿on F. M. , and Lacaze R., ”Bidirectional reflectance of Earth targets:
evaluation of analytical models using a large set of spaceborne measurements with emphasis
on the Hot Spot”, Remote Sens. Environm., Vol. 90, 210-220 (2004)
References 271

[27] Makarau, A., Richter, R., Müller, R., and Reinartz, P., ”Haze detection and removal in re-
motely sensed multispectral imagery”, IEEE TGRS, Vol. 52, 5895-5905 (2014).

[28] Makarau, A., Richter, R., Schläpfer, D., and Reinartz, P., ”Combined haze and cirrus removal
for multispectral imagery”, IEEE GRSL, Vol. 13, 379-383 (2016).

[29] Mouroulis, P., Green, R. O., and Chrien, T. G., ”Design of pushbroom imaging spectrometers
for optimum recovery of spectroscopic and spatial information”, Applied Optics, Vol. 39, 2210-
2220 (2000).

[30] Nicodemus, F. E., Richmond, J. C., Hsia, J. J., Ginsberg, I. W., and Limperis, T., ”Geometrical
considerations and nomenclature for reflectance”, Washington, DC, USA, U.S. Department of
Commerce, National Bureau of Standards, (1977).

[31] Richter, R., and Schläpfer, D., ”Atmospheric/topographic correction for satellite imagery:
ATCOR-2/3 User Guide”, DLR IB 565-01/16, Wessling, Germany (2019).

[32] Richter, R., and Schläpfer, D., ”Atmospheric/topographic correction for airborne imagery:
ATCOR-4 User Guide”, DLR IB 565-02/16, Wessling, Germany (2019).

[33] Slater, P. N., ”Radiometric considerations in remote sensing”, Proc. IEEE, Vol. 73, 997-1011
(1985).

[34] Santer, R., et al., ”SPOT Calibration at the La Crau Test Site (France)”, Remote Sensing of
Environment, Vol. 41, 227-237 (1992).

[35] Richter, R., ”On the in-flight absolute calibration of high spatial resolution spaceborne sensors
using small ground targets”, Int. J. Remote Sensing, Vol. 18, 2827-2833 (1997).

[36] Asner, G., ”Canopy shadow in IKONOS satellite observations of tropical forests and savannas”
Remote Sensing of Environment, Vol. 87, 521-533 (2003).

[37] Shao, Y., Taff, G. N., and Walsh, S. J. , ”Shadow detection and building-height estimation
using IKONOS data”, Int. J. Remote Sensing, Vol. 32, 6929-6944 (2011).

[38] Smith, J.A., Tzeu, L. L., Ranson, K. J., ”The Lambertian assumption and Landsat data”,
Photogr. Engin. Remote Sens., Vol. 46, 1183-1189 (1980).

[39] Holben, B. N. and Justice, C. O., ”The topographic effect on spectral response from nadir-
pointing sensors”, Photogr. Engin. Remote Sens., Vol. 46, 1191-1200 (1980).

[40] Justice, C. O., Wharton, S. W., and Holben, B. N., ”Application of digital terrain data to
quantify and reduce the topographic effect on Landsat data”, Int. J. Remote Sens., Vol. 2,
213-230 (1981).

[41] Teillet, M., Guindon, B., and Goodenough, D. G., ”On the slope-aspect correction of multi-
spectral scanner data”, Can. J. Remote Sens.., Vol. 8, 84-106 (1982).

[42] Proy, C., Tanre, D., and Deschamps, P. Y., ”Evaluation of topographic effects in remotely
sensed data”, Remote Sens. Environ., Vol. 30, 21-32 (1989).

[43] C. Conese, C., Gilabert, A., Maselli, P., and Bottai, L., ”Topographic normalization of TM
scenes through the use pf an atmospheric correction method and ditital terrain models”, Pho-
togr. Engin. Remote Sens., Vol. 59, 1745-1753 (1993).
References 272

[44] S. Sandmeier, S., and Itten, K. I., ”A physically based model to correct atmospheric and
illumination effects in optical satellite data of rugged terrain”, IEEE TGRS, Vol. 34, 708-717
(1997).

[45] Sandmeier, S.T., and Deering, D. W. , ”Structure analysis and classification of boreal forests
using airborne hyperspectral BRDF data from ASAS”, Remote Sensing of Environment vol.
69, no. 3, pp. 281-295 (1999).

[46] Richter, R., ”Correction of satellite imagery over montainous terrain”, Applied Optics, Vol.
37, 4004-4015 (1998).

[47] Richter, R., and Schläpfer, D., ”Geo-atmospheric processing of airborne imaging spectrometry
data. Part 2: atmospheric topographic correction”, Int. J. Remote Sens., Vol. 23, 2631-2649
(2002).

[48] Riano, D., Chuvieco, E., Salas, J., and Aguado, I., ”Assessment of different topographic
corrections in Landsat-TM data for mapping vegetation types”, IEEE TGRS, Vol. 41, 1056-
1061 (2003).

[49] Minnaert, M., ”The reciprocity principle in lunar photometry”, Astrophys. J., Vol. 93, 403-410
(1941).

[50] Kriebel, T., ”Measured spectral bidirectional reflection properties of four vegetated surfaces”,
Appl. Opt., Vol. 17, 253-259 (1978).

[51] Schaaf, C. B., Li, X., and Strahler, A. H., ”Topographic effects on bidirectional and hemi-
spherical reflectances calculated with a geometric-optical canopy model”, IEEE TGRS, Vol.
32, 1186-1192 (1994).

[52] F.-M. Breon, F. M. and Vermote, E., ”Correction of MODIS surface reflectance time series for
BRDF effects”, Remote Sens. Environ., Vol. 125, 1-9 (2012).

[53] Richter, R., ”Bandpass-resampling effects on the retrieval of radiance and surface reflectance”,
Applied Optics, Vol. 39, 5001-5005 (2000).

[54] Richter, R., ”Bandpass-resampling effects for the retrieval of surface emissivity”, Applied Op-
tics, Vol. 41, 3523-3529 (2002).

[55] Richter, R., and Müller, A., ”De-shadowing of satellite/airborned imagey”, Int. J. Remote
Sensing, Vol. 26, 3137-3148 (2005).

[56] Richter, R., Schläpfer, D., and Müller, A., ”An automatic atmospheric correction algorithm
for visible/NIR imagery”, Int. J. Remote Sensing, Vol. 27, 2077-2085 (2006).

[57] Richter, R., and Schläpfer, D., ”Considerations on water vapor and surface reflectance re-
trievals for a spaceborne imaging spectrometer”, IEEE TGRS, Vol.46, 1958-1966 (2008).

[58] Richter, R., Kellenberger, T., and Kaufmann, H., ”Comparison of topographic correction
methods”, Remote Sensing, Vol. 1, 184-196 (2009).

[59] Richter, R., Schläpfer, D., and and Müller, A., ”Operational atmospheric correction for imaging
spectrometers accounting for the smile effect”, IEEE TGRS, Vol.49, 1772-1780 (2011).
References 273

[60] Richter, R., Wang, X., Bachmann, M., and Schläpfer, D., ”Correction of cirrus effects in
Sentinel-2 type of imagery”, Int. J. Remote Sensing, Vol.32, 2931-2941 (2011).

[61] Richter, R., Heege, T., Kiselev, V., and Schläpfer, D., ”Correction of ozone influence on TOA
radiance”, Int. J. Remote Sensing, Vol.35, 8044-8056 (2014).

[62] A. Rodger, ”SODA: a new method of in-scene atmospheric water vapor estimation and post-
flight spectral recalibration for hyperspectral sensors. Application to the HyMap sensor at two
locations”, Remote Sens. Environ., vol. 115, pp.536-547, (2011).

[63] Santer, R., Ramon, D., Vidot, J., and Dilligeard, E., ”A surface reflectance model for aerosol
remote sensing over land”, Int. J. Remote Sensing, Vol.28, 737-760 (2007).

[64] Schaepman-Strub, G., Schaepman, M., Painter, T., Dangel, S., and Martonchik, J., ”Re-
flectance quantities in optical remote sensing - definitions and case studies”, Remote Sensing
of Environment, Vol. 103, 27-42 (2006).

[65] Schläpfer, D., Borel, C. C., Keller, J., and Itten, K. I., ”Atmospheric precorrected differential
absorption technique to retrieve columnar water vapor”, Remote Sensing of Environment, Vol.
65, 353-366 (1998).

[66] Schläpfer, D., and Richter, R., ”Spectral polishing of high resolution imaging spectroscopy
data”, Earsel SIG-IS Workshop, Edinburgh (2011).

[67] Schläpfer, D., Richter R., and Feingersh T., ”Operational BRDF Effects Correction for Wide-
Field-of-View Optical Scanners (BREFCOR)”, IEEE Trans. Geoscience and Remote Sensing,
vol. 53, no. 4, pp. 1855-1864, (2015).

[68] Schläpfer, D., Hueni, A., and Richter R., ”Cast shadow detection to quantify the aerosol
optical thickness for atmospheric correction of high spatial resolution optical imagery”, Remote
Sensing, vol. 10, 200; doi:10.3390/rs10020200 (2018).

[69] Sirguey, P., ”Simple correction of multiple reflection effects in rugged terrain”, Int. J. Remote
Sensing, Vol. 30, 1075-1081 (2009).

[70] D. R. Thompson, B.-C. Gao, R. O. Green, D. A. Roberts, P. E. Dennison, and S. R. Lundeen,


”Atmospheric correction for global mapping spectroscopy: ATREM advances for the HyspIRI
preparatory campaign”, Remote Sens. Environ., Vol, 167, pp.64-77 (2015)

[71] Thuillier, G., Herse, M., Labs, D., Foujols, T., Peetermans, W., Gillotay, D., Simon, P. C.,
and Mandel, H., ”The solar spectral irrandiance from 200 to 2400 nm as measured by the
SOLSPEC spectrometer from the ATLAS and EURECA missions”, Solar Physics, Vol. 214, 1
- 22 (2003).

[72] Wanner W., A. H. Strahler, B. Hu, P. Lewis, J.-P. Muller, X. Li, C. L. B. Schaaf, and M. J.
Barnsle, ”Global retrieval of bidirectional reflectance and albedo over land from EOS MODIS
and MISR data: Theory and algorithm”, J. Geophys. Res., vol. 102, no. 14, pp. 17143-17161,
(1997).

[73] Vincent, R., ”Rock-type discrimination from ratioed infrared scanner images of Pisgah Crater,
California”, Science Vol. 175, 986-988 (1972).
References 274

[74] Sobrino, J. A., Jimenez-Munoz, J. C., Soria, G., Romaguera, M., Guanter, L., and Moreno,
J., ”Land surface emissivity retrieval from different VNIR and TIR sensors”, IEEE TGRS.,
Vol. 46, 316-327 (2008).

[75] Dash, P., Göttsche, F.-M., Olesen, F.-S., and Fischer, H., ”Land surface temperature and
emissivity estimation form passive sensor data: theory and practice - current trends”, Int. J
Remote Sensing, Vol. 23, 2563-2594 (2002).

[76] Young, S. J., Johnson, B. R., and Hackwell, J. A., ”An in-scene method for atmospheric
compensation of thermal hyperspectral data”, J. Geophys. Research, Vol. 107, No. D24, 4774-
4793 (2002).

[77] Gu, D., Gillesspie, A. R., Kahle, A. B., and Palluconi, F. D., ”Autonomous atmospheric com-
pensation (AAC) of high resolution hyperspectral thermal infrared remote-sensing imgery”,
IEEE TGRS., Vol. 38, 2557-2570 (2000).

[78] Borel, C., ”Error analysis for a temperature and emissivity retrieval algorithm for hyperspectral
imaging data” Int. J Remote Sensing, Vol. 29, 5029-5045 (2008).

[79] Kahle, A. B., et al., ”Middle infrared multispectral aircraft scanner data analysis for geological
applications”, Applied Optics, Vol. 19, 2279-2290 (1980).

[80] McMillin, L. M., ”Estimation of sea surface temperature from two infrared window measure-
ments with different absorption”, J. Geophys. Res. Vol. 80, 5113-5117 (1975).

[81] Gillespie, A. R., ”Lithologic mapping of silicate rocks using TIMS”, In Proc. TIMS Data User’s
Workshop, JPL Publ. 83-38 (Pasadena, CA), pp. 29-44 (1986).

[82] Realmuto, V. J., ”Separating the effects of temperature and emissivity: emissivity spectrum
normalization”, in Proc. 2nd TIMS Workshop. Pasadena, CA: Jet Propl. Lab. JPL Publication
90-55 (1990).

[83] Gillespie, A., et al., ”A temperature and emissivity separation algorithm for Advanced Space-
borne Thermal Emission and Reflection Radiometer (ASTER) images”, IEEE Trans. Geosc.
Remote Sensing, Vol. 36, 1113-1126 (1998).

[84] Coll, C., Caselles, V., Rubio, E., Sospreda, F., and Valor, E., ”Temperature and emissivity
separation from calibrated data of the Digital Airborne Imaging Spectrometer”, Remote Sens.
Environm., Vol. 76, 250-259 (2001).

[85] Kleespies, T. J., and McMillin, L. M., ”Retrieval of precipitable water from observations in
the split window over varying surface temperature”, J. Applied Meteorology, Vol. 29, 851-862
(1990).

[86] Li. Z. L., et al., ”A new approach for retrieving precipitable water from ATSR2 split-window
channel data over land area”, Int. J. Remote Sensing, Vol. 24, 3163-3180 (2003).

[87] Jimenez-Munoz, J. C., and Sobrino, J. A., ”Atmospheric water vapour content retrieval from
visible and thermal data in the framework of the DAISEX campaign”, Int. J. Remote Sensing,
Vol. 26, 3163-3180 (2005).

[88] Baret, F., and Guyot, G., 1991, ”Potentials and limits of vegetation indices for LAI and APAR
assessment”, Remote Sensing of Environment, Vol. 35, 161-173 (1991).
References 275

[89] Choudhury, B. J., ”Synergism of multispectral satellite observation for estimating regional
land surface evaporation”, Remote Sensing of Environment, Vol. 49, 264-274 (1994).
[90] Huete, A. R., ”A soil adjusted vegetation index (SAVI)”, Remote Sensing of Environment,
Vol. 25, 295-309 (1988).
[91] Asrar, G., Fuchs, M., Kanemasu, E. T., and Hatfield, J. L., ”Estimating absorbed photosyn-
thetically active radiation and leaf area index from spectral reflectance in wheat”, Agron. J.,
Vol. 76, 300-306 (1984).
[92] Asrar, G. ”Theory and Applications of Optical Remote Sensing”, J. Wiley, New York, (1989).
[93] Wiegand, C. L., Gerbermann, A. H., Gallo, K. P., Blad, B. L., and Dusek, D., ”Multisite
analyses of spectral-biophysical data for corn”, Remote Sensing of Environment, Vol. 33, 1-16
(1990).
[94] Wiegand, C. L., Richardson, A. J., Escobar, D. E., and Gerbermann, A. H., ”Vegetation
indices in crop assessments”, Remote Sensing of Environment, Vol. 35, 105-119 (1991).
[95] Buettner, K. J. K., and Kern, C. D., ”The determination of infrared emissivities of terrestrial
surfaces, Journal of Geophysical Research, Vol. 70, 1329-1337 (1965).
[96] Wolfe, W. L., and Zissis, G. J., ”The Infrared Handbook”, Office of Naval Research, Washing-
ton, DC., (1985).
[97] Sutherland, R. A., ”Broadband and spectral emissivities (2-18 µm) of some natural soils and
vegetation, Journal of Atmospheric and Oceanic Technology, Vol. 3, 199-202 (1986).
[98] Salisbury, J. W., and D’Aria, D. M., ”Emissivity of terrestrial materials in the 8-14 µm atmo-
spheric window”, Remote Sensing of Environment, Vol. 42, 83-106 (1992).
[99] Brutsaert, W., ”On a derivable formula for long-wave radiation from clear skies”, Water Re-
sources Research, Vol. 11, 742-744, (1975).
[100] Idso, S. B., and Jackson, R. D., ”Thermal radiation from the atmosphere”, J. Geophysical
Research, Vol. 74, 5397-5403 (1969).
[101] Carlson, T. N., Capehart, W. J., and Gillies, R. R., ”A new look at the simplified method for
remote sensing of daily evapotranspiration”, Remote Sensing of Environment, Vol. 54, 161-167
(1995).
[102] Moran, M. S., Clarke, T. R., Inoue, Y., and Vidal, A., ”Estimating crop water deficit using
the relation between surface-air temperature and spectral vegetation index”, Remote Sensing
of Environment, Vol. 49, 246-263 (1994).
[103] Zhang, Y., Guindon, B., and Cihlar, J., ”An image transform to characterize and compensate
for spatial variations in thin cloud contamination of Landsat images”, Remote Sensing of
Environment, Vol. 82, 173-187 (2002).
[104] Zhu, Z., and Woodcock, C. E., ”Object-based cloud and cloud shadow detection in Landsat
imagery”, Remote Sensing of Environment, Vol. 118, 83-94 (2012).
[105] Zhu, Z., Wang, S., , and Woodcock, C. E., ”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, Vol. 159, 269-277 (2015).
Appendix A

Altitude Profile of Standard


Atmospheres

This chapter contains the altitude profiles of ATCOR’s standard atmospheres that are based on
the MODTRAN code. Only the lower 5 km altitudes are shown, since this region has the largest
influence on the radiative transfer results and usually comprises about 90-95% of the total water
vapor column. For multispectral sensors without water vapor bands, e.g., Landsat TM or SPOT,
the selection of the atmosphere should be coupled to the season of the image data acquisition. The
influence of a large error in the water vapor estimate (e.g., 50%) on the reflectance retrieval is
usually very small (about 1-2% reflectance at a reflectance level of 40% for Landsat TM band 4).

However, for sensors with water vapor bands (e.g., MOS-B or hyperspectral sensors) the water
vapor content plays an important role. For these sensors the database contains files with four water
vapor columns (2.9, 2.0, 1.0, 0.4 cm). These are used to generate interpolated and extrapolated
values for the LUTs. In analogy to the files for the airborne version of ATCOR the file names are
”h99000 wv29 rura.atm”, ”h99000 wv20 rura.atm”, etc., where the h99000 indicates the symbolic
height of 99000 m used for satellites, the water vapor column content wv (cm or g cm−2 ) is scaled
with 10, and the aerosol type is included in the last part of the name.

altitude pressure temperature rel. humidity abs. humidity


(km) (mbar) (◦ C) (%) (gm−3 )
0 1013 26.4 7.5 1.9
1 904 20.4 7.3 1.3
2 805 14.4 7.4 0.9
3 715 10.4 4.8 0.5
4 633 3.8 3.5 0.2
5 559 -3.0 3.8 0.1

Table A.1: Altitude profile of the dry atmosphere. Total (ground-to-space) water vapor content = 0.41 (cm
or g cm−2 ).

276
APPENDIX A. ALTITUDE PROFILE OF STANDARD ATMOSPHERES 277

altitude pressure temperature rel. humidity abs. humidity


(km) (mbar) (◦ C) (%) (g/m−3 )
0 1018 -1.0 77 3.5
1 897 -4.5 70 2.5
2 789 -8.0 65 1.8
3 694 -11.5 57 1.2
4 608 -17.5 50 0.7
5 531 -23.5 47 0.4

Table A.2: Altitude profile of the midlatitude winter atmosphere. Total (ground-to-space) water vapor
content = 0.85 (cm or g cm−2 ).

altitude pressure temperature rel. humidity abs. humidity


(km) (mbar) (◦ C) (%) (g/m−3 )
0 1013 10.0 56 5.2
1 902 3.0 47 2.8
2 802 -1.0 41 1.9
3 710 -5.0 40 1.4
4 628 - 9.0 40 1.0
5 554 -14.0 40 0.6

Table A.3: Altitude profile of the fall (autumn) atmosphere. Total (ground-to-space) water vapor content
= 1.14 (cm or g cm−2 )

altitude pressure temperature rel. humidity abs. humidity


(km (mbar) (◦ C) (%) (g/m−3 )
0 1013 15.0 46 5.9
1 900 8 .5 49 4.2
2 795 2.0 52 2.9
3 701 -4.5 51 1.8
4 616 -11.0 50 1.1
5 540 -17.5 48 0.6

Table A.4: Altitude profile of the 1976 US Standard. Total (ground-to-space) water vapor content = 1.42
(cm or g cm−2 ).
APPENDIX A. ALTITUDE PROFILE OF STANDARD ATMOSPHERES 278

altitude pressure temperature rel. humidity abs. humidity


(km) (mbar) (◦ C) (%) (g/m−3 )
0 1010 14.0 75 9.1
1 896 8.5 70 6.0
2 792 3.1 70 4.2
3 700 -2.3 65 2.7
4 616 -7.7 60 1.7
5 541 -13.1 53 1.0

Table A.5: Altitude profile of the subarctic summer atmosphere. Total (ground-to-space) water vapor
content = 2.08 (cm or g cm−2 ).

altitude pressure temperature rel. humidity abs. humidity


(km) (mbar) (◦ C) (%) (g/m−3 )
0 1013 21.0 76 13.9
1 902 16.5 66 9.3
2 802 12.0 55 5.9
3 710 6.0 45 3.9
4 628 0.0 39 1.9
5 554 -6.0 31 1.0

Table A.6: Altitude profile of the midlatitude summer atmosphere. Total (ground-to-space) water vapor
content = 2.92 (cm or g cm−2 ).

altitude pressure temperature rel. humidity abs. humidity


(km) (mbar) (◦ C) (%) (g/m−3 )
0 1013 26.4 75 18.9
1 904 20.4 73 13.0
2 805 14.4 74 9.3
3 715 10.4 48 4.7
4 633 3.8 35 2.2
5 559 -3.0 38 1.5

Table A.7: Altitude profile of the tropical atmosphere. Total (ground-to-space) water vapor content = 4.11
(cm or g cm−2 ).
Appendix B

Comparison of Solar Irradiance


Spectra

The following two plots show the relative differences between two extraterrestrial solar irradiance
sources:

• Kurucz 1997 (distributed with MODTRAN, Berk et al. 2008 [?]). The previous high-
resolution (”monochromatic”) databases of ATCOR were calculated with this spectrum.

• Fontenla 2011 (Fontenla et al., 2009, 2011 [8, 9]). The new ATCOR release uses the improved
quiet sun spectrum of Fontenla and co-workers, also referred to as ”low activity sun”.

As explained in chapters 5.8.8, 5.8.9 the user can convert the database of atmospheric look-up ta-
bles from one solar irradiance source to another one, provided that the spectral range and sampling
distance agrees with the template spectra in the ”sun irradiance” directory of ATCOR. Currently,
irradiance spectra of Kurucz 1997, Kurucz 2005 (distributed with MODTRAN [?]), and Fontenla
2011 are offered.

The plots show the detailed information (line structure) contained in the Fontenla spectrum. The
curves with 2.8 nm and 10 nm represent results based on a moving average of the the 0.4 nm data
over 7 and 25 spectral points, respectively.

279
APPENDIX B. COMPARISON OF SOLAR IRRADIANCE SPECTRA 280

You might also like