Skip to main content

Universal Hyperbolic Geometry Library

Project description

UHG-Based Anomaly Detection

This repository contains an implementation of anomaly detection using Universal Hyperbolic Geometry (UHG) principles. The code leverages the UHG library to perform geometric operations in hyperbolic space.

Overview

Universal Hyperbolic Geometry (UHG) provides a powerful framework for representing complex hierarchical data. This implementation uses UHG principles to detect anomalies in network traffic data by embedding the data in hyperbolic space and identifying points that deviate from the normal patterns.

Key Features

  • UHG-based graph neural network for anomaly detection
  • Efficient implementation of UHG operations using the UHG library
  • Support for large-scale datasets through batched processing
  • Visualization tools for analyzing embeddings and anomaly scores

Installation

  1. Clone this repository:
git clone https://github.com/yourusername/uhg-anomaly-detection.git
cd uhg-anomaly-detection
  1. Install the required dependencies:
pip install -r requirements.txt

Usage

Basic Usage

from uhg_anomaly_detection_refactored import load_and_preprocess_data, create_graph_data, UHGGraphNN, UHGAnomalyLoss

# Load and preprocess data
features, labels, feature_info = load_and_preprocess_data("your_data.csv")

# Create graph data
graph_data = create_graph_data(features, labels, k=5)

# Create model
model = UHGGraphNN(
    in_channels=features.shape[1],
    hidden_channels=64,
    embedding_dim=32,
    num_layers=2,
    dropout=0.2
)

# Create loss function
criterion = UHGAnomalyLoss(spread_weight=0.1, quad_weight=1.0, margin=1.0)

# Create optimizer
optimizer = torch.optim.Adam(model.parameters(), lr=0.001, weight_decay=1e-5)

# Train the model
model.train()
for epoch in range(100):
    optimizer.zero_grad()
    z = model(graph_data.x, graph_data.edge_index)
    loss = criterion(z, graph_data.edge_index)
    loss.backward()
    optimizer.step()
    print(f"Epoch {epoch+1}, Loss: {loss.item():.4f}")

# Generate embeddings
model.eval()
with torch.no_grad():
    embeddings = model(graph_data.x, graph_data.edge_index).cpu().numpy()

Using UHG Utilities Directly

The uhg_utils.py file provides a clean interface to the UHG library. You can use these utilities in your own code:

from uhg_utils import uhg_quadrance, uhg_spread, uhg_cross_ratio, to_uhg_space

# Convert points to UHG space
points = to_uhg_space(your_data)

# Compute quadrance (UHG distance) between points
distance = uhg_quadrance(points[0], points[1])

# Compute spread (UHG angle) between lines
spread = uhg_spread(line1, line2)

# Compute cross-ratio of four points
cr = uhg_cross_ratio(p1, p2, p3, p4)

File Structure

  • uhg_utils.py: Utility functions that provide a clean interface to the UHG library
  • uhg_anomaly_detection_refactored.py: Main implementation of UHG-based anomaly detection
  • requirements.txt: List of required dependencies

UHG Library Integration

This implementation uses the UHG library for core geometric operations. The uhg_utils.py file serves as a bridge between the application code and the UHG library, providing a clean interface and handling edge cases.

Key UHG operations used:

  • quadrance: Computes the squared distance between points in hyperbolic space
  • spread: Computes the squared angle between lines in hyperbolic space
  • cross_ratio: Computes the cross-ratio of four points, a projective invariant
  • normalize_points: Normalizes points according to UHG conventions
  • join_points: Computes the line joining two points
  • meet_line_point: Computes the intersection of a line and a point

References

  • Norman J. Wildberger, "Universal Hyperbolic Geometry I: Trigonometry", Geometriae Dedicata, 2013
  • Norman J. Wildberger, "Universal Hyperbolic Geometry II: A pictorial overview", KoG, 2013
  • Norman J. Wildberger, "Universal Hyperbolic Geometry III: First Steps in Projective Triangle Geometry", KoG, 2014

License

MIT License

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

uhg-0.3.5.tar.gz (378.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

uhg-0.3.5-py3-none-any.whl (84.2 kB view details)

Uploaded Python 3

File details

Details for the file uhg-0.3.5.tar.gz.

File metadata

  • Download URL: uhg-0.3.5.tar.gz
  • Upload date:
  • Size: 378.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.10

File hashes

Hashes for uhg-0.3.5.tar.gz
Algorithm Hash digest
SHA256 a889aa8f227007896054385dd34b13067ebaddf3b754959f887fd690256a6f40
MD5 9d4588a780bb74766601918d020c0e37
BLAKE2b-256 06a53ce6d6603992cb8624e17c438ea7648060ce7cd1886aa00a59456400dfbd

See more details on using hashes here.

File details

Details for the file uhg-0.3.5-py3-none-any.whl.

File metadata

  • Download URL: uhg-0.3.5-py3-none-any.whl
  • Upload date:
  • Size: 84.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.10

File hashes

Hashes for uhg-0.3.5-py3-none-any.whl
Algorithm Hash digest
SHA256 4d66cebda3129584512af1370106f487ae9fcc8e0e235177e9b55f0fa7212178
MD5 21e4354b56ba808b0c3cf07ec81ec32f
BLAKE2b-256 7047c98d1aae2675f69109ab28de1ab8607be53657c45ac167c22a8a536cd84e

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page