I`d like to multiply the value of function fuz <- gset_defuzzify by 2 if user choose English on radio button and by 1,5 if Spanish is chosen.
P.S.: I still don`t know how to take input values for fuzzy_inference...
library(shiny)
library(shinyjs)
library(sets)
library(datasets)
ui <- fluidPage(numericInput(inputId = "one", label="Type number",1, min=1, max=120),
numericInput(inputId = "two", label="Type number",1, min = 1, max=120),
numericInput(inputId = "three", label="Type number",1, min = 1, max=120),
numericInput(inputId = "four", label="Type number",1, min = 1, max=120),
textOutput("sub"), br(),
actionButton("act", "Show"),
br(),
radioButtons(inputId = "RB",label="Choose",
c("English"="English",
"French"="French",
"German"="German",
"Spanish"="Spanish",
"None"="None")),
textOutput("sw"),
textOutput("text")
)
server <- function(input, output){
output$text <- renderText({
RB <- switch(input$RB,
English= "You schould learn German.",
French = "You schould learn Spanish.",
German = "You schould learn English.",
Spanish = "You schould learn Portuguese.",
None ="You schould learn Polish.")
})
variables <- set(wo = fuzzy_partition(varnames = c(notMany2 = 15, enough2 = 25, many2 = 35),FUN = fuzzy_cone, radius = 10),
top = fuzzy_partition(varnames = c(notMany3 = 20, enough3 = 50, many3 = 100),FUN = fuzzy_cone, radius = 25),
c = fuzzy_partition(varnames = c(k4 = 52, k3 = 42, k2 = 32,k1 = 22), sd = 3)
)
rules <- set (fuzzy_rule(wo %is% notMany2 && top %is% notMany3
|| wo %is% notMany2 && top %is% notMany3
|| wo %is% notMany2 && top %is% notMany3
, c %is% k1),
fuzzy_rule( wo %is% notMany2 && top %is% enough3
|| wo %is% notMany2 && top %is% many3,c %is% k2))
system <- fuzzy_system(variables,rules)
fi <- fuzzy_inference(system, list(wo = 20, top= 10))
fuz <- gset_defuzzify(fi, 'centroid')
output$sub <- renderText({fuz})
}
shinyApp(ui = ui, server = server)