forked from rdpeng/ExData_Plotting1
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathplot3.R
39 lines (30 loc) · 1.85 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
37
38
39
## This script downloads the data if it does not exist already and creates/stores the third plot from the Courser Project 1
## If the file does not exist, then downloads the file from the remote server.
destfile <- "./household_power_consumption.zip"
if(!file.exists(destfile)) {
fileUrl <- "https://d396qusza40orc.cloudfront.net/exdata%2Fdata%2Fhousehold_power_consumption.zip"
download.file(fileUrl, destfile = destfile, method = "curl")
}
## Unzips dataset
unzipedFile <- "./household_power_consumption.txt"
if(!file.exists(destfile)) {
unzip(destfile)
}
## Reads the whole dataset since it's not that big
data <- read.table(unzipedFile, sep = ";", header = T, na.strings = "?")
## Transforms the Date column into a usable date format dd/mm/yyyy HH:MM:SS
data$Date <- strptime(paste(data$Date, data$Time), "%d/%m/%Y %H:%M:%S")
## Transforms the Time column into a usable time format hh:mm:ss. Note that the date parte of this variable was created automaticly
## by the strptime function and thus, it has no meaning whatsoever.
data$Time <- strptime(data$Time, format = "%H:%M:%S")
## Subsets the data to only include from the dates 2007-02-01 (feb 1st 2007) and 2007-02-02 (feb 2nd 2007)
subData <- subset(data, Date > strptime("2007-02-01", "%Y-%m-%d") & Date < strptime("2007-02-03", "%Y-%m-%d"))
## Opens a png device and sets the width and height of the image.
png(filename="./plot3.png", width = 480, height = 480)
## Creates the actual plot.
plot(subData$Date, subData$Sub_metering_1, type = "l", ylab = "Energy sub metering", xlab = "", col = "black")
lines(subData$Date, subData$Sub_metering_2, col = "red")
lines(subData$Date, subData$Sub_metering_3, col = "blue")
legend("topright", col = c("black", "red", "blue"), legend = c("Sub_metering_1", "Sub_metering_2", "Sub_metering_3"), lwd = 1)
## Closes the png device and saves the image to disk.
dev.off()