pathrex-sys 0.1.0

Native FFI bindings for SuiteSparse:GraphBLAS and LAGraph used by the pathrex crate.
Documentation
% LAGraph/src/test/ranker.m

% LAGraph, (c) 2019-2022 by The LAGraph Contributors, All Rights Reserved.
% SPDX-License-Identifier: BSD-2-Clause
% See additional acknowledgments in the LICENSE file,
% or contact permission@sei.cmu.edu for the full terms.

% using MATLAB graph/centrality to compute the pagerank

clear all
version
s = dir ('../../data/*.mtx') ;

for k = 1:length(s)
    filename = ['../../data/' s(k).name] ;
    % fprintf ('\n=================== filename: %s\n', filename) ;
    try
        [A Z] = mread (filename) ;
        ok = true ;
    catch me
        ok = false ;
    end

    if (~ok)
        % fprintf ('BAD: %s bad\n', filename) ;
        continue
    end

    [m n] = size (A) ;
    if (m ~= n)
        % fprintf ('%s: rectangular\n', filename) ;
        continue ;
    end

    A = spones (spones (A) + spones (Z)) ;
    % get the out degree
    d = sum (A, 2) ;
    nsnks = length (find (d == 0)) ;
    if (nsnks > 0)
        fprintf ('%s has %d sinks\n', filename, nsnks) ;
        % continue ;
    end

    % make the graph
    G = digraph (A) ;
    pr = centrality (G, 'pagerank') ;

    fprintf ('OK: %g %6d %s\n', sum (pr), n, filename) ;

end

files = { 'karate.mtx', 'west0067.mtx', 'ldbc-directed-example.mtx' } ;

for k = 1:length (files)
    [A Z] = mread (['../../data/' files{k}]) ;
    A = spones (spones (A) + spones (Z)) ;
    G = digraph (A) ;
    pr = centrality (G, 'pagerank') ;
    fprintf ('\n%s\n', files {k}) ;
    fprintf ('%16.10f\n', pr) ;
end