基於R語言的GD庫實現地理探測器並自動將連續變數轉為類別變數

来源:https://www.cnblogs.com/fkxxgis/p/18093713
-Advertisement-
Play Games

本文介紹基於R語言中的GD包,依據柵格影像數據,實現自變數最優離散化方法選取與執行,併進行地理探測器(Geodetector)操作的方法~ ...


  本文介紹基於R語言中的GD包,依據柵格影像數據,實現自變數最優離散化方法選取與執行,併進行地理探測器Geodetector)操作的方法。

  首先,在R語言中進行地理探測器操作,可通過geodetector包、GD包等2個包實現。其中,geodetector包是地理探測器模型的原作者團隊開發的,其需要保證輸入的自變數數據已經全部為類別數據;其具體操作方法大家可以參考地理探測器R語言實現:geodetector。而GD包則是另一位學者開發的,其可自動實現自變數數據最優離散化方法選取與執行;本文介紹的就是基於GD包實現地理探測器的具體操作。此外,如果希望基於Excel實現地理探測器,大家可以參考地理探測器Geodetector下載、使用、結果分析方法

1 包的安裝與導入

  首先,我們可以先到GD包在R語言中的官方網站,大致瞭解一下該包的簡要介紹、開發團隊等基本信息。

  隨後,我們開始GD包的下載與安裝。輸入如下所示的代碼,即可開始包的下載與安裝過程。

install.packages("GD")

  輸入代碼後,按下回車鍵,運行代碼;如下圖所示。在安裝GD包時,會自動將其所需依賴的其他包(如果在此之前沒有配置過)都一併配置好,非常方便。

image

  接下來,輸入如下的代碼,將GD包導入。

library("GD")

  輸入代碼後,按下回車鍵,運行代碼;如下圖所示。

2 數據讀取與預處理

  接下來,我們需要讀取柵格圖像數據,並將其轉為GD包可以識別的數據框Data Frames)格式。

  其中,讀取柵格數據的方法,大家參考基於R語言的raster包讀取遙感影像即可;關於數據格式的轉換,大家參考地理探測器R語言實現:geodetector即可。這一部分的內容本文就不再贅述。

3 地理探測器執行

  接下來,我們就可以開始地理探測器的具體分析;強烈建議大家基於GD包中的gdm()函數,實現一步到位的地理探測器分析操作。

  首先,如果大家輸入數據中的自變數數據具有連續變數,需要將其轉換為類別變數gdm()函數可以實現連續變數離散化方式尋優自動執行。其中,我們可以選擇的離散化方式包括相等間隔法自然間斷點法分位數分類法幾何間隔法標準差法5種不同的方法,分別對應以下第一句代碼中的"equal""natural""quantile""geometric""sd"5個選項。此外,我們還可以依據數據的特征,對自變數離散化的類別數量加以限定,具體代碼如下所示。

discmethod <- c("equal", "natural", "quantile", "geometric", "sd")
discitv <- c(4:10)

  其中,上述第一句代碼表示,我們後續將從相等間隔法自然間斷點法分位數分類法幾何間隔法標準差法5種不同的方法中,找到每一個連續變數對應的最優離散化方法;第二句代碼則表示,在後續尋找最優離散化方法的同時,還需要對每一個變數的分類數量加以尋優——c(4:10)就表示我們分別將每一個連續變數分為4類、5類、6類,以此類推,一直到10類,從其中找到最優結果對應的類別數量

  接下來,我們即可調用gdm()函數,執行地理探測器分析的具體操作;其中,my_gd為保存地理探測器結果的變數;函數的第一個參數,表示因變數與自變數的關係,~前的變數即為因變數~後的變數即為自變數,多個自變數之間通過+相連接;第二個參數表示自變數中的連續變數,程式將自動對這些連續變數加以離散化方法尋優與執行;第三個參數表示存儲自變數與因變數數據的數據框Data Frames)格式的變數;最後兩個變數,即為前面我們選擇的離散化方法類別數量

