【GEE筆記】在線分類流程,標注樣本點、分類和精度評價

GEE在線分類流程

介紹

GEE(Google Earth Engine)是一個強大的地理信息處理平臺,可以實現在線的遙感影像分析和處理。本文將介紹如何使用GEE進行在線的分類流程,包括標注樣本點、分類和精度評價。本文以2020年5月至8月的哨兵2影像為例,對區域內的土地覆蓋類型進行分類。

標注樣本點

首先,加載原始影像,進行在線的標注。
加載的影像:
在這里插入圖片描述

加載影像的代碼如下:

var geometry = ee.Geometry.Polygon([[[121.81940156260009, 40.92383488850036],[121.81940156260009, 40.73887826797227],[121.99998933115478, 40.73887826797227],[121.99998933115478, 40.92383488850036]]], null, false)
var year=2020 //設置年份
var bandlist=['B2','B3','B4','B8','B11','B12'] //設置波段列表
var start = ee.Date(year+'-5-1'); //設置開始日期
var finish = ee.Date(year+'-8-1'); //設置結束日期var dataset = ee.ImageCollection('COPERNICUS/S2_SR') //加載哨兵2影像集合.filterDate(start, finish) //按日期過濾.filterBounds(geometry) //按范圍過濾.filter(ee.Filter.lt('CLOUDY_PIXEL_PERCENTAGE', 20)) //按云量過濾dataset=dataset.select(bandlist); //按波段選擇            
var rgbVis = {min: 0.0, max: 3000, bands: ['B4', 'B3', 'B2'], //設置RGB波段
};Map.centerObject(geometry) //地圖中心定位到范圍
print(dataset) //打印影像集合信息var image=dataset.median().clip(geometry) //計算影像集合的中值,并裁剪到范圍
Map.addLayer(image,rgbVis) //添加影像圖層

標注樣本點過程如下:
1、創建樣本點集合對象(集合名稱可以設置為類別名稱便于區分)
在這里插入圖片描述
2、設置類別字段及其屬性(屬性為類別數字代碼)
在這里插入圖片描述
在這里插入圖片描述

分類

接下來,進行分類。選擇隨機森林算法作為分類器(也可選擇GEE官方其他分類器)。將樣本點集合分為訓練集和測試集,用訓練集來訓練分類器,用測試集來評估分類器的性能。

分類主要包括合并樣本點集合、劃分訓練集和測試集、訓練分類器、應用分類器、添加分類圖層。分類的結果如下圖所示:
在這里插入圖片描述

分類的代碼如下:

var sample=danshui.merge(haishui).merge(jianpeng).merge(nongtian).merge(luwie).merge(jianzhu)
.merge(tantu).merge(caodi) //合并樣本點集合var withRandom = sample.randomColumn('random'); //給樣本點集合添加隨機數列
var split = 0.7;  //七成訓練 三成測試
var trainingPartition2 = withRandom.filter(ee.Filter.lt('random', split)); //按隨機數列劃分訓練集
var testingPartition = withRandom.filter(ee.Filter.gte('random', split)); //按隨機數列劃分測試集var trainingPartition=image.sampleRegions({ //從影像中提取訓練集的像素值collection: trainingPartition2, //輸入訓練集scale:10, //設置空間分辨率properties: ['Map'], //設置類別字段})
var classifier = ee.Classifier.smileRandomForest(100).train({ //訓練隨機森林分類器features: trainingPartition, //輸入訓練集classProperty:'Map', //設置類別字段// inputProperties :['B4', 'B3', 'B2']
});
var classied=image.classify(classifier,"smileRandomForest"); //應用分類器Map.addLayer(classied.randomVisualizer()) //添加分類圖層

精度評價

最后需要評估分類器的性能,計算分類精度。
在這里插入圖片描述

可以通過以下代碼來評估分類精度:

