The Crisis Mapping Toolkit is a collection of algorithms and utilities for creating maps in response to crisis. The CMT relies on Google Earth Engine (EE) for much of its data processing. The CMT is released under the Apache 2 license.
The CMT is developed by the NASA Ames Intelligent Robotics Group, with generous support from the Google Crisis Response Team and the Google Earth Engine Team.
The CMT currently provides:
- Algorithms to determine flood extent from MODIS data, such as multiple thresholding techniques, learned approaches, Dynamic Nearest Neighbor Search, and more.
- Algorithms to determine flood extent from SAR data, such as histogram thresholding and active contour.
- Various helpful utilities, such as:
- An improved visualization UI, with a drop down menu of layers similar to the EE javascript playground.
- Local EE image download and processing, for the occasional operation that cannot be done efficiently in EE.
- A configurable domain specification to define problem domains and data sources in XML.
The CMT is under heavy development, so expect frequent changes and additional features. Please contact Brian Coltin (brian.j.coltin at nasa dot gov) with any questions.
- Download the CMT source code from Github.
- Install PyQt4.
- Install the CMT with
python setup.py install
Before calling any CMT function, you must initialize EE, either by calling ee.Initialize, or by using the cmt ee_authenticate package:
from cmt import ee_authenticate
ee_authenticate.initialize()
To use this authentication method, store your google EE API email address in the file ~/.local/google_service_account.txt, and your private key in the file ~/.local/google_service_api_private_key.pem.
To use the CMT UI, replace your import of the EE map client:
from ee.mapclient import centerMap, addToMap
with
from cmt.mapclient_qt import centerMap, addToMap
then use the centerMap and addToMap functions exactly as before. That's it!
See the documentation in local_ee_image.py. When you construct a LocalEEImage, the image is downloaded from EE with the specified scale and bounding box using getDownloadURL. You can then access individual pixels or bands as PIL Images. Images are cached locally so if you are testing on the same image you do not need to wait to download every time. We recommend using LocalEEImage sparingly, only for operations which cannot be performed through EE, as downloading the entire image is expensive in both time and bandwidth.
To use the data sources in the config directory, you must join the Crisis Mapping Toolkit Users Google Group. Joining this group will give you the necessary permissions to view our data.
If you use the Sentinel-1 data, you agree to the Sentinel-1 Data Use Terms and Conditions.
To access Skybox data, you must join the Skybox for Good Google Group.
Unfortunately, all TerraSAR-X data and the Skybox Malawi image cannot be shared.