Google Earth Engine谷歌地球引擎ee.ImageCollection多张栅格影像数据格式的基本处理

  本文主要对GEE中的ee.ImageCollection格式数据图层基本处理操作加以介绍。

  本文是谷歌地球引擎(Google Earth Engine,GEE)系列教学文章的第十一篇,更多GEE文章请参考专栏:GEE学习与应用https://blog.csdn.net/zhebushibiaoshifu/category_11081040.html)。

  在第二篇GEE教学博客https://blog.csdn.net/zhebushibiaoshifu/article/details/117296956)中,我们通过搜索的方式导入了GEE内置的遥感影像数据与各类矢量数据;而在第九篇GEE教学博客https://blog.csdn.net/zhebushibiaoshifu/article/details/119545059)中,我们通过代码的方式获取了Landsat 5 Collection 1 Tier 1的大气表观反射率TOA Reflectance产品。本文依然采用代码方式,获取Landsat 8 Collection 1 Tier 1的初始影像Raw Scenes产品。

  其中,依据第十篇GEE教学博客https://blog.csdn.net/zhebushibiaoshifu/article/details/119568274)中提及的ee.Geometry.Point()函数,设置一个点要素,作为后期研究区域的参照点(即获取能覆盖这一点要素的Landsat 8遥感影像);同时依据第二篇GEE教学博客https://blog.csdn.net/zhebushibiaoshifu/article/details/117296956)中提及的遥感影像时间筛选方法,对Landsat 8遥感影像的时间段进行筛选。这里用到了两个之前教学博客中没有介绍的新函数——首先是.filterBounds()函数,作用为获取覆盖点要素point的遥感影像,即对遥感影像进行空间角度的筛选;其次是.sort()函数,作用为对ee.ImageCollection格式数据中的多层遥感影像按照一定规则进行排序。

var point=ee.Geometry.Point(116.36863, 39.961029);
var date_start=ee.Date("2020-05-01");
var date_end=ee.Date("2020-07-01");
var my_landsat=ee.ImageCollection("LANDSAT/LC08/C01/T1").filterBounds(point)
.filterDate(date_start,date_end).sort("CLOUD_COVER",true);
print(my_landsat);

  在这里,"CLOUD_COVER"表示遥感影像的云覆盖量,true表示按照排序指标的升序进行排列——即对于ee.ImageCollection格式数据中多景遥感影像,基于云覆盖量由少至多的顺序进行排列。还有需要强调的一点是,"CLOUD_COVER"并不是遥感影像波段的名称,而属于影像的元数据,或者说是属性。

  通过print()函数打印在右侧的信息,我们可以看到这个ee.ImageCollection格式数据中包含三个元素(即3 elements),也就是含有三景重叠的遥感影像。

  我们可以通过.first()函数获取一个ee.ImageCollection格式数据中的第一景影像。在这里,由于前述代码实现了云覆盖量由少至多的顺序进行排列,因此第一景影像也就是云覆盖量最低的那一景影像。

var first_landsat=my_landsat.first();
print(first_landsat);

  除了本文开头提及的按照一个点要素来筛选遥感影像,我们还可以按照LandsatPathRow分幅进行筛选。

//var point=ee.Geometry.Point(116.36863, 39.961029);
var date_start=ee.Date("2019-07-01");
var date_end=ee.Date("2020-06-01");
var my_landsat=ee.ImageCollection("LANDSAT/LC08/C01/T1")
.filter(ee.Filter.eq("WRS_PATH",123))
.filter(ee.Filter.eq("WRS_ROW",032))
.filterDate(date_start,date_end);
print(my_landsat);

  其中,ee.Filter.eq()函数表示按照某种方式进行筛选,"WRS_PATH"参数表示按照遥感影像属性中的Path分幅作为筛选标准,123表示筛选出Path号为123的遥感影像。

  筛选完后,我们可以将ee.ImageCollection格式数据中每一个要素的名称(即每一景遥感影像的名称)转为列表格式。

