aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorThomas White <taw@bitwiz.org.uk>2015-05-09 00:28:42 +0200
committerThomas White <taw@physics.org>2015-05-19 13:57:14 +0200
commitd5c4f2c4f68ac0893b7f37d8835cd01c849360e8 (patch)
tree3bcd528efd02a611fc571c9761f180a9b40fab48 /src
parent143981305d0e3859e60a65d9f0b3d2ab147cdd52 (diff)
Minimise Ipart-GpIfull/L instead of Ipart-pIfull/GL
It's about a million times easier
Diffstat (limited to 'src')
-rw-r--r--src/hrs-scaling.c4
-rw-r--r--src/post-refinement.c14
2 files changed, 9 insertions, 9 deletions
diff --git a/src/hrs-scaling.c b/src/hrs-scaling.c
index ac9e4673..1e51fd4c 100644
--- a/src/hrs-scaling.c
+++ b/src/hrs-scaling.c
@@ -328,8 +328,8 @@ static void run_merge_job(void *vwargs, int cookie)
res = resolution(crystal_get_cell(cr), h, k, l);
/* Total (multiplicative) correction factor */
- corr = G * exp(2.0*B*res*res) * get_lorentz(refl)
- / get_partiality(refl);
+ corr = exp(2.0*B*res*res) * get_lorentz(refl)
+ / (G * get_partiality(refl));
esd = get_esd_intensity(refl) * corr;
w = 1.0 / pow(esd, 0.5);
diff --git a/src/post-refinement.c b/src/post-refinement.c
index 51645f50..3008b7af 100644
--- a/src/post-refinement.c
+++ b/src/post-refinement.c
@@ -174,7 +174,7 @@ static double volume_fraction(double rlow, double rhigh, double pr,
}
-/* Return the gradient of p/G wrt parameter 'k' given the current status
+/* Return the gradient of pG wrt parameter 'k' given the current status
* of the crystal. */
double gradient(Crystal *cr, int k, Reflection *refl, PartialityModel pmodel)
{
@@ -188,7 +188,7 @@ double gradient(Crystal *cr, int k, Reflection *refl, PartialityModel pmodel)
get_partial(refl, &rlow, &rhigh, &p);
if ( k == GPARAM_OSF ) {
- return -p/(osf*osf);
+ return p;
}
if ( k == GPARAM_R ) {
@@ -203,7 +203,7 @@ double gradient(Crystal *cr, int k, Reflection *refl, PartialityModel pmodel)
Rghigh = volume_fraction_rgradient(rhigh, R, pmodel);
gr = 4.0*psph/(3.0*D) + (4.0*R/(3.0*D))*(Rglow - Rghigh);
- return gr / osf;
+ return gr * osf;
}
@@ -222,12 +222,12 @@ double gradient(Crystal *cr, int k, Reflection *refl, PartialityModel pmodel)
ds = 2.0 * resolution(crystal_get_cell(cr), hs, ks, ls);
gr = (ds/2.0)*(glow+ghigh) - 4.0*R*psph*ds/(3.0*D*D);
- return gr / osf;
+ return gr * osf;
}
gr = r_gradient(crystal_get_cell(cr), k, refl, image) * (glow-ghigh);
- return gr / osf;
+ return gr * osf;
}
@@ -429,7 +429,7 @@ static double pr_iterate(Crystal *cr, const RefList *full,
}
- delta_I = I_partial - (p * I_full / (L*G));
+ delta_I = I_partial - (G * p * I_full / L);
v_c = w * delta_I * gradients[k];
v_curr = gsl_vector_get(v, k);
gsl_vector_set(v, k, v_curr + v_c);
@@ -512,7 +512,7 @@ static double guide_dev(Crystal *cr, const RefList *full)
// h, k, l, G, p, I_partial, I_full,
// I_partial - p*G*I_full);
- dev += pow(I_partial - p*I_full/(G*L), 2.0);
+ dev += pow(I_partial - G*p*I_full/L, 2.0);
}