#define HELPTEXT \ " Extract neighbours of vertices of a graph.\n\
\n\
The output file has a header ifand only if the input file does.\n\
No isomorph reduction is done.\n\
\n\
-l Canonically label outputs (default is same labelling as input)\n\
-C Extract closed neighbourhoods instead.\n\
-c Extract non-neighbourhoods instead.\n\
-d# -d#:# Only include vertices with original degree in the given range\n\
-v# -v#:# Only include vertices with these vertex numbers (first is 0).\n\
No empty graphs are output.\n\ For digraphs, out-degree and out-neighbourhoods are used.\n\
-q Suppress auxiliary information\n"
staticvoid
getsubgraph(graph *gin, int *perm, int nperm, graph *gout, int m, int n) /* Makes a subgraph gin<perm[0..nperm-1]> */
{ long li; int i,j,k; int newm;
set *gi,*wgi;
newm = SETWORDSNEEDED(nperm);
for (li = (long)newm * (long)nperm; --li >= 0;) gout[li] = 0;
for (i = 0, gi = (set*)gout; i < nperm; ++i, gi += newm)
{
wgi = GRAPHROW(gin,perm[i],m); for (j = 0; j < nperm; ++j)
{
k = perm[j]; if (ISELEMENT(wgi,k)) ADDELEMENT(gi,j);
}
}
}
if (codetype&HAS_HEADER)
{ if (outcode == SPARSE6) writeline(outfile,SPARSE6_HEADER); elseif (outcode == DIGRAPH6) writeline(outfile,DIGRAPH6_HEADER); else writeline(outfile,GRAPH6_HEADER);
}
t = CPUTIME; while (TRUE)
{ if ((g = readgg(infile,NULL,0,&m,&n,&digraph)) == NULL) break;
++nin;
#if !MAXN
DYNALLOC2(graph,gsub,gsub_sz,m,n,"nbrhoodg"); if (dolabel) DYNALLOC2(graph,gx,gx_sz,m,n,"nbrhoodg");
DYNALLOC1(int,perm,perm_sz,n,"nbrhoodg"); #endif
for (v = minvert, gv = GRAPHROW(g,minvert,m);
v < n && v <= maxvert; ++v, gv += m)
{
degv = 0; for (i = 0; i < m; ++i) degv += POPCOUNT(gv[i]); if (degv < mindeg || degv > maxdeg) continue;
if (Cswitch)
{
perm[0] = v;
nsub = 1; for (i = 0; i < n; ++i) if (ISELEMENT(gv,i) && i != v) perm[nsub++] = i;
} elseif (cswitch)
{
nsub = 0; for (i = 0; i < n; ++i) if (!ISELEMENT(gv,i) && i != v) perm[nsub++] = i;
} else
{
nsub = 0; for (i = 0; i < n; ++i) if (ISELEMENT(gv,i) && i != v) perm[nsub++] = i;
}
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.