11.08.2013 Views

Introduction R & ggplot2. - Stat405 - Hadley Wickham

Introduction R & ggplot2. - Stat405 - Hadley Wickham

Introduction R & ggplot2. - Stat405 - Hadley Wickham

SHOW MORE
SHOW LESS

Create successful ePaper yourself

Turn your PDF publications into a flip-book with our unique Google optimized e-Paper software.

<strong>Stat405</strong><br />

Statistical computing & graphics<br />

Monday, August 20, 12<br />

<strong>Hadley</strong> <strong>Wickham</strong>


Monday, August 20, 12<br />

1. <strong>Introduction</strong>s<br />

2. Syllabus<br />

3. <strong>Introduction</strong> to linux<br />

4. <strong>Introduction</strong> to R<br />

5. Diving in


Monday, August 20, 12<br />

HELLO<br />

my name is<br />

<strong>Hadley</strong>


At Rice, I’m a<br />

• McMurtry divisional advisor,<br />

• major advisor for Statistics<br />

Away from Rice, I<br />

• love to cook<br />

• have two dogs<br />

• travel too much<br />

Monday, August 20, 12


Monday, August 20, 12<br />

http://stat405.had.co.nz<br />

hadley@rice.edu


Monday, August 20, 12<br />

Syllabus


Monday, August 20, 12<br />

Tools<br />

Computer: mac/windows/linux<br />

Software: R, text editor, latex ( = Rstudio)<br />

Brain: scepticism, curiosity, organisation


Monday, August 20, 12<br />

Homework<br />

Lowest grade dropped.<br />

Honour code: you can discuss ideas with other<br />

class members, but you must present your own<br />

work. All code should be your own.<br />

Late policy: 20% penalty if turned in by 9am<br />

Monday. Homeworks not accepted after that time.<br />

All homeworks must be submitted in physical<br />

form. Electronic versions will only be accepted in<br />

exceptional circumstances.


Monday, August 20, 12<br />

Team projects<br />

3 bigger team projects, culminating in<br />

poster presentation at the end of year.<br />

Teams of 4-5 people, assigned by <strong>Hadley</strong>.<br />

Will teach team work skills. Option to<br />

disband after first project. Firing and<br />

quitting.


Monday, August 20, 12<br />

Rstudio


Monday, August 20, 12<br />

Setup<br />

Install R and Rstudio on your computer,<br />

following the instructions on the class<br />

website.<br />

You can also use Rstudio online:<br />

https://www.clear.rice.edu/rstudio<br />

(note that the files are saved in your Rice computing account)


Monday, August 20, 12


Monday, August 20, 12<br />

Console – run code here


Monday, August 20, 12<br />

Output – plots and help


Monday, August 20, 12<br />

Editor – save code here


Monday, August 20, 12<br />

Editor – save code here<br />

Hint: learn the<br />

keyboard shortcuts


Monday, August 20, 12<br />

In editor:<br />

Short cuts<br />

Command/ctrl + enter: send code to console<br />

Ctrl + 2: move cursor to console<br />

In console:<br />

Up arrow: retrieve previous command<br />

Ctrl + up arrow: search commands<br />

Ctrl + 1: move cursor to editor


Monday, August 20, 12<br />

<strong>Introduction</strong><br />

to R


Monday, August 20, 12<br />

Learning a new<br />

language is hard!


Monday, August 20, 12<br />

Scatterplot basics<br />

install.packages("ggplot2")<br />

library(ggplot2)<br />

?mpg<br />

head(mpg)<br />

str(mpg)<br />

summary(mpg)<br />

qplot(displ, hwy, data = mpg)


Monday, August 20, 12<br />

Scatterplot basics<br />

install.packages("ggplot2")<br />

library(ggplot2)<br />

?mpg<br />

head(mpg)<br />

str(mpg)<br />

summary(mpg)<br />

Always explicitly<br />

specify the data<br />

qplot(displ, hwy, data = mpg)


hwy<br />

40<br />

35<br />

30<br />

25<br />

20<br />

15<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ● ● ● ●<br />

● ● ● ● ● ●<br />

qplot(displ, hwy, data = mpg) displ<br />

Monday, August 20, 12<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ●<br />

●<br />

● ● ● ●<br />

●<br />

●<br />

●<br />

●<br />

● ●<br />

● ● ●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ● ● ●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ● ●<br />

●<br />

