Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add a tutorial for datetime data #1193

Merged
merged 69 commits into from
Jun 5, 2021
Merged
Show file tree
Hide file tree
Changes from 63 commits
Commits
Show all changes
69 commits
Select commit Hold shift + click to select a range
0b7adbe
Add placeholder
noorbuchi Apr 7, 2021
b0ffcee
Merge branch 'master' into master
noorbuchi Apr 9, 2021
5eaa7e7
Rename file to fix circular import
Apr 9, 2021
d6bea4e
Merge branch 'master' of github.com:noorbuchi/pygmt
Apr 9, 2021
1e6623f
Fix format and update index.rst
Apr 9, 2021
f072f3a
Added tutorial template in file.
cklima616 Apr 9, 2021
71099d2
Fixed small formatting error.
cklima616 Apr 9, 2021
75b6922
Add first example and short description
Apr 11, 2021
dee89d9
Merge branch 'master' into master
noorbuchi Apr 11, 2021
4953166
Add python built-in examples
Apr 12, 2021
2626e27
remove warning note
noorbuchi Apr 12, 2021
df0bb7a
Merge branch 'master' into data_stuctures_examples
noorbuchi Apr 12, 2021
b6218c3
add ISO and Pandas exampels
Apr 13, 2021
e8a5dd4
Merge branch 'data_stuctures_examples' of github.com:noorbuchi/pygmt …
Apr 13, 2021
67995c6
Merge branch 'master' into master
noorbuchi Apr 13, 2021
94dc7e7
Added description for ISO example
nathandloria Apr 14, 2021
a4639f0
Merge pull request #1 from noorbuchi/data_stuctures_examples
noorbuchi Apr 14, 2021
9d3839c
[format-command] fixes
actions-bot Apr 14, 2021
ca1e45c
add basic example
Apr 14, 2021
e165f9c
Merge branch 'master' into master
noorbuchi Apr 15, 2021
dd66ce9
Elaborate on example with axis labeling
Apr 15, 2021
98ae1c1
Add axis labeling example description
Apr 15, 2021
aa9f7da
Add second axes example
Apr 15, 2021
d49b185
added xarray example
nathandloria Apr 16, 2021
df093a9
[format-command] fixes
actions-bot Apr 16, 2021
43d2988
Added descriptions and updated examples for mix-matching and pandas
nathandloria Apr 16, 2021
40d36c9
Expand description, removed unused section
Apr 16, 2021
3fa6d3e
resolve Todo
Apr 16, 2021
b441ce2
Add generation using pygmt.info
Apr 16, 2021
d29c9e1
Merge pull request #2 from noorbuchi/primary-secondary-axis-examples
noorbuchi Apr 16, 2021
cca7099
[format-command] fixes
actions-bot Apr 16, 2021
c1b6e24
Fix header formatting
Apr 16, 2021
9f85cbd
[format-command] fixes
actions-bot Apr 16, 2021
4f1d06e
Remove commented out Code from formatting.
cklima616 Apr 16, 2021
744d77d
Merge branch 'master' of github.com:noorbuchi/pygmt
cklima616 Apr 16, 2021
3d22feb
Add np.array example.
cklima616 Apr 16, 2021
09e9d70
Edit to region parameter values.
cklima616 Apr 16, 2021
4683f93
fix date conversion issue
Apr 16, 2021
70deeef
[format-command] fixes
actions-bot Apr 16, 2021
7d232a9
Attempt to fix example.
cklima616 Apr 16, 2021
2ea27c7
Change point style for variety.
cklima616 Apr 16, 2021
75f7e8c
Fixed capitalization to adhere to formatting.
cklima616 Apr 16, 2021
4e7104d
Fix parameter value.
cklima616 Apr 16, 2021
2fead57
Fix reference to Frames tutorial
Apr 16, 2021
351fbb0
Merge branch 'master' of github.com:noorbuchi/pygmt
Apr 16, 2021
28c41e6
Elaborate on pygmt.info description
Apr 16, 2021
385478c
Apply suggestions from code review
noorbuchi Apr 20, 2021
b5075f9
Merge branch 'master' into master
noorbuchi Apr 20, 2021
d33ead9
Update examples/tutorials/date_time_charts.py
cklima616 Apr 21, 2021
bfe56a3
Update examples/tutorials/date_time_charts.py
cklima616 Apr 21, 2021
c345a51
Update examples/tutorials/date_time_charts.py
cklima616 Apr 21, 2021
e94a183
Update examples/tutorials/date_time_charts.py
cklima616 Apr 21, 2021
358bea3
Apply suggestions from code review
noorbuchi Apr 23, 2021
073546c
Remove duplicate statement
noorbuchi Apr 27, 2021
81565b5
Apply suggestions from code review
noorbuchi Apr 27, 2021
f5e8272
Merge branch 'master' into master
noorbuchi May 29, 2021
dec02e3
Add suggested fixes
May 29, 2021
9f7028b
Apply suggestions from code review
noorbuchi May 29, 2021
cb73337
Fix typo
May 29, 2021
b5b1bde
[format-command] fixes
actions-bot May 29, 2021
4d28a5e
Apply suggestions from code review
noorbuchi May 29, 2021
29bedf4
Apply suggestions from code review
noorbuchi May 31, 2021
2390302
Add more fixes from review
noorbuchi May 31, 2021
8be3b3e
Apply suggestions from code review
noorbuchi Jun 2, 2021
a945934
Reword paragraphs, fix cross reference
Jun 2, 2021
5578ca4
Apply suggestions from code review
noorbuchi Jun 2, 2021
810dca7
Add external GMT links
Jun 2, 2021
ca92276
Apply suggestions from code review
noorbuchi Jun 2, 2021
3da1778
Merge branch 'master' into master
seisman Jun 5, 2021
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions doc/index.rst
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,7 @@
tutorials/plot.rst
tutorials/lines.rst
tutorials/vectors.rst
tutorials/date_time_charts.rst
tutorials/text.rst
tutorials/contour_map.rst
tutorials/earth_relief.rst
Expand Down
349 changes: 349 additions & 0 deletions examples/tutorials/date_time_charts.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,349 @@
"""
Plotting datetime charts
========================

PyGMT accepts a variety of datetime objects to plot data and create charts.
Aside from the built-in Python ``datetime`` object, PyGMT supports input using
ISO formatted strings, ``pandas``, ``xarray``, as well as ``numpy``.
These data types can be used to plot specific points as well as get
passed into the ``region`` parameter to create a range of the data on an axis.

The following examples will demonstrate how to create plots
using the different datetime objects.
"""
# sphinx_gallery_thumbnail_number = 0

