MyNixOS website logo
Description

Constructing Hierarchical Voronoi Tessellations and Overlay Heatmaps for Data Analysis.

Facilitates building topology preserving maps for rich multivariate data. Credits to Mu Sigma for their continuous support throughout the development of the package.

HVT: Collection of functions used to build hierarchical topology preserving maps

Zubin Dowlaty

2024-05-02

1. Abstract

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 2D 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:

  1. 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.

  2. 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 an embedding) coordinates into the desired output dimension.

  3. 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.

  4. Scoring: Scoring new data sets and recording their assignment using the map objects from the above steps, in a sequence of maps if required.

  5. 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, see vignette for more details.

Figure 1: The Voronoi tessellation for layer 1 and number of cells 900 with the heat map overlaid for variable z.

2. Vignettes

Following are the links to the vignettes for the HVT package:

2.1 HVT Vignette

HVT Vignette: Contains descriptions of the functions used for vector quantization and construction of hierarchical voronoi tessellations for data analysis.

2.2 HVT Model Diagnostics Vignette

HVT Model Diagnostics Vignette: Contains descriptions of functions used to perform model diagnostics and validation for HVT model.

2.3 HVT Scoring Cells with Layers using scoreLayeredHVT

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.

2.4 Temporal Analysis and Visualization: Leveraging Time Series Capabilities in HVT

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.

3. Version History

HVT (v24.5.2)

2nd May, 2024

In this version of HVT package, the following new features have been introduced:

  1. Updated Nomenclature: To make the function names more consistent and understandable/intuitive, we have renamed the functions throughout the package. Given below are the few instances.
  • HVT to trainHVT
  • predictHVT to scoreHVT
  • predictLayerHVT to scoreLayeredHVT
  1. Restructured Functions: The functions have been rearranged and grouped into new sections which are highlighted on the index page of package’s PDF documentation. Given below are the few instances.
  • 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.
  1. 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.

  2. Temporal Analysis

  • The new update focuses on the integration of time series capabilities into the HVT package by extending its foundational operations to time series data which is emphasized in this vignette.
  • The new functionalities are introduced to analyze underlying patterns and trends within the data, providing insights into its evolution over time and also offering the capability to analyze the movement of the data by calculating its transitioning probability and creates elegant plots and GIFs.

Below are the new functions and its 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.

HVT (v23.11.02)

17th November, 2023

This version of HVT package offers functionality to score cells with layers based on a sequence of maps created using scoreLayeredHVT. Given below are the steps to created the successive set of maps.

  1. Map A - The output of trainHVT function which is trained on parent data.

  2. Map B - The output of trainHVT function which is trained on the 'data with novelty' created from removeNovelty function.

  3. 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

Figure 2: Data Segregation for scoring based on a sequence of maps using scoreLayeredHVT()

HVT (v22.12.06)

06th December, 2022

This version of HVT package offers features for both training an HVT model and eliminating outlier cells from the trained model.

  1. Training or Compression: The initial step entails training the parent data using the trainHVT function, specifying the desired compression percentage and quantization error.

  2. 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'.

4. Installation of HVT (v24.5.2)

library(devtools)
devtools::install_github(repo = "Mu-Sigma/HVT")
Metadata

Version

24.5.2

License

Unknown

Platforms (75)

    Darwin
    FreeBSD
    Genode
    GHCJS
    Linux
    MMIXware
    NetBSD
    none
    OpenBSD
    Redox
    Solaris
    WASI
    Windows
Show all
  • aarch64-darwin
  • aarch64-genode
  • aarch64-linux
  • aarch64-netbsd
  • aarch64-none
  • aarch64_be-none
  • arm-none
  • armv5tel-linux
  • armv6l-linux
  • armv6l-netbsd
  • armv6l-none
  • armv7a-darwin
  • armv7a-linux
  • armv7a-netbsd
  • armv7l-linux
  • armv7l-netbsd
  • avr-none
  • i686-cygwin
  • i686-darwin
  • i686-freebsd
  • i686-genode
  • i686-linux
  • i686-netbsd
  • i686-none
  • i686-openbsd
  • i686-windows
  • javascript-ghcjs
  • loongarch64-linux
  • m68k-linux
  • m68k-netbsd
  • m68k-none
  • microblaze-linux
  • microblaze-none
  • microblazeel-linux
  • microblazeel-none
  • mips-linux
  • mips-none
  • mips64-linux
  • mips64-none
  • mips64el-linux
  • mipsel-linux
  • mipsel-netbsd
  • mmix-mmixware
  • msp430-none
  • or1k-none
  • powerpc-netbsd
  • powerpc-none
  • powerpc64-linux
  • powerpc64le-linux
  • powerpcle-none
  • riscv32-linux
  • riscv32-netbsd
  • riscv32-none
  • riscv64-linux
  • riscv64-netbsd
  • riscv64-none
  • rx-none
  • s390-linux
  • s390-none
  • s390x-linux
  • s390x-none
  • vc4-none
  • wasm32-wasi
  • wasm64-wasi
  • x86_64-cygwin
  • x86_64-darwin
  • x86_64-freebsd
  • x86_64-genode
  • x86_64-linux
  • x86_64-netbsd
  • x86_64-none
  • x86_64-openbsd
  • x86_64-redox
  • x86_64-solaris
  • x86_64-windows