graph alternatives and similar packages
Based on the "Science and Data Analysis" category.
Alternatively, view graph alternatives based on common mentions on social networks and blogs.

gonum
Gonum is a set of numeric libraries for the Go programming language. It contains libraries for matrices, statistics, optimization, and more 
Stats
A well tested and comprehensive Golang statistics library package with no dependencies. 
gosl
Linear algebra, eigenvalues, FFT, Bessel, elliptic, orthogonal polys, geometry, NURBS, numerical quadrature, 3D transfinite interpolation, random numbers, Mersenne twister, probability distributions, optimisation, differential equations. 
dataframego
DataFrames for Go: For statistics, machinelearning, and data manipulation/exploration 
gonum/mat64
The general purpose package for matrix computation. Package mat64 provides basic linear algebra operations for float64 matrices. 
calendarheatmap
đź“… Calendar heatmap inspired by GitHub contribution activity 
TextRank
:wink: :cyclone: :strawberry: TextRank implementation in Golang with extendable features (summarization, phrase extraction) and multithreading (goroutine). 
sparse
Sparse matrix formats for linear algebra supporting scientific and machine learning applications 
evaler
Implements a simple floating point arithmetic expression evaluator in Go (golang). 
triangolatte
2D triangulation library. Allows translating lines and polygons (both based on points) to the language of GPUs. 
piecewiselinear
tiny linear interpolation library for go (factored out from https://github.com/sgreben/yeetgif) 
PiHex
PiHex Library, written in Go, generates a hexadecimal number sequence in the number Pi in the range from 0 to 10,000,000. 
GoStats
GoStats is a go library for math statistics mostly used in ML domains, it covers most of the statistical measures functions. 
assocentity
Package assocentity returns the average distance from words to a given entity and its synonyms 
mudlarkgo
A collection of packages providing (hopefully) useful code for use in software using Google's Go programming language.
Build timeseriesbased applications quickly and at scale.
Do you think we are missing an alternative of graph or a related project?
Popular Comparisons
README
Your basic graph
Golang library of basic graph algorithms
[Topological ordering](top.png)
Topological ordering, image by David Eppstein, CC0 1.0.
This library offers efficient and welltested algorithms for
 breadthfirst and depthfirst search,
 topological ordering,
 strongly and weakly connected components,
 bipartion,
 shortest paths,
 maximum flow,
 Euler walks,
 and minimum spanning trees.
The algorithms can be applied to any graph data structure implementing
the two Iterator
methods: Order
, which returns the number of vertices,
and Visit
, which iterates over the neighbors of a vertex.
All algorithms operate on directed graphs with a fixed number of vertices, labeled from 0 to n1, and edges with integer cost. An undirected edge {v, w} of cost c is represented by the two directed edges (v, w) and (w, v), both of cost c. A selfloop, an edge connecting a vertex to itself, is both directed and undirected.
Graph data structures
The type Mutable
represents a directed graph with a fixed number
of vertices and weighted edges that can be added or removed.
The implementation uses hash maps to associate each vertex
in the graph with its adjacent vertices. This gives constant
time performance for all basic operations.
The type Immutable
is a compact representation of an immutable graph.
The implementation uses lists to associate each vertex in the graph
with its adjacent vertices. This makes for fast and predictable
iteration: the Visit method produces its elements by reading
from a fixed sorted precomputed list.
Virtual graphs
The subpackage graph/build
offers a tool for building graphs of type Virtual
.
In a virtual graph no vertices or edges are stored in memory, they are instead computed as needed. New virtual graphs are constructed by composing and filtering a set of standard graphs, or by writing functions that describe the edges of a graph.
The following standard graphs are predefined:
 empty graphs,
 complete graphs and complete bipartite graphs,
 grid graphs and complete kary trees,
 cycle graphs and circulant graphs,
 and hypergraphs.
The following operations are supported:
 adding and deleting sets of edges,
 adding cost functions,
 filtering graphs by edge functions,
 complement, intersection and union,
 subgraphs,
 connecting graphs at a single vertex,
 joining two graphs by a set of edges,
 matching two graphs by a set of edges,
 cartesian product and tensor product.
Nonvirtual graphs can be imported, and used as building blocks,
by the Specific
function. Virtual graphs don't need to be â€śexportedâ€¬â€ť;
they implement the Iterator
interface and hence can be used directly
by any algorithm in the graph package.
Installation
Once you have installed Go, run this command
to install the graph
package:
go get github.com/yourbasic/graph
Documentation
There is an online reference for the package at godoc.org/github.com/yourbasic/graph.
Roadmap
 The API of this library is frozen.
 Bug fixes and performance enhancement can be expected.
 New functionality might be included.
 Version numbers adhere to semantic versioning.
The only accepted reason to modify the API of this package is to handle issues that can't be resolved in any other reasonable way.
New features and performance enhancements are limited to basic algorithms and data structures, akin to the ones that you might find in a computer science textbook.
Stefan Nilsson â€“ korthaj