● ●<br />

● ● ● ● ● ● ● ●<br />

●<br />

● ●<br />

● ●<br />

● ●<br />

●<br />

●<br />

●<br />

●<br />

● ● ●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ●<br />

● ●<br />

2 3 4 5 6 7<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />


Monday, August 20, 12<br />

Additional variables<br />

Can display additional variables with<br />

aesthetics (like shape, colour, size) or<br />

faceting (small multiples displaying<br />

different subsets)


hwy<br />

40<br />

35<br />

30<br />

25<br />

20<br />

15<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ● ● ●<br />

●<br />

●<br />

●<br />

●<br />

● ●●<br />

●<br />

●<br />

●<br />

● ●<br />

● ● ●<br />

●<br />

●● ● ● ●<br />

●<br />

●<br />

●<br />

●<br />

● ● ● ● ● ●<br />

● ● ● ●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

qplot(displ, hwy, colour displ = class, data = mpg)<br />

Monday, August 20, 12<br />

●<br />

●<br />

● ● ●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ● ● ● ● ● ● ●<br />

●<br />

● ●<br />

● ●<br />

●●<br />

●<br />

●<br />

● ●●<br />

●<br />

● ●●●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ●<br />

● ●<br />

2 3 4 5 6 7<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

class<br />

● 2seater<br />

● compact<br />

● midsize<br />

● minivan<br />

● pickup<br />

● subcompact<br />

● suv


hwy<br />

40<br />

35<br />

30<br />

25<br />

20<br />

15<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ● ● ●<br />

●<br />

●<br />

●<br />

●<br />

● ●●<br />

●<br />

●<br />

●<br />

● ●<br />

● ● ●<br />

●<br />

●● ● ● ●<br />

●<br />

●<br />

●<br />

●<br />

● ● ● ● ● ●<br />

● ● ● ●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

qplot(displ, hwy, colour displ = class, data = mpg)<br />

Monday, August 20, 12<br />

●<br />

●<br />

● ● ●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ● ● ● ● ● ● ●<br />

●<br />

● ●<br />

● ●<br />

●●<br />

●<br />

●<br />

● ●●<br />

●<br />

● ●●●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ●<br />

● ●<br />

2 3 4 5 6 7<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

class<br />

● 2seater<br />

● compact<br />

● midsize<br />

● minivan<br />

● pickup<br />

● subcompact<br />

● suv<br />

Legend chosen and<br />

displayed automatically.


Monday, August 20, 12<br />

Your turn<br />

Experiment with colour, size, and shape<br />

aesthetics.<br />

What’s the difference between discrete or<br />

continuous variables?<br />

What happens when you combine<br />

multiple aesthetics?


Monday, August 20, 12<br />

Colour<br />

Size<br />

Shape<br />

Discrete Continuous<br />

Rainbow of<br />

colours<br />

Discrete size<br />

steps<br />

Different shape<br />

for each<br />

Gradient from<br />

red to blue<br />

Linear mapping<br />

between radius<br />

and value<br />

Shouldn’t work


Monday, August 20, 12<br />

Faceting<br />

Small multiples displaying different<br />

subsets of the data.<br />

Useful for exploring conditional<br />

relationships. Useful for large data.


Monday, August 20, 12<br />

Your turn<br />

qplot(displ, hwy, data = mpg) +<br />

facet_grid(. ~ cyl)<br />

qplot(displ, hwy, data = mpg) +<br />

facet_grid(drv ~ .)<br />

qplot(displ, hwy, data = mpg) +<br />

facet_grid(drv ~ cyl)<br />

qplot(displ, hwy, data = mpg) +<br />

facet_wrap(~ class)


Monday, August 20, 12<br />

Summary<br />

facet_grid(): 2d grid, rows ~ cols, . for<br />

no split<br />

facet_wrap(): 1d ribbon wrapped into 2d


Monday, August 20, 12<br />

Aside: workflow<br />

Keep a copy of the slides open so that<br />

you can copy and paste the code.<br />

For complicated commands, write them<br />

in the editing area and then copy and<br />

paste.


hwy<br />

40<br />

35<br />

30<br />

25<br />

20<br />

15<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ● ●<br />

● ● ● ● ●<br />

qplot(cty, hwy, data = mpg) cty<br />

Monday, August 20, 12<br />

What’s the<br />

problem with<br />

this plot?<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ● ● ●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ● ●<br />

