onesparse
one_sparse : Sparse linear algebra and graph extension for PostgreSQL 18
Overview
| ID | Extension | Package | Version | Category | License | Language |
|---|---|---|---|---|---|---|
| 2620 | onesparse
|
one_sparse
|
1.0.0 |
FEAT
|
Apache-2.0
|
C
|
| Attribute | Has Binary | Has Library | Need Load | Has DDL | Relocatable | Trusted |
|---|---|---|---|---|---|---|
--s-d--
|
No
|
Yes
|
No
|
Yes
|
no
|
no
|
| Relationships | |
|---|---|
| Schemas | onesparse |
| See Also | age
pgrouting
postgis
|
PG18 only; upstream release v1.0.0 ships extension SQL version 0.1.0
Packages
| Type | Repo | Version | PG Major Compatibility | Package Pattern | Dependencies |
|---|---|---|---|---|---|
| EXT | PIGSTY
|
1.0.0 |
18
17
16
15
14
|
one_sparse |
- |
| RPM | PIGSTY
|
1.0.0 |
18
17
16
15
14
|
onesparse_$v |
graphblas, lagraph |
| DEB | PIGSTY
|
1.0.0 |
18
17
16
15
14
|
postgresql-$v-onesparse |
libgraphblas10, liblagraph1, liblagraphx1 |
| Linux / PG | PG18 | PG17 | PG16 | PG15 | PG14 |
|---|---|---|---|---|---|
el8.x86_64
|
PIGSTY 1.0.0
|
MISS
|
MISS
|
MISS
|
MISS
|
el8.aarch64
|
PIGSTY 1.0.0
|
MISS
|
MISS
|
MISS
|
MISS
|
el9.x86_64
|
PIGSTY 1.0.0
|
MISS
|
MISS
|
MISS
|
MISS
|
el9.aarch64
|
PIGSTY 1.0.0
|
MISS
|
MISS
|
MISS
|
MISS
|
el10.x86_64
|
PIGSTY 1.0.0
|
MISS
|
MISS
|
MISS
|
MISS
|
el10.aarch64
|
PIGSTY 1.0.0
|
MISS
|
MISS
|
MISS
|
MISS
|
d12.x86_64
|
PIGSTY 1.0.0
|
MISS
|
MISS
|
MISS
|
MISS
|
d12.aarch64
|
PIGSTY 1.0.0
|
MISS
|
MISS
|
MISS
|
MISS
|
d13.x86_64
|
PIGSTY 1.0.0
|
MISS
|
MISS
|
MISS
|
MISS
|
d13.aarch64
|
PIGSTY 1.0.0
|
MISS
|
MISS
|
MISS
|
MISS
|
u22.x86_64
|
PIGSTY 1.0.0
|
MISS
|
MISS
|
MISS
|
MISS
|
u22.aarch64
|
PIGSTY 1.0.0
|
MISS
|
MISS
|
MISS
|
MISS
|
u24.x86_64
|
PIGSTY 1.0.0
|
MISS
|
MISS
|
MISS
|
MISS
|
u24.aarch64
|
PIGSTY 1.0.0
|
MISS
|
MISS
|
MISS
|
MISS
|
u26.x86_64
|
PIGSTY 1.0.0
|
MISS
|
MISS
|
MISS
|
MISS
|
u26.aarch64
|
PIGSTY 1.0.0
|
MISS
|
MISS
|
MISS
|
MISS
|
Source
pig build pkg one_sparse; # build rpm/debInstall
Make sure PGDG and PIGSTY repo available:
pig repo add pgsql -u # add both repo and update cacheInstall this extension with pig:
pig install one_sparse; # install via package name, for the active PG version
pig install onesparse; # install by extension name, for the current active PG version
pig install onesparse -v 18; # install for PG 18Create this extension with:
CREATE EXTENSION onesparse;Usage
Sources: homepage, release v1.0.0, control file at v1.0.0, intro docs, matrix docs, vector docs, algorithm examples
OneSparse is a PostgreSQL extension that binds SuiteSparse:GraphBLAS into Postgres and exposes sparse linear algebra and graph algorithms as new types, functions, and operators.
The docs treat matrix as the core type, with vector and scalar built on top of the same model. The v1.0.0 release exists, while the extension control file at that tag still declares SQL default_version = '0.1.0'.
Core Setup
CREATE EXTENSION onesparse;
SET search_path TO public,onesparse;
SELECT 'int32'::matrix;
SELECT 'int32'::vector;
SELECT 'int32:42'::scalar;The docs site organizes the API around matrix, vector, and scalar, with interactive examples using casts and constructors.
Matrix and Vector
The matrix page shows common operations such as construction, print(), draw(), assignment, extraction, cast_to(), resize, and aggregation. The vector page documents the matching vector API including nvals(), size(), eadd(), emult(), reduce_scalar(), choose(), and apply().
SELECT print('int32(4:4)'::matrix);
SELECT draw('int32(4:4)[1:2:1 2:3:2 3:1:3]'::matrix);
SELECT eadd('int32[0:1 1:2 2:3]'::vector, 'int32[0:1 1:2 2:3]'::vector, 'plus_int32');
SELECT reduce_scalar('int32[0:1 1:2 2:3]'::vector, 'plus_monoid_int32');Graph Algorithms
The examples page uses Matrix Market input and graph visualization with draw(...). The documented graph algorithms include:
bfs(graph, 1)for level and parent BFSsssp(cast_to(graph, 'int32'), 1::bigint, 1)for single-source shortest pathpagerank(graph)for ranking vertices by link structuretriangle_centrality(graph)for triangle-based centralitybetweenness(graph, ARRAY[...])andsquare_clustering(graph)for additional graph analysis
Representative example from the docs:
SELECT draw(triu(graph), (SELECT level FROM bfs(graph, 1)), false, false, true, 0.5)
FROM karate;The same guide shows loading a graph with mmread('/home/postgres/onesparse/demo/karate.mtx').