var list=my_landsat.toList(100);
print(list);

  其中,.toList()函数作用是将原有数据(ee.ImageCollection格式数据中每一个要素的名称)转为列表,100表示从ee.ImageCollection格式数据中获取要素名称的最大个数(即最多从ee.ImageCollection格式数据中获取100个要素的名称存入列表),这一参数只要远大于ee.ImageCollection格式数据中的要素个数即可。

  可以通过.length()函数获取列表数据的长度;这一长度也就是ee.ImageCollection格式数据中要素的个数。

var list_size=list.length();
print("The size of list is:",list_size);

  此外,还可以对ee.ImageCollection格式数据执行.size()函数,同样可以获取其要素个数。

var image_count=my_landsat.size();
print("The size of image is:",image_count);

  我们还可以对ee.ImageCollection格式数据的元数据(属性)进行获取。

print(my_landsat);

  首先,打印一下ee.ImageCollection格式数据,可以看到其properties中包含了很多属性信息;接下来我们就以date_range为例进行操作。date_range表示ee.ImageCollection格式数据中,遥感影像成像的起止时间。

  利用.get()函数就可以获取ee.ImageCollection格式数据的具体某一项属性。

var date_range=my_landsat.get("date_range");
print(date_range);

  打印出的起止时间格式如下图所示。这种用一长串数字来表示时间的格式为Unix Epoch,即Unix时间戳,其表示从1970年01月01 日00:00:00(GMT)开始以来的秒数;这里还需要注意,在JavaScript中,Unix Epoch的单位是毫秒,若要换为秒需要进行换算。

  我们还可以将起止时间转换为列表的形式。

var date_range_list=ee.List(date_range);
print(date_range_list);

  执行代码,可以看到是否转换为列表对于起止时间的显示而言并没有很大区别。

  Unix Epoch这种时间表示方法看起来不方便,我们可以将其转换为我们熟知的日期表示格式。

var date_range_ymd=ee.DateRange(date_range_list.get(0),date_range_list.get(1));
print("Date range is:",date_range_ymd);

  其中,ee.DateRange()就是一个可以起到转换时间格式作用的函数;同时,分别用.get()函数获取起止时间的第一个和第二个元素;第九篇GEE教学博客https://blog.csdn.net/zhebushibiaoshifu/article/details/119545059)已经介绍过,列表元素初始下标为0,因此分别用01来获取列表中的第一个和第二个元素。

  起止时间转换后,我们可以看到2013年04月到2021年08月这个范围并不是前面我们用.filterDate(date_start,date_end)语句筛选后的日期,而是Landsat 8卫星发射并投入使用后到目前的时间;因此我们可以知道,ee.ImageCollection格式数据中properties内的date_range属性指的是整个初始数据集Landsat 8 Collection 1 Tier 1的初始影像Raw Scenes产品)的起止时间,而不是经过筛选后(包括经过成像时间筛选与空间筛选后)得到的剩下几景遥感影像的起止时间。

  还可以利用.aggregate_stats()函数统计ee.ImageCollection格式数据某一项属性的信息,其统计得到的信息包括ee.ImageCollection格式数据中,全部遥感影像的某一项属性值的极值、总和、平均值、标准差等。

var statistics=my_landsat.aggregate_stats("SUN_ELEVATION");
print(statistics);

  此外,可以将.sort()函数与.first()函数一起执行,从而获取排序后,排在第一位的那一景遥感影像。

var least_cloud=my_landsat.sort("CLOUD_COVER",true).first();
print(least_cloud);

  这里需要注意,执行上述代码后得到的是一景遥感影像(即ee.Image格式的数据)。

  同时,.sort()函数排序后,我们还可以获取排序前几位的遥感影像。

var recent_image=my_landsat.sort("system:time_start",false).limit(10);
print(recent_image);

  其中,利用.limit()函数获取有限的遥感影像,10表示获取10景,即获取成像时间离目前最近的10景遥感影像。因此,执行这一代码后获取的是多景遥感影像,即ee.ImageCollection格式的数据。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,980评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,178评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,868评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,498评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,492评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,521评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,910评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,569评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,793评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,559评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,639评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,342评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,931评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,904评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,144评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,833评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,350评论 2 342

推荐阅读更多精彩内容