import datetime

import numpy as np
import pandas as pd
import pygmt
import xarray as xr

###############################################################################
# Using Python's ``datetime``
# ---------------------------
#
# In this example, Python's built-in ``datetime`` module is used
# to create data points stored in list ``x``. Additionally,
# dates are passed into the ``region`` parameter in the format
# ``(x_start, x_end, y_start, y_end)``,
# where the date range is plotted on the x-axis.
# An additional notable parameter is ``style``, where it's specified
# that data points are to be plotted in an **X** shape with a size
# of 0.3 centimeters.
#

x = [
datetime.date(2010, 6, 1),
datetime.date(2011, 6, 1),
datetime.date(2012, 6, 1),
datetime.date(2013, 6, 1),
]
y = [1, 2, 3, 5]

fig = pygmt.Figure()
fig.plot(
projection="X10c/5c",
region=[datetime.date(2010, 1, 1), datetime.date(2014, 12, 1), 0, 6],
frame=["WSen", "afg"],
x=x,
y=y,
style="x0.3c",
pen="1p",
)
fig.show()

###############################################################################
# In addition to specifying the date, ``datetime`` supports
# the exact time at which the data points were recorded. Using :meth:`datetime.datetime`
# the ``region`` parameter as well as data points can be created
# with both date and time information.
#
# Some notable differences to the previous example include
core-man marked this conversation as resolved.
Show resolved Hide resolved
#
# - Modifying ``frame`` to only include West(left) and South (bottom) border, and removing grid lines
noorbuchi marked this conversation as resolved.
Show resolved Hide resolved
# - Using circles to plot data points defined through ``c`` in ``style`` parameter

x = [
datetime.datetime(2021, 1, 1, 3, 45, 1),
datetime.datetime(2021, 1, 1, 6, 15, 1),
datetime.datetime(2021, 1, 1, 13, 30, 1),
datetime.datetime(2021, 1, 1, 20, 30, 1),
]
y = [5, 3, 1, 2]

fig = pygmt.Figure()
fig.plot(
projection="X10c/5c",
region=[
datetime.datetime(2021, 1, 1, 0, 0, 0),
datetime.datetime(2021, 1, 2, 0, 0, 0),
0,
6,
],
frame=["WS", "af"],
x=x,
y=y,
style="c0.4c",
pen="1p",
color="blue",
)
fig.show()