●<br />

● ●<br />

●<br />

●<br />

● ●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ●<br />

10 15 20 25 30 35<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />


hwy<br />

40<br />

35<br />

30<br />

25<br />

20<br />

15<br />

● ●<br />

● ●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ●<br />

● ●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ●<br />

●<br />

● ●<br />

● ●<br />

● ●<br />

● ●<br />

●●<br />

● ●<br />

● ●<br />

●<br />

●<br />

●<br />

● ●<br />

●<br />

● ●<br />

● ● ●<br />

●<br />

●<br />

●<br />

●<br />

● ● ●<br />

● ●<br />

●<br />

●<br />

●●●<br />

● ●<br />

● ●<br />

● ● ●●<br />

●<br />

●<br />

●<br />

●<br />

● ●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ● ●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●●<br />

● ●<br />

●<br />

● ●●<br />

● ●<br />

●<br />

● ●<br />

●<br />

●<br />

●<br />

●<br />

●●<br />

●<br />

● ● ●<br />

● ●<br />

● ●<br />

●<br />

●<br />

● ●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ● ●● ●<br />

●<br />

● ●<br />

●<br />

● ●<br />

●<br />

●<br />

● ●<br />

●<br />

●<br />

●● ●<br />

●<br />

●<br />

●<br />

●<br />

● ●<br />

●<br />

●<br />

● ●●<br />

●<br />

● ●<br />

●<br />

●<br />

●<br />

●<br />

● ●<br />

● ●<br />

● ●<br />

●●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ●<br />

● ●<br />

●<br />

qplot(cty, hwy, data = mpg, cty geom = "jitter")<br />

Monday, August 20, 12<br />

●<br />

●<br />

● ●<br />

●<br />

●<br />

10 15 20 25 30 35<br />

●<br />

●●<br />

●<br />

●<br />

●<br />

●<br />

●<br />


hwy<br />

40<br />

35<br />

30<br />

25<br />

20<br />

15<br />

● ●<br />

● ●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ●<br />

● ●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ●<br />

●<br />

● ●<br />

● ●<br />

● ●<br />

● ●<br />

●●<br />

● ●<br />

● ●<br />

●<br />

●<br />

●<br />

● ●<br />

●<br />

● ●<br />

● ● ●<br />

●<br />

●<br />

●<br />

●<br />

● ● ●<br />

● ●<br />

●<br />

●<br />

●●●<br />

● ●<br />

● ●<br />

● ● ●●<br />

●<br />

●<br />

●<br />

●<br />

● ●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ● ●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●●<br />

● ●<br />

●<br />

● ●●<br />

● ●<br />

●<br />

● ●<br />

●<br />

●<br />

●<br />

●<br />

●●<br />

●<br />

● ● ●<br />

● ●<br />

● ●<br />

●<br />

●<br />

● ●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ● ●● ●<br />

●<br />

● ●<br />

●<br />

● ●<br />

●<br />

●<br />

● ●<br />

●<br />

●<br />

●● ●<br />

●<br />

●<br />

●<br />

●<br />

● ●<br />

●<br />

●<br />

● ●●<br />

●<br />

● ●<br />

●<br />

●<br />

●<br />

●<br />

● ●<br />

● ●<br />

● ●<br />

●●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ●<br />

● ●<br />

●<br />

qplot(cty, hwy, data = mpg, cty geom = "jitter")<br />

Monday, August 20, 12<br />

●<br />

●<br />

● ●<br />

●<br />

●<br />

10 15 20 25 30 35<br />

●<br />

●●<br />

●<br />

●<br />

●<br />

●<br />

geom controls<br />

“type” of plot<br />

●<br />


class<br />

hwy<br />

15<br />

20<br />

25<br />

30<br />

35<br />

40<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

2seater compact midsize minivan pickup subcompact suv<br />

qplot(class, hwy, data = mpg)<br />

Monday, August 20, 12


class<br />

hwy<br />

15<br />

20<br />

25<br />

30<br />

35<br />

40<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

2seater compact midsize minivan pickup subcompact suv<br />

qplot(class, hwy, data = mpg)<br />

How could<br />

we improve<br />

this plot?<br />

Brainstorm<br />

for 1 minute.<br />

Monday, August 20, 12


eorder(class, hwy)<br />

hwy<br />

15<br />

20<br />

25<br />

30<br />

35<br />

40<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

pickup suv minivan 2seater midsize subcompact compact<br />

Monday, August 20, 12


hwy<br />

40<br />

35<br />

30<br />

25<br />

20<br />

15<br />

●<br />

● ●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

Incredibly useful<br />

●<br />

● technique!<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

qplot(reorder(class, hwy), reorder(class, hwy, hwy) data = mpg)<br />

Monday, August 20, 12<br />

●<br />

●<br />

● ●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ●<br />

pickup suv minivan 2seater midsize subcompact compact<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />


hwy<br />

40<br />

35<br />

30<br />

25<br />

20<br />

15<br />

●<br />

●<br />

●<br />

● ●<br />

●<br />

●●<br />

●<br />

●<br />

●<br />

●<br />

● ● ●<br />

● ●<br />

●<br />

● ●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ●<br />

●<br />

●<br />

●●<br />

●<br />

●<br />

● ●<br />

●<br />

●<br />

●<br />

●<br />

● ●<br />

●<br />

●<br />

●<br />

● ● ●<br />

●<br />

● ●<br />

●<br />

● ●<br />

●<br />

● ●●<br />

● ● ●●<br />

●<br />

●●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

qplot(reorder(class, hwy), reorder(class, hwy, data hwy) = mpg, geom = "jitter")<br />

Monday, August 20, 12<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ●<br />

● ●<br />

● ●●<br />

● ●<br />

● ●<br />

●<br />

●<br />

● ●<br />

● ●<br />

●<br />

● ●<br />

●<br />

● ●<br />

● ●●●<br />

●<br />

● ● ●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ●●<br />

●<br />

●●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ●<br />

●<br />

●<br />

●<br />

●<br />

● ●<br />

● ●<br />

● ●<br />

●<br />

● ●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ●<br />

pickup suv minivan 2seater midsize subcompact compact<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ●<br />

●<br />

●● ●<br />

●<br />


hwy<br />

40<br />

35<br />

30<br />

25<br />

20<br />

15<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

qplot(reorder(class, hwy), hwy, reorder(class, data hwy) = mpg, geom = "boxplot")<br />

Monday, August 20, 12<br />

pickup suv minivan 2seater midsize subcompact compact<br />

●<br />

●<br />

●<br />

●<br />


hwy<br />

40<br />

35<br />

30<br />

25<br />

20<br />

15<br />

●<br />

●<br />

● ● ● ● ●<br />

●<br />

●●<br />

●<br />

●<br />

●<br />

●<br />

● ●●<br />

● ● ● ● ● ● ●<br />

● ● ●<br />

● ●<br />

●<br />

●<br />

●<br />

● ●<br />

●<br />

● ●<br />

●<br />

●<br />

●<br />

● ●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●●<br />

● ●<br />

●● ● ● ●<br />

●<br />

●<br />

● ●<br />

●<br />

●<br />

● ●<br />

●●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ●<br />

●<br />

●<br />

●<br />

●<br />

● ● ●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ●<br />

●<br />

●<br />

●<br />

● ●<br />

● ● ●<br />

●<br />

●<br />

●<br />

● ● ●<br />

● ●<br />

●<br />

● ●●●<br />

●<br />

● ● ●<br />

●<br />

● ●<br />

●<br />

●<br />

● ●<br />

●<br />

●<br />

● ●<br />

● ●<br />

● ● ●<br />

●<br />

●<br />

● ●<br />

● ●●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

● ●<br />

● ● ●<br />

● ● ●<br />

●●<br />

●<br />

qplot(reorder(class, hwy), hwy, data = mpg,<br />

geom = c("jitter", "boxplot"))<br />

reorder(class, hwy)<br />

Monday, August 20, 12<br />

pickup suv minivan 2seater midsize subcompact compact<br />

●<br />

● ●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />

●<br />


Monday, August 20, 12<br />

Your turn<br />

Read the help for reorder. Redraw the<br />

previous plots with class ordered by<br />

median hwy.<br />

How would you put the jittered points on<br />

top of the boxplots?


Monday, August 20, 12<br />

Aside: coding strategy<br />

At the end of each interactive session, you<br />

want a summary of everything you did. Two<br />

options:<br />

1. Copy from the history panel.<br />

2. Build up the important bits as you go.<br />

(recommended)

Hooray! Your file is uploaded and ready to be published.

Saved successfully!

Ooh no, something went wrong!