Register
Login
Resources
Docs Blog Datasets Glossary Case Studies Tutorials & Webinars
Product
Data Engine LLMs Platform Enterprise
Pricing Explore
Connect to our Discord channel
Integration:  dvc git github
Dongdong Tian bc673bc943
non_ascii_to_octal: Return the input string if it only contains printable ASCII characters (#3199)
9 hours ago
1b74d4d8f5
Initialize data version control for managing test images (#1036)
3 years ago
16b89456eb
CI: slash-commands-dispatch: Fix typo (#3196)
1 day ago
ci
4f3c5e44af
Bump to ghotscript 10.03.0 (#3112)
1 month ago
doc
809880c671
Wrap GMT's standard data type GMT_GRID for grids and refactor wrappers to use virtualfiles for output grids (#2398)
1 week ago
5234b52b3b
Remote Datasets: Adjust attributes - remove "title", use default of "name" and "long_name", introduce "description" (#3048)
22 hours ago
bc673bc943
non_ascii_to_octal: Return the input string if it only contains printable ASCII characters (#3199)
9 hours ago
1b74d4d8f5
Initialize data version control for managing test images (#1036)
3 years ago
19c4f559fe
gitignore: Ignore the sg_execution_times.rst file generated by Sphinx-Gallery (#3145)
4 weeks ago
d2e0c0892b
doc: Convert README from ReST to Markdown (#3059)
1 month ago
39c49fa1d4
Update link to Jing-Hui Tong's GitHub account (#3066)
1 month ago
9269fbcb2f
Add CITATION.cff file for PyGMT (#1592)
2 years ago
198e2785d5
Changelog entry for v0.11.0 (#3022)
2 months ago
4902687d93
Use the org-wide code of conduct (#2020)
1 year ago
3076ddcff5
Wrap long lines in CONTRIBUTING.md (#2915)
4 months ago
925e90e71c
Update copyright year to 2024 (#2935)
3 months ago
5696542700
Exclude CODE_OF_CONDUCT.md, AUTHORSHIP.md and pygmt/tests directory from distributions (#2957)
3 months ago
14593ad1d5
Makefile: Remove unused variable, fix pygmt to $PROJECT and remove .benchmarks directory (#3080)
1 month ago
b2518728ed
Document the support policy for minimum required GMT versions (#3070)
1 month ago
b490b0fae1
Change the dev dependency 'matplotlib' to 'matplotlib-base' to reduce local environment size (#3158)
3 weeks ago
d40c440047
SPEC 0: Bump minimum supported versions to xarray 2022.06 (#3151)
3 weeks ago
d40c440047
SPEC 0: Bump minimum supported versions to xarray 2022.06 (#3151)
3 weeks ago
Storage Buckets
Data Pipeline
Legend
DVC Managed File
Git Managed File
Metric
Stage File
External File

README.md

You have to be logged in to leave a comment. Sign In

PyGMT

A Python interface for the Generic Mapping Tools

Documentation (development version) | Contact | TryOnline

Latest version on PyPI Latest version on conda-forge GitHub Actions Tests status GitHub Actions GMT Dev Tests status Ruff Test coverage status CodSpeed Performance Benchmarks Compatible Python versions. Discourse forum Digital Object Identifier for the Zenodo archive PyOpenSci GitHub license 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! For a quicker introduction, check out our 3 minute overview!

Afterwards, feel free to look at our Tutorials, visit the Gallery, and check out some external PyGMT examples!

Quick Introduction to PyGMT YouTube Video

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 across the Earth, Ocean, and Planetary sciences and beyond.

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, xarray.DataArray for grids, and geopandas.GeoDataFrame for geographical data.

Quickstart

Installation

Simple installation using mamba:

mamba install --channel conda-forge pygmt

If you use conda:

conda install --channel conda-forge pygmt

For other ways to install pygmt, see the full installation instructions.

Getting started

As a starting point, you can open a Python interpreter or a Jupyter notebook, and try the following example:

import pygmt
fig = pygmt.Figure()
fig.coast(projection="H10c", region="g", frame=True, land="gray")
fig.show()

For more examples, please have a look at the Gallery and Tutorials.

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_2024_10578540,
  author       = {Tian, Dongdong and
                  Uieda, Leonardo and
                  Leong, Wei Ji and
                  Schlitzer, William and
                  Fröhlich, Yvonne and
                  Grund, Michael and
                  Jones, Max and
                  Toney, Liam and
                  Yao, Jiayuan and
                  Magen, Yohai and
                  Tong, Jing-Hui and
                  Materna, Kathryn and
                  Belem, Andre and
                  Newton, Tyler and
                  Anant, Abhishek and
                  Ziebarth, Malte and
                  Quinn, Jamie and
                  Wessel, Paul},
  title        = {{PyGMT: A Python interface for the Generic Mapping Tools}},
  month        = feb,
  year         = 2024,
  publisher    = {Zenodo},
  version      = {0.11.0},
  doi          = {10.5281/zenodo.10578540},
  url          = {https://doi.org/10.5281/zenodo.10578540}
}

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 GMT 6 paper (which PyGMT wraps around). Note that some modules like dimfilter, surface, and x2sys also have their dedicated citations. 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.

Other official wrappers for GMT:

  • GMT.jl: A Julia wrapper for GMT.
  • gmtmex: A Matlab/Octave wrapper for GMT.

Other non-official Python wrappers for GMT (not maintained):

Minimum supported versions

PyGMT has adopted SPEC 0 alongside the rest of the Scientific Python ecosystem, and therefore:

  • Support for Python versions be dropped 3 years after their initial release.
  • Support for core package dependencies (NumPy/Pandas/Xarray) be dropped 2 years after their initial release.

Similarly, the PyGMT team has decided to discontinue support for GMT versions 3 years after their initial release.

Please see Minimum Supported Versions for the minimum supported versions of GMT, Python and core package dependencies.

Tip!

Press p or to see the previous file or, n or to see the next file

About

A Python interface for the Generic Mapping Tools.

https://www.pygmt.org
Collaborators 8

Comments

Loading...