X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~yarrgweb/git?p=ypp-sc-tools.db-test.git;a=blobdiff_plain;f=yarrg%2Frsmain.c;h=2e1c500308658ed53c60a49e7b9fc3f64590a268;hp=fa52f81fb6481924da98b1407a477dace851450e;hb=3579e35d2b8ed951db24cc4873c155fded7f4375;hpb=9e57f1e2a73c8e8d69ee616672681bee29694afe diff --git a/yarrg/rsmain.c b/yarrg/rsmain.c index fa52f81..2e1c500 100644 --- a/yarrg/rsmain.c +++ b/yarrg/rsmain.c @@ -12,32 +12,37 @@ int max_dist= -1; FILE *debug_file; FILE *output; -DEBUG_DEFINE_SOME_DEBUGF(tableau,tabdebugf); +#define tabdebugf printf -#define CTR(x) int ctr_##x; +#define CTR(x) int ctr_##x; +#define CTRA(x,n) int ctr_##x[n]; COUNTER_LIST #undef CTR +#undef CTRA -static PotentialResult ****results; - /* results[start_isle_ix][finalisle][midisle]-> */ +static Bucket ****results[GRANUS]; + /* results[GRANUS][start_isle_ix][finalisle][midisle]-> */ static pid_t debugoutpid; int main(int argc, const char **argv) { const char *arg; - int i; + int i, ap; + int granui; #ifndef debug_flags debug_flags= ~( dbg_sql2 ); #endif - + for (;;) { arg= *++argv; if (arg[0] != '-') break; #ifndef debug_flags if (!strcmp(arg,"-DN")) { debug_flags= 0; + } else if (!strcmp(arg,"-D1")) { + debug_flags= ~(dbg_sql2|dbg_lp|dbg_value2); } else #endif { @@ -72,24 +77,24 @@ int main(int argc, const char **argv) { debug_file= stderr; } + const char *database= *argv++; + sysassert( !setvbuf(debug,0,_IOLBF,0) ); max_mass= atof(*argv++); max_volu= atof(*argv++); max_capi= atof(*argv++); double loss_per_league= atof(*argv++); - - if (!loss_per_league) loss_per_league= 1e-7; distance_loss_factor_per_league= 1.0 - loss_per_league; - setup_sql(); + setup_sql(database); setup_value(); setup_search(); for (i=0; iabsolute)); - tabdebugf(" "); - tabdebugf("%4d",(int)(result->perleague)); - } + int mid, fin; + for (granui=0; granuipr; \ - if (!pr) continue; \ - const int *const ports= pr->absperl##_ports; \ - int nports; \ - for (nports=0; nports=0; nports++); \ - int finisle= ports[nports-1]; int finarch= isle2arch(finisle); \ - int midarch= route2midarch(ports,nports); \ - fprintf(output, \ - " @%2d #%2d | start%3d mid%d f%d:%3d | %5d %5d %4d |", \ - pos, nhighscores_##absperl - 1 - pos, \ - ports[0], midarch, finarch,finisle, \ - (int)hs->value, (int)pr->absolute, (int)pr->perleague); \ - for (i=0; iprs[A].value[A])); + tabdebugf(" "); + tabdebugf("%4d",(int)(result->prs[P].value[P])); + } + } + tabdebugf("\n"); + } + } /* i */ + + for (ap=0; ap=0; pos--) { + HighScoreEntry *hs= &highscores[granui][ap][pos]; + Bucket *bucket= hs->bucket; + if (!bucket) continue; + OnePotentialResult *pr= &bucket->prs[ap]; + const int *const ports= pr->ports; + int nports; + for (nports=0; nports=0; nports++); + int finisle= ports[nports-1]; + int finarch= isle2arch(finisle); + int midisle= ports[nports/2]; + int midarch= route2midarch(ports,nports); + fprintf(output, + " @%2d %c#%2d | start%3d mid%d:%3d f%d:%3d | %5d %5d %4d |", + pos, "ap"[ap], nhighscores[granui][ap] - pos, + ports[0], midarch,midisle, finarch,finisle, + (int)hs->value, (int)pr->value[A], (int)pr->value[P]); + for (i=0; i