Skip to main content

A Python interface for the Generic Mapping Tools

Project description

A Python interface for the Generic Mapping Tools

Documentation (development version) | Contact | Try Online

Latest version on PyPI GitHub Actions Tests status GitHub Actions GMT Dev Tests status Test coverage status Compatible Python versions. Discourse forum Digital Object Identifier for the Zenodo archive Contributor Code of Conduct

Why PyGMT?

A beautiful map is worth a thousand words. To truly understand how powerful PyGMT is, play with it online on Binder! But if you need some convincing first, watch this 1 hour introduction to PyGMT!

Afterwards, feel free to look at our Tutorials or visit the PyGMT Gallery.

Remote Online Sessions for Emerging Seismologists (ROSES): Unit 8 - PyGMT

About

PyGMT is a library for processing geospatial and geophysical data and making publication quality maps and figures. It provides a Pythonic interface for the Generic Mapping Tools (GMT), a command-line program widely used in the Earth Sciences.

We rely heavily on new features that have been implemented in GMT 6.0. In particular, a new modern execution mode that greatly simplifies figure creation. These features are not available in the 5.4 version of GMT.

Project goals

  • Make GMT more accessible to new users.

  • Build a Pythonic API for GMT.

  • Interface with the GMT C API directly using ctypes (no system calls).

  • Support for rich display in the Jupyter notebook.

  • Integration with the PyData ecosystem: numpy.ndarray or pandas.DataFrame for data tables and xarray.DataArray for grids.

Contacting Us

Contributing

Code of conduct

Please note that this project is released with a Contributor Code of Conduct. By participating in this project you agree to abide by its terms.

Contributing Guidelines

Please read our Contributing Guide to see how you can help and give feedback.

Imposter syndrome disclaimer

We want your help. No, really.

There may be a little voice inside your head that is telling you that you’re not ready to be an open source contributor; that your skills aren’t nearly good enough to contribute. What could you possibly offer?

We assure you that the little voice in your head is wrong.

Being a contributor doesn’t just mean writing code. Equally important contributions include: writing or proof-reading documentation, suggesting or implementing tests, or even giving feedback about the project (including giving feedback about the contribution process). If you’re coming to the project with fresh eyes, you might see the errors and assumptions that seasoned contributors have glossed over. If you can write any code at all, you can contribute code to open source. We are constantly trying out new skills, making mistakes, and learning from those mistakes. That’s how we all improve and we are happy to help others learn.

This disclaimer was adapted from the MetPy project.

Citing PyGMT

PyGMT is a community developed project. See the AUTHORS.md file on GitHub for a list of the people involved and a definition of the term “PyGMT Developers”. Feel free to cite our work in your research using the following BibTeX:

@software{pygmt_2021_5607255,
  author       = {Uieda, Leonardo and
                  Tian, Dongdong and
                  Leong, Wei Ji and
                  Jones, Meghan and
                  Schlitzer, William and
                  Toney, Liam and
                  Grund, Michael and
                  Yao, Jiayuan and
                  Magen, Yohai and
                  Materna, Kathryn and
                  Newton, Tyler and
                  Anant, Abhishek and
                  Ziebarth, Malte and
                  Quinn, Jamie aand
                  Wessel, Paul},
  title        = {{PyGMT: A Python interface for the Generic Mapping Tools}},
  month        = oct,
  year         = 2021,
  publisher    = {Zenodo},
  version      = {v0.5.0},
  doi          = {10.5281/zenodo.5607255},
  url          = {https://doi.org/10.5281/zenodo.5607255}
}

To cite a specific version of PyGMT, go to our Zenodo page at https://doi.org/10.5281/zenodo.3781524 and use the “Export to BibTeX” function there. It is also strongly recommended to cite the GMT6 paper (which PyGMT wraps around). Note that some modules like surface and x2sys also have their dedicated citation. Further information for all these can be found at https://www.generic-mapping-tools.org/cite.

License

PyGMT is free software: you can redistribute it and/or modify it under the terms of the BSD 3-clause License. A copy of this license is provided in LICENSE.txt.

Support

The development of PyGMT has been supported by NSF grants OCE-1558403 and EAR-1948603.

Compatibility with GMT/Python/NumPy versions

PyGMT Version

Documentation

GMT

Python

Numpy

Dev (upcoming release)

Dev Documentation (reflects main branch)

>=6.2.0

>=3.7

>=1.18

v0.5.0 (latest release)

v0.5.0 Documentation

>=6.2.0

>=3.7

>=1.18

v0.4.1

v0.4.1 Documentation

>=6.2.0

>=3.7

>=1.17

v0.4.0

v0.4.0 Documentation

>=6.2.0

>=3.7

>=1.17

v0.3.1

v0.3.1 Documentation

>=6.1.1

>=3.7

v0.3.0

v0.3.0 Documentation

>=6.1.1

>=3.7

v0.2.1

v0.2.1 Documentation

>=6.1.1

>=3.6

v0.2.0

v0.2.0 Documentation

>=6.1.1

3.6 - 3.8

v0.1.2

v0.1.2 Documentation

>=6.0.0

3.6 - 3.8

v0.1.1

v0.1.1 Documentation

>=6.0.0

3.6 - 3.8

v0.1.0

v0.1.0 Documentation

>=6.0.0

3.6 - 3.8

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pygmt-0.5.0.tar.gz (205.9 kB view details)

Uploaded Source

Built Distribution

pygmt-0.5.0-py3-none-any.whl (317.1 kB view details)

Uploaded Python 3

File details

Details for the file pygmt-0.5.0.tar.gz.

File metadata

  • Download URL: pygmt-0.5.0.tar.gz
  • Upload date:
  • Size: 205.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.7

File hashes

Hashes for pygmt-0.5.0.tar.gz
Algorithm Hash digest
SHA256 3e83e4fb01046a5e240dfe72f88e0767703934ee7ae01e7d1f9cc883f5b1f0f1
MD5 18ed20a3475f84ef0ff006b460bb6355
BLAKE2b-256 75e63c4a48a68f8a5dcd801f4ffc28cb884d6c94d899f2a294a6e5ea8e2ac7d4

See more details on using hashes here.

File details

Details for the file pygmt-0.5.0-py3-none-any.whl.

File metadata

  • Download URL: pygmt-0.5.0-py3-none-any.whl
  • Upload date:
  • Size: 317.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.7

File hashes

Hashes for pygmt-0.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 e675b71f286fddcf02ea0be07096013ffa6ec851c94ae2dc13a9039172796a8c
MD5 b71bfd6ce45087b08681cf75404fcc01
BLAKE2b-256 16a3a77aa34fbd6ba4a15a99d797d321c19afd19d53a74e62976981241da23d5

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page