########################################################################################
# Using ISO Format
# ----------------
#
# In addition to Python's ``datetime`` library, PyGMT also supports passing times
# in ISO format. Basic ISO strings are formatted as ``YYYY-MM-DD``
# with each ``-`` delineated section marking the four digit year value, two digit
# month value, and two digit day value respectively.
#
# When including time of day into ISO strings, the ``T`` character is used, as
# can be seen in the following example. This character is immediately followed
# by a string formatted as ``hh:mm:ss`` where each ``:`` delineated section marking
# the two digit hour value, two digit minute value, and two digit second value
# respectively. The figure in the following example is plotted over a horizontal
# range of one year from 1/1/2016 to 1/1/2017.

x = ["2016-02-01", "2016-06-04T14", "2016-10-04T00:00:15", "2016-12-01T05:00:15"]
y = [1, 3, 5, 2]
fig = pygmt.Figure()
fig.plot(
projection="X10c/5c",
region=["2016-01-01", "2017-01-1", 0, 6],
frame=["WSen", "afg"],
x=x,
y=y,
style="a0.45c",
pen="1p",
color="dodgerblue",
)
fig.show()

###############################################################################
# Mixing and matching ``datetime`` and ISO
# ----------------------------------------
noorbuchi marked this conversation as resolved.
Show resolved Hide resolved
#
# The following example provides context on how both ``datetime`` and ISO
# date data can be plotted using PyGMT. This can be helpful when dates and times
# are coming from different sources, meaning conversions do not need to take place
# between ISO and datetime in order to create valid plots.

x = ["2020-02-01", "2020-06-04", "2020-10-04", datetime.datetime(2021, 1, 15)]
y = [1.3, 2.2, 4.1, 3]
fig = pygmt.Figure()
fig.plot(
projection="X10c/5c",
region=[datetime.datetime(2020, 1, 1), datetime.datetime(2021, 3, 1), 0, 6],
frame=["WSen", "afg"],
x=x,
y=y,
style="i0.4c",
pen="1p",
color="yellow",
)
fig.show()

########################################################################################
# Using :meth:`pandas.date_range`
# -------------------------------
#
# In the following example, a ``pandas.date_range`` object is used to pass date
noorbuchi marked this conversation as resolved.
Show resolved Hide resolved
# data to the PyGMT figure. This object is set using the pandas method ``date_range()``.
noorbuchi marked this conversation as resolved.
Show resolved Hide resolved
# This particular object contains 7 different :class:`pandas.DatetimeIndex` objects, with the
# number being manipulated by the ``periods`` parameter. Each period begins at the start
# of a business quarter as denoted by BQS when passed to the ``periods`` parameter. The inital
# date is the first argument that is passed to :meth:`pandas.date_range` and it marks the first
noorbuchi marked this conversation as resolved.
Show resolved Hide resolved
# data in the object ``x`` that will be plotted.

x = pd.date_range("2018-03-01", periods=7, freq="BQS")
y = [4, 5, 6, 8, 6, 3, 5]

fig = pygmt.Figure()
fig.plot(
projection="X10c/10c",
region=[datetime.datetime(2017, 12, 31), datetime.datetime(2019, 12, 31), 0, 10],
frame=["WSen", "ag"],
x=x,
y=y,
style="i0.4c",
pen="1p",
color="purple",
)
fig.show()

########################################################################################
# Using :class:`xarray.DataArray`
# ------------------------------
#
# In this example, instead of using a :meth:`pandas.date_range` object, ``x`` is initialized
# as an :class:`xarray.DataArray` object. Such object provides a wrapper around traditional
# data formats allowing this data to have varying labeled dimensions and support
# operations that use various pieces of metadata. The following code uses a
# :meth:`pandas.date_range` object to fill the DataArray with data, yet this is not
# essential for the creation of a valid DataArray.
noorbuchi marked this conversation as resolved.
Show resolved Hide resolved

x = xr.DataArray(data=pd.date_range(start="2020-01-01", periods=4, freq="Q"))
y = [4, 7, 5, 6]

fig = pygmt.Figure()
fig.plot(
projection="X10c/10c",
region=[datetime.datetime(2020, 1, 1), datetime.datetime(2021, 4, 1), 0, 10],
frame=["WSen", "ag"],
x=x,
y=y,
style="n0.4c",
pen="1p",
color="red",
)
fig.show()

###############################################################################
# Using :class:`numpy.datetime64`
# ------------------------------
# In this example, instead of using a ``pd.date_range`` object, ``x`` is initialized
noorbuchi marked this conversation as resolved.
Show resolved Hide resolved
# as an ``np.array`` object. Similar to :class:`xarray.DataArray` this wraps the
# dataset before passing it as a paramater. However, ``np.array`` objects use less
# memory and allow developers to specify datatypes, and even pass multiple.
#
noorbuchi marked this conversation as resolved.
Show resolved Hide resolved

x = np.array(["2010-06-01", "2011-06-01T12", "2012-01-01T12:34:56"], dtype="datetime64")
y = [2, 7, 5]

