使用R中的ggplot2在散点图中指向具有单个椭圆的点

时间:2018-02-07 17:15:22

标签: r ggplot2 scatter-plot ellipse

我的数据集由4列组成,如下所示: enter image description here

左边的两列代表地理结构的坐标XY,左边的两列代表“每个”地理单位的大小(直径南北和东西)

我想以图形方式表示一个散点图,在这里绘制所有坐标,并在每个点上绘制一个包含每个地理单位直径的椭圆。

手动,只使用两个点,图像应该是这样的: enter image description here

我怎样才能使用ggplot2?

您可以下载数据here

2 个答案:

答案 0 :(得分:4)

使用ggforce中的geom_ellipse()

library(ggplot2)
library(ggforce)

d <- data.frame(
  x = c(10, 20),
  y = c(10, 20),
  ns = c(5, 8),
  ew = c(4, 4)
)

ggplot(d, aes(x0 = x, y0 = y, a = ew/2, b = ns/2, angle = 0)) + 
  geom_ellipse() +
  coord_fixed()

reprex package创建于2019-06-01(v0.2.1)

答案 1 :(得分:3)

我没有向what Claus Wilke already posted above添加任何新代码。所有的功劳都归功于克劳斯。我只是用实际数据测试它,并显示OP如何发布数据,

需要加载包

# install.packages(c("tidyverse"), dependencies = TRUE)
library(tidyverse)

阅读数据,

tbl <- read.table(
text = "
X Y Diameter_N_S Diameter_E_W
-4275   1145    77  96
-4855   1330    30  25
-4850   1612    45  90
-4990   1410    15  15
-5055   1230    60  50
-5065   1503    43  45
-5135   1305    40  50
-5505   1190    55  70
-5705   1430    90  40
-5645   1535    52  60
", header = TRUE, stringsAsFactors = FALSE) %>% as_tibble()

显示数据,

tbl
#> # A tibble: 10 x 4
#>        X     Y Diameter_N_S Diameter_E_W
#>    <int> <int>        <int>        <int>
#>  1 -4275  1145           77           96
#>  2 -4855  1330           30           25
#>  3 -4850  1612           45           90
#>  4 -4990  1410           15           15
#>  5 -5055  1230           60           50
#>  6 -5065  1503           43           45
#>  7 -5135  1305           40           50
#>  8 -5505  1190           55           70
#>  9 -5705  1430           90           40
#> 10 -5645  1535           52           60

加载更多需要的包

library(ggforce) # devtools::install_github("thomasp85/ggforce")

执行

ggplot(tbl, aes(x0 = X, y0 = Y, a = Diameter_E_W, b = Diameter_N_S, angle = 0)) +
        geom_ellipsis() + geom_point(aes(X, Y), size = .5) + coord_fixed() + theme_bw()

enter image description here