The HVT package is a collection of R functions to facilitate building topology preserving maps for rich multivariate data analysis, see Figure 1
as an example of a 3D torus map generated from the package. Tending towards a big data preponderance, a large number of rows. A collection of R functions for this typical workflow is organized below:
Data Compression: Vector quantization (VQ), HVQ (hierarchical vector quantization) using means or medians. This step compresses the rows (long data frame) using a compression objective.
Data Projection: Dimension projection of the compressed cells to 1D,2D or Interactive surface plot with the Sammons Non-linear Algorithm. This step creates topology preserving map (also called mathematical embeddings) coordinates into the desired output dimension.
Tessellation: Create cells required for object visualization using the Voronoi Tessellation method, package includes heatmap plots for hierarchical Voronoi tessellations (HVT). This step enables data insights, visualization, and interaction with the topology preserving map useful for semi-supervised tasks.
Scoring: Scoring new data sets or test data and recording their assignment using the map objects from the above steps, in a sequence of maps if required.
Temporal Analysis and Visualization: A Collection of new functions that leverages the capacity of the HVT package by analyzing time series data for its underlying patterns, calculation of transitioning probabilities and the visualizations for the flow of data over time.
The HVT package allows creation of visually stunning tessellations, showcasing the power of topology preserving maps. below is an image depicting a captivating tessellation of a torus.
Following are the links to the vignettes for the HVT package:
HVT Vignette: Contains descriptions of the functions used for vector quantization and construction of Hierarchical Voronoi Tessellations for data analysis.
HVT Model Diagnostics Vignette: Contains descriptions of functions used to perform model diagnostics and validation for the HVT model.
HVT Scoring Cells with Layers using scoreLayeredHVT: Contains descriptions of the functions used for scoring cells with layers based on a sequence of maps using scoreLayeredHVT.
Temporal Analysis and Visualization: Leveraging Time Series Capabilities in HVT: Contains descriptions of the functions used for analyzing time series data and its flow maps.
Visualizing LLM Embeddings using HVT (Hierarchical Voronoi Tessellation): Contains the implementation and analysis of hierarchical clustering using the clustHVT
function to evaluate and visualize token embeddings generated by OpenAI.
Implementation of t-SNE and UMAP in trainHVT function: Contains enhancements to the trainHVT
function with advanced dimensionality reduction techniques such as t-SNE and UMAP, and includes a table of evaluation metrics to improve analysis, visualization, and interpretability.
4th September, 2024
In this version of the HVT package, the following new features and vignettes have been introduced:
Features
Implementation of t-SNE and UMAP in trainHVT
: This update incorporates dimensionality reduction methods like t-SNE and UMAP in the trainHVT
function, complementing the existing Sammon’s projection. It also enables the visualization of these techniques across all hierarchical levels within the HVT framework.
Implementation of dimensionality reduction evaluation metrics: This update introduces highly effective dimensionality reduction evaluation metrics as part of the output list of the trainHVT
function. These metrics are organized into two levels: Level 1 (L1) and Level 2 (L2). The L1 metrics address key areas of dimensionality reduction which are mentioned below, by ensuring comprehensive evaluation and performance.
clustHVT
function: In this update, we introduced a new function called clustHVT
specifically designed for Hierarchical clustering analysis. The function performs clustering of cells exclusively when the hierarchy level is set to 1, determining the optimal number of clusters by evaluating various indices. Based on user input, it conducts hierarchical clustering using AGNES with the default ward.D2 method. The output includes a dendrogram and an interactive 2D clustered HVT map that reveals cell context upon hovering. This function is not applicable when the hierarchy level is greater than 1.Vignettes
Implementation of t-SNE and UMAP in trainHVT
function: This vignette showcases the integration of t-SNE and UMAP in the trainHVT
function, offering a comprehensive guide on how to apply and visualize these dimensionality reduction techniques. It also covers the dimensionality reduction evaluation metrics and provides insights into their interpretation.
Visualizing LLM Embeddings using HVT (Hierarchical Voronoi Tessellation): This vignette will outline the process of analyzing OpenAI-generated token embeddings using the HVT package, covering data compression, visualization, and hierarchical clustering, as well as comparing domain name assignments for clusters. It examines HVT’s effectiveness in preserving contextual relationships between embeddings. Additionally, it provides a brief overview of the newly added clustHVT
function and its parameters.
2nd May, 2024
In this version of the HVT package, the following new features have been introduced:
HVT
to trainHVT
predictHVT
to scoreHVT
predictLayerHVT
to scoreLayeredHVT
trainHVT
function now resides within the Training_or_Compression
section.plotHVT
function now resides within the Tessellation_and_Heatmap
section.scoreHVT
function now resides within the Scoring
section.Enhancements: The pre-existed functions, hvtHmap
and exploded_hmap
, have been combined and incorporated into the plotHVT
function. Additionally, plotHVT
now includes the ability to perform 1D plotting.
Temporal Analysis
Below are the new functions and their brief descriptions:
plotStateTransition
: Provides the time series flowmap plot.getTransitionProbability
: Provides a list of transition probabilities.reconcileTransitionProbability
: Provides plots and tables for comparing transition probabilities calculated manually and from markovchain function.plotAnimatedFlowmap
: Creates flowmaps and animations for both self state and without self state scenarios.17th November, 2023
This version of the HVT package offers functionality to score cells with layers based on a sequence of maps created using scoreLayeredHVT
. Given below are the steps to create the successive set of maps.
Map A - The output of trainHVT
function which is trained on parent data.
Map B - The output of trainHVT
function which is trained on the ‘data with novelty’ created from removeNovelty
function.
Map C - The output of trainHVT
function which is trained on the ‘data without novelty’ created from removeNovelty
function.
The scoreLayeredHVT
function uses these three maps to score the test datapoints.
Let us try to understand the steps with the help of the diagram below
06th December, 2022
This version of the HVT package offers features for both training an HVT model and eliminating outlier cells from the trained model.
Training or Compression: The initial step entails training the parent data using the trainHVT
function, specifying the desired compression percentage and quantization error.
Remove novelty cells: Following the training process, outlier cells can be identified manually from the 2D hvt plot. These outlier cells can then be inputted into the removeNovelty
function, which subsequently produces two datasets in its output: one containing ‘data with novelty’ and the other containing ‘data without novelty’.
library(devtools)
::install_github(repo = "Mu-Sigma/HVT") devtools