Skip to content
Snippets Groups Projects
Select Git revision
  • 0e844bb28c85e8b7a87d482cc3996d0d7d612db0
  • master default protected
2 results

cs_reach.c

Blame
  • Lubomir Riha's avatar
    Lubomir Riha authored
    3da58453
    History
    cs_reach.c 682 B
    #include "cs.h"
    /* xi [top...n-1] = nodes reachable from graph of G*P' via nodes in B(:,k).
     * xi [n...2n-1] used as workspace */
    csi cs_reach (cs *G, const cs *B, csi k, csi *xi, const csi *pinv)
    {
        csi p, n, top, *Bp, *Bi, *Gp ;
        if (!CS_CSC (G) || !CS_CSC (B) || !xi) return (-1) ;    /* check inputs */
        n = G->n ; Bp = B->p ; Bi = B->i ; Gp = G->p ;
        top = n ;
        for (p = Bp [k] ; p < Bp [k+1] ; p++)
        {
            if (!CS_MARKED (Gp, Bi [p]))    /* start a dfs at unmarked node i */
            {
                top = cs_dfs (Bi [p], G, top, xi, xi+n, pinv) ;
            }
        }
        for (p = top ; p < n ; p++) CS_MARK (Gp, xi [p]) ;  /* restore G */
        return (top) ;
    }