fig = pygmt.Figure()
fig.plot(
projection="X10c/10c",
region=[datetime.datetime(2010, 1, 1), datetime.datetime(2012, 6, 1), 0, 10],
frame=["WS", "ag"],
x=x,
y=y,
style="s0.5c",
pen="1p",
color="blue",
)
fig.show()

########################################################################################
# Generating Region
# -----------------
noorbuchi marked this conversation as resolved.
Show resolved Hide resolved
#
# Another way of creating charts involving datetime data can be done
# by automatically generating the region of the plot. This can be done
# by passing the dataframe to :meth:`pygmt.info`, which will find
# maximum and minimum values for each column and create a list
# that could be passed as region. Additionally, a spacing argument
noorbuchi marked this conversation as resolved.
Show resolved Hide resolved
# can be passed to increase the range past the maximum and minimum
# data points.

data = [
["20200712", 1000],
["20200714", 1235],
["20200716", 1336],
["20200719", 1176],
["20200721", 1573],
["20200724", 1893],
["20200729", 1634],
]
df = pd.DataFrame(data, columns=["Date", "Score"])
df.Date = pd.to_datetime(df["Date"], format="%Y%m%d")

fig = pygmt.Figure()
region = pygmt.info(
table=df[["Date", "Score"]], per_column=True, spacing=(700, 700), coltypes="T"
)

fig.plot(
region=region,
projection="X15c/10c",
frame=["WSen", "afg"],
x=df.Date,
y=df.Score,
style="c0.4c",
pen="1p",
color="green3",
)

fig.show()

########################################################################################
# Setting Primary and Secondary Time Axes
# ---------------------------------------
#
# This example focuses on labeling the axes and setting intervals
# at which the labels are expected to appear. All of these modifications
# are added to the ``frame`` parameter and each item in that list modifies
# a specific section of the plot.
#
# Starting off with ``WS``, adding this string means that only
# Western/Left (**W**) and Southern/Bottom (**S**) borders of
# the plot will be shown. For more information on this, please
# refer to :doc:`frame instructions </tutorials/frames>`.
#
# The other important item in the ``frame`` list is
# ``"sxa1Of1D"``. This string modifies the secondary
# labeling (**s**) of the x-axis (**x**). Specifically,
# it sets the main annotation and major tick spacing interval
# to one month (**a1O**) (capital letter o, not zero). Additionally,
# it sets the minor tick spacing interval to 1 day (**f1D**).
# The labeling of this axis is also modified using
# ``pygmt.config(FORMAT_DATE_MAP="o")`` to use the month's
noorbuchi marked this conversation as resolved.
Show resolved Hide resolved
# name instead of its number.

x = pd.date_range("2013-05-02", periods=10, freq="2D")
y = [4, 5, 6, 8, 9, 5, 8, 9, 4, 2]

fig = pygmt.Figure()
with pygmt.config(FORMAT_DATE_MAP="o"):
fig.plot(
projection="X15c/10c",
region=[datetime.datetime(2013, 5, 1), datetime.datetime(2013, 5, 25), 0, 10],
frame=["WS", "sxa1Of1D", "pxa5d", "sy+lLength", "pya1+ucm"],
x=x,
y=y,
style="c0.4c",
pen="1p",
color="green3",
)

fig.show()

########################################################################################
# The same concept shown above can be applied to smaller
# as well as larger intervals. In this example,
# data is plotted for different times throughout two days.
# Primary x-axis labels are modified to repeat every 6 hours
# and secondary x-axis label repeats every day and shows
# the day of the week.
#
# Another notable mention in this example is
# ``pygmt.config(FORMAT_CLOCK_MAP="-hhAM")``
# which specifies the used format for time.
noorbuchi marked this conversation as resolved.
Show resolved Hide resolved
# In this case, leading zeros are removed
# using **(-)**, and only hours are displayed.
noorbuchi marked this conversation as resolved.
Show resolved Hide resolved
# Additionally, an AM/PM system is being used
# instead of a 24-hour system.

x = pd.date_range("2021-04-15", periods=8, freq="6H")
y = [2, 5, 3, 1, 5, 7, 9, 6]

fig = pygmt.Figure()
with pygmt.config(FORMAT_CLOCK_MAP="-hhAM"):
fig.plot(
projection="X15c/10c",
region=[
datetime.datetime(2021, 4, 14, 23, 0, 0),
datetime.datetime(2021, 4, 17),
0,
10,
],
frame=["WS", "sxa1K", "pxa6H", "sy+lSpeed", "pya1+ukm/h"],
x=x,
y=y,
style="n0.4c",
pen="1p",
color="lightseagreen",
)
fig.show()