This article is in continuation of the Exploratory Data Analysis in R ― One Variable , where we discussed EDA of pseudo facebook dataset.
In this article, we will learn about data aggregation, conditional means and scatter plots, based on pseudo facebook dataset curated by Udacity.
Now we will look at two continuous variables at the same time. Scatter plot is one the best plots to examine the relationship between two variables. Lets draw a scatter plot between age and friend count of all the users.
qplot(age,friend_count,data=pf)OR
ggplot(aes(x=age,y=friend_count),data=pf)+ geom_point()scatter plot is the default plot when we use geom_point().
data:image/s3,"s3://crabby-images/58c39/58c39ca43758402a4482c851660cca3440e6aa2e" alt="Explore Two Variables Using R"
Plot 1 Scatter Plot ― Friend Count VsAge
From the above plot, following two observations are quite evident:
people with an age of less than 30, have thousands of friends there is a vertical line at age 69 and close to 100, which seems incorrect.We know that the minimum age required to hold a Facebook account is 13 years, and 90 seems a pretty big age, so let's restrict our x-axis from 13 to 90.
ggplot(aes(x=age,y=friend_count),data=pf)+ geom_point()+ xlim(13,90)data:image/s3,"s3://crabby-images/10e16/10e1677e03f15d07d95b822c45fee4bb5ed344f8" alt="Explore Two Variables Using R"
Plot 2 Scatter Plot ― Age Vs Friend Count (x axis restricted)
The above plot is better that Plot 1, but the lower part is overcrowded, which makes it difficult to count the number of points in that area.
Alpha aesthetics of geom_point can be used to set transparency levels of the points in the overcrowded area of the plot.
For our scenario, lets set an alpha value of 1/20, which means it will take 20 points to complete a black dot.
ggplot(aes(x=age,y=friend_count),data=pf)+ geom_point(alpha=1/20)+ xlim(13,90)data:image/s3,"s3://crabby-images/51d81/51d81ffb21a43a7a9b96fb25644d74b8883afbf9" alt="Explore Two Variables Using R"
Plot 3 Scatter Plot ― Age Vs Friend Count ― Alpha Aesthetics
Further, add jitter to our plot to spread out the points which are overplotted.
Jittering refers to adding small amount of random noise to data.
ggplot(aes(x=age,y=friend_count),data=pf)+ geom_jitter(alpha=1/20)+ xlim(13,90)data:image/s3,"s3://crabby-images/529e0/529e07fe8d5afdab67cb1634b957dfe68af7ec94" alt="Explore Two Variables Using R"
Plot 4 Scatter Plot ― Age Vs Friend Count ― Jittering
From the above plot, it can be inferred that the majority of users below 25 years of age have friends less than 1000. This inference contradicts our first observation from plot 1, symbolizing the importance of EDA.
Further, let's use coord_trans for visualization.
ggplot(aes(x=age,y=friend_count),data=pf)+ geom_point(alpha=1/20)+ xlim(13,90)+ coord_trans(y = "sqrt")OR
ggplot(aes(x=age,y=friend_count),data=pf)+ geom_point(alpha=1/20,position=position_jitter(h=0))+ xlim(13,90)+ coord_trans(y = "sqrt")data:image/s3,"s3://crabby-images/f04ac/f04acf7e3bc2cfa2a6ca84cfb6c5b05fc9abbd35" alt="Explore Two Variables Using R"
Plot 5 Scatter Plot ― Age Vs Friend Count ― Use coord_trans
With this plot, it is much easier to see friend count, conditional and age.
From data visualization until now, we can observe every point in the dataset. Still, it's not possible to determine important quantities such as mean and media from such display. Sometimes we want to understand, how mean or median varies with other variable. Let’s create a table which provides us with mean and median of all age. For this we will be using D Plyr . A basic tutorial for Dplyr can be found here and here . Same can be created using functions such as lapply, tapply, and split .
age_groups<-group_by(pf,age) pf.fc_by_age<-summarise(age_groups, friend_count_mean=mean(friend_count), friend_count_median=median(friend_count), n=n()) pf.fc_by_age<-arrange(pf.fc_by_age,age) head(pf.fc_by_age)Above code produces a tibble , and the output is as shown below:
A tibble: 6 x 4 age friend_count_mean friend_count_median n <int> <dbl> <dbl> <int> 1 13 165. 74 484 2 14 251. 132 1925 3 15 348. 161 2618 4 16 352. 172. 3086 5 17 350. 156 3283 6 18 331. 162 5196Tibbles are a modern take on data frames. They keep the features that have stood the test of time, and drop the features that used to be convenient but are now frustrating. More about it can found here .
Using the above tibble, we will be plotting scatter plot for age Vs friend_count_mean.
ggplot(aes(age,friend_count_mean),data=pf.fc_by_age) + geom_point()data:image/s3,"s3://crabby-images/76567/7656712c2970c6f5192154471da41642a0284a61" alt="Explore Two Variables Using R"
Plot 6 Scatter Plot ― Age Vs Friend CountMean
Joining above scattered dots with lines. Please observe the geom_line.
ggplot(aes(age,friend_count_mean),data=pf.fc_by_age) + geom_line()data:image/s3,"s3://crabby-images/8819b/8819bff6619770a5b1a197bb3915c1d830f56076" alt="Explore Two Variables Using R"
Plot 7 Line Plot ― Age Vs Friend CountMean
Cool! Let's plot our previous scatter plot in plot 5, with the tibble.
ggplot(aes(x=age,y=friend_count),data=pf)+ geom_point(alpha=1/20, position=position_jitter(h=0), color='red')+ xlim(13,90)+ coord_trans(y = "sqrt")+ geom_line(stat='summary',fun.y=mean)+ geom_line(stat='summary',fun.y=median,linetype=2,color='blue')+ geom_line(stat='summary',fun.y=quantile,fun.args=list(probs=0.9),color='blue')data:image/s3,"s3://crabby-images/c3787/c3787613d015cb971127f6700deace6c09f5fdfd" alt="Explore Two Variables Using R"
Plot 8 ― Overlaying summaries with rawdata
From above we can infer, that more than 1000 friends is a rare occurrence. To zoom it further we can use coord_cartesian.
ggplot(aes(