基于 Flexbrdf/hytools/topo 目录下的代码,我来详细解释地形校正的原理。 地形校正原理详解 地形校正(Topographic Correction)的目的是消除地形起伏(坡度、坡向)对高光谱图像反射率的影响。由于太阳光入射角度在不同坡度和坡向上的变化,同一地物在不同地形位置会呈现不同的辐射亮度,地形校正就是要将这种差异归一化到水平地表的条件。 一、核心概念:入射角余弦(cosine i) 地形校正的核心是计算入射角余弦(cosine of incidence angle),即太阳光线与地表法线之间夹角的余弦值。 计算公式(在 topo.py:53): cosine_i = np.cos(solar_zn)*np.cos(slope) + np.sin(solar_zn)*np.sin(slope)*np.cos(relative_az) 其中: solar_zn:太阳天顶角(太阳光线与垂直方向的夹角) solar_az:太阳方位角 slope:地面坡度 aspect:地面坡向 relative_az = aspect - solar_az:相对方位角 物理意义: 当 cosine_i = 1 时,太阳光垂直照射地面(正午水平地表) 当 cosine_i < 1 时,太阳光斜射,照度降低 背阴坡 cosine_i 较小,向阳坡 cosine_i 较大 二、支持的5种地形校正方法 1. Cosine 校正(余弦校正) 原理:最简单的地形校正方法,假设地表为朗伯体(各向同性反射)。 校正公式(cosine.py:50): c_factor = cos_solar_zn / cos_i cos_solar_zn:水平地表的太阳天顶角余弦 cos_i:实际地表的入射角余弦 校正效果: corrected_reflectance = original_reflectance × (cos_solar_zn / cos_i) 特点: 简单快速 假设地表是理想朗伯体,对非朗伯体(如植被)校正过度 2. SCS 校正(Sun-Canopy-Sensor) 原理:考虑森林冠层对地形影响的简化模型,基于 "cosine i" 但增加坡度因子。 校正公式(scs.py:51): c_factor = (cos_slope × cos_solar_zn) / cos_i 与 Cosine 方法的区别: 增加了 cos_slope 项(坡度余弦) 考虑了坡度对观测路径的影响 适用场景:森林覆盖区域 3. C 校正(C-Correction) 原理:在 Cosine 校正基础上增加一个经验系数 C,用于调整非朗伯体效应。 校正公式(c.py:177): correction_factor = (cos_sz + C) / (cosine_i + C) 其中 C 系数的计算过程(c.py:42-76): 对每个波段,建立反射率与 cosine_i 的线性关系: ρ = slope × cos_i + intercept 通过最小二乘拟合(OLS)或非负最小二乘(NNLS)求解 计算 C 系数(Soenen et al. 2005, Eq. 8): C = intercept / slope 物理意义:C 值越大,表示地表越接近朗伯体,校正强度越接近 Cosine 方法;C 值越小,校正越保守。 拟合方法选择(c_fit_type): ols:普通最小二乘(Ordinary Least Squares) nnls:非负最小二乘(Non-Negative Least Squares) wls:加权最小二乘(Weighted Least Squares) 4. SCS+C 校正(推荐用于森林) 原理:结合 SCS 和 C 校正的优势,是目前森林地形校正的主流方法(Soenen et al. 2005, IEEE TGRS)。 计算步骤(scsc.py): 计算 c1 因子: c1 = cos(solar_zn) × cos(slope) 计算 C 系数(与 C 校正相同,通过线性回归) 综合校正因子(scsc.py:115-125): correction_factor = (c1 + C × cos_slope) / (cos_i + C) 为什么有效: SCS 部分处理冠层-地形几何关系 C 部分调整非朗伯体效应 相比单独使用 SCS 或 C 校正,能更好地保持植被反射率的一致性 5. Modified Minnaert 校正(改进的 Minnaert) 原理:基于 Minnaert 指数的半经验方法,区分植被和非植被区域进行不同强度的校正(Richter et al. 2009)。 算法流程(modminn.py:46-83): 计算调整后的太阳天顶角: if solar_zn < 45°: solar_zn_t = solar_zn + 20° if 45° ≤ solar_zn ≤ 55°: solar_zn_t = solar_zn + 15° if solar_zn > 55°: solar_zn_t = solar_zn + 10° NDVI 掩膜分类: 植被区(NDVI > 0.2) 非植被区(NDVI ≤ 0.2) 计算基础校正因子: factor = cos_i / cos(solar_zn_t) 分区应用不同指数: 区域 短波(<720nm) 长波(≥720nm) 非植被 factor^(1/2) factor^(1/2) 植被 factor^(3/4) factor^(1/3) 限幅处理: factor = np.clip(factor, 0.25, 1.0) 阈值控制:当入射角小于调整后的太阳天顶角时不进行校正 特点: 自适应不同地物类型 区分短波和长波有不同的散射特性 通过指数控制校正强度,避免过度校正 三、地形校正的工作流程 从 topo.py:104-154 可以看出地形校正的完整流程: 1. 设置地形参数(set_topo) ↓ 2. 生成计算掩膜(calc_mask) ↓ 3. 计算校正系数(calc_*_coeffs) - 遍历每个波段(跳过坏波段) - 根据选定的算法类型计算校正因子 ↓ 4. 应用校正(apply_*) - 支持多种数据切分方式:line/column/band/chunk/pixels 四、关键配置参数 参数 类型 说明 适用算法 type str 校正算法类型 所有 calc_mask list 计算校正系数的掩膜条件 所有 apply_mask list 应用校正的掩膜条件 所有 c_fit_type str C系数拟合方法:ols/nnls/wls c, scs+c sample_perc float 采样比例(用于分组计算) 分组计算时 五、算法选择建议 场景 推荐算法 理由 裸土/岩石 Cosine 或 C 地表接近朗伯体 森林植被 SCS+C 考虑冠层几何,校正效果最好 草地/灌木 SCS 简单有效 混合地物 Modified Minnaert 自适应不同地物 需要精确结果 C 或 SCS+C + 分组计算 按NDVI分组计算C系数 六、参考文献 SCS+C 方法:Soenen, S. A., Peddle, D. R., & Coburn, C. A. (2005). SCS+C: A Modified Sun-Canopy-Sensor Topographic Correction in Forested Terrain. IEEE TGRS, 43(9), 2148-2159. 方法比较:Richter, R., Kellenberger, T., & Kaufmann, H. (2009). Comparison of topographic correction methods. Remote Sensing, 1(3), 184-196. C 校正:Teillet, P. M., Guindon, B., & Goodenough, D. G. (1982). On the slope-aspect correction of multispectral scanner data. Canadian Journal of Remote Sensing, 8(2), 84-106.