From: Adam Dickmeiss Date: Wed, 23 Mar 2011 19:07:16 +0000 (+0100) Subject: Improve estimate hit counts for rsprox sets. X-Git-Tag: v2.0.46~1 X-Git-Url: http://sru.miketaylor.org.uk/cgi-bin?a=commitdiff_plain;h=83bf8018b4eeb1ed7a52ccd91cd628c0857997ab;p=idzebra-moved-to-github.git Improve estimate hit counts for rsprox sets. The method used now is similar to and-sets. --- diff --git a/rset/rsprox.c b/rset/rsprox.c index e886108..22a8702 100644 --- a/rset/rsprox.c +++ b/rset/rsprox.c @@ -313,39 +313,27 @@ static void r_pos(RSFD rfd, double *current, double *total) RSET ct = rfd->rset; struct rset_prox_rfd *p = (struct rset_prox_rfd *)(rfd->priv); int i; - double r = 0.0; - double cur, tot = -1.0; - double scur = 0.0, stot = 0.0; - - yaz_log(YLOG_DEBUG, "rsprox_pos"); - + double ratio = 0.0; + for (i = 0; i < ct->no_children; i++) { - rset_pos(p->rfd[i], &cur, &tot); - if (tot > 0) + double cur, tot; + rset_pos(p->rfd[i], &cur, &tot); + if (tot > 0.0) { - scur += cur; - stot += tot; + double nratio = cur / tot; + if (ratio < nratio) + ratio = nratio; } } - if (tot < 0) - { /* nothing found */ - *current = -1; - *total = -1; - } - else if (tot < 1) - { /* most likely tot==0 */ - *current = 0; - *total = 0; - } + *current = (double) p->hits; + if (ratio > 0.0) + *total = *current/ratio; else - { - r = scur/stot; - *current = (double) p->hits; - *total = *current/r ; - } - yaz_log(YLOG_DEBUG,"prox_pos: [%d] %0.1f/%0.1f= %0.4f ", - i,*current, *total, r); + *total = 0.0; + + yaz_log(YLOG_DEBUG, "prox_pos: [%d] %0.1f/%0.1f= %0.4f ", + i, *current, *total, ratio); } static void r_get_terms(RSET ct, TERMID *terms, int maxterms, int *curterm)