Design useful tools that do one thing well and work together: rediscovering the UNIX philosophy while building the Fatiando a Terra project
Abstract
The Fatiando a Terra project (https://www.fatiando.org) was started in 2010 as a Python library for visualization, forward modelling, and inversion across different geophysical methods. Over the following 8 years, the project attracted new contributors and grew to include cutting-edge methods, toy examples for teaching, and helper functions for visualization. Standards around testing, documentation, and code style evolved and new tools appeared around the ecosystem (such as SimPEG, PyVista, Devito, and pyGIMLi), making some of our functionality redundant and outdated. In an attempt to better interface with the emerging ecosystem, we started a major restructuring of the code base in 2018. Our goals were to: Split the project into several software packages, each with a narrow and well-defined scope. This change would allow contributors to focus on the parts of the project that they care about the most. It would also be crucial to establish our niche in the current geophysics OSS landscape. Set high standards for documentation and test coverage. We aim for full test coverage of the code and comprehensive API and narrative documentation, which would be enforced through automated checks and code review. Carefully design of our APIs (application programming interfaces) and focus on meeting real-world use cases. Our approach is to design and thoroughly discuss the code interfaces by creating examples of usage before writing the actual implementation. Connect and nurture our community. The project developer pool has always been small and it would take constant deliberate effort to foster a community that is willing to take ownership of the project. The project is currently composed of the following packages: Pooch: download and cache data files for research projects and documentation sample data. Verde: machine-learning inspired point-cloud data processing and interpolation. Harmonica: gravity and magnetic data processing, forward modelling, and inversion. Boule: reference ellipsoids and normal gravity calculations. RockHound: a collection of open-access datasets for use in documentation and tutorials. This presentation will cover the current available functionality and some of the lessons learned from developing, growing, and maintaining the project, including current challenges and our future plans.
- Publication:
-
AGU Fall Meeting Abstracts
- Pub Date:
- December 2021
- Bibcode:
- 2021AGUFMNS15C0380U