my_gd <- gdm(A_LCCS0 ~ C_SlopeS0 + D_AspectS0 + DEM_Reclass + F_LCS0,
                        continuous_variable = c("C_SlopeS0", "D_AspectS0"),
                        data = tif_frame,
                        discmethod = discmethod,
                        discitv = discitv)

  這裡需要註意,如果大家不是通過腳本運行的R語言,而是每次寫一句代碼然後按下回車鍵運行一下,那麼上述代碼中的換行就需要通過同時按下Shift鍵與回車鍵實現。輸入上述代碼後,如下圖所示。

  隨後,即可運行代碼。稍等片刻(具體時長與數據量有關),即可得到地理探測器的結果my_gd。這一變數的具體結構、內容如下圖所示。

  我們可以輸入如下的代碼,將變數my_gd列印出來。

my_gd

  所得結果如下圖所示。

  可以看到,my_gd變數包含了每一個連續變數在離散化後,對應的最優離散化方法類別數量,以及地理探測器的各個分析結果。具體結果的含義與研讀方法,大家參考地理探測器Geodetector下載、使用、結果分析方法,以及地理探測器R語言實現:geodetector這兩篇文章即可,這裡就不再贅述。

  此外,我們可以通過如下的代碼,將上述結果加以可視化。

plot(my_gd)

  運行上述代碼,結果如下圖所示。

  此時,在RStudio軟體的右下方“Plots”中,即可看到可視化結果,如下圖所示。其中,我們可以通過下圖中紅色方框內的箭頭,實現不同圖片的切換顯示。

  上述結果包含7張圖像,其分別與上上圖中的7項輸出內容對應——第一張圖是最優離散化方法的選取過程,第二張圖則是所選出的最優離散化方法對應的分類情況;後5張圖就是地理探測器的分析結果圖,即上上圖中最後5plot分別對應的結果。

  至此,我們就完成了基於R語言中的GD包,依據多張柵格圖像數據,實現類別變數的自動離散化,併進行地理探測器Geodetector)操作的完整流程。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Spring 為開發 Java 應用程式提供了全面的基礎架構支持,它將 Java 對象交由容器統一管理,從而實現控制反轉(IOC)和依賴註入(DI),並提供了一些常用模塊如 SpringAOP、SpringJDBC、SpringMVC 等等 SpringBoot 繼承了 Spring 的核心思想,並 ...
  • 在處理PDF文檔時,有時需要為文檔中的每一頁添加頁眉和頁腳,以包含一些有用的信息,如文檔標題、章節名稱、日期、頁碼等。對於需要自動化處理的場景,或者需要在大量文檔中添加一致的頁眉和頁腳,可以通過編程的方式來實現。本文將介紹如何使用Java為PDF文件添加頁眉、頁腳。 所需工具:Free Spire. ...
  • 今天講一個常見的gc compiler(也就是官方版本的go編譯器和runtime)在垃圾回收的掃描標記階段做的優化。 我對這個優化的描述印象最深的是在bigcache的註釋里,大致內容是如果map的鍵值都不包含指針,那麼gc掃描的時候不管這個map多大都不會深入掃描map內部存儲的數據,只檢查ma ...
  • 目錄簡介架構Application 和組件簡單入門示例先決條件創建項目編譯庫文件引用庫文件運行項目界面交互示例創建項目編譯庫文件實現應用函數引用庫文件運行項目參考資料 簡介 Sauron 是一個多功能的 Web 框架和庫,用於構建客戶端和/或伺服器端 Web 應用程式,重點關註人體工程學、簡單性和優 ...
  • 前言 springboot 整合 ES 有兩種方案,ES 官方提供的 Elasticsearch Java API Client 和 spring 提供的 [Spring Data Elasticsearch](Spring Data Elasticsearch) 兩種方案各有優劣 Spring:高 ...
  • EasyCode —— 基於 IntelliJ IDEA Ultimate 版開發的一個代碼生成插件,主要通過自定義模板(基於 velocity)來生成各種你想要的代碼。 ...
  • 本文詳細介紹瞭如何使用Python中的Matplotlib、Seaborn、Bokeh和Plotly等庫進行數據可視化,並深入探討了一系列主題,涵蓋了從基礎的靜態圖表到高級的交互性和動態可視化的方方面面。 ...
  • 本文主要講述Java中各類鎖機制的特點,包括重入鎖、悲觀/樂觀鎖、偏向/輕量級/重量級鎖、分段鎖和自旋鎖,闡述其優缺點及一些適用場景。 ...
一周排行
    -Advertisement-
    Play Games
  • .Net8.0 Blazor Hybird 桌面端 (WPF/Winform) 實測可以完整運行在 win7sp1/win10/win11. 如果用其他工具打包,還可以運行在mac/linux下, 傳送門BlazorHybrid 發佈為無依賴包方式 安裝 WebView2Runtime 1.57 M ...
  • 目錄前言PostgreSql安裝測試額外Nuget安裝Person.cs模擬運行Navicate連postgresql解決方案Garnet為什麼要選擇Garnet而不是RedisRedis不再開源Windows版的Redis是由微軟維護的Windows Redis版本老舊,後續可能不再更新Garne ...
  • C#TMS系統代碼-聯表報表學習 領導被裁了之後很快就有人上任了,幾乎是無縫銜接,很難讓我不想到這早就決定好了。我的職責沒有任何變化。感受下來這個系統封裝程度很高,我只要會調用方法就行。這個系統交付之後不會有太多問題,更多應該是做小需求,有大的開發任務應該也是第二期的事,嗯?怎麼感覺我變成運維了?而 ...
  • 我在隨筆《EAV模型(實體-屬性-值)的設計和低代碼的處理方案(1)》中介紹了一些基本的EAV模型設計知識和基於Winform場景下低代碼(或者說無代碼)的一些實現思路,在本篇隨筆中,我們來分析一下這種針對通用業務,且只需定義就能構建業務模塊存儲和界面的解決方案,其中的數據查詢處理的操作。 ...
  • 對某個遠程伺服器啟用和設置NTP服務(Windows系統) 打開註冊表 HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\W32Time\TimeProviders\NtpServer 將 Enabled 的值設置為 1,這將啟用NTP伺服器功 ...
  • title: Django信號與擴展:深入理解與實踐 date: 2024/5/15 22:40:52 updated: 2024/5/15 22:40:52 categories: 後端開發 tags: Django 信號 松耦合 觀察者 擴展 安全 性能 第一部分:Django信號基礎 Djan ...
  • 使用xadmin2遇到的問題&解決 環境配置: 使用的模塊版本: 關聯的包 Django 3.2.15 mysqlclient 2.2.4 xadmin 2.0.1 django-crispy-forms >= 1.6.0 django-import-export >= 0.5.1 django-r ...
  • 今天我打算整點兒不一樣的內容,通過之前學習的TransformerMap和LazyMap鏈,想搞點不一樣的,所以我關註了另外一條鏈DefaultedMap鏈,主要調用鏈為: 調用鏈詳細描述: ObjectInputStream.readObject() DefaultedMap.readObject ...
  • 後端應用級開發者該如何擁抱 AI GC?就是在這樣的一個大的浪潮下,我們的傳統的應用級開發者。我們該如何選擇職業或者是如何去快速轉型,跟上這樣的一個行業的一個浪潮? 0 AI金字塔模型 越往上它的整個難度就是職業機會也好,或者說是整個的這個運作也好,它的難度會越大,然後越往下機會就會越多,所以這是一 ...
  • @Autowired是Spring框架提供的註解,@Resource是Java EE 5規範提供的註解。 @Autowired預設按照類型自動裝配,而@Resource預設按照名稱自動裝配。 @Autowired支持@Qualifier註解來指定裝配哪一個具有相同類型的bean,而@Resourc... ...