基于 GEE Sentinel-1 数据集提取水体

目录

[1 水体提取原理](#1 水体提取原理)

[2 完整代码](#2 完整代码)

[3 运行结果](#3 运行结果)


1 水体提取原理

水体提取是地理信息和遥感技术的关键应用之一,对于多个领域都具有重要的应用价值。它有助于更好地管理水资源,保护环境,减少灾害风险,促进可持续发展,以及确保饮用水供应的安全。水体提取技术的不断发展和改进将进一步提高这些应用的效益。

阈值分割方法是 SAR 数据提取水体方法中原理简单,应用最为广泛的。利用水体在 SAR 图像上散射值低,会呈现暗区的特点,通过求解图像直方图的极值点来设定成值,将图像中小于阈值部分标记为非水体大于阈值部分标记为水体。

使用 Google Earth Engine 进行水体提取的优点包括全球数据覆盖、强大的计算能力、多源数据集集成、实时数据更新、、易于使用的编程界面、可视化和交互性、协作和共享以及开放数据访问。这些特点使 GEE 成为处理水体提取和其他地理信息任务的强大工具。

下面简要介绍如何使用 GEE 来提取水体信息,采用 SDWI 指数提取水体,计算公式是 :SDWI = ln(10 * VH * VV) - 8

2 完整代码

javascript 复制代码
// 设置时间范围
var startDate = '2022-01-01';
var endDate = '2022-12-31';

//感兴趣的区域信息
var roi = ee.FeatureCollection('projects/ee-zhangkanghnust/assets/HengShaoLou');

// 使用Sentinel-1数据集
var s1Collection = ee.ImageCollection('COPERNICUS/S1_GRD')
    .filterBounds(roi)
    .filterDate(startDate, endDate)
    .filter(ee.Filter.listContains('transmitterReceiverPolarisation', 'VV'))
    .filter(ee.Filter.eq('instrumentMode', 'IW'));

// 定义SDWI计算函数
var calculateSDWI = function(image) {
    var XVH = image.select('VH');
    var XVV = image.select('VV');
    return image.expression('log(10 * VV * VH) - 8', {'VV': XVV, 'VH': XVH}).rename('SDWI');
};

// 计算SDWI
var s1SDWI = s1Collection.map(calculateSDWI);

// 合并SDWI图层
var sdwiComposite = s1SDWI.median().clip(roi);
Map.addLayer(sdwiComposite);

// 定义水体掩膜
var waterMask = sdwiComposite.gt(0).clip(roi);

// 可视化水体掩膜
var visParams = {
    min: 0,
    max: 1,
    palette: ['FFFFFF', '0000FF'] // 蓝色表示水体,白色表示非水体
};

// 在地图上显示水体掩膜
Map.centerObject(roi, 10);
Map.addLayer(waterMask, visParams, 'Water Mask');
Map.addLayer(roi, {}, "roi");

3 运行结果

研究区范围

哨兵1号影像

水体提取结果

叠加显示结果

相关推荐
主机哥哥30 分钟前
阿里云OpenClaw(原Clawdbot/Moltbot)一键秒级部署教程
阿里云·云计算
打码人的日常分享3 小时前
智能制造数字化工厂解决方案
数据库·安全·web安全·云计算·制造
70asunflower4 小时前
阿里云无影云电脑 Docker 使用完全指南
阿里云·docker·云计算
主机哥哥4 小时前
零基础入门:阿里云OpenClaw部署全流程详解(图文版)
阿里云·云计算
久绊A5 小时前
春节前云平台运维深度巡检-实操经验
运维·安全·容器·kubernetes·云平台
白佳宝6 小时前
MySQL8.0.27高可用
云计算·dba
weixin_307779136 小时前
C#实现两个DocumentDB实例之间同步数据
开发语言·数据库·c#·云计算
Ivanqhz12 小时前
现代异构高性能计算(HPC)集群节点架构
开发语言·人工智能·后端·算法·架构·云计算·边缘计算
福大大架构师每日一题14 小时前
agno v2.4.7发布!新增Else条件分支、AWS Bedrock重排器、HITL等重大升级全解析
javascript·云计算·aws
TG_yunshuguoji16 小时前
阿里云代理商:如何通过控制台连接ECS实例?
运维·阿里云·云计算