Skip to content

wri/cities-cif

Repository files navigation

Cities Indicator Framework

The Cities Indicator Framework (CIF) is a set of Python tools to make it easier to calculate zonal statistics for cities by providing a standardized set of data layers for inputs and a common framework for using those layers to calculate indicators.

Quick start

Installation

  • pip install git+https://github.com/wri/[email protected] to install a specific version.
  • pip install git+https://github.com/wri/cities-cif/releases/latest gives you the latest stable release.
  • pip install git+https://github.com/wri/cities-cif gives you the main branch with is not stable.

NOTE: If you have already installed the package and want to update to the latest code you may need to add the --force-reinstall flag

PR Review

  1. Prerequisites
  2. Git
  3. https://cli.github.com/
    • On MacOS I recommend the Homebrew option
    • If you don't have an ssh key, it will install one for you
  4. Conda (or Mamba) to install dependencies
    • If you have Homebrew brew install --cask miniconda

Dependencies

There are 2 ways to install dependencies. Choose one...

Conda

conda env create -f environment.yml or conda env update -f environment.yml

Setuptools

python setup.py NOTE: If you are using this method you may want to use something like pyenv to manage Python environments

Credentials

To run the module,

  1. You need access to Google Earth Engine
  2. Install https://cloud.google.com/sdk/docs/install
  3. If you want to use the ERA5 and CAMS layers:
    1. you need to install the Climate Data Store (CDS) Application Program Interface (API)
    2. create a .cdsapirc file in your home directory, specifying both urls (https://cds.climate.copernicus.eu/api and https://ads.atmosphere.copernicus.eu/api) and the key that you've obtained from the ECMWF site.

Interactive development

For most people working in a notebook or IDE the script should walk you thourgh an interactive authentication process. You will just need to be logged in to your Google account that has access to GEE in your browser.

Programatic access

If you have issues with this or need to run the script as part of an automated workflow we have a GEE-enabled GCP service account that can be used. Get in touch with Saif or Chris to ask about getting the credetials.

Set the following environment variables:

  • GOOGLE_APPLICATION_CREDENTIALS: The path of GCP credentials JSON file containing your private key.
  • GOOGLE_APPLICATION_USER: The email for your GCP user.

For example, you could set the following in your ~/.zshrc file:

export GOOGLE_APPLICATION_USER=developers@citiesindicators.iam.gserviceaccount.com
export GOOGLE_APPLICATION_CREDENTIALS=/path/to/credentials/file

How to contribute

All are welcome to contribute by creating a Pull Request. We try to follow the Github Flow workflow.

See PR Review for more details and options on how to review a PR.

See the developer docs to learn more about how to add data layers and indicators.