GEE——土地利用分类之监督分类

利用GEE做监督分类,以武汉市为例。

训练器我们选择随机森林;数据选择Landsat-8;训练样本使用的是GEE提供的一种,它把地表分为三类:水体、植被和城市用地。

  • 选择训练样本

用要素集来标记训练样本。每个要素都有一个landcover 的属性,0表示城市用地,1表示植被,2表示水体。

  • 对影像进行分类

其中一部分进行分类器的训练,还有一部分留下来做精度验证。

  • 输出影像及混淆矩阵
print(LABEL_DATA);
var wuhan = ee.FeatureCollection('users/goodmalest/wuhan')

//选择的训练样本
function maskL8sr(image) {//去云
  var cloudShadowBitMask = (1 << 3);
  var cloudsBitMask = (1 << 5);
  var qa = image.select('pixel_qa');
  var mask = qa.bitwiseAnd(cloudShadowBitMask).eq(0)
                .and(qa.bitwiseAnd(cloudsBitMask).eq(0));
  return image.updateMask(mask);
}
var landsatImage = ee.ImageCollection("LANDSAT/LC08/C01/T1_SR")
    .filterDate('2019-01-01', '2019-12-31')
    .map(maskL8sr)
    .mean();
// 使用下列波段作为特征
var bands = ['B2', 'B3', 'B4', 'B5', 'B6', 'B7'];

// 通过要素集在Landsat-8中选取样本,把landcover属性赋予样本
var training = landsatImage.select(bands).sampleRegions({
  collection: LABEL_DATA,
  properties: ['landcover'],
  scale: 30
});

// 做精度评价
// 在training要素集中增加一个random属性,值为0到1的随机数
var withRandom = training.randomColumn('random');

//把生成随机数大于0.7的分成测试数据,否则为训练数据。这样可以把数据分成两份
var split = 0.7; 
var trainingPartition = withRandom.filter(ee.Filter.lt('random', split));
var testingPartition = withRandom.filter(ee.Filter.gte('random', split));

// 利用70%数据随机森林进行训练
var trainedClassifier = ee.Classifier.randomForest(5).train({
  features: trainingPartition,
  classProperty: 'landcover',
  inputProperties: bands
});

//对Landsat-8进行分类
var class_img=landsatImage.select(bands).classify(trainedClassifier);
// 对测试数据进行预测
var test = testingPartition.classify(trainedClassifier);
// 制作混淆矩阵,并打印出来
var confusionMatrix = test.errorMatrix('landcover', 'classification');
print('Confusion Matrix', confusionMatrix);
Map.centerObject(LABEL_DATA);
Map.centerObject(wuhan, 8);
Map.addLayer(wuhan);
Map.addLayer(class_img.clip(wuhan), {min: 0, max: 2, palette: ['red', 'green', 'blue']});
//划分为城市(红色)、水体(蓝色)、植被(绿色)

分类结果:

混淆矩阵:

  • 9
    点赞
  • 187
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 11
    评论
在Google Earth Engine (GEE)中,土地利用分类是通过使用不同的分类算法来将遥感影像数据分为不同的土地利用类型。在引用\[2\]中,使用了随机森林算法(smileRandomForest())来进行土地利用分类。该算法通过训练一个分类器,将输入的特征数据与已知的土地利用类型进行匹配,从而对未知地区进行分类。在这个例子中,使用了训练数据(trainingPartition)和测试数据(testingPartition)来训练和验证分类器。分类结果通过classify()函数得到,并可以在地图上进行可视化。\[2\] 此外,在使用随机森林方法进行分类时,可以根据需要选择最佳的决策树数量,并计算所使用特征的重要性。在引用\[3\]中,通过尝试不同数量的决策树,计算了每个数量下的分类准确率,并绘制了准确率随决策树数量变化的图表。同时,还可以使用explain()函数来计算特征的重要性,并通过图表展示各个特征的重要性程度。\[3\] 总结来说,在GEE中进行土地利用分类可以使用不同的分类算法,如随机森林法,同时可以根据需要选择最佳的决策树数量和计算特征的重要性。 #### 引用[.reference_title] - *1* *2* *3* [【Google Earth Engine】利用GEE进行Landsat 8 SR数据土地利用分类](https://blog.csdn.net/weixin_42347880/article/details/122669624)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

月球上看星星

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值