mirror of
https://github.com/johrpan/geposanui.git
synced 2025-10-26 11:17:24 +01:00
filters: Add default filter based on percentile
This commit is contained in:
parent
663128271e
commit
f1337f0331
1 changed files with 24 additions and 2 deletions
26
R/filters.R
26
R/filters.R
|
|
@ -6,13 +6,27 @@ filters_ui <- function(id) {
|
|||
NS(id, "method"),
|
||||
"Filter method",
|
||||
choices = list(
|
||||
"Percentile" = "percentile",
|
||||
"Cut-off score" = "score",
|
||||
"Maximum number of genes" = "rank"
|
||||
"Maximum number of genes" = "rank",
|
||||
"None" = "none"
|
||||
)
|
||||
),
|
||||
tabsetPanel(
|
||||
id = NS(id, "sliders"),
|
||||
type = "hidden",
|
||||
tabPanelBody(
|
||||
value = "percentile",
|
||||
sliderInput(
|
||||
NS(id, "percentile"),
|
||||
label = "Minimum percentile",
|
||||
post = "%",
|
||||
min = 0,
|
||||
max = 100,
|
||||
step = 1,
|
||||
value = 95
|
||||
)
|
||||
),
|
||||
tabPanelBody(
|
||||
value = "score",
|
||||
sliderInput(
|
||||
|
|
@ -35,6 +49,9 @@ filters_ui <- function(id) {
|
|||
step = 50,
|
||||
value = 2500
|
||||
)
|
||||
),
|
||||
tabPanelBody(
|
||||
value = "none"
|
||||
)
|
||||
)
|
||||
)
|
||||
|
|
@ -54,10 +71,15 @@ filters_server <- function(id, results) {
|
|||
reactive({
|
||||
results <- results()
|
||||
|
||||
if (input$method == "score") {
|
||||
if (input$method == "percentile") {
|
||||
n_ranks <- nrow(results)
|
||||
results[rank <= (1 - (input$percentile / 100)) * n_ranks]
|
||||
} else if (input$method == "score") {
|
||||
results[score >= input$score / 100]
|
||||
} else if (input$method == "rank") {
|
||||
results[rank <= input$rank]
|
||||
} else {
|
||||
results
|
||||
}
|
||||
})
|
||||
})
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue