forked from rdpeng/ExData_Plotting1
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathplot4.R
59 lines (48 loc) · 1.88 KB
/
plot4.R
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
# project 1 plot4.R
setwd("~/Desktop/Coursera/exploratory/project1")
library(dplyr)
library(data.table)
library(lubridate)
data_url = 'https://d396qusza40orc.cloudfront.net/exdata%2Fdata%2Fhousehold_power_consumption.zip'
if (!file.exists('household_power_consumption.zip')) {
download_date <- date()
download.file(data_url, 'household_power_consumption.zip', method = 'curl')
}
if (!file.exists('household_power_consumption.txt')) {
unzip_date <- date()
unzip('household_power_consumption.zip')
}
data <- fread('household_power_consumption.txt', na.strings="?")
dt.data <- tbl_dt(data)
# fix the date for a filter
dt.data$LDate <- dmy(dt.data$Date)
# subset for only the 2007-02-01 and 2007-02-02 data
dt.data.subset <- filter(dt.data, LDate == ymd('20070201') |
LDate == ymd('20070202'))
# make sure the labels end up days of week POSIXlt?
datetimes <- strptime(paste(dt.data.subset$Date,
dt.data.subset$Time, sep=" "),
"%d/%m/%Y %H:%M:%S")
png(file = "plot4.png", width = 480, height = 480)
## plot the data
# set to 2 x 2 columns
par(mfrow = c(2, 2))
# plot 1
plot(datetimes, dt.data.subset$Global_active_power,
type="l", xlab="", ylab="Global Active Power")
# plot 2
plot(datetimes, dt.data.subset$Voltage,
type="l", xlab="datetime", ylab="Voltage")
# plot3
plot(datetimes, dt.data.subset$Sub_metering_1,
type="l", ylab="Energy Submetering", xlab="")
lines(datetimes, dt.data.subset$Sub_metering_2, type="l", col="red")
lines(datetimes, dt.data.subset$Sub_metering_3, type="l", col="blue")
legend("topright",
c("Sub_metering_1", "Sub_metering_2", "Sub_metering_3"),
bty="n", lty=1,
col=c("black", "red", "blue"))
# plot4 - Global Reactive Power
plot(datetimes, dt.data.subset$Global_reactive_power,
type="l", xlab="datetime", ylab="Global_reactive_power")
dev.off()