How to use viewmastR with saved models
2024-02-14
SavedModel.RmdInstalling Rust
First you need to have an updated Rust installation. Go to this site to learn how to install Rust.
Installing viewmastR
You will need to have the devtools package installed…
devtools::install_github("furlan-lab/viewmastR")Now you run viewmastR
The model path is specified using the ‘dir’ argument
seu<-viewmastR(seu, seur, ref_celldata_col = "SFClassification", selected_features = vg, dir = "/tmp/sc_local", max_epochs = 3)Run inference
We can use the function viewmastR_infer to run inference a saved model. We will need to pass the same vector of variable features we used to initially create the model. We can use query_celldata_col to specify the name of the metadata column in the returned object. An optional vector of labels can be provided. Additionally, instead of returning the input object with predictions added, you may instead return the probabilities using the return_probs argument.
seu<-viewmastR_infer(seu, model_dir = "/tmp/sc_local", vg, labels = levels(factor(seur$SFClassification)))
DimPlot(seu, group.by = "viewmastR_inferred", cols = seur@misc$colors)
A confusion matrix comparing the results using viewmastR to viewmastR_infer having saved the model to disc.
Open question as to why a small number of cells are different :)
confusion_matrix(pred = factor(seu$viewmastR_inferred), gt = factor(seu$viewmastR_pred), cols = seur@misc$colors)
Appendix
## R version 4.4.3 (2025-02-28)
## Platform: aarch64-apple-darwin20
## Running under: macOS Sequoia 15.4.1
## 
## Matrix products: default
## BLAS:   /Library/Frameworks/R.framework/Versions/4.4-arm64/Resources/lib/libRblas.0.dylib 
## LAPACK: /Library/Frameworks/R.framework/Versions/4.4-arm64/Resources/lib/libRlapack.dylib;  LAPACK version 3.12.0
## 
## locale:
## [1] en_US.UTF-8/en_US.UTF-8/en_US.UTF-8/C/en_US.UTF-8/en_US.UTF-8
## 
## time zone: America/Los_Angeles
## tzcode source: internal
## 
## attached base packages:
## [1] stats     graphics  grDevices utils     datasets  methods   base     
## 
## other attached packages:
## [1] ggplot2_3.5.2      Seurat_5.3.0       SeuratObject_5.1.0 sp_2.2-0          
## [5] viewmastR_0.4.0   
## 
## loaded via a namespace (and not attached):
##   [1] fs_1.6.6                    matrixStats_1.5.0          
##   [3] spatstat.sparse_3.1-0       RcppMsgPack_0.2.4          
##   [5] lubridate_1.9.4             httr_1.4.7                 
##   [7] RColorBrewer_1.1-3          doParallel_1.0.17          
##   [9] tools_4.4.3                 sctransform_0.4.2          
##  [11] backports_1.5.0             R6_2.6.1                   
##  [13] lazyeval_0.2.2              uwot_0.2.3                 
##  [15] GetoptLong_1.0.5            withr_3.0.2                
##  [17] gridExtra_2.3               scCustomize_3.0.1          
##  [19] progressr_0.15.1            cli_3.6.5                  
##  [21] Biobase_2.66.0              textshaping_1.0.0          
##  [23] Cairo_1.6-2                 spatstat.explore_3.4-3     
##  [25] fastDummies_1.7.5           labeling_0.4.3             
##  [27] sass_0.4.10                 spatstat.data_3.1-6        
##  [29] proxy_0.4-27                ggridges_0.5.6             
##  [31] pbapply_1.7-2               pkgdown_2.1.1              
##  [33] systemfonts_1.2.2           foreign_0.8-90             
##  [35] R.utils_2.13.0              dichromat_2.0-0.1          
##  [37] parallelly_1.45.0           rstudioapi_0.17.1          
##  [39] generics_0.1.4              shape_1.4.6.1              
##  [41] ica_1.0-3                   spatstat.random_3.4-1      
##  [43] dplyr_1.1.4                 Matrix_1.7-3               
##  [45] ggbeeswarm_0.7.2            S4Vectors_0.44.0           
##  [47] abind_1.4-8                 R.methodsS3_1.8.2          
##  [49] lifecycle_1.0.4             yaml_2.3.10                
##  [51] snakecase_0.11.1            SummarizedExperiment_1.36.0
##  [53] recipes_1.2.1               SparseArray_1.6.2          
##  [55] Rtsne_0.17                  paletteer_1.6.0            
##  [57] grid_4.4.3                  promises_1.3.3             
##  [59] crayon_1.5.3                miniUI_0.1.2               
##  [61] lattice_0.22-7              cowplot_1.1.3              
##  [63] magick_2.9.0                pillar_1.10.2              
##  [65] knitr_1.50                  ComplexHeatmap_2.22.0      
##  [67] GenomicRanges_1.58.0        rjson_0.2.23               
##  [69] boot_1.3-31                 future.apply_1.20.0        
##  [71] codetools_0.2-20            glue_1.8.0                 
##  [73] spatstat.univar_3.1-3       data.table_1.17.6          
##  [75] vctrs_0.6.5                 png_0.1-8                  
##  [77] spam_2.11-1                 Rdpack_2.6.4               
##  [79] gtable_0.3.6                rematch2_2.1.2             
##  [81] assertthat_0.2.1            cachem_1.1.0               
##  [83] gower_1.0.2                 xfun_0.52                  
##  [85] rbibutils_2.3               S4Arrays_1.6.0             
##  [87] mime_0.13                   prodlim_2025.04.28         
##  [89] reformulas_0.4.0            survival_3.8-3             
##  [91] timeDate_4041.110           SingleCellExperiment_1.28.1
##  [93] iterators_1.0.14            pbmcapply_1.5.1            
##  [95] hardhat_1.4.1               lava_1.8.1                 
##  [97] fitdistrplus_1.2-2          ROCR_1.0-11                
##  [99] ipred_0.9-15                nlme_3.1-168               
## [101] RcppAnnoy_0.0.22            GenomeInfoDb_1.42.3        
## [103] bslib_0.9.0                 irlba_2.3.5.1              
## [105] vipor_0.4.7                 KernSmooth_2.23-26         
## [107] rpart_4.1.24                colorspace_2.1-1           
## [109] BiocGenerics_0.52.0         Hmisc_5.2-3                
## [111] nnet_7.3-20                 ggrastr_1.0.2              
## [113] tidyselect_1.2.1            compiler_4.4.3             
## [115] htmlTable_2.4.3             desc_1.4.3                 
## [117] DelayedArray_0.32.0         plotly_4.11.0              
## [119] checkmate_2.3.2             scales_1.4.0               
## [121] lmtest_0.9-40               stringr_1.5.1              
## [123] digest_0.6.37               goftest_1.2-3              
## [125] spatstat.utils_3.1-4        minqa_1.2.8                
## [127] rmarkdown_2.29              XVector_0.46.0             
## [129] htmltools_0.5.8.1           pkgconfig_2.0.3            
## [131] base64enc_0.1-3             lme4_1.1-37                
## [133] sparseMatrixStats_1.18.0    MatrixGenerics_1.18.1      
## [135] fastmap_1.2.0               rlang_1.1.6                
## [137] GlobalOptions_0.1.2         htmlwidgets_1.6.4          
## [139] UCSC.utils_1.2.0            shiny_1.10.0               
## [141] DelayedMatrixStats_1.28.1   farver_2.1.2               
## [143] jquerylib_0.1.4             zoo_1.8-14                 
## [145] jsonlite_2.0.0              ModelMetrics_1.2.2.2       
## [147] R.oo_1.27.0                 magrittr_2.0.3             
## [149] Formula_1.2-5               GenomeInfoDbData_1.2.13    
## [151] dotCall64_1.2               patchwork_1.3.1            
## [153] Rcpp_1.0.14                 reticulate_1.42.0          
## [155] stringi_1.8.7               pROC_1.18.5                
## [157] zlibbioc_1.52.0             MASS_7.3-65                
## [159] plyr_1.8.9                  parallel_4.4.3             
## [161] listenv_0.9.1               ggrepel_0.9.6              
## [163] forcats_1.0.0               deldir_2.0-4               
## [165] splines_4.4.3               tensor_1.5.1               
## [167] circlize_0.4.16             igraph_2.1.4               
## [169] spatstat.geom_3.4-1         RcppHNSW_0.6.0             
## [171] reshape2_1.4.4              stats4_4.4.3               
## [173] evaluate_1.0.4              ggprism_1.0.5              
## [175] nloptr_2.2.1                foreach_1.5.2              
## [177] httpuv_1.6.16               RANN_2.6.2                 
## [179] tidyr_1.3.1                 purrr_1.0.4                
## [181] polyclip_1.10-7             future_1.58.0              
## [183] clue_0.3-66                 scattermore_1.2            
## [185] janitor_2.2.1               xtable_1.8-4               
## [187] monocle3_1.3.7              e1071_1.7-16               
## [189] RSpectra_0.16-2             later_1.4.2                
## [191] viridisLite_0.4.2           class_7.3-23               
## [193] ragg_1.4.0                  tibble_3.3.0               
## [195] beeswarm_0.4.0              IRanges_2.40.1             
## [197] cluster_2.1.8.1             timechange_0.3.0           
## [199] globals_0.18.0              caret_7.0-1
getwd()## [1] "/Users/sfurlan/develop/viewmastR/vignettes"