Source code for pyrfu.plot.add_position

#!/usr/bin/env python
# -*- coding: utf-8 -*-

# 3rd party imports
import numpy as np
from matplotlib.axes import Axes
from matplotlib.dates import num2date
from xarray.core.dataarray import DataArray

# Local imports
from ..pyrf.t_eval import t_eval

__author__ = "Louis Richard"
__email__ = "louisr@irfu.se"
__copyright__ = "Copyright 2020-2023"
__license__ = "MIT"
__version__ = "2.4.2"
__status__ = "Prototype"


[docs]def add_position( ax: Axes, r_xyz: DataArray, spine: float = 20, position: str = "top", fontsize: float = 10, ) -> Axes: r"""Add extra axes to plot spacecraft position. Parameters ---------- ax : matplotlib.axes._axes.Axes Axis where to label the spacecraft position. r_xyz : xarray.DataArray Time series of the spacecraft position. spine : float, Optional Relative position of the axes. Default is 20. position : str, Optional Axis position wtr to the reference axis. Default is "top". fontsize : float, Optional xticks label font size. Default is 10. Returns ------- axr : matplotlib.axes._axes.Axes Twin axis with spacecraft position as x-axis label. """ x_lim = ax.get_xlim() t_ticks = [t_.replace(tzinfo=None) for t_ in num2date(ax.get_xticks())] t_ticks = np.array(t_ticks).astype("<M8[ns]") r_ticks = t_eval(r_xyz, t_ticks).data ticks_labels = [] for ticks_ in r_ticks: ticks_labels.append( f"{ticks_[0]:3.2f}\n{ticks_[1]:3.2f}\n{ticks_[2]:3.2f}", ) axr = ax.twiny() axr.spines[position].set_position(("outward", spine)) axr.xaxis.set_ticks_position(position) axr.xaxis.set_label_position(position) axr.set_xticks(t_ticks) axr.set_xticklabels(ticks_labels, fontsize=fontsize) axr.set_xlim(x_lim) return axr