Skip to content

Continuous mapping of genetic diversity

License

Unknown, MIT licenses found

Licenses found

Unknown
LICENSE
MIT
LICENSE.md
Notifications You must be signed in to change notification settings

AnushaPB/wingen

Repository files navigation

wingen

codecov R-CMD-check test-coverage license: MIT

Generate continuous maps of genetic diversity using moving windows with options for rarefaction, interpolation, and masking.

Citation

Please cite the original Bishop et al. (2023) paper if you use this package:

Bishop, A. P., Chambers, E. A., & Wang, I. J. (2023). Generating continuous maps of genetic diversity using moving windows. Methods in Ecology and Evolution, 14, 1175–1181. http://doi.org/10.1111/2041-210X.14090

Checkout our Methods blog post about wingen for a quick overview of the package and its uses.

Installation

Install wingen from GitHub with:

# install.packages("devtools")
devtools::install_github("AnushaPB/wingen", build_vignettes = TRUE)

Example

The following example demonstrates the basic functionality of wingen using a small subset (100 variant loci x 100 samples) of the simulated data from Bishop et al. (2023).

library(wingen)
# Load example data
load_middle_earth_ex()

The core function of this package is window_gd(), which takes as inputs a vcfR object (or a path to a .vcf file), sample coordinates (as a data.frame, matrix, or sf object), and a raster layer (as a SpatRaster or RasterLayer) which the moving window will slide across. Users can control the genetic diversity statistic that is calculated (stat), the window dimensions (wdim), the aggregation factor to use on the raster (fact), whether to perform rarefaction (rarify), and other aspects of the moving window calculations. Additional arguments for this function are described in the vignette and function documentation.

# Run moving window calculations of pi with rarefaction
wgd <- window_gd(lotr_vcf,
  lotr_coords,
  lotr_lyr,
  stat = "pi",
  wdim = 7,
  fact = 3,
  rarify = TRUE
)

# Use plot_gd() to plot the genetic diversity layer and plot_count() to plot the sample counts layer
par(mfrow = c(1, 2), oma = rep(0, 4), mar = rep(0, 4), pty = "s")
plot_gd(wgd, main = "Moving window pi", legend.width = 1.5)
plot_count(wgd, main = "Moving window sample counts", legend.width = 1.5)

Next, the output from window_gd() can be interpolated using kriging with the krig_gd() function.

# Krige genetic diversity (disaggregate grid to project across a smoother final surface)
kgd <- krig_gd(wgd, lotr_lyr, index = 1, disagg_grd = 2)

Finally, the output from krig_gd() (or window_gd()) can be masked to exclude areas that fall outside of the study area or that were undersampled.

# Mask results that fall outside of the "range"
mgd <- mask_gd(kgd, lotr_range)
# Plot results
par(mfrow = c(1, 2), oma = rep(0, 4), mar = rep(0, 4), pty = "s")

plot_gd(kgd, main = "Kriged pi", legend.width = 1.5)

plot_gd(mgd, main = "Masked pi", legend.width = 1.5)

For an extended walk through, see the package vignette:

vignette("wingen-vignette")

A pdf of the vignette can also be found here

Example analyses from Bishop et al. (2023) can be found in the paperex directory.

About

Continuous mapping of genetic diversity

Resources

License

Unknown, MIT licenses found

Licenses found

Unknown
LICENSE
MIT
LICENSE.md

Stars

Watchers

Forks

Packages

No packages published

Contributors 4

  •  
  •  
  •  
  •