vignettes/v06_group_similarity.Rmd
v06_group_similarity.Rmd
The methods of group similarity implemented in simona are mainly from the supplementary file of the paper “Mazandu et al., Gene Ontology semantic similarity tools: survey on features and challenges for biological knowledge discovery. Briefings in Bioinformatics 2017”. Original denotations have been slightly modified to make them more consistent. Also more explanations have been added in this vignette.
There are two groups of terms denoted as and represented as two sets:
$$ T_p = \{ a_1, a_2, ...\} \\ T_q = \{ b_1, b_2, ... \} $$
where is a term in set and is a term in set .
The wrapper function group_sim()
calculates semantic similarities between two groups of terms with a specific method. Note the method name can be partially matched.
group_sim(dag, group1, group2, method = ..., control = list(...))
Some of the group similarity methods have no assumption of which similarity measure between single terms to use. If there are annotation already provided in the DAG object, by default Sim_Lin_1998 is used, or else Sim_WP_1994 is used. The term similarity method can be set via the term_sim_method
parameter in control
. Additionally parameters for a specific term_sim_method
can also be set in control
.
group_sim(dag, group1, group2, method = ..., control = list(term_sim_method = ...))
All supported group similarity methods are:
## [1] "GroupSim_pairwise_avg" "GroupSim_pairwise_max"
## [3] "GroupSim_pairwise_BMA" "GroupSim_pairwise_BMM"
## [5] "GroupSim_pairwise_ABM" "GroupSim_pairwise_HDF"
## [7] "GroupSim_pairwise_MHDF" "GroupSim_pairwise_VHDF"
## [9] "GroupSim_pairwise_Froehlich_2007" "GroupSim_pairwise_Joeng_2014"
## [11] "GroupSim_SimALN" "GroupSim_SimGIC"
## [13] "GroupSim_SimDIC" "GroupSim_SimUIC"
## [15] "GroupSim_SimUI" "GroupSim_SimDB"
## [17] "GroupSim_SimUB" "GroupSim_SimNTO"
## [19] "GroupSim_SimCOU" "GroupSim_SimCOT"
## [21] "GroupSim_SimLP" "GroupSim_Ye_2005"
## [23] "GroupSim_SimCHO" "GroupSim_SimALD"
## [25] "GroupSim_Jaccard" "GroupSim_Dice"
## [27] "GroupSim_Overlap" "GroupSim_Kappa"
Denote as the semantic similarity between term and where is from group and is from group , The similarity between group and group is the average similarity of every pair of individual terms in the two groups:
The term semantic similarity method and the IC method can be set via control
argument, for example:
group_sim(dag, group1, group2, method = "GroupSim_pairwise_avg" control = list(term_sim_method = "Sim_Lin_1998", IC_method = "IC_annotation")`.
Other parameters for the term_sim_method
can also be set in the control
list.
Paper link: https://doi.org/10.1093/bioinformatics/btg153.
The similarity is defined as the maximal among all pairs of terms in group and :
The term semantic similarity method and the IC method can be set via control
argument, for example:
group_sim(dag, group1, group2, method = "GroupSim_pairwise_max" control = list(term_sim_method = "Sim_Lin_1998", IC_method = "IC_annotation")`.
Other parameters for the term_sim_method
can also be set in the control
list.
Paper link: https://doi.org/10.1109/TCBB.2005.50.
BMA stands for “best-match average”. First define similarity of a term to a group of terms as
which corresponds to the most similar term in to . Then the BMA similarity is calculated as:
The term semantic similarity method and the IC method can be set via control
argument, for example:
group_sim(dag, group1, group2, method = "GroupSim_pairwise_BMA" control = list(term_sim_method = "Sim_Lin_1998", IC_method = "IC_annotation")`.
Other parameters for the term_sim_method
can also be set in the control
list.
Paper link: https://doi.org/10.1155/2012/975783.
BMM stands for “best-match max”. It is defined as:
The term semantic similarity method and the IC method can be set via control
argument, for example:
group_sim(dag, group1, group2, method = "GroupSim_pairwise_BMM" control = list(term_sim_method = "Sim_Lin_1998", IC_method = "IC_annotation")`.
Other parameters for the term_sim_method
can also be set in the control
list.
Paper link: https://doi.org/10.1186/1471-2105-7-302.
ABM stands for “average best-match”. It is defined as:
The term semantic similarity method and the IC method can be set via control
argument, for example:
group_sim(dag, group1, group2, method = "GroupSim_pairwise_ABM" control = list(term_sim_method = "Sim_Lin_1998", IC_method = "IC_annotation")`.
Other parameters for the term_sim_method
can also be set in the control
list.
Paper link: https://doi.org/10.1186/1471-2105-14-284.
First define the distance of a term to a group of terms :
Then the Hausdorff distance between two groups are:
This final similarity is:
The term semantic similarity method and the IC method can be set via control
argument, for example:
group_sim(dag, group1, group2, method = "GroupSim_pairwise_HDF" control = list(term_sim_method = "Sim_Lin_1998", IC_method = "IC_annotation")`.
Other parameters for the term_sim_method
can also be set in the control
list.
Instead of using the maximal distance from a group to the other group, MHDF uses mean distance:
This final similarity is:
The term semantic similarity method and the IC method can be set via control
argument, for example:
group_sim(dag, group1, group2, method = "GroupSim_pairwise_MHDF" control = list(term_sim_method = "Sim_Lin_1998", IC_method = "IC_annotation")`.
Other parameters for the term_sim_method
can also be set in the control
list.
Paper link: https://doi.org/10.1109/ICPR.1994.576361.
It is defined as:
This final similarity is:
The term semantic similarity method and the IC method can be set via control
argument, for example:
group_sim(dag, group1, group2, method = "GroupSim_pairwise_VHDF" control = list(term_sim_method = "Sim_Lin_1998", IC_method = "IC_annotation")`.
Other parameters for the term_sim_method
can also be set in the control
list.
Paper link: https://doi.org/10.1073/pnas.0702965104.
The similarity is:
The term semantic similarity method and the IC method can be set via control
argument, for example:
group_sim(dag, group1, group2, method = "GroupSim_pairwise_Froehlich_2007" control = list(term_sim_method = "Sim_Lin_1998", IC_method = "IC_annotation")`.
Other parameters for the term_sim_method
can also be set in the control
list.
Paper link: https://doi.org/10.1186/1471-2105-8-166.
Similar to VHDF, but it directly uses the similarity:
The term semantic similarity method and the IC method can be set via control
argument, for example:
group_sim(dag, group1, group2, method = "GroupSim_pairwise_Joeng_2014" control = list(term_sim_method = "Sim_Lin_1998", IC_method = "IC_annotation")`.
Other parameters for the term_sim_method
can also be set in the control
list.
Paper link: https://doi.org/10.1109/tcbb.2014.2343963.
It is based on the average distance between every pair of terms in the two groups:
Or use the longest distance between two terms:
There is a parameter distance which takes value of "longest_distances_via_LCA"
(the default) or "shortest_distances_via_NCA"
:
group_sim(dag, group1, group2, method = "GroupSim_SimALN", control = list(distance = "shortest_distances_via_NCA"))
Paper link: https://doi.org/10.1109/CBMS.2008.27.
This category of methods depend on the IC of terms in the two groups as well as their ancestor terms.
Denote and as the two sets of ancestors of terms in group and respectively:
The GroupSim_SimGIC, GroupSim_SimDIC and GroupSim_SimUIC are very similar. They are based on the IC of the ancestor terms, defined as:
IC method can be set via the control
argument. By default if there is annotation associated, IC_annotation is used, or else IC_offspring is used.
group_sim(dag, group1, group2, method = "GroupSim_SimGIC", control = list(IC_method = ...))
These four methods are based on the counts of ancestor terms:
group_sim(dag, group1, group2, method = "GroupSim_SimUI")
Let’s write and as two vectors and . Taking as an example, it is where is the number of total terms in the DAG. The value is assigned to the corresponding term and is defined as:
The semantic similarity is defined as the cosine similarity between the two vectors:
It can also be written as:
IC method can be set via the control
argument. By default if there is annotation associated, IC_annotation is used, or else IC_offspring is used.
group_sim(dag, group1, group2, method = "GroupSim_SimCOU", control = list(IC_method = ...))
It is the largest depth of terms in .
group_sim(dag, group1, group2, method = "GroupSim_SimLP")
It is a normalized version of GroupSim_SimLP:
Since the minimal depth is zero for root.
group_sim(dag, group1, group2, method = "GroupSim_Ye_2005")
Paper link: https://doi.org/10.1038/msb4100034.
This category of methods consider the items annotated to the two groups of terms.
It is based on the annotated items. Denote as the total number of annotated items of (after merging all its offspring terms). The similarity is calculated as:
where , is the minimal number of annotated items in the DAG which in most cases is 1, is the maximal number of annotated items, which is the total number of items annotated to the complete DAG.
The similarity can also be written in form of :
group_sim(dag, group1, group2, method = "GroupSim_SimCHO")
Since and are two sets, the Kappa coeffcient, Jaccard coeffcient, Dice coeffcient and overlap coeffcient can be naturally used.
group_sim(dag, group1, group2, method = "GroupSim_Jaccard", control = list(universe = ...)) group_sim(dag, group1, group2, method = "GroupSim_Dice", control = list(universe = ...)) group_sim(dag, group1, group2, method = "GroupSim_Overlap", control = list(universe = ...)) group_sim(dag, group1, group2, method = "GroupSim_Kappa", control = list(universe = ...))
## R version 4.4.1 (2024-06-14)
## Platform: x86_64-apple-darwin20
## Running under: macOS Sonoma 14.5
##
## Matrix products: default
## BLAS: /Library/Frameworks/R.framework/Versions/4.4-x86_64/Resources/lib/libRblas.0.dylib
## LAPACK: /Library/Frameworks/R.framework/Versions/4.4-x86_64/Resources/lib/libRlapack.dylib; LAPACK version 3.12.0
##
## locale:
## [1] en_GB.UTF-8/en_GB.UTF-8/en_GB.UTF-8/C/en_GB.UTF-8/en_GB.UTF-8
##
## time zone: Europe/Berlin
## tzcode source: internal
##
## attached base packages:
## [1] stats graphics grDevices utils datasets methods base
##
## other attached packages:
## [1] simona_1.3.12 knitr_1.48
##
## loaded via a namespace (and not attached):
## [1] sass_0.4.9 xml2_1.3.6 shape_1.4.6.1
## [4] digest_0.6.37 magrittr_2.0.3 evaluate_0.24.0
## [7] grid_4.4.1 RColorBrewer_1.1-3 iterators_1.0.14
## [10] circlize_0.4.16 fastmap_1.2.0 foreach_1.5.2
## [13] doParallel_1.0.17 jsonlite_1.8.8 GlobalOptions_0.1.2
## [16] promises_1.3.0 ComplexHeatmap_2.20.0 codetools_0.2-20
## [19] textshaping_0.4.0 jquerylib_0.1.4 cli_3.6.3
## [22] shiny_1.9.1 rlang_1.1.4 crayon_1.5.3
## [25] scatterplot3d_0.3-44 cachem_1.1.0 yaml_2.3.10
## [28] tools_4.4.1 parallel_4.4.1 colorspace_2.1-1
## [31] httpuv_1.6.15 GetoptLong_1.0.5 BiocGenerics_0.50.0
## [34] mime_0.12 R6_2.5.1 png_0.1-8
## [37] matrixStats_1.3.0 stats4_4.4.1 lifecycle_1.0.4
## [40] S4Vectors_0.42.1 fs_1.6.4 htmlwidgets_1.6.4
## [43] IRanges_2.38.1 clue_0.3-65 ragg_1.3.2
## [46] cluster_2.1.6 pkgconfig_2.0.3 desc_1.4.3
## [49] pkgdown_2.1.0 bslib_0.8.0 later_1.3.2
## [52] Rcpp_1.0.13 systemfonts_1.1.0 xfun_0.47
## [55] xtable_1.8-4 rjson_0.2.22 htmltools_0.5.8.1
## [58] igraph_2.0.3 rmarkdown_2.28 Polychrome_1.5.1
## [61] compiler_4.4.1