Skip to content

Commit

Permalink
DOC: update resample docs
Browse files Browse the repository at this point in the history
  • Loading branch information
jreback committed Oct 8, 2015
1 parent f0c7c41 commit fe48704
Show file tree
Hide file tree
Showing 2 changed files with 48 additions and 34 deletions.
1 change: 1 addition & 0 deletions doc/source/release.rst
Original file line number Diff line number Diff line change
Expand Up @@ -117,6 +117,7 @@ Thanks
- Joris Van den Bossche
- Joris Vankerschaver
- Josh Levy-Kramer
- Julien Danjou
- Ka Wo Chen
- Karrie Kehoe
- Kelsey Jordahl
Expand Down
81 changes: 47 additions & 34 deletions doc/source/timeseries.rst
Original file line number Diff line number Diff line change
Expand Up @@ -1157,14 +1157,16 @@ Converting to Python datetimes

.. _timeseries.resampling:

Up- and downsampling
--------------------
Resampling
----------

With 0.8, pandas introduces simple, powerful, and efficient functionality for
Pandas has a simple, powerful, and efficient functionality for
performing resampling operations during frequency conversion (e.g., converting
secondly data into 5-minutely data). This is extremely common in, but not
limited to, financial applications.

``resample`` is a time-based groupby, followed by a reduction method on each of its groups.

See some :ref:`cookbook examples <cookbook.resample>` for some advanced strategies

.. ipython:: python
Expand Down Expand Up @@ -1203,19 +1205,6 @@ end of the interval is closed:
ts.resample('5Min', closed='left')
For upsampling, the ``fill_method`` and ``limit`` parameters can be specified
to interpolate over the gaps that are created:

.. ipython:: python
# from secondly to every 250 milliseconds
ts[:2].resample('250L')
ts[:2].resample('250L', fill_method='pad')
ts[:2].resample('250L', fill_method='pad', limit=2)
Parameters like ``label`` and ``loffset`` are used to manipulate the resulting
labels. ``label`` specifies whether the result is labeled with the beginning or
the end of the interval. ``loffset`` performs a time adjustment on the output
Expand All @@ -1240,34 +1229,58 @@ retains the input representation.
(detail below). It specifies how low frequency periods are converted to higher
frequency periods.

Note that 0.8 marks a watershed in the timeseries functionality in pandas. In
previous versions, resampling had to be done using a combination of
``date_range``, ``groupby`` with ``asof``, and then calling an aggregation
function on the grouped object. This was not nearly as convenient or performant
as the new pandas timeseries API.

Sparse timeseries
Up Sampling
~~~~~~~~~~~

For upsampling, the ``fill_method`` and ``limit`` parameters can be specified
to interpolate over the gaps that are created:

.. ipython:: python
# from secondly to every 250 milliseconds
ts[:2].resample('250L')
ts[:2].resample('250L', fill_method='pad')
ts[:2].resample('250L', fill_method='pad', limit=2)
Sparse Resampling
~~~~~~~~~~~~~~~~~

If your timeseries are sparse, be aware that upsampling will generate a lot of
intermediate points filled with whatever passed as ``fill_method``. What
``resample`` does is basically a group by and then applying an aggregation
method on each of its groups, which can also be achieve with something like the
following.
Sparse timeseries are ones where you have a lot fewer points relative
to the amount of time you are looking to resample. Naively upsampling a sparse series can potentially
generate lots of intermediate values. When you don't want to use a method to fill these values, e.g. ``fill_method`` is ``None``,
then intermediate values will be filled with ``NaN``.

Since ``resample`` is a time-based groupby, the following is a method to efficiently
resample only the groups that are not all ``NaN``

.. ipython:: python
def round(t, freq):
# round a Timestamp to a specified freq
return Timestamp((t.value // freq.delta.value) * freq.delta.value)
rng = date_range('2014-1-1', periods=100, freq='D') + Timedelta('1s')
ts = Series(range(100), index=rng)
from functools import partial
If we want to resample to the full range of the series

rng = date_range('1/1/2012', periods=100, freq='S')
.. ipython:: python
ts.resample('3T',how='sum')
We can instead only resample those groups where we have points as follows:

.. ipython:: python
ts = Series(randint(0, 500, len(rng)), index=rng)
from functools import partial
from pandas.tseries.frequencies import to_offset
def round(t, freq):
# round a Timestamp to a specified freq
freq = to_offset(freq)
return Timestamp((t.value // freq.delta.value) * freq.delta.value)
ts.groupby(partial(round, freq=offsets.Minute(3))).sum()
ts.groupby(partial(round, freq='3T')).sum()
.. _timeseries.periods:

Expand Down

0 comments on commit fe48704

Please sign in to comment.