Хорошо, так что я хочу иметь один сюжет, где у меня будет число «х» романов, и мы сможем увидеть разброс определенного слова во всех романах. Каждый роман имеет разную длину (общее количество слов), поэтому ось «х» должна быть романом, а ось «у» должна быть длиной каждого романа. Прямо сейчас я могу создать отдельный сюжет для каждого романа, но я хочу, чтобы все они были вместе. Вот что у меня есть:
input.dir<-("corpus2")
files.v<-dir(input.dir, "\\.txt$")
corpus<-corpus(files.v, input.dir)
tiempo<-tiempo(corpus)
noche<-palabra("día", corpus, tiempo)
dispersion(noche)
#corpus
corpus<-function(files.v, input.dir){
text.word.vector.l<-list()
for(i in 1:length(files.v)){
text.v <- scan(paste(input.dir, files.v[i], sep="/"), what="character", sep="\n")
Encoding(text.v)<-"UTF-8"
text.v <- paste(text.v, collapse=" ")
text.lower.v <- tolower(text.v)
text.words.v <- strsplit(text.lower.v, "\\W")
text.words.v <- unlist(text.words.v)
text.words.v <- text.words.v[which(text.words.v!="")]
text.word.vector.l[[files.v[i]]] <- text.words.v
}
return(text.word.vector.l)
}
#tiempo
tiempo <- function(argument1){
tiempo.l<-list()
for (i in 1:length(argument1)){
time<-seq(1:length(argument1[[i]]))
tiempo.l[[files.v[i]]]<-time
}
return(tiempo.l)
}
#palabra
palabra<-function(keyword, argument1, argument2){
hits.l<-list()
for (i in 1:length(argument1)) {
hits.v<-which(argument1[[i]]==keyword)
hits.keyword.v<-rep(NA, length(argument2[[i]]))
hits.keyword.v[hits.v]<-1
hits.l[[files.v[i]]]<-hits.keyword.v
}
return(hits.l)
}
#dispersion
dispersion<-function(argument1){
options(scipen=5)
for (i in 1:length(argument1)) {
plot(argument1[[i]], main="Dispersion plot",
xlab="time", ylab="keyword", type="h", ylim=c(0,1), yaxt='n')
}
}
Как я могу построить это вместе? Вот картина того, что, на мой взгляд, должно выглядеть:
То, что я пытаюсь сделать, это более или менее объединить все эти сюжеты: