The GreyWolfPathAnalysis project focuses on the analysis of grey wolf movement patterns in the Alberta region of Canada. Using GPS telemetry data and various data structures such as graphs, hash tables, and stacks, this project seeks to answer key questions about wolf migration corridors, territorial behavior, and the effects of environmental conditions. The project integrates concepts from previous data structures such as Lists, Stacks, Queues, Maps, and Ordered Maps.
The students edit this section to add their names, Uniandes emails, and specify which project functionality of the project they will implement.
- Student No. 1 Ángel Farfán, Student No. 1 Uniandes Email [email protected], Student No. 1 20222183.
- Student No. 2 Juan José Díaz, Student No. 2 Uniandes Email [email protected], Student No. 2 202220657.
- Student No. 3 Name Andrés Cáceres, Student No. 3 Uniandes Email [email protected], Student No. 3 202214863.
Climate change and the loss of natural habitats are pressing issues facing nations today. In the pursuit of species conservation and coexistence, many zoologists and biologists have launched animal monitoring projects to better understand animal behavior and improve conservation policies.
In the northeastern forest ecosystems of Alberta, Canada, a project was conducted between 2013 and 2014 to monitor 17 grey wolves (Canis lupus). The monitored area spanned approximately 8759 km². Using GPS telemetry, researchers observed how snowfall impacted wolf behavior. Results indicated that heavy snowfalls (over 10 cm) reduced wolf mobility from an average of 13.14 km/day to 10.06 km/day, with a variation of ± 8.92 km/day. It was noted that wolf packs only began to recover their mobility after at least two days, reaching an average of 11.3 km/day. This reduction in mobility significantly affected hunting success, as wolves spent more than 20 hours hunting deer and up to 48 hours hunting moose.
These findings are critical for understanding how extreme weather conditions, exacerbated by climate change, impact wolf behavior and hunting patterns, potentially leading to increased contact with human settlements. This project is based on data collected by researchers Amanda Droghini and Stan Boutin from the University of Alberta's Department of Biological Sciences, as published in their 2018 paper, "The calm during the storm: Snowfall events decrease the movement rates of grey wolves (Canis lupus)."
The dataset for this challenge was sourced from the Movebank repository, specifically from the study "Boutin Alberta Grey Wolf." The dataset includes information from 46 wolves and 239,194 GPS telemetry data points recorded between February 2012 and September 2014. The original data contains two key tables: one detailing the GPS telemetry events and another describing the individual wolves involved in the study.
- United Nations Sustainable Development Goals (Biodiversity)
- The calm during the storm: Snowfall events decrease the movement rates of grey wolves (Canis lupus), published October 31, 2018.
- Boutin Alberta Grey Wolf, Movebank Study
This repository is part of the Data Structures and Algorithms (EDA) teaching framework at Universidad de los Andes. The repository was developed by faculty professors and staff in the Department of Systems and Computer Engineering (DISC) and uses the Non-Object-Oriented Python library DISCLib.
DISClib · DISClib Demo and Examples · Report Bug · Request Feature
IMPORTANT This is a work in progress and is part of a teaching framework for undergraduate college students at Universidad de los Andes. This project Is NOT intended as a full-functional source code project.
The challenge template has four main parts:
- DISClib Root folder with the official course library. For more on its implementation, visit the DISClib Repository.
- App Folder with the model-view-controller (MVC) Python scripts. In here, the students implement their code to complete the challenge.
- Data Folder with CSV data files to load into the application. Students must add the course-provided data files to complete the challenge.
- Docs Folder with reports, data tables, and other documentation. Students add their project report, data tables, and other documentation to complement their code implementation.
As a conservationist biologist, I want to know if there is a path between two meeting points used by wolves. The expected output includes:
- Total distance between the two points.
- Total number of meeting points along the path.
- Total number of tracking nodes (wolf movements) in the path.
- First and last five vertices (including the origin and destination) with:
- Identifier of the meeting point.
- Latitude and longitude of the point.
- Number of wolves present at the point.
- First and last wolf identifiers that transit through that point.
As a conservationist biologist, I want to know the corridor with the fewest points (meeting or tracking) between an origin and destination point. The expected output includes:
- Total distance between the two points.
- Total number of meeting points along the path.
- Total number of tracking nodes in the path.
- First and last five vertices (including the origin and destination) with:
- Identifier of the meeting point.
- Latitude and longitude of the point.
- Number of wolves present at the point.
- First and last wolf identifiers that transit through that point.
As a park ranger, I want to know the territories of wolf packs within the forest habitat. The output must contain:
- Total number of packs identified by their meeting and tracking points.
- The top five packs with the most control over territory, including:
- Number of meeting and tracking points within the territory.
- First and last three meeting points in the territory.
- Number of wolves in the pack.
- First and last three members of the pack, including:
- Wolf identifier.
- Taxonomy.
- Life stage.
- Sex.
- Study location.
- Maximum and minimum latitude and longitude of the territory.
As a park ranger, I want to identify the shortest migration corridor between two specific points within the Athabasca Oil Sands Region (AOSR). The expected output includes:
- Distance between the origin GPS point and the nearest meeting point.
- Distance between the destination GPS point and the nearest meeting point.
- Total distance of the path between origin and destination.
- Total number of meeting points along the path.
- Total number of wolves using the identified corridor.
- First and last three meeting points (including the origin and destination) with:
- Identifier of the meeting point.
- Latitude and longitude.
- Number of wolves present at the point.
- First and last wolf identifiers that transit through that point.
As a park ranger, I want to recognize the longest migration corridor I can inspect from a specific meeting point. The output must include:
- Maximum number of possible routes for inspection.
- The longest migration corridor, with:
- Number of visited meeting and tracking points.
- Total distance covered.
- Sequence of meeting points and wolves along the route.
As a conservationist biologist, I want to identify behavioral differences in wolves based on their sex over a given period. The expected output includes two parts:
-
The wolf that covered the most distance in the given range:
- Wolf identifier, taxonomy, life stage, sex, and study location.
- Total distance traveled.
- Longest route taken by the wolf:
- Total possible distance traveled.
- Total number of meeting and tracking points along the path.
- First and last three meeting points with:
- Identifier of the meeting point.
- Latitude and longitude.
- Number of wolves present at the point.
- First and last wolf identifiers.
-
The wolf that covered the least distance with similar details as above.
As a conservationist biologist, I want to observe the effects of climatic conditions on pack mobility and the territory they can cover. The output must contain:
- Total number of packs identified by their movement and meeting points.
- The first and last three packs with the largest territory based on meeting points, including:
- Number of wolves in the pack.
- First and last three pack members, including:
- Wolf identifier, taxonomy, life stage, sex, and study location.
- Maximum and minimum latitude and longitude in the territory.
- The longest route identified within the territory.
As a conservationist biologist, I want to visualize the results of all the application requirements. For this, teams are encouraged to graphically represent the results using multimedia resources and graphical interfaces. Suggested tools
To use this template, you need to follow the steps below:
- Read the official project document published in the course official site at BrightSpace.
- Distribute the project functionalities and implementation responsibilities among the group members.
- Download the official dataset for the project at the course official site at BrightSpace.
- Unzip and load the dataset into the application at the Data folder.
- Import the necessary modules from DISClib into the MVC scripts at the App folder.
- Implement the missing functions according to the project needs in the MVC scripts at the App folder.
- Evaluate the implementation of the MVC scripts, record your tests and analysis in the documents at the Docs folder (The report MUST BE in PDF format).
For further information and contact, use the following links:
- Official Repository DISClib.
- Repository for Demo and Examples.
If you require further information, please contact us via this email.
Contributions are what make the open-source community such an amazing place to learn, inspire, and create. Any contributions you make are greatly appreciated.
If you have a suggestion that would make this project better, please fork the repo and create a pull request. You can also simply open an issue with the tag "enhancement".
Don't forget to give the project a star! Thanks again!
- Fork the Project.
- Create your Feature Branch (
git checkout -b feature/AmazingFeature
). - Commit your Changes (
git commit -m 'Add some AmazingFeature'
). - Push to the Branch (
git push origin feature/AmazingFeature
). - Open a Pull Request.
Copyright 2020, Departamento de sistemas y Computación, Universidad de Los Andes. Developed for the class "ISIS1225 - Estructuras de Datos y Algoritmos" or "ISIS1225 - Data Structure and Algorithms" in English.
This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more information.
- Dario Correal is the original author and main developer of the library.
- Santiago Arteaga is a contributor and repository administrator.
- Luis Florez is a contributor and developed examples and tutorials for the library.