ggplot2 Time Series Heatmaps
How do you easily get beautiful calendar heatmaps of time series in ggplot2? E.g:
I was impressed by the lattice-based implementation from Paul Bleicher of Humedica, which you can find referenced in http://blog.revolutionanalytics.com/2009/11/charting-time-series-as-calendar-heat-maps-in-r.html
. Then, when other blogs like http://timelyportfolio.blogspot.com/2012/04/piggybacking-and-hopefully-publicizing.html
picked up the topic, I decided to try a ggplot2 implementation. In a comment to the above Revolution Analytics post, Hadley
already presented a quick ggplot rendition, upon which I build here.
How do you attack the problem? Looking at the example output above:
- We facet_grid by "months" and "years"
- The data itself is plotted by "week of month" and "day of week" and coloured according to the value of interest
So, given a time series we just have to fiddle with time indexes to create a data.frame containing the time series as well as per observation the corresponding "month", "year", "week of month", "day of week". The rest is then a one-liner of code with Hadley's wonderful ggplot2
The following code contains step by step comments:
It should be easy to wrap into a function and I hope its useful.
To leave a comment
for the author, please follow the link and comment on his blog: MarginTale
offers daily e-mail updates
news and tutorials
on topics such as: visualization (ggplot2
), programming (RStudio
, Web Scraping
) statistics (regression
, time series
) and more...
If you got this far, why not subscribe for updates
from the site? Choose your flavor: e-mail
, or facebook