Files
obitools4/autodoc/docmd/pkg/obigraph/graph.md
T
Eric Coissac 8c7017a99d ⬆️ version bump to v4.5
- Update obioptions.Version from "Release 4.4.29" to "/v/ Release v5"
- Update version.txt from 4.29 → .30
(automated by Makefile)
2026-04-13 13:34:53 +02:00

31 lines
1.8 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
# `obigraph` Package: Semantic Overview
The `obigraph` package provides a generic, type-safe undirected/directed graph implementation in Go. Its core features include:
- **Generic Graph Structure**: Parametrized over vertex type `V` and edge data type `T`, enabling flexible use with arbitrary user-defined types.
- **Bidirectional Edge Tracking**: Maintains both forward (`Edges`) and reverse (`ReverseEdges`) adjacency maps for efficient neighbor/parent queries.
- **Edge Management**:
- `AddEdge`: Adds an *undirected* edge (inserted in both directions).
- `AddDirectedEdge`: Adds a *directed* edge (only one direction).
- `SetAsDirectedEdge`: Converts an existing undirected edge into a directed one by removing the reverse link.
- **Graph Queries**:
- `Neighbors(v)`: Returns all adjacent vertices (outgoing in directed case).
- `Parents(v)`: Returns incoming neighbors via reverse adjacency.
- `Degree(v)` / `ParentDegree(v)`: Compute vertex degrees (total or incoming).
- **Customizable Vertex/Edge Properties**:
- `VertexWeight`, `EdgeWeight`: Funcs to assign weights (default: constant weight = 1.0).
- `VertexId`: Custom vertex label generator (default: `"V%d"`).
- **GML Export**:
- `Gml(...)` / `WriteGml(...)`: Generates or writes a Graph Modelling Language (GML) representation.
- Supports directed/undirected modes, degree-based filtering (`min_degree`), and visual styling:
- Vertex shape: `circle` if weight ≥ threshold, else `rectangle`.
- Size scaled by square root of vertex weight.
- Uses Gos `text/template` for rendering.
- **File I/O**: Directly writes GML to file via `WriteGmlFile(...)`.
- **Logging & Safety**: Uses Logrus for bounds-checking errors; panics on template parsing/writing failures.
The package is designed for lightweight, high-performance graph modeling and visualization-ready export.