Skip to content
This repository has been archived by the owner on Jan 9, 2025. It is now read-only.

tsdataclinic/unicef-hackday-q423

Repository files navigation

This project is no longer maintained by Two Sigma. We continue to encourage independent development.

UNICEF

The United Nations Children's Fund (UNICEF) is an agency of the United Nations focused on providing humanitarian relief for children across the world. For this Hack Day, Data Clinic is partnering with UNICEF to use publicly available data sets to better understand how children in Africa are affected by conflict and climate change. This data science project will draw on several publicly available datasets which include:

  • Armed Conflict Location and Event Data Project (ACLED): detailed event level data on instances of armed conflict across Africa from 1997 onwards. Includes information about involved actors, latitude/longitude location, conflict type, and free text description.
  • WorldPop: High resolution population density estimates in each country in Africa. We have processed these data into an easier to use geojson file that contains point estimates of the number of children living in an area.
  • Children Climate Risk Index (CCRI): UNICEF dataset containing a set of 27 indicators of climate risk to children across countries in Africa.
  • World Risk Index: Country level estimates of disaster risk from extreme natural events and

You can find a much more detailed overview of the data sources here.

The goal of this project is to develop a data pipeline to combine these open data sources and develop metrics around the impact of climate change and conflict on children. We have provided some notebooks for you to get started on working with these datasets, and provide guidance and support on working with geospatial data.

Getting Started

Git stuff

We encourage people to follow the git feature branch workflow which you can read more about here: How to use git as a Data Scientist For each feature you are adding to the code:

  1. Switch to the master branch and pull the most recent changes
git checkout master 
git pull
  1. Make a new branch for your addition
git checkout -b cleaning_script
  1. Write your awesome code.
  2. Once it's done add it to git
git status
git add {files that have changed}
git commit -m {some descriptive commit message}
  1. Push the branch to gitlab
git push -u origin cleaning_script
  1. Go to git lab and create a merge request.
  2. Either merge the branch yourself if your confident it's good or request that someone else reviews the changes and merges it in.
  3. Repeat
  4. ...
  5. Profit.

Project Organization

Data Clinic projects are a little different form internal Two Sigma projects. We work with external partners who will either be the ones who we hope will take our work and use it in their day to day missions to empower the communities they serve. We also try to open source as much of our analysis as possible to enable others to build on what we have done.

Because these wider audiences will have to deal with the code / analysis we write potentially long after all our volunteers have moved on, we try to adhere to some best practises while working on a project.

To that end we have adopted the Data Science Cookie cutter approach to project structure. The full structure is described in detail in the next section but some major guidelines are:

  1. Data should be immutable. Datafiles should not be modified in place ever especially the data in RAW. Instead scripts should be written that reads in data from a previous step and outputs the results to a new file.

  2. Treat analysis as code in a DAG: Each script should build on those that go before it, reading in data from the raw data files and from interim data files and generating new datasets. It shouldn't be required for you to run a processing stage again once it has been run. The make file is a good way to ensure this.

  3. Notebooks should be for exploration and communication. Try to keep processing code out of notebooks especially code that can be used in multiple parts of the analysis. Instead add that code to the robinhood module. In general someone coming to the project fresh should be able to recreate the analysis using nothing but the code in the robinhood directory and data in the data directory. An example notebook for how to access the module can be found in notebooks/Examples.ipynb

Directory Structure:

├── LICENSE
├── README.md          <- The top-level README for developers using this project.
├── data
│   ├── raw            <- Data from third party sources.
│   └── processed      <- The final, canonical data sets for modeling.
│
├── notebooks          <- Jupyter notebooks. Naming convention is a number (for ordering),
│                         the creator's initials, and a short `-` delimited description, e.g.
│                         `1.0-jqp-initial-data-exploration`.
│
├── references         <- Data dictionaries, manuals, and all other explanatory materials.
│
├── src                <- Source code for use in this project.
│   ├── __init__.py    <- Makes src a Python module
│   │
│   ├── data           <- Scripts to download or generate data
│   │   └── utils.py

Project based on the cookiecutter data science project template. #cookiecutterdatascience

About

Some of the output from Q4'23 Hackday with UNICEF

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published