aboutsummaryrefslogtreecommitdiff
path: root/src/post-refinement.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/post-refinement.c')
-rw-r--r--src/post-refinement.c18
1 files changed, 11 insertions, 7 deletions
diff --git a/src/post-refinement.c b/src/post-refinement.c
index 818911df..3e6ffd0f 100644
--- a/src/post-refinement.c
+++ b/src/post-refinement.c
@@ -670,12 +670,14 @@ static double pr_iterate(Crystal *cr, const RefList *full,
}
-static double log_residual(Crystal *cr, const RefList *full, int free)
+static double log_residual(Crystal *cr, const RefList *full, int verbose,
+ int free, int *pn_used)
{
double dev = 0.0;
double G, B;
Reflection *refl;
RefListIterator *iter;
+ int n_used = 0;
G = crystal_get_osf(cr);
B = crystal_get_Bfac(cr);
@@ -714,9 +716,11 @@ static double log_residual(Crystal *cr, const RefList *full, int free)
dev += w*dc*dc;
}
+ if ( pn_used != NULL ) *pn_used = n_used;
return dev;
}
+
static double residual(Crystal *cr, const RefList *full, int verbose, int free,
int *pn_used)
{
@@ -798,8 +802,8 @@ void all_residuals(Crystal **crystals, int n_crystals, RefList *full,
r = residual(crystals[i], full, 0, 0, NULL);
free_r = residual(crystals[i], full, 0, 1, NULL);
- log_r = log_residual(crystals[i], full, 0);
- free_log_r = log_residual(crystals[i], full, 1);
+ log_r = log_residual(crystals[i], full, 0, 0, NULL);
+ free_log_r = log_residual(crystals[i], full, 0, 1, NULL);
if ( isnan(r) || isnan(free_r)
|| isnan(log_r) || isnan(free_log_r) ) continue;
@@ -863,13 +867,13 @@ static void do_scale_refine(Crystal *cr, const RefList *full,
int i, done;
double old_dev;
- old_dev = log_residual(cr, full, 0);
+ old_dev = log_residual(cr, full, 0, 0, NULL);
if ( verbose ) {
STATUS("Initial G=%.2f, B=%e\n",
crystal_get_osf(cr), crystal_get_Bfac(cr));
STATUS("Scaling initial dev = %10.5e, free dev = %10.5e\n",
- old_dev, log_residual(cr, full, 0));
+ old_dev, log_residual(cr, full, 0, 1, NULL));
}
i = 0;
@@ -880,12 +884,12 @@ static void do_scale_refine(Crystal *cr, const RefList *full,
scale_iterate(cr, full, pmodel);
- dev = log_residual(cr, full, 0);
+ dev = log_residual(cr, full, 0, 0, NULL);
if ( fabs(dev - old_dev) < dev*0.01 ) done = 1;
if ( verbose ) {
STATUS("Scaling %2i: dev = %10.5e, free dev = %10.5e\n",
- i+1, dev, log_residual(cr, full, 0));
+ i+1, dev, log_residual(cr, full, 0, 0, NULL));
}
i++;