我正在开发一个Shiny应用程序,旨在猜测用户输入文本片段中的下一个单词。为此,我加载了三个包含可能的下一个单词猜测的数据框,并使用grepl查找与用户输入文本末尾匹配的三元组或二元组。在“常规”R中构建时没有出现错误或问题,但在转换为Shiny时,我遇到了以下错误:
错误:嵌套评估太深:无限递归/选项(表达式=)?
正如其他Stack Overflow帖子所建议的那样,我调整了options(expressions = )值,但仍然遇到错误。没有太多其他信息来指导我,并且注意到它已经没有问题,有人能看出我哪里错了吗?提前感谢!
背景资料:Win 7,64位操作系统|R v3.1.1|RStudio v0.98.944 ui.R
错误:嵌套评估太深:无限递归/选项(表达式=)?
正如其他Stack Overflow帖子所建议的那样,我调整了options(expressions = )值,但仍然遇到错误。没有太多其他信息来指导我,并且注意到它已经没有问题,有人能看出我哪里错了吗?提前感谢!
背景资料:Win 7,64位操作系统|R v3.1.1|RStudio v0.98.944 ui.R
library(shiny)
shinyUI(fluidPage(
titlePanel("Capstone: Word Guesser"),
fluidRow(
column(12,
mainPanel(
h4('Sentence Fragment'),
p('Please enter a snippet of text - with this as a start, the app will provide you 5 guesses in ranked order to complete your phrase'),
textInput('sentence', "Snippet:", value = "Enter some text and have a great"),
h4('Guesses'),
p('Below are our top five guesses for the word that completes this snippet'),
verbatimTextOutput("final.guesses")
)
)
)
))
server.R
options(expressions = 10000)
quad.grams <- readRDS("quadgrams.rds")
tri.grams <- readRDS("trigrams.rds")
kneser.ney <- readRDS("kneserney.rds")
library(shiny)
library(tm)
library(plyr)
library(stringi)
library(RWeka)
library(stringr)
function(input, output, clientData, session) {
observe({
sentence <- reactive({as.character(input$sentence)})
sentence <- reactive({str_replace_all(sentence(), "[[:punct:]]", "")})
sentence <- reactive({tolower(sentence())})
sentence <- reactive({scan_tokenizer(sentence())})
n <- reactive({length(sentence())})
tri.frag <- reactive({paste(sentence()[n() - 2], sentence()[n() - 1], sentence()[n()])})
bi.frag <- reactive({paste(sentence()[n() - 1], sentence()[n()])})
quad.guesses <- reactive({quad.grams[grepl(tri.frag(), quad.grams$n1.Gram) == TRUE, 2]})
tri.guesses <- reactive({tri.grams[grepl(bi.frag(), tri.grams$n1.Gram) == TRUE, 2]})
guesses <- reactive({c(quad.guesses(), tri.guesses(), kneser.ney$nGram)})
output$final.guesses <- renderPrint({guesses()[1:5]})
})
}