library("sf")
library("terra")
library("dplyr")
library("readr")
library("ggplot2")
library("terra")
library("adehabitatHR")
library("ggspatial")
Berechnung Homeranges
Libraries laden
Daten einlesen
Einlesen des Gesamtdatensatzes von Moodle, Sichtung des Datensatzes und der Datentypen
<- read_delim("datasets/fallstudie_n/Aufgabe3_Homeranges_Rehe_landforst_241011.csv", delim = ";")
Rehe
str(Rehe)
Aufgabe 1
Im Datensatz Rehe eine neue Spalte mit Datum und Zeit in einer Spalte kreieren. Beim Format hat sich ein Fehler eingeschlichen. Findet ihr ihn?
<- Rehe |>
Rehe mutate(UTC_DateTime = as.POSIXct(paste(UTC_Date, UTC_Time),
format = "%Y-%m-%d %H:%M:%S"))
Aufgabe 2
Mit den folgenden Zeilen können die GPS-Punkte visualisiert werden
<- st_as_sf(Rehe, coords = c("X", "Y"), crs = 21781)
Rehe_sf
<- filter(Rehe_sf, TierID == "RE13")
RE13
plot(RE13["TierID"])
Hier einige Zeilen Code, um eine HomeRange zu berechnen.
Herumschrauben an der Ausdehnung, resp. prozentualer Anteil Punkte in der HR (Funktion getverticeshr)
→ Ziel: eine Karte erstellen mit der Visualiserung mindestens einer HR
<- st_coordinates(RE13)
RE13_xy
<- as(RE13["TierID"], "Spatial")
RE13_sp
<- 0.5 * (sd(RE13_xy[, 1]) + sd(RE13_xy[, 2]))
sigma <- nrow(RE13)
n <- sigma * n ^ (-1 / 6) * 0.9 # scaled reference: href * 0.9
href
<- kernelUD(RE13_sp, h = href, grid = 25)
kud
<- getverticeshr(kud, percent = 95) # Berechnung der Home Range (95% Isopleth)
homerange
# Schreibt HR in den oben beschriebenen Ordner (als Shapefile)
<- st_as_sf(homerange)
hr
st_write(
hr,dsn = "results",
layer = "HR_RE13",
driver = "ESRI Shapefile",
delete_layer = TRUE
)## Deleting layer `HR_RE13' using driver `ESRI Shapefile'
## Writing layer `HR_RE13' to data source `results' using driver `ESRI Shapefile'
## Writing 1 features with 2 fields and geometry type Polygon.
# mit diesem Befehl kann die HR geplottet werden
ggplot(hr) +
geom_sf(size = 1, alpha = 0.3, color = "red", fill="red") +
coord_sf(datum = sf::st_crs(21781))+
theme(
axis.title = element_blank(),
axis.text = element_blank(),
axis.ticks = element_blank(),
legend.position="none"
)
# und die Punkte der GPS-Lokalisationen darüber gelegt werden
ggplot(hr) +
geom_sf(size = 1, alpha = 0.3, color = "red", fill="red") +
geom_sf(data = RE13, aes(fill = "red")) +
coord_sf(datum = sf::st_crs(21781))+
theme(
axis.title = element_blank(),
axis.text = element_blank(),
axis.ticks = element_blank(),
legend.position="none"
)
Code um die Homerange auf der Landeskarte 1:25000 zu plotten. Transparenz kann mit alpha angepasst werden.
<- rast("datasets/fallstudie_n/pk25_wpz.tif")
pk25_wpz
ggplot(hr, aes(color = "red", fill = "red")) +
annotation_spatial(pk25_wpz) +
geom_sf(size = 1, alpha = 0.3) +
geom_sf(data = RE13, aes(fill = "red")) +
coord_sf(datum = sf::st_crs(21781)) +
theme(
axis.title = element_blank(),
axis.text = element_blank(),
axis.ticks = element_blank(),
legend.position = "none"
)
Nachbauen des Sampling Grids mit den Kreisen (Wird als Grundlage für Extraktion der Umweltvariablen innerhalb der Homeranges benötigt)
- Ausdehnung des Grids basiert auf
hr
- Cellsize des Grids: 25m
<- st_make_grid(hr, 25, what = "centers")
x25 <- st_buffer(x25, 12.5)
grid_plot
ggplot(grid_plot, color = "black", fill = NA) +
geom_sf() +
geom_sf(data = RE13, color = "blue", ) +
geom_sf(data = hr, color = "red", fill = NA, size = 2) +
coord_sf(datum = 21781) +
theme(
axis.title = element_blank(),
axis.text = element_blank(),
axis.ticks = element_blank(),
legend.position = "none"
)
Aufgabe 3
Testen der Variablen der Vegetationsschichten von letzter Woche auf einen linearen Zusammenhang (Korrelation; Funktion cor.test). DG_Baumschicht vs. DG_os / DG_Strauchschicht vs. DG_us aus dem Datensatz df_with_lidar_2024 den wir letzte Woche erstellt haben
Die Theorie in den Vormittagslektionen zu Korrelation folgt erst ab 29.10.
<- read_delim("datasets/fallstudie_n/df_with_lidar_2024.csv", delim = ";")
df_with_lidar
cor.test(~ DG_Strauchschicht + DG_us_2022, data = df_with_lidar, method = "pearson")
##
## Pearson's product-moment correlation
##
## data: DG_Strauchschicht and DG_us_2022
## t = 4.3863, df = 171, p-value = 2.011e-05
## alternative hypothesis: true correlation is not equal to 0
## 95 percent confidence interval:
## 0.1772221 0.4460498
## sample estimates:
## cor
## 0.3180136