| 
									
										
										
										
											2021-06-24 22:38:16 +02:00
										 |  |  | library(data.table) | 
					
						
							|  |  |  | library(DT) | 
					
						
							|  |  |  | library(shiny) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-25 12:03:11 +02:00
										 |  |  | source("input.R") | 
					
						
							| 
									
										
										
										
											2021-08-25 15:01:18 +02:00
										 |  |  | source("process.R") | 
					
						
							| 
									
										
										
										
											2021-06-24 22:38:16 +02:00
										 |  |  | source("scatter_plot.R") | 
					
						
							| 
									
										
										
										
											2021-08-25 11:59:27 +02:00
										 |  |  | source("util.R") | 
					
						
							| 
									
										
										
										
											2021-06-24 22:38:16 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-25 12:03:11 +02:00
										 |  |  | data <- run_cached("input", load_input, "input") | 
					
						
							| 
									
										
										
										
											2021-08-25 15:01:18 +02:00
										 |  |  | results <- run_cached("results", process_input, data) | 
					
						
							| 
									
										
										
										
											2021-06-24 22:38:16 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | server <- function(input, output) { | 
					
						
							| 
									
										
										
										
											2021-08-25 15:01:18 +02:00
										 |  |  |     filtered <- results[cluster_length >= 10] | 
					
						
							|  |  |  |     merged <- merge.data.table(filtered, data$genes, by.x = "gene", by.y = "id") | 
					
						
							|  |  |  |     setorder(merged, -cluster_length) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-06-24 22:38:16 +02:00
										 |  |  |     output$genes <- renderDT({ | 
					
						
							|  |  |  |         datatable( | 
					
						
							| 
									
										
										
										
											2021-08-25 15:01:18 +02:00
										 |  |  |             merged[, .(.I, name, chromosome, cluster_length, cluster_mean)], | 
					
						
							| 
									
										
										
										
											2021-06-24 22:38:16 +02:00
										 |  |  |             rownames = FALSE, | 
					
						
							| 
									
										
										
										
											2021-08-25 15:01:18 +02:00
										 |  |  |             colnames = c( | 
					
						
							|  |  |  |                 "Rank", | 
					
						
							|  |  |  |                 "Gene", | 
					
						
							|  |  |  |                 "Chromosome", | 
					
						
							|  |  |  |                 "Cluster length", | 
					
						
							|  |  |  |                 "Cluster mean" | 
					
						
							|  |  |  |             ), | 
					
						
							| 
									
										
										
										
											2021-06-24 22:38:16 +02:00
										 |  |  |             style = "bootstrap" | 
					
						
							|  |  |  |         ) | 
					
						
							|  |  |  |     }) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     output$scatter <- renderPlot({ | 
					
						
							| 
									
										
										
										
											2021-08-25 15:01:18 +02:00
										 |  |  |         gene_ids <- merged[input$genes_rows_selected, gene] | 
					
						
							| 
									
										
										
										
											2021-06-24 22:38:16 +02:00
										 |  |  |         scatter_plot(gene_ids, data) | 
					
						
							|  |  |  |     }) | 
					
						
							|  |  |  | } |