-
Notifications
You must be signed in to change notification settings - Fork 0
/
who_nrc.R
93 lines (70 loc) · 2.95 KB
/
who_nrc.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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
library(ggplot2)
library(syuzhet)
library(dplyr)
library(tidytext)
news <- read.csv(file="/home/cynthiak/Ebola/all_source_text.csv", header=TRUE, sep=",")
Sentimentscores_who <- read.csv(text="day,month_year,sentiment,score")
head(Sentimentscores_who)
for (row in 1:nrow(news)) {
curr_date <-toString(news[row, "date"])
current_date <- strsplit(curr_date, "-")[[1]]
month_year <- paste(current_date[2], current_date[3],sep="_")
text <- news[row, "who_text"]
#convert all text to lower case
text <- tolower(text)
# Replace blank space (“rt”)
text <- gsub("rt", "", text)
# Replace @UserName
text <- gsub("@\\w+", "", text)
# Remove punctuation
text <- gsub("[[:punct:]]", "", text)
# Remove links
text <- gsub("http\\w+", "", text)
# Remove tabs
text <- gsub("[ |\t]{2,}", "", text)
# Remove blank spaces at the beginning
text <- gsub("^ ", "", text)
# Remove blank spaces at the end
text <- gsub(" $", "", text)
#getting emotions using in-built function
sentiment_who<-get_nrc_sentiment((text))
#calculationg total score for each sentiment
Sentimentscores<-data.frame(colSums(sentiment_who[,]))
names(Sentimentscores)<-"Score"
Sentimentscores<-cbind("day"=rep(current_date[1],10),"month_year"=rep(month_year,10),"sentiment"=rownames(Sentimentscores),Sentimentscores)
rownames(Sentimentscores)<-NULL
Sentimentscores_who <- rbind(Sentimentscores_who, Sentimentscores)
}
head(Sentimentscores_who)
names(Sentimentscores_who)
agg_sentiment <- aggregate(Sentimentscores_who$Score, by=list(date=Sentimentscores_who$month_year, sentiment=Sentimentscores_who$sentiment), FUN=sum)
names(agg_sentiment)[3] <- "Score"
normalize <- function(x) {
return ((x - min(x)) / (max(x) - min(x)))
}
dfNorm <- as.data.frame(lapply(agg_sentiment["Score"], normalize))
head(dfNorm)
new <- subset(agg_sentiment, select = -Score )
new <-cbind(new, "Score"=dfNorm)
head(new)
new$date <- as.factor(new$date)
#plotting the sentiments with scores
p <- ggplot(data=new,aes(x=date,y=Score, group=sentiment))+ geom_line(aes(color=sentiment))+
geom_point(aes(color=sentiment))+
theme(legend.position="right")+
xlab("Days")+ylab("scores")+ggtitle("Sentiments nrc - source WHO")
#p+scale_color_manual(values=c("#999999", "#E69F00", "#56B4E9", "#FF6347", "#228B22", "#008080", "#FFA500", "#800080", "#CCCC00", "#FF69B4"))
p+scale_color_brewer(palette="Paired")
positive <- subset(new, sentiment=="positive")
new2 <- rbind(positive, negative)
negative <- subset(new, sentiment=="negative")
anticipation <- subset(new, sentiment=="anticipation")
new2 <- anticipation
fear <- subset(new, sentiment=="fear")
new2 <- rbind(anticipation, fear)
q <- ggplot(data=new2,aes(x=date,y=Score, group=sentiment))+ geom_line(aes(color=sentiment))+
geom_point(aes(color=sentiment))+
theme(legend.position="right")+
xlab("Day")+ylab("scores")+ggtitle("Anticipation/Fear sentiments plot - WHO")
q+scale_color_brewer(palette="Spectral")
q+scale_colour_viridis_d(option = "D")