forked from rdpeng/ExData_Plotting1
-
Notifications
You must be signed in to change notification settings - Fork 0
/
plot3.R
36 lines (32 loc) · 1.36 KB
/
plot3.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
### Download and unzip
hpc_url <- "https://d396qusza40orc.cloudfront.net/exdata%2Fdata%2Fhousehold_power_consumption.zip"
download.file(hpc_url, "hpc.zip")
unzip("hpc.zip")
file.remove("hpc.zip")
### Read relevant rows
txt <- "household_power_consumption.txt"
relevant_rows <- grep("^[12]/2/2007", readLines(txt))
hpc <- read.table(txt, skip = relevant_rows[[1]] - 1, # Skip all rows before start of relevant rows
nrows = length(relevant_rows), # Select the number of relevant rows
sep = ";", na.strings = "?") # NAs are coded as "?"
### Add header
header <- read.table("household_power_consumption.txt", nrows = 1, sep = ";")
names(hpc) <- unlist(header[1,])
### Concatenate date and time and convert to datetime format
hpc$Date <- paste(hpc$Date, hpc$Time)
hpc$Date <- strptime(hpc$Date, format = "%d/%m/%Y %H:%M:%S")
names(hpc)[1] <- "datetime"
hpc <- hpc[,-2] # Time column is redundant now
### Plot graphic to PNG
png("plot3.png", width = 480, height = 480)
y1 <- hpc$Sub_metering_1
y2 <- hpc$Sub_metering_2
y3 <- hpc$Sub_metering_3
x <- hpc$datetime
plot(x, y1, type="n", xlab = "", ylab = "Energy sub metering")
lines(x, y1, col = "Black")
lines(x, y2, col = "Red")
lines(x, y3, col = "Blue")
legend("topright", legend = c("Sub_metering_1", "Sub_metering_2", "Sub_metering_3"),
lty = c(1,1), col = c("Black", "Red", "Blue"))
dev.off()