The GSgalgoR package provides a practical but straightforward callback mechanism
for adapting different galgo() execution sections to final user needs. The
GSgalgoR callbacks mechanism enables adding custom functions to change the
galgo() function behavior by including minor modification to galgo’s workflow.
A common application of the callback mechanism is to implement personalized
reports, saving partial information during the evolution process or compute the
execution time.
There are five possible points where the user can hook its own code inside
galgo() execution process.
galgo() execution process. (i.e. when galgo()
is about to start.)galgo() execution process. (i.e. when galgo() is about
to finish. )Each one of the five possible hooks can be accessed through parameters
with the *_callback* suffix in the galgo() function.
galgo(...,
    start_galgo_callback = callback_default,# `galgo()` is about to start.
    end_galgo_callback = callback_default,  # `galgo()` is about to finish.
    start_gen_callback = callback_default, # At the beginning of each generation
    end_gen_callback = callback_default,    # At the end of each generation
    report_callback = callback_default,     # In the middle of the generation,
                                            #  right after the new mating pool 
                                            #  have been created.
    ...) A callback function definition can be any R function accepting six parameters.
-userdir: the directory (“character”) where the user can save information
into local filesystem.
-generation: the number (“integer”) of the current generation/iteration.
-pop_pool: the data.frame containing the resulting solutions for current
iteration.
-pareto: the solutions found by galgo() accross all generations in the
solution space
-prob_matrix: the expression set (“matrix) where features are rows and
samples distributed in columns.
-current_time: The current time (an object of class”POSIXct").
The following callback function example prints the generation number and current time every two iterations
library(GSgalgoR)
my_callback <-
    function(userdir = "",
        generation,
            pop_pool,
            pareto,
            prob_matrix,
            current_time) {
    # code starts  here
    if (generation%%2 == 0)
        message(paste0("generation: ",generation,
                    " current_time: ",current_time))
    }then, the my_callback() function needs to be assigned to some of the
available hooks provided by the galgo(). An example of such assignment and
the resulting output is provided in the two snippets below.
A reduced version of the
TRANSBIG
dataset is used to setup the expression and clinical information
required for the galgo() function.
library(breastCancerTRANSBIG)data(transbig)
train <- transbig
rm(transbig)
expression <- Biobase::exprs(train)
clinical <- Biobase::pData(train)
OS <- survival::Surv(time = clinical$t.rfs, event = clinical$e.rfs)
# use a reduced dataset for the example
expression <- expression[sample(1:nrow(expression), 100), ]
# scale the expression matrix
expression <- t(scale(t(expression)))Then, the galgo() function is invoked and the recently defined function
my_callback() is assigned to the report_callback hook-point.
library(GSgalgoR)# Running galgo
GSgalgoR::galgo(generations = 6, 
            population = 15, 
            prob_matrix = expression, 
            OS = OS,
    start_galgo_callback = GSgalgoR::callback_default, 
    end_galgo_callback = GSgalgoR::callback_default,
    report_callback = my_callback,      # call `my_callback()` in the mile 
                                        # of each generation/iteration.
    start_gen_callback = GSgalgoR::callback_default,
    end_gen_callback = GSgalgoR::callback_default) 
#> Using CPU for computing pearson distance
#> generation: 2 current_time: 2022-11-01 17:43:59
#> generation: 4 current_time: 2022-11-01 17:44:01
#> generation: 6 current_time: 2022-11-01 17:44:02
#> NULLThe following callback function save in a temporary directory the solutions
obtained every five generation/iteration. A file the number of the generation
and with a rda. extension will be left in a directory defined
by the tempdir() function.
my_save_pop_callback <-
    function(userdir = "",
            generation,
            pop_pool,
            pareto,
            prob_matrix,
            current_time) {
        directory <- paste0(tempdir(), "/")
        if (!dir.exists(directory)) {
            dir.create(directory, recursive = TRUE)
        }
        filename <- paste0(directory, generation, ".rda")
        if (generation%%2 == 0){
            save(file = filename, pop_pool)
        }
        message(paste("solution file saved in",filename))
    }As usual, the galgo() function is invoked and the recently defined
function my_save_pop_callback() is assigned to the end_gen_callback
hook-point. As a result, every five generation/iteration the complete
solution obtained by galgo will be saved in a file.
# Running galgo
GSgalgoR::galgo(
    generations = 6, 
    population = 15, 
    prob_matrix = expression, 
    OS = OS,
    start_galgo_callback = GSgalgoR::callback_default, 
    end_galgo_callback = GSgalgoR::callback_default,   
    report_callback = my_callback,# call `my_callback()` 
                                #  in the middle of each generation/iteration.
    start_gen_callback = GSgalgoR::callback_default,
    end_gen_callback = my_save_pop_callback # call `my_save_pop_callback()` 
                                            # at the end of each 
                                            #   generation/iteration
    ) 
#> Using CPU for computing pearson distance
#> solution file saved in /tmp/RtmpGYkM2n/1.rda
#> generation: 2 current_time: 2022-11-01 17:44:09
#> solution file saved in /tmp/RtmpGYkM2n/2.rda
#> solution file saved in /tmp/RtmpGYkM2n/3.rda
#> generation: 4 current_time: 2022-11-01 17:44:11
#> solution file saved in /tmp/RtmpGYkM2n/4.rda
#> solution file saved in /tmp/RtmpGYkM2n/5.rda
#> generation: 6 current_time: 2022-11-01 17:44:12
#> solution file saved in /tmp/RtmpGYkM2n/6.rda
#> NULLBy default, GSfalgoR implements four callback functions
callback_default() a simple callback that does nothing at all. It is just
used for setting the default behavior of some of the hook-points
inside galgo()
callback_base_report() a report callback for printing basic information
about the solution provided by galgo() such as fitness and crowding distance.
callback_no_report() a report callback for informing the user galgo is
running. Not valuable information is shown.
callback_base_return_pop() a callback function for building and returning t
he galgo.Obj object.
In the the default definition of the galgo() function the hook-points are
defined as follow:
-start_galgo_callback = callback_default
-end_galgo_callback = callback_base_return_pop
-report_callback = callback_base_report
-start_gen_callback = callback_default
-end_gen_callback = callback_default
Notice by using the callback mechanism it is possible to modify even the
returning value of the galgo() function. The default
callback_base_return_pop() returns a galgo.Obj object, however it would
simple to change that behavior for something like the my_save_pop_callback()
and the function will not returning any value.
# Running galgo
GSgalgoR::galgo(
    generations = 6, 
    population = 15, 
    prob_matrix = expression, 
    OS = OS,
    start_galgo_callback = GSgalgoR::callback_default, 
    end_galgo_callback = my_save_pop_callback,
    report_callback = my_callback,  # call `my_callback()` 
                                    # in the middle of each generation/iteration
    start_gen_callback = GSgalgoR::callback_default,
    end_gen_callback = GSgalgoR::callback_default
    ) 
#> Using CPU for computing pearson distance
#> generation: 2 current_time: 2022-11-01 17:44:19
#> generation: 4 current_time: 2022-11-01 17:44:20
#> generation: 6 current_time: 2022-11-01 17:44:21
#> solution file saved in /tmp/RtmpGYkM2n/6.rdaFor preserving the return behavior of the galgo() function,
callback_base_return_pop() should be called inside a custom callback.
An example of such situation is shown below:
another_callback <-
    function(userdir = "",
            generation,
            pop_pool,
            pareto,
            prob_matrix,
            current_time) {
    # code starts  here
    # code ends here  
    callback_base_return_pop(userdir,
                            generation,
                            pop_pool,
                            prob_matrix,
                            current_time)
    }sessionInfo()
#> R version 4.2.1 (2022-06-23)
#> Platform: x86_64-pc-linux-gnu (64-bit)
#> Running under: Ubuntu 20.04.5 LTS
#> 
#> Matrix products: default
#> BLAS:   /home/biocbuild/bbs-3.16-bioc/R/lib/libRblas.so
#> LAPACK: /home/biocbuild/bbs-3.16-bioc/R/lib/libRlapack.so
#> 
#> locale:
#>  [1] LC_CTYPE=en_US.UTF-8       LC_NUMERIC=C              
#>  [3] LC_TIME=en_GB              LC_COLLATE=C              
#>  [5] LC_MONETARY=en_US.UTF-8    LC_MESSAGES=en_US.UTF-8   
#>  [7] LC_PAPER=en_US.UTF-8       LC_NAME=C                 
#>  [9] LC_ADDRESS=C               LC_TELEPHONE=C            
#> [11] LC_MEASUREMENT=en_US.UTF-8 LC_IDENTIFICATION=C       
#> 
#> attached base packages:
#> [1] stats     graphics  grDevices utils     datasets  methods   base     
#> 
#> other attached packages:
#>  [1] survminer_0.4.9             ggpubr_0.4.0               
#>  [3] ggplot2_3.3.6               genefu_2.30.0              
#>  [5] AIMS_1.30.0                 e1071_1.7-12               
#>  [7] iC10_1.5                    iC10TrainingData_1.3.1     
#>  [9] impute_1.72.0               pamr_1.56.1                
#> [11] cluster_2.1.4               biomaRt_2.54.0             
#> [13] survcomp_1.48.0             prodlim_2019.11.13         
#> [15] survival_3.4-0              Biobase_2.58.0             
#> [17] BiocGenerics_0.44.0         GSgalgoR_1.8.0             
#> [19] breastCancerUPP_1.35.0      breastCancerTRANSBIG_1.35.0
#> [21] BiocStyle_2.26.0           
#> 
#> loaded via a namespace (and not attached):
#>   [1] backports_1.4.1        BiocFileCache_2.6.0    splines_4.2.1         
#>   [4] listenv_0.8.0          GenomeInfoDb_1.34.0    digest_0.6.30         
#>   [7] SuppDists_1.1-9.7      foreach_1.5.2          htmltools_0.5.3       
#>  [10] magick_2.7.3           fansi_1.0.3            magrittr_2.0.3        
#>  [13] memoise_2.0.1          doParallel_1.0.17      limma_3.54.0          
#>  [16] globals_0.16.1         Biostrings_2.66.0      prettyunits_1.1.1     
#>  [19] colorspace_2.0-3       blob_1.2.3             rappdirs_0.3.3        
#>  [22] xfun_0.34              dplyr_1.0.10           crayon_1.5.2          
#>  [25] RCurl_1.98-1.9         jsonlite_1.8.3         zoo_1.8-11            
#>  [28] iterators_1.0.14       glue_1.6.2             gtable_0.3.1          
#>  [31] zlibbioc_1.44.0        XVector_0.38.0         car_3.1-1             
#>  [34] future.apply_1.9.1     abind_1.4-5            scales_1.2.1          
#>  [37] DBI_1.1.3              rstatix_0.7.0          Rcpp_1.0.9            
#>  [40] gridtext_0.1.5         xtable_1.8-4           progress_1.2.2        
#>  [43] bit_4.0.4              proxy_0.4-27           mclust_6.0.0          
#>  [46] km.ci_0.5-6            stats4_4.2.1           lava_1.7.0            
#>  [49] httr_1.4.4             ellipsis_0.3.2         pkgconfig_2.0.3       
#>  [52] XML_3.99-0.12          farver_2.1.1           sass_0.4.2            
#>  [55] dbplyr_2.2.1           utf8_1.2.2             tidyselect_1.2.0      
#>  [58] labeling_0.4.2         rlang_1.0.6            AnnotationDbi_1.60.0  
#>  [61] munsell_0.5.0          tools_4.2.1            cachem_1.0.6          
#>  [64] cli_3.4.1              generics_0.1.3         RSQLite_2.2.18        
#>  [67] broom_1.0.1            evaluate_0.17          stringr_1.4.1         
#>  [70] fastmap_1.1.0          yaml_2.3.6             bootstrap_2019.6      
#>  [73] knitr_1.40             bit64_4.0.5            survMisc_0.5.6        
#>  [76] purrr_0.3.5            KEGGREST_1.38.0        future_1.28.0         
#>  [79] xml2_1.3.3             compiler_4.2.1         filelock_1.0.2        
#>  [82] curl_4.3.3             png_0.1-7              ggsignif_0.6.4        
#>  [85] tibble_3.1.8           bslib_0.4.0            stringi_1.7.8         
#>  [88] highr_0.9              lattice_0.20-45        Matrix_1.5-1          
#>  [91] commonmark_1.8.1       markdown_1.3           survivalROC_1.0.3     
#>  [94] KMsurv_0.1-5           vctrs_0.5.0            pillar_1.8.1          
#>  [97] lifecycle_1.0.3        BiocManager_1.30.19    jquerylib_0.1.4       
#> [100] data.table_1.14.4      bitops_1.0-7           R6_2.5.1              
#> [103] bookdown_0.29          KernSmooth_2.23-20     gridExtra_2.3         
#> [106] IRanges_2.32.0         parallelly_1.32.1      codetools_0.2-18      
#> [109] assertthat_0.2.1       withr_2.5.0            S4Vectors_0.36.0      
#> [112] GenomeInfoDbData_1.2.9 ggtext_0.1.2           parallel_4.2.1        
#> [115] hms_1.1.2              grid_4.2.1             nsga2R_1.1            
#> [118] tidyr_1.2.1            class_7.3-20           rmarkdown_2.17        
#> [121] mco_1.15.6             carData_3.0-5          rmeta_3.0