当前位置: 首页 > article >正文

使用R语言进行美国失业率时空分析(包括绘图)

今天写一篇利用R语言,针对面板数据的简单分析与绘图。让我们直接开始把。

一、数据准备

这次的示例数据非常简单,只有一个shp格式的美国区县矢量数据,我们在QGIS中打开数据查看一下它的属性表。事实上我们需要的数据都在属性表的字段中。

图片

二、开始分析

1、引入必要的包,将本地的数据导入,查看数据是否正确。进行简单可视化。

library(sf)
library(tmap)

shp <- st_read("G:/Maping/demo/data/data/USA_data/ncovr/NAT.shp")

head(shp)

数据当中"UE60", "UE70", "UE80", "UE90"字段分别表示1960,1970,1980,1990年的美国各区县的失业率。下面我们别将各年份的数据可视化出来。

ue60 = tm_shape(shp) +
  tm_polygons("UE60", palette = "Reds", title = "1960 Unemployment Rate") +
  tm_compass(position = c(0.8, 0.86)) +
  tm_scale_bar(position = c(0.77,0.06), breaks = c(0,500,1000)) +
  tm_layout(legend.title.size = 0.8)
ue60

#如果想保存到本地,运行下面这句话就行了
tmap_save(ue60, "G:/Maping/ue60.png", dpi = 300)

同理,我们只要修改字段,就可以绘制不同年份的美国失业率地图了。我们也可以运用之前文章中提到的绘制组图的方法将他们一起绘制。绘制组图教程。如下: 

2、计算新的字段变化率幅度,并且可视化出来。

这个其实很简单,就是使用UE90-UE60就好了。代码如下:

#添加变化率字段
shp$Change_6090 <- shp$UE90 - shp$UE60
change = tm_shape(shp) +
  tm_polygons("Change_6090", palette = "-RdYlBu", title = "Legend") +
  tm_layout(
    main.title = "Change in Unemployment Rate (1960-1990)",  # 添加标题
    main.title.position = "center",                        # 标题居中
    main.title.size = 1.5,
    legend.position = c(0.86,0.01)
  )
change          
tmap_save(change, "G:/Maping/change60_90.png", dpi = 300)

3、进行全局空间自相关分析,计算Moran's I指数

我们还可以进一步的做分析,通过计算四个年份的失业率的均值,对失业率的数据进行空间自相关分析。代码如下:

library(spdep)

shp$UEmean <- rowMeans(st_drop_geometry(shp)[, c("UE60", "UE70", "UE80", "UE90")], na.rm = TRUE)
nb <- poly2nb(shp) # 创建邻接关系
lw <- nb2listw(nb, style = "W") # 权重矩阵
moran <- moran.test(shp$UEmean, lw)
print(moran)

我把结果贴出来:

4、热点分析,进行可视化

这里我们可以识别高失业率或低失业率的热点区域,代码如下:

# 热点分析
hotspot <- localG(shp$UEmean, lw)

# 将热点分析结果添加到数据
shp$hotspot <- hotspot

# 绘制热点分析结果
hot = tm_shape(shp) +
  tm_polygons("hotspot", palette = "-RdYlBu", title = " ") +
  tm_compass(position = c(0.8, 0.86)) +
  tm_scale_bar(position = c(0.77,0.06), breaks = c(0,500,1000)) +
  tm_layout(
    main.title = "Hotspot Analysis)",  # 添加标题
    main.title.position = "center",                        # 标题居中
    main.title.size = 1.5,
    legend.text.size = 0.8
  )
tmap_save(hot, "G:/Maping/hotmean.png", dpi = 300)

以上就是全部内容了谢谢你的支持,我是加拿大一枝黄花。 


http://www.kler.cn/a/416223.html

相关文章:

  • 周鸿祎再次“创业”,盯上百度
  • 关于PyTorch中的Dataloader运行异常问题以及部分图标含义
  • 代码随想录第四十五天
  • 【小白学机器学习42】进行多次抽样,样本的分布参数和总体的分布参数的关系
  • Oracle RAC的DB未随集群自动启动
  • 利用Java爬虫获取阿里巴巴中国站跨境属性的详细指南
  • Ubuntu下安装EMQTT
  • 公链开发中的技术实现路径:构建高效、安全的去中心化网络
  • 三格电子—单通道串口服务器
  • 生成唯一ID的作用?有哪些方式方法?
  • GWAS数据库ieugwasr包最新配置API用户Token方法
  • 中国科学院大学研究生学术英语读写教程 Unit7 Materials Science TextA 原文和翻译
  • 循环神经网络:从基础到应用的深度解析
  • 使用PyTorch在AMD GPU上进行INT8量化实现精简化的LLM推理
  • python找出Excel文件大于2048个字符长度的数据
  • JiaJia-CP-1,2,3的WP(1)
  • mybatis-plus 对于属性为null字段不更新
  • JavaScript异步编程和与之相关的概念
  • 音视频入门基础:MPEG2-TS专题(10)——PAT简介
  • hdlbits系列verilog解答(Exams/m2014 q4a)-86