var pixelValues2=classied.sampleRegions({ //從影像中提取測試集的像素值collection: testingPartition, //輸入測試集scale:10, 
});
print("pixelValues2",pixelValues2); //打印測試集信息
var confusionMatrix2 = pixelValues2.errorMatrix("Map", 'smileRandomForest');//,[10,20,30,40,50,60,80,90] //計算混淆矩陣
print('confusionMatrix', confusionMatrix2); //打印混淆矩陣
print('accuracy()', confusionMatrix2.accuracy()); //打印總體精度
// print('consumersAccuracy', confusionMatrix2.consumersAccuracy());
print('kappa()', confusionMatrix2.kappa()); //打印Kappa系數
//print('order()', confusionMatrix.order());
// print('producersAccuracy()', confusionMatrix2.producersAccuracy());

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/209007.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/209007.shtml
英文地址,請注明出處:http://en.pswp.cn/news/209007.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

什么是散列函數

散列函數是一種公開的數學函數。散列函數運算的輸入信息也可叫作報文。散列函數運算后所得到的結果叫作散列碼或者叫作消息摘要。散列函數具有如下一些特點: (1)不同內容的報文具有不同的散列碼,而一旦原始報文有任何改變&#xf…

__attribute__ 詳解

GNU C的一大特色(卻不被初學者所知)就是__attribute__機制。__attribute__可以設置函數屬性(Function Attribute)、變量屬性(Variable Attribute)和類型屬性(Type Attribute)。 特征: __attribute__書寫特征是: __attribute__前后都有兩個下劃線,并切后面會緊…

文件管理和操作工具Path Finder mac功能介紹

Path Finder mac是一款Mac平臺上的文件管理和操作工具,提供了比Finder更豐富的功能和更直觀的用戶界面。它可以幫助用戶更高效地瀏覽、復制、移動、刪除和管理文件,以及進行各種高級操作。 Path Finder mac軟件功能 - 文件瀏覽:可以快速瀏覽文…

【數據結構 — 排序 — 插入排序】

數據結構 — 排序 — 插入排序 一.排序1.1.排序的概念及其運用1.1.1排序的概念1.1.2排序運用1.1.3 常見的排序算法 二.插入排序2.1.直接插入排序2.1.1.算法講解2.1.2.代碼實現2.1.2.1.函數定義2.1.2.2.算法接口實現2.1.2.3.測試代碼實現2.1.2.4.測試展示 2.2.希爾排序2.2.1.算法…

ASO優化:幫助實現企業和用戶的共贏

大數據時代APP拉獲新客,ASO優化應該這么玩! 市場那么大,用戶那么廣。企業設計的APP如何在茫茫人群中精準地把自己送到用戶面前,并與ta產生溝通呢。隨著時代的發展,數據成為企業競爭的核心。APP的營銷發展離不開數據推…

gcc tips - GCC使用技巧與高級特性

目錄 1. 獲取 GCC 編譯器預定義的宏 2. 列出依賴的頭文件 3. 保存預處理結果到文件(展開define, 展開include header) 4. 寫回調跟蹤記錄函數運行 -finstrument-functions 5. -fdump-rtl-expand 畫函數調用關系圖 GCC,全稱GNU Compiler …

第一課【習題】三方庫

三方組件是開發者在系統能力的基礎上進行了一層具體功能的封裝,對其能力進行拓展的工具 。 可以通過ohpm uninstall 指令下載指定的三方庫 lottie使用loadAnimation方法加載動畫。 通過ohpm安裝lottie后,在哪個文件中會生成相關的配置信息&#xf…

C++ - 哈希

在順序結構以及平衡樹中,由于元素關鍵碼與其存儲位置之間沒有對應的關系,因此在查找一個元素時,必須要經過關鍵碼的多次比較;比如順序表中需要從表頭開始依次往后比對尋找,查找時間復雜度為 O(N),平衡樹中需…

快速登錄界面關于如何登錄以及多賬號列表解析以及config配置文件如何讀取以及JsLogin模塊與SdoLogin模塊如何通信(4)

1、### Jslogin模塊與前端以及JsLogin模塊與Sdologin的交互 配置文件的讀取: <CompanyIdForQq value"301"/> <CompanyIdForWx value"300"/><CompanyIdForWb value"302"/><qq value"https://graph.qq.com/oauth2.0/au…

freertos統計任務運行時間和堆棧使用情況(快速應用篇)

這里寫自定義目錄標題 背景配置FreeRTOSCconfig.h統計時鐘源任務中打印 背景 本文直接講解如果快速實現freertos打印任務運行時間&#xff0c;堆棧使用情況等調試信息&#xff0c;不講解原理。 配置 FreeRTOSCconfig.h 增加以下代碼&#xff1a; #define configUSE_TRACE_…

