Skip to content

Latest commit

 

History

History
92 lines (76 loc) · 4.93 KB

README.md

File metadata and controls

92 lines (76 loc) · 4.93 KB

underfoot

Underfoot is a mobile app for revealing the hydrological and geological world beneath your feet. Well, sort of. It's mostly just something I tinker with in my spare time. It'll probably never be done. If you're interested in a more fully-functional app for geological exploration, check out rockd.

Still reading? This repo is mostly for data prep. I used to have some Ionic-based mobile app stuff here but I've given up on Ionic and am currently just tinkering with a native Android app.

Vagrant Setup

You'll need to install Vagrant and VirtualBox.

git clone https://github.com/kueda/underfoot.git
cd underfoot
vagrant up # This will take a while
vagrant ssh

# Subsequent commands in the Vagrant VM

# This is kind of optional. You could just run the code from /vagrant/, i.e. the
# files on the host, but it might be a bit safer to clone them from the repo and
# work on a separate clone. Then you have the awkwardness of copying files back
# and forth if you're developing, or syncing folders
# (https://www.vagrantup.com/docs/synced-folders/basic_usage.html). Up to you.
git clone https://github.com/kueda/underfoot.git
cd underfoot

# Set up a python virtual environment
virtualenv venv -p python3
source venv/bin/activate

# Install deps and some stuff for working with ESRI Arc/Info coverages
pip install -r requirements.txt
python setup.py

# Make a pack
python packs.py us-ca-oakland

Adding Sources

Each source is an executable Python script that creates a directory at sources/work-SCRIPT_NAME containing data in a standardized format that can be synthesized. Rocks and water sources have different requirements.

Rocks

  1. A GeoJSON filed named units.geojson that contains all the geological map units, each of which contains the following properties:
    1. code: Code used to label the unit
    2. title
    3. description
    4. lithology: rocks included in this unit
    5. rock_type: igneous, sedimentary, or metamorphic
    6. formation
    7. grouping: i.e. the group, e.g. Franciscan Complex
    8. span: geologic time span of unit formation, e.g. Cretaceous, extracted from source but generally verbatim
    9. controlled_span: geologic time span of unit based on a controlled vocabulary dereived from the Wikipedia "Period start" template
    10. min_age: Minimum age of the unit
    11. max_age: Maximum age of the unit
    12. est_age: Estimated age of the unit
  2. A JSON file named citation.json containing a single-item array of CSL Data items of the kind exported from Zotero.

Water

  1. A GeoPackage named waterbodies.gpkg containing a single waterbodies layer with the following properties:
    1. waterbody_id: unique identifier within this file
    2. source_id: unique identifier provided by the source
    3. source_id_attr: name of the attribute the source_id was derived from
    4. name
    5. type: type of waterbody, one of
      1. treatment
      2. storage
      3. evaporator
      4. swamp/marsh
      5. reservoir
      6. lake/pond
    6. is_natural: boolean indicating whether or not the body was made by humans
    7. permanence: perennial or ephemeral
    8. geom: MultiPolygon geometry
  2. A GeoPackage named waterways.gpkg containing a single waterways layer with the following properties:
    1. TODO
  3. A GeoPackage named watersheds.gpkg containing a single watersheds layer with the following properties:
    1. TODO
  4. A CSV named waterways-network.csv describing the connectivity and direction of flow in the waterways, using the source_id attribute.
    1. source_id
    2. to_source_id
    3. from_source_id
  5. A JSON file named citation.json containing a single-item array of CSL Data items of the kind exported from Zotero.

Sources can be single scripts or modules. Preferrably they will contain as little data as possible and instead download and transorm open data from the Internet, e.g. USGS publications, though some data will probably be necessary since few sources are fully machine-readable. There are numerous helper methods for writing source scripts in the sources/util module.

If you'd like to contribute a source, please file an issue first proposing a new source, and if we agree it should be added, work on a feature branch in your own fork and issue a pull request when it's ready. If that sounds like too much coding, file an issue anyway and I might put together a script if you perform some of the digitization / transcription.

Running Tests

Coverage is pretty limited but there are a few.

pytest