diff --git a/.github/workflows/cache_data.yaml b/.github/workflows/cache_data.yaml index d4e7d9948a5..b2258b1ed29 100644 --- a/.github/workflows/cache_data.yaml +++ b/.github/workflows/cache_data.yaml @@ -33,6 +33,7 @@ jobs: miniforge-version: latest miniforge-variant: Mambaforge mamba-version: "*" + run-post: false use-mamba: true # Install GMT and other required dependencies from conda-forge diff --git a/.github/workflows/ci_docs.yml b/.github/workflows/ci_docs.yml index 5463e5e7f86..fa57d3e34f5 100644 --- a/.github/workflows/ci_docs.yml +++ b/.github/workflows/ci_docs.yml @@ -64,6 +64,7 @@ jobs: miniforge-version: latest miniforge-variant: Mambaforge mamba-version: "*" + run-post: false use-mamba: true # Install GMT and other required dependencies from conda-forge diff --git a/.github/workflows/ci_tests.yaml b/.github/workflows/ci_tests.yaml index 1c4a539d20a..48f09dfb472 100644 --- a/.github/workflows/ci_tests.yaml +++ b/.github/workflows/ci_tests.yaml @@ -84,6 +84,7 @@ jobs: miniforge-version: latest miniforge-variant: Mambaforge mamba-version: "*" + run-post: false use-mamba: true # Install GMT and other required dependencies from conda-forge diff --git a/.github/workflows/ci_tests_dev.yaml b/.github/workflows/ci_tests_dev.yaml index ba37aacdfcf..0eb655f2285 100644 --- a/.github/workflows/ci_tests_dev.yaml +++ b/.github/workflows/ci_tests_dev.yaml @@ -90,6 +90,7 @@ jobs: miniforge-version: latest miniforge-variant: Mambaforge mamba-version: "*" + run-post: false use-mamba: true # Install dependencies from conda-forge diff --git a/.github/workflows/ci_tests_legacy.yaml b/.github/workflows/ci_tests_legacy.yaml index 227fb436fc5..26b11cbbdb8 100644 --- a/.github/workflows/ci_tests_legacy.yaml +++ b/.github/workflows/ci_tests_legacy.yaml @@ -58,6 +58,7 @@ jobs: miniforge-version: latest miniforge-variant: Mambaforge mamba-version: "*" + run-post: false use-mamba: true # Install GMT and other required dependencies from conda-forge diff --git a/pygmt/datasets/samples.py b/pygmt/datasets/samples.py index cf122579338..efe885bcfe0 100644 --- a/pygmt/datasets/samples.py +++ b/pygmt/datasets/samples.py @@ -32,8 +32,9 @@ def list_sample_data(): "mars_shape": "Table of topographic signature of the hemispheric dichotomy of " " Mars from Smith and Zuber (1996)", "maunaloa_co2": "Table of CO2 readings from Mauna Loa", - "ocean_ridge_points": "Table of ocean ridge points for the entire world", "notre_dame_topography": "Table 5.11 in Davis: Statistics and Data Analysis in Geology", + "ocean_ridge_points": "Table of ocean ridge points for the entire world", + "rock_compositions": "Table of rock sample compositions", "usgs_quakes": "Table of global earthquakes from the USGS", } return names @@ -80,6 +81,7 @@ def load_sample_data(name): # Dictionary of private load functions load_func = { + "rock_compositions": _load_rock_sample_compositions, "earth_relief_holes": _load_earth_relief_holes, "maunaloa_co2": _load_maunaloa_co2, "notre_dame_topography": _load_notre_dame_topography, @@ -360,6 +362,26 @@ def load_mars_shape(**kwargs): return data +def _load_rock_sample_compositions(): + """ + Loads a table of rock sample compositions. + + Returns + ------- + data : pandas.DataFrame + The data table with columns "water", "air", and "limestone". + """ + + fname = which("@ternary.txt", download="c") + return pd.read_csv( + fname, + delim_whitespace=True, + header=None, + names=["water", "air", "limestone"], + usecols=(0, 1, 2), + ) + + def _load_notre_dame_topography(): """ Load Table 5.11 in Davis: Statistics and Data Analysis in Geology. diff --git a/pygmt/tests/test_datasets_samples.py b/pygmt/tests/test_datasets_samples.py index 3bbe93bc5d3..e0d3b3f3a7c 100644 --- a/pygmt/tests/test_datasets_samples.py +++ b/pygmt/tests/test_datasets_samples.py @@ -186,3 +186,18 @@ def test_maunaloa_co2(): assert summary.loc["max", "date"] == 2019.3699 assert summary.loc["min", "co2_ppm"] == 313.2 assert summary.loc["max", "co2_ppm"] == 414.83 + + +def test_rock_sample_compositions(): + """ + Check that the @ternary.txt dataset loads without errors. + """ + data = load_sample_data(name="rock_compositions") + assert data.shape == (1000, 3) + summary = data.describe() + assert summary.loc["min", "water"] == 0 + assert summary.loc["max", "water"] == 1 + assert summary.loc["min", "air"] == 0 + assert summary.loc["max", "air"] == 0.921 + assert summary.loc["min", "limestone"] == 0 + assert summary.loc["max", "limestone"] == 0.981