class: center, middle, inverse, title-slide # Implementing proximity based social network analysis using spatsoc ### Alec L. Robitaille, Quinn M.R. Webber and Eric Vander Wal ### 2019-02-07 --- background-image: url("images/ducksandzebras.png") background-position: center background-size: contain # The paradox of being social in spatial context --- # History of spatsoc * ### Linking social behavior and space use * ### Most practical to use animals with GPS collars * ### GPS collars typically used to quantify measures of habitat selection or movement, but not social proximity * ### Webber and Vander Wal review links between social and spatial ecology --- background-image: url("images/evoframe.png") background-position: center background-size: contain # History of spatsoc --- # History of spatsoc: big ideas, big data ## Idea: * #### Individualize social network proximity and habitat selection patterns and determine how these traits influence reproductive success. ## Data: * #### Caribou in Newfoundland, Elk and wolves in Manitoba * #### For example, in Newfoundland, many studies quantifying habitat selection patterns for Newfoundland caribou, but no incorporation of social processes .center[data:image/s3,"s3://crabby-images/b63d0/b63d0b77db0f64a33333bd18e2b2ab7de9204239" alt=""] --- # Informal implementation * ### Need for functions to generate social networks for GPS collared caribou * ### Original “home-made” functions made by Quinn were limited .pull-right[data:image/s3,"s3://crabby-images/18723/1872302f01732bbe207f2ceb40f38f7a55fd7c3c" alt=":scale 100%"] * #### Inflexible * #### Slow * #### Prone to breaking --- # Formal implementation * #### Early functions simply generated buffers around an individual's temporally discrete GPS fixes and detected whether other individuals were within those buffers .center[data:image/s3,"s3://crabby-images/bcaf6/bcaf66322efb1e81608ee021a9db3da946172a5a" alt=""] --- # History of spatsoc: putting it to the test .center[ data:image/s3,"s3://crabby-images/d92b8/d92b8a26f38897578fdaf6464c3a90305e4e70cb" alt=":scale 70%" data:image/s3,"s3://crabby-images/c2511/c251192f02a13f2797ab9f2fc149aa196020ad5e" alt=":scale 65%" ] ??? spatsoc used to generate proximity based social networks and compared across seasons --- # History of spatsoc: applications * #### Social processes can be relevant for conservation managers: * #### Allee effects * #### Detection-dilution trade-off for predators * #### Detect locations where animals aggregate * #### Determine whether animals more likely to aggregate at certain times of year * #### If survival/reproductive of collared animals is known, can determine whether social association was related to survival .center[data:image/s3,"s3://crabby-images/c8840/c88404d7000b43c761f1c041c3c8d7ee76e12f90" alt=":scale 45%"] --- # Package basics .pull-left[
] .sidebar[ Package checklist: `\(\> \checkmark\)` novel and interesting method `\(\> \Box\)` easy to use, flexible `\(\> \Box\)` extensive documentation `\(\> \Box\)` well tested ] ??? <!-- ## how spatsoc works --> --- # Workflow
--- # Temporal grouping ```r group_times(DT, datetime = c('idate', 'itime'), threshold = '5 minutes') ``` .pull-left[ * grouped by "nearest" * threshold must be divisible by 24 hours or 60 minutes |idate | itime| minutes| timegroup| |:----------|--------:|-------:|---------:| |2018-12-12 | 01:00:00| 0| 1| |2018-12-12 | 01:02:00| 0| 1| |2018-12-12 | 01:01:00| 0| 1| |2018-12-12 | 03:00:00| 0| 2| |2018-12-12 | 03:02:00| 0| 2| |2018-12-12 | 03:00:00| 0| 2| |2018-12-12 | 05:00:00| 0| 3| |2018-12-12 | 05:01:00| 0| 3| |2018-12-12 | 05:01:00| 0| 3| ] .fixed-pos-r[
] --- # Spatial grouping .center[[`data.table`](https://github.com/Rdatatable/data.table) + GIS operations + [`igraph`](https://github.com/igraph/rigraph)] .pull-left[ |function | operation | |:----------|--------:| |`group_pts` | distance matrix | |`group_lines` | line intersection | |`group_polys` | polygon overlap | ] .fixed-pos-r[
] --- # Spatial grouping: points ```r group_pts(DT, threshold = 5, id = 'ID', coords = c('X', 'Y'), timegroup = 'timegroup') ``` .pull-left[ data:image/s3,"s3://crabby-images/df142/df142896eb344878d6e34893ad193e8c5a115c58" alt=":scale 100%" ] .fixed-pos-r[
] --- # Spatial grouping: lines ```r group_lines(DT, threshold = 50, projection = utm, id = 'ID', coords = c('X', 'Y'), timegroup = 'timegroup', sortBy = 'datetime') ``` .pull-left[ data:image/s3,"s3://crabby-images/42116/4211636ca30b7825da472c88d6994de99a497993" alt=":scale 100%" ] .fixed-pos-r[
] --- # Spatial grouping: polygons ```r group_polys(DT, area = FALSE, 'mcp', list(percent = 95), projection = utm, id = 'ID', coords = c('X', 'Y')) ``` .pull-left[ * binary or proportional area overlap data:image/s3,"s3://crabby-images/3708e/3708e059c157c37f057eadc23e62ac5290e49341" alt=":scale 100%" ] .fixed-pos-r[
] --- # Spatial grouping all three spatial grouping functions internally use the same logic: 1. use GIS operations to build a logical matrix 1. use `igraph` to calculate the connected components .center[data:image/s3,"s3://crabby-images/182cc/182ccceffe03d13ffe1d3baa8c1ca2b84ebacb76" alt=""] --- # Flexible thresholds .pull-left[ spatiotemporal grouping with spatsoc is flexible to different user data: 1. Temporal thresholding can be a value on the scale of minutes, hours or days 2. Spatial threshold can be 0 for simple overlap and intersection or any positive value for buffered overlap .warn[ Note that this flexibility comes with a requirement for system specific knowledge and/or sensitivity analysis. ] ] .sidebar[ Package checklist: `\(\> \checkmark\)` novel and interesting method `\(\> \checkmark\)` easy to use, flexible `\(\> \Box\)` extensive documentation `\(\> \Box\)` well tested ] ??? e.g. this warn is a TODO for us --- # Social network analysis ```r randomizations(DT, type = 'trajectory', ...) get_gbi(DT = DT, group = 'group', id = 'ID') ``` .pull-left[ data:image/s3,"s3://crabby-images/dfc3a/dfc3a43a5a82e431cca44624667cd04d1a91b84f" alt=":scale 80%" | | A| B| C| D| E| F| |:--|--:|--:|--:|--:|--:|--:| |1 | 1| 1| 1| 0| 1| 1| |2 | 1| 1| 1| 0| 1| 1| |3 | 0| 0| 0| 1| 0| 0| |4 | 0| 0| 0| 1| 0| 0| ] .fixed-pos-r[
] --- background-image: url("images/ropensci.png") background-position: center background-size: contain # rOpenSci software review <!-- * Editors, reviewers * Standard of rOpenSci: documentation, ease of use * What did the reviewers comment on/ask for improvement --> ??? share this: https://github.com/ropensci/onboarding/issues/237 and this: https://ropensci.org/blog/2018/12/04/spatsoc/ --- # rOpenSci software review .pull-left[ * common goal of improving the package * emphasize extensive testing, continuous integration and user accessibility ] .sidebar[ Package checklist: `\(\> \checkmark\)` original and useful method `\(\> \checkmark\)` easy to use, flexible `\(\> \checkmark\)` extensive documentation `\(\> \checkmark\)` well tested ] .fixed-pos-b[[data:image/s3,"s3://crabby-images/99d98/99d98cb7b575ba9b8cea864a7574ef7f633333f5" alt="ropensci\_footer"](https://ropensci.org)] --- # rOpenSci software review .pull-left[data:image/s3,"s3://crabby-images/412fd/412fdb706b350336f0a198db6b1b121edc287455" alt=""] .sidebar[ Package checklist: `\(\> \checkmark\)` original and useful method `\(\> \checkmark\)` easy to use, flexible `\(\> \checkmark\)` extensive documentation `\(\> \checkmark\)` well tested ] ??? expectations <!--basic testing example--> <!-- this example --> --- # Next steps: functions * ### dyadic pairing * ### spatial point clustering .center[[data:image/s3,"s3://crabby-images/4f03d/4f03d52e56c134022d13a7683a21845e6fbe4d6a" alt=":scale 80"](https://github.com/ropensci/spatsoc/issues)] --- # Next steps: applications * #### spatsoc essentially boils down to points in time and space * #### Can be used to determine encounter rates among predators and prey * #### Could also be used to determine proximity of individuals to fixed locations .center[data:image/s3,"s3://crabby-images/3f9f3/3f9f38f267babb0900bead717d9403b82f506571" alt=":scale 60%"] --- # Conclusion * ### spatsoc is an R package that groups GPS relocations in time and space * ### Primary intention was to generate proximity based social networks, but other use-cases available * ### spatsoc is in revision for publication, but we’re always looking to grow the package and the functions * ### If you have an idea, let us know or open an issue! --- # Acknowledgements .center[ [data:image/s3,"s3://crabby-images/f72d5/f72d5459fa27751d180cb9bc899127e0080a3be0" alt=":scale 25%"](weel.gitlab.io) data:image/s3,"s3://crabby-images/6a663/6a663adb1c81b314d166dbac4af61a17661f30ab" alt=":scale 25%" data:image/s3,"s3://crabby-images/03135/031356ca59670039065584ceb1a4d1a0ee65feae" alt=":scale 25%" data:image/s3,"s3://crabby-images/309ec/309ec996c31486fc56e47c2b58ce61f2905fbc27" alt=":scale 25%" data:image/s3,"s3://crabby-images/114e9/114e92312237c583d496ba7d35cb74422a3bdbec" alt=":scale 25%" [data:image/s3,"s3://crabby-images/2e5b1/2e5b17d3122a3f0c6e3c997970d9d0430bcdd172" alt=":scale 25%"](https://ropensci.org) ] .footnote[ This presentation was built using [Yihui Xie's xaringan package](https://github.com/yihui/xaringan). ]