From f25994acae2ef374c13dee106b4e3118272aa493 Mon Sep 17 00:00:00 2001 From: Thomas White Date: Thu, 17 Nov 2011 17:24:53 +0100 Subject: Weight partiality graph mean according to ESDs --- src/scaling-report.c | 27 +++++++++++++++++---------- 1 file changed, 17 insertions(+), 10 deletions(-) diff --git a/src/scaling-report.c b/src/scaling-report.c index 32791bbc..7cbe8ee3 100644 --- a/src/scaling-report.c +++ b/src/scaling-report.c @@ -173,8 +173,8 @@ static void partiality_graph(cairo_t *cr, const struct image *images, int n, const double g_height = 200.0; int i; const int nbins = 25; - double totals[nbins]; - int counts[nbins]; + double t_num[nbins]; + double t_den[nbins]; double prob; double pcalcmin[nbins]; double pcalcmax[nbins]; @@ -193,8 +193,8 @@ static void partiality_graph(cairo_t *cr, const struct image *images, int n, -M_PI/3.0, J_RIGHT); for ( i=0; i= pcalcmin[bin]) && (pcalc < pcalcmax[bin]) ) { - totals[bin] += pobs; - counts[bin]++; + double esd_pobs, esd_Ip, esd_If; + esd_Ip = get_esd_intensity(refl); + esd_If = get_esd_intensity(f); + esd_If *= images[i].osf; + esd_pobs = pow(esd_Ip/Ipart, 2.0); + esd_pobs += pow(esd_If/Ifull, 2.0); + esd_pobs = sqrt(esd_pobs); + t_num[bin] += pobs / esd_pobs; + t_den[bin] += 1.0 / esd_pobs; } } @@ -270,9 +277,9 @@ static void partiality_graph(cairo_t *cr, const struct image *images, int n, double pos = pcalcmin[i] + (pcalcmax[i] - pcalcmin[i])/2.0; - if ( counts[i] == 0 ) continue; + if ( t_den[i] == 0.0 ) continue; cairo_line_to(cr, g_width*pos, - g_height - g_height*(totals[i]/counts[i])); + g_height - g_height*(t_num[i]/t_den[i])); } cairo_set_source_rgb(cr, 0.0, 0.0, 0.0); -- cgit v1.2.3