An implementation of the Grammar of Graphics in R
Clone or download
Latest commit 3550772 Oct 18, 2018
Failed to load latest commit information.
.github Add movebot config Oct 14, 2018
R don't fail when manual scales have missing `values` parameter. (#2916) Sep 28, 2018
data-raw Add new txhousing dataset Aug 20, 2015
data Add new txhousing dataset Aug 20, 2015
icons Tweak icons May 9, 2018
inst Update CITATION (#1984) Jan 24, 2017
man Fix back-transformation of ranges in coords (#2821) Sep 25, 2018
revdep Update email.yml for 3.1.0 release (#2923) Oct 1, 2018
tests Implement sec.axis for date, time, and datetime scales (#2806) Sep 18, 2018
vignettes Fix typo in 2.2.0 release vignette (#2683) Jun 25, 2018
.Rbuildignore Add to Rbuildignore (#2925) Oct 1, 2018
.gitattributes Avoid merge conflicts in NEWS file Feb 25, 2014
.gitignore Update revdep template Nov 30, 2017
.travis.yml Improved vdiffr setup (#2856) Sep 1, 2018 Update documentation for CII badging requirements (#2792) Sep 13, 2018
DESCRIPTION Update visual tests with dev vdiffr (#2886) Sep 13, 2018 Update documentation for CII badging requirements (#2792) Sep 13, 2018 Updates link to reprex how-to in issues template (#2385) Jan 2, 2018
LICENSE Make GPL-2 license explicit Sep 15, 2016
NAMESPACE Implement geom_sf_label() and geom_sf_text() (#2761) Aug 24, 2018
NEWS Standardise spelling: ‘faceting’ instead of ‘facetting’ (#2413) Jan 21, 2018 remove typo Oct 18, 2018
README.Rmd Minor documentation edits (#2727) Jul 10, 2018 Minor documentation edits (#2727) Jul 10, 2018
_pkgdown.yml Minor documentation edits (#2727) Jul 10, 2018
appveyor.yml Use vdiffr for visual unit tests (#1874) Feb 1, 2017
codecov.yml Suppress codecov comments Jul 28, 2016 Update release comments Jun 25, 2018
ggplot2.Rproj Upgrade RStudio Jun 1, 2017


Travis Build Status AppVeyor Build Status Coverage Status CRAN_Status_Badge


ggplot2 is a system for declaratively creating graphics, based on The Grammar of Graphics. You provide the data, tell ggplot2 how to map variables to aesthetics, what graphical primitives to use, and it takes care of the details.


# The easiest way to get ggplot2 is to install the whole tidyverse:

# Alternatively, install just ggplot2:

# Or the the development version from GitHub:
# install.packages("devtools")



It’s hard to succinctly describe how ggplot2 works because it embodies a deep philosophy of visualisation. However, in most cases you start with ggplot(), supply a dataset and aesthetic mapping (with aes()). You then add on layers (like geom_point() or geom_histogram()), scales (like scale_colour_brewer()), faceting specifications (like facet_wrap()) and coordinate systems (like coord_flip()).


ggplot(mpg, aes(displ, hwy, colour = class)) + 



ggplot2 is now over 10 years old and is used by hundreds of thousands of people to make millions of plots. That means, by-and-large, ggplot2 itself changes relatively little. When we do make changes, they will be generally to add new functions or arguments rather than changing the behaviour of existing functions, and if we do make changes to existing behaviour we will do them for compelling reasons.

If you are looking for innovation, look to ggplot2’s rich ecosystem of extensions. See a community maintained list at

Learning ggplot2

If you are new to ggplot2 you are better off starting with a systematic introduction, rather than trying to learn from reading individual documentation pages. Currently, there are three good places to start:

  1. The data visualisation and graphics for communication chapters in R for data science. R for data science is designed to give you a comprehensive introduction to the tidyverse, and these two chapters will you get up to speed with the essentials of ggplot2 as quickly as possible.

  2. If you’d like to take an interactive online course, try Data visualisation with ggplot2 by Rick Scavetta on DataCamp.

  3. If you want to dive into making common graphics as quickly as possible, I recommend The R Graphics Cookbook by Winston Chang. It provides a set of recipes to solve common graphics problems. A 2nd edition is due out in 2018.

If you’ve mastered the basics and want to learn more, read ggplot2: Elegant Graphics for Data Analysis. It describes the theoretical underpinnings of ggplot2 and shows you how all the pieces fit together. This book helps you understand the theory that underpins ggplot2, and will help you create new types of graphics specifically tailored to your needs. The book is not available for free, but you can find the complete source for the book at

Getting help

There are two main places to get help with ggplot2:

  1. The RStudio community is a friendly place to ask any questions about ggplot2.

  2. Stack Overflow is a great source of answers to common ggplot2 questions. It is also a great place to get help, once you have created a reproducible example that illustrates your problem.