使用google earth engine(GEE)提取2000年到2019年长江下游水体(河流、湖泊)数据[通俗易懂]

使用google earth engine(GEE)提取2000年到2019年长江下游水体(河流、湖泊)数据[通俗易懂]我最近想通过GEE直接统计长时间序列下长江下游流域的水体面积变化情况,如果通过传统做法很复杂,于是想到了使用GEE。下面是提取水体的效果图,时间是2000年的,你也可以设置显示2000-2019年中任意一年的水体数据。代码链接:https://code.earthengine.google.com/2440b9511ba0c1cefaf926c7c47e5ea2读者可以先通过代码看看效果,下面我说一下最主要的思路:1.数据源的选择;2.数据的时间、地点筛选;3.水体的标准设置;4

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

我最近想通过GEE直接统计长时间序列下长江下游流域的水体面积变化情况,如果通过传统做法很复杂,于是想到了使用GEE。下面是提取水体的效果图,时间是2000年的,你也可以设置显示2000-2019年中任意一年的水体数据

使用google earth engine(GEE)提取2000年到2019年长江下游水体(河流、湖泊)数据[通俗易懂]使用google earth engine(GEE)提取2000年到2019年长江下游水体(河流、湖泊)数据[通俗易懂]

代码链接:

https://code.earthengine.google.com/de4c42e80c432a909a4167b2b6333e6e使用google earth engine(GEE)提取2000年到2019年长江下游水体(河流、湖泊)数据[通俗易懂]https://code.earthengine.google.com/de4c42e80c432a909a4167b2b6333e6e

读者可以先通过代码看看效果,下面我说一下最主要的思路:

1.数据源的选择;

2.数据的时间、地点筛选;

3.水体的标准设置;

4.影像数据导出;

5.统计长江水体面积;

6.时间迭代函数。

下面是每个步骤的做法:

1.数据源的选择:

水体数据源是JRC Monthly Water History, v1.1,这个数据库拥有1987年到现在的全球水体分布图,而这个数据库是根据LANDSAT数据提取的。

使用google earth engine(GEE)提取2000年到2019年长江下游水体(河流、湖泊)数据[通俗易懂]

这个数据只有一个波段,3个值:0,1,2.。其中0代表没有数据;1代表有数据,不是水体;2代表有数据,是水体。

使用google earth engine(GEE)提取2000年到2019年长江下游水体(河流、湖泊)数据[通俗易懂]

我们直接通过GEE的import功能,引进这个数据库:

使用google earth engine(GEE)提取2000年到2019年长江下游水体(河流、湖泊)数据[通俗易懂]

2.数据的时间、地点筛选:

year是研究的年份,yantze_down是我上传的长江中下游的shp图;

//设置需要提取的区域,由于是上传的shp文件,需要转为geometry的格式
    var yantze_down_region = yantze_down.geometry();

    //设置需要提取的年份
    var startDate = ee.Date.fromYMD(year, 1, 1);
    var endDate = ee.Date.fromYMD(year, 12, 31);
    
    //筛选JRC水体数据
    var myjrc = jrc.filterBounds(yantze_down_region).filterDate(startDate, endDate);

3.水体的标准设置;

在这一步时一定要注意,由于JRC数据一年有12景,我们需要根据12景影像来统计一年的合成影像,而不是单单一景。所以合成方法是什么?我考虑到长江下游某些地方绘出翔一些低洼地暂时性积水,但这并不能算作湖泊。而我的目的是稳定性的湖泊、河流。所以我的合成方法是:

某个像素有7个月是水,则该像素为水体。


    //在每个月份的影像中添加一个obs属性的波段,一个像素如果有数据,则为1,没有数据则为0
    myjrc = myjrc.map(function(img){
      var obs = img.gt(0);
      return img.addBands(obs.rename('obs').set('system:time_start', img.get('system:time_start')));
    });

    //在每个月份的影像中添加一个onlywater属性的波段,一个像素如果有水则为1,没有水则为0
    myjrc = myjrc.map(function(img){
      var water = img.select('water').eq(2);
      return img.addBands(water.rename('onlywater').set('system:time_start', img.get('system:time_start')));
    });
    
    //计算每个像素点在一年12景影像中, 有数据的次数
    var totalObs = ee.ImageCollection(myjrc.select('obs')).sum().toFloat();
    
    //计算每个像素点在一年12景影像中, 有水的次数
    var totalWater = ee.ImageCollection(myjrc.select('onlywater')).sum().toFloat();
    
    //统计每个像素点在一年中有水的比例
    var floodfreq = totalWater.divide(totalObs).multiply(100);
    
    //删除没有值的像素
    var myMask = floodfreq.eq(0).not();
    floodfreq = floodfreq.updateMask(myMask);
    
    var viz = {min:0, max:50, palette: ['blue', 'white', 'green']};
    var floodfreq1=floodfreq.clip(yantze_down_region);
    var year_folder=year+"folder_gte";
    
    //如果某个像素一年有7个月有水,则为水体
    var gte60=floodfreq1.gte(60)

4.影像数据导出;

这个就太简单了,直接导出,文件名字为年份,不用详细说。

    
    //导出影像
    Export.image.toDrive({
      image: gte60,
      region: yantze_down_region,
      // fileDimensions:2560,
      scale: 30,
      maxPixels : 1e13,
      folder:year_folder,
      description:year_folder});

Task里面就可以有每一年长江下游区域的水体TIFF图,点击下载

使用google earth engine(GEE)提取2000年到2019年长江下游水体(河流、湖泊)数据[通俗易懂]

5.统计长江水体面积;

这个用reduce函数,直接统计水体面积,也很简单,不详细说。

    //计算计算长江下游水体面积
    var stats2 = gte60.reduceRegion({
      reducer: ee.Reducer.sum(),
      geometry: yantze_down_region,
      scale: 30,
      maxPixels: 1E13
    });

    print(year_folder);
    print(stats2);

控制台里面输出每一年的水体像元个数,每一个像元的面积为30m*30m:

使用google earth engine(GEE)提取2000年到2019年长江下游水体(河流、湖泊)数据[通俗易懂]

6.时间迭代函数。

因为我想统计长时间序列的水体数据,所以进行一个迭代。在这之前,先将前5个步骤封装,传入参数为年份,方便我们在时间迭代函数中进行调用:

//获取哪一年的,如果你想获取2000年到2019年,将条件改为i<20
for(var i=0;i<2;i++){
  if (i<10){  var year='200'+i;}
  if (i>10||i==10){  var year='20'+i;}
  var yearn = parseInt(JSON.parse(year));
  get_yearly_water(yearn);
}

提取水体的过程也就完成了,你按照我这个办法,可以提取全球任意地点长时间序列的水体数据,希望对你有帮助。

可以前往“地信遥感数据汇”​​​​​​​获取更多数据。
https://www.gisrsdata.com/

使用google earth engine(GEE)提取2000年到2019年长江下游水体(河流、湖泊)数据[通俗易懂]

 

 VX:kitmyfaceplease2;欢迎关注公众号:锐多宝的地理空间;

使用google earth engine(GEE)提取2000年到2019年长江下游水体(河流、湖泊)数据[通俗易懂]

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/193097.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 强大的自适应jQuery焦点图特效

    jQuery焦点图切换自适应效果自适应jQuery焦点图特效是一款支持移动端的响应式jQuery焦点图插件,支持flexible布局,支持移动触摸事件等。今天我们要来分享一款很灵活的jQuery焦点图

    2021年12月21日
    55
  • allure报告打开为loading状态「建议收藏」

    allure报告打开为loading状态「建议收藏」生成测试报告命令python3-mpytest–alluredir=../unit/allure_resulttest_case.pyalluregenerate./unit/allure_result-o./unit/allure_report直接在pycharm中右击allure报告中的index.html,使用如下图方式打开的allure报告打开一切顺利!!!在jenkins中把报告打包通过附件发送到邮件,然后在邮件中下载解压打开就会出现如下情况二、问

    2022年7月26日
    38
  • 面试之springboot自动配置原理「建议收藏」

    面试之springboot自动配置原理「建议收藏」自动配置首先从注解说起。@SpringBootApplication由三个注解组成:@CompanentScan,@EnableAutoConfiguration,@SpringBootConfiguration(其实就是@Configuration注解),其中@EnableAutoConfiguration通过@Import注解将AutoConfigurationImportSelector.class这个类引进来。该类会去加载所有jar包的META-INFO下面的spring-……

    2022年8月21日
    3
  • ecshop彻底去版权把信息修改成自己的全教程

    ecshop彻底去版权把信息修改成自己的全教程前台部分:一、去掉头部title部分的ECSHOP演示站-Poweredbyecshop1、问题:“ECSHOP演示站”方法:在后台商店设置–商店标题修改2、问题:“Poweredby

    2022年7月2日
    23
  • MATLAB 矢量图(风场、电场等)标明矢量大小的方法——箭头比例尺及风矢杆图的绘制

    MATLAB 矢量图(风场、电场等)标明矢量大小的方法——箭头比例尺及风矢杆图的绘制作者:中国科学院大气物理研究所律成林MATLAB中标明矢量图中矢量大小的方法:绘制箭头比例尺,或绘制风矢杆图。m_vec函数绘制的箭头长度仅与矢量大小本身有关。本人基于m_vec绘制结果,开发了一个可以在Figure内任意位置为指定的矢量图绘制箭头比例尺的函数——m_arrow_scale2,本文已包含该函数的代码,该函数考虑了方方面面,如文本标注、位置、字体等参数,且预设了很多参数供使用者选择,选择余地非常多,使用起来非常方便,功能也较为强大。本着“授人以渔”的原则,倾注了本人对MATLAB深刻理解。

    2022年6月28日
    116
  • 数据库课程设计——MySQL火车票售票系统[通俗易懂]

    数据库课程设计——MySQL火车票售票系统[通俗易懂]数据库课程设计——火车票售票系统听所有人很烦数据库课程设计?阅读本篇文章会让你不那么烦躁~系统开发平台:开发工具:eclipse,sublime开发语言:Java,jsp,css,JavaScript数据库:MySQL中间件:tomcat8.0后台框架:SpringMVC服务器:阿里云ECS线上地址:http://www.shadowingszy.top:8080/TrainT…

    2022年5月19日
    41

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号