git clone 命令

git clone 是一個用于克隆&#xff08;clone&#xff09;遠程 Git 倉庫到本地的命令。 git clone 可以將一個遠程 Git 倉庫拷貝到本地&#xff0c;讓自己能夠查看該項目&#xff0c;或者進行修改。 git clone 命令&#xff0c;你可以復制遠程倉庫的所有代碼和歷史記錄&#xf…

template

類型&#xff1a; string 詳細&#xff1a; 一個字符串模板作為 Vue 實例的標識使用。模板將會替換掛載的元素。掛載元素的內容都將被忽略&#xff0c;除非模板的內容有分發插槽。 如果值以 # 開始&#xff0c;則它將被用作選擇符&#xff0c;并使用匹配元素的 innerHTML 作為…

深入了解 Axios 攔截器

深入了解 Axios 攔截器 本文將向您介紹什么是 Axios 攔截器以及如何使用它們。通過分步指南和示例代碼&#xff0c;您將學習如何使用 Axios 攔截器來處理請求和響應&#xff0c;并添加授權和錯誤處理。 什么是 Axios 攔截器&#xff1f; Axios 攔截器允許您在請求發送和響應…

阿里云SLB的使用總結

一、什么是SLB 實現k8s的服務service的一種推薦方式&#xff0c;也是服務上云后&#xff0c;替代LVS的一個必選產品。 那么它有什么作用呢&#xff1f; 1、負載均衡&#xff0c;是它與生俱來的。可以配置多個服務器組&#xff1a;包括虛擬服務器組、默認服務器組、主備服務器…

markdown快捷鍵

markdown快捷鍵 快捷鍵 Markdown 圖標 快捷鍵 撤銷 Ctrl Z 重做 Ctrl Y 加粗 Ctrl B 斜體 Ctrl I 標題 Ctrl Shift H 有序列表 Ctrl Shift O 無序列表 Ctrl Shift U 待辦列表 Ctrl Shift C 插入代碼 Ctrl Shift K 插入鏈接 Ctrl Shift L 插入圖片 Ctrl Shif…

JUnit 之初體驗

文章目錄 1.定義2.引入1&#xff09;使用 Maven 工具2&#xff09;使用 Gradle 工具3&#xff09;使用 Jar 包 2.樣例0&#xff09;前提1&#xff09;測試類2&#xff09;測試方法3&#xff09;測試斷言4&#xff09;實施 總結 1.定義 JUnit 是一個流行的 Java 單元測試框架&a…

H5ke14--1--拖放

介紹drag,drop 一.被拖動元素,目標(釋放區) 元素要設置dragable屬性:true,false,auto 被拖動元素上面有三個事件,drag,dragend,按下左鍵,移動種,鼠標松,這三個事件一般只用獲取我們的被拖動元素 冒泡:event是可以繼承的,mouseevent鼠標事件,dragevent拖放事件,前面都是一個…

ubuntu 修改系統時間,解決更新軟件報錯問題

ubuntu在更新軟件時出現E: Release file for http://security.ubuntu.com/ubuntu/dists/bionic-security/InRelease 錯誤 網上解決方法一&#xff1a;修改系統時間 修改時區 timedatectl set-timezone Asia/Shanghai 查看當前時間 date -R date -s “2023-12-5 15:57:15” 查看…

C++11多線程基本知識點

文章目錄 進程和線程的概念進程和線程的區別 C多線程的基本內容創建線程std::thread線程IDstd::thread對象生命周期和線程等待和分離線程參數傳遞引用類型成員函數作為線程入口和線程基類的封裝lambda臨時函數作為線程入口函數lambda函數lambda線程 多線程同步和通信多線程通信…

Python基礎(一、安裝環境及入門)

一、安裝 Python 訪問 Python 官方網站 并點擊 "Downloads"&#xff08;下載&#xff09;。 在下載頁面中&#xff0c;你會看到最新的 Python 版本。選擇與你的操作系統相對應的 Windows 安裝程序并下載。 雙擊下載的安裝程序&#xff0c;運行安裝向導。 在安裝向…