#define HELPTEXT \ " Delete some vertices from a file of graphs.\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\n\
-d# -d#:# Only remove vertices with original degree in the given range\n\ For digraphs, the out-degree is used.\n\
-n# The number of vertices to delete (default 1).\n\
-v# -v#:# Vertex number or numbers that it is allowed to delete\n\
(first vertex is number 0).\n\
-m# Lower bound on minimum degree of output graphs.\n\
-r# Choose # random sets of points (not necessarily different)\n\
-a The deleted points must be adjacent.\n\
-b The deleted points must be non-adjacent.\n\
-i Leave deleted vertices as isolates, not compatible with -m.\n\
No empty graphs are output. No warning is issued if\n\
-d, -v -n, -m together imply no graphs are output.\n\ For digraphs, out-degree is used for -d and -m.\n\
-q Suppress auxiliary information\n"
staticvoid
writeone(graph *g, int m, int n, int *del, int ndel, int outmindeg, boolean isolates) /* Delete the stated vertices and write it is mindeg is high enough.
* The vertices to delete are del[0] < del[1] < ... < del[ndel-1]. */
{ int i,j,k,nx,mx,deg;
graph *gi,*gxi,*gq;
ssize_t ii; #if MAXN
graph gx[MAXN*MAXM];
graph hx[MAXN*MAXM]; int lab[MAXN]; #else
DYNALLSTAT(graph,gx,gx_sz);
DYNALLSTAT(graph,hx,hx_sz);
DYNALLSTAT(int,lab,lab_sz); #endif
if (isolates)
{
nx = n;
mx = m;
} else
{
nx = n - ndel; /* Always positive */
mx = SETWORDSNEEDED(nx);
}
#if !MAXN
DYNALLOC2(graph,gx,gx_sz,mx,nx,"delptg"); if (dolabel) DYNALLOC2(graph,hx,hx_sz,mx,nx,"delptg");
DYNALLOC1(int,lab,lab_sz,nx,"delptg"); #endif
if (isolates)
{ for (ii = mx*(ssize_t)nx; --ii >= 0; )
gx[ii] = g[ii]; for (j = 0; j < ndel; ++j)
{
k = del[j];
EMPTYSET(GRAPHROW(gx,k,mx),mx); for (i = 0, gxi = gx; i < nx; ++i, gxi += mx)
DELELEMENT(gxi,k);
}
} else
{
j = 0; for (i = 0; i < del[0]; ++i) lab[j++] = i; for (k = 1; k < ndel; ++k) for (i = del[k-1]+1; i < del[k]; ++i) lab[j++] = i; for (i = del[ndel-1]+1; i < n; ++i) lab[j++] = i;
EMPTYSET(gx,nx*(size_t)mx);
for (i = 0, gxi = (set*)gx; i < nx; ++i, gxi += mx)
{
gi = GRAPHROW(g,lab[i],m); for (j = 0; j < nx; ++j)
{
k = lab[j]; if (ISELEMENT(gi,k)) ADDELEMENT(gxi,j);
}
}
}
if (outmindeg > 0)
{ for (i = 0, gxi = (set*)gx; i < nx; ++i, gxi += mx)
{
deg = 0; for (j = 0; j < mx; ++j) deg += POPCOUNT(gxi[j]); if (deg < outmindeg) return;
}
}
staticvoid
delrandom(int ndel, int *del, graph *g, int m, int n, int outmindeg, int *okverts, int nvok, boolean isolates) /* Delete ndel vertices chosen at random from okverts[0..nvok-1] */
{ int i,k;
for (i = 0; i < nvok; ++i) del[i] = okverts[i];
if (2*ndel < nvok)
{ /* Choose ndel */
k = 0; do
{
i = KRAN(nvok); if (del[i] >= 0)
{
del[i] = -1 - del[i];
++k;
}
} while (k < ndel);
k = 0; for (i = 0; i < nvok; ++i) if (del[i] < 0) del[k++] = -1 - del[i];
} else
{ /* Remove nvok-ndel */
k = 0; do
{
i = KRAN(nvok); if (del[i] >= 0)
{
del[i] = -1;
++k;
}
} while (k < nvok-ndel);
k = 0; for (i = 0; i < nvok; ++i) if (del[i] >= 0) del[k++] = del[i];
}
staticvoid
search(int level, int ndel, int *del, graph *g, int m, int n, int outmindeg, int *okverts, int lastok, int nvok, boolean isolates) /* level vertices have been chosen, last one was okverts[lastok] */
{ int i;
if (level == ndel)
{
writeone(g,m,n,del,ndel,outmindeg,isolates); return;
}
for (i = lastok+1; i <= level + nvok - ndel; ++i)
{
del[level] = okverts[i];
search(level+1,ndel,del,g,m,n,
outmindeg,okverts,i,nvok,isolates);
}
}
staticvoid
search_a(int level, int ndel, int *del, graph *g, int m, int n, set *avail, int outmindeg, int *okverts, int lastok, int nvok, boolean isolates) /* level vertices have been chosen, last one was okverts[lastok] */
{ int i,j,v;
set *gv;
if (level == ndel)
{
writeone(g,m,n,del,ndel,outmindeg,isolates); return;
}
for (i = lastok+1; i <= level + nvok - ndel; ++i)
{
v = okverts[i]; if (ISELEMENT(avail,v))
{
gv = g + m*(size_t)v; if (level < ndel-1) for (j = 0; j < m; ++j) avail[m+j] = avail[j] & gv[j];
del[level] = v;
search_a(level+1,ndel,del,g,m,n,
avail+m,outmindeg,okverts,i,nvok,isolates);
}
}
}
staticvoid
search_b(int level, int ndel, int *del, graph *g, int m, int n, set *avail, int outmindeg, int *okverts, int lastok, int nvok, boolean isolates) /* level vertices have been chosen, last one was okverts[lastok] */
{ int i,j,v;
set *gv;
if (level == ndel)
{
writeone(g,m,n,del,ndel,outmindeg,isolates); return;
}
for (i = lastok+1; i <= level + nvok - ndel; ++i)
{
v = okverts[i]; if (ISELEMENT(avail,v))
{
gv = g + m*(size_t)v; if (level < ndel-1) for (j = 0; j < m; ++j) avail[m+j] = avail[j] & ~gv[j];
del[level] = v;
search_b(level+1,ndel,del,g,m,n,
avail+m,outmindeg,okverts,i,nvok,isolates);
}
}
}
int
main(int argc, char *argv[])
{ char *infilename,*outfilename;
FILE *infile;
boolean badargs,quiet,dswitch,nswitch,vswitch,mswitch;
boolean adj,nonadj,isolates,delrand; int i,j,m,n,v,argnum; int ndel,outmindeg; int codetype;
graph *g;
nauty_counter nin; char *arg,sw;
setword *gv; long mindeg,maxdeg,irand,numrand; long minv,maxv; int iminv,imaxv,actmaxv,nvok; int degv; double t; #if MAXN int okverts[MAXN]; int del[MAXN]; #else
DYNALLSTAT(int,okverts,okverts_sz);
DYNALLSTAT(int,del,del_sz); #endif
DYNALLSTAT(set,avail,avail_sz);
if (nswitch && ndel < 1) gt_abort(">E delptg: bad argument for -n\n"); if (adj && nonadj) gt_abort(">E delptg: -a and -b are incompatible\n"); if (mswitch && isolates)
gt_abort(">E delptg: -m and -i are incompatible\n"); if (delrand && (adj || nonadj))
gt_abort(">E delptg: -r is incompatible with -a and -b\n");
if (badargs)
{
fprintf(stderr,">E Usage: %s\n",USAGE);
GETHELP; exit(1);
}
if (!quiet)
{
fprintf(stderr,">A delptg"); if (dolabel||adj||nonadj||isolates)
fprintf(stderr," -%s%s%s%s",(dolabel?"l":""),
(adj?"a":""),(nonadj?"b":""),(isolates?"i":"")); if (dswitch) fprintf(stderr," -d%ld:%ld",mindeg,maxdeg); if (nswitch) fprintf(stderr," -n%d",ndel); if (vswitch) fprintf(stderr," -v%ld:%ld",minv,maxv); if (mswitch) fprintf(stderr," -m%d",outmindeg); if (delrand) fprintf(stderr," -r%ld",numrand); if (argnum > 0) fprintf(stderr," %s",infilename); if (argnum > 1) fprintf(stderr," %s",outfilename);
fprintf(stderr,"\n");
fflush(stderr);
}
nvok = 0; for (v = 0, gv = g; v < n && v <= actmaxv; ++v, gv += m)
{ if (v < iminv) continue;
degv = 0; for (i = 0; i < m; ++i) degv += POPCOUNT(gv[i]); if (degv < mindeg || degv > maxdeg) continue;
okverts[nvok++] = v;
}
if (nvok < ndel)
{
FREES(g); continue;
}
if (adj || nonadj)
{ for (i = 0; i < nvok; ++i)
ADDELEMENT(avail,okverts[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.