aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorThomas White <taw@physics.org>2011-05-26 13:38:02 +0200
committerThomas White <taw@physics.org>2012-02-22 15:27:28 +0100
commitd824368691552038f74fc5fc79ddb7b25fac55df (patch)
treef11d18d3470156342a40d0a3196f8880da13f63b
parent2c2bb0426ceff2ddc9284b506102b967d768dadf (diff)
Increase precision
-rw-r--r--tests/pr_gradient_check.c27
1 files changed, 14 insertions, 13 deletions
diff --git a/tests/pr_gradient_check.c b/tests/pr_gradient_check.c
index 617de4df..12bb3290 100644
--- a/tests/pr_gradient_check.c
+++ b/tests/pr_gradient_check.c
@@ -26,7 +26,7 @@
static void scan_partialities(RefList *reflections, RefList *compare,
- int *valid, double *vals[3], int idx)
+ int *valid, long double *vals[3], int idx)
{
int i;
Reflection *refl;
@@ -101,7 +101,7 @@ static UnitCell *new_shifted_cell(UnitCell *input, int k, double shift)
static void calc_either_side(struct image *image, double incr_val,
- int *valid, double *vals[3], int refine)
+ int *valid, long double *vals[3], int refine)
{
RefList *compare;
UnitCell *cell;
@@ -123,7 +123,7 @@ static int test_gradients(struct image *image, double incr_val, int refine,
{
Reflection *refl;
RefListIterator *iter;
- double *vals[3];
+ long double *vals[3];
int i;
int *valid;
int nref;
@@ -137,9 +137,9 @@ static int test_gradients(struct image *image, double incr_val, int refine,
return -1;
}
- vals[0] = malloc(nref*sizeof(double));
- vals[1] = malloc(nref*sizeof(double));
- vals[2] = malloc(nref*sizeof(double));
+ vals[0] = malloc(nref*sizeof(long double));
+ vals[1] = malloc(nref*sizeof(long double));
+ vals[2] = malloc(nref*sizeof(long double));
if ( (vals[0] == NULL) || (vals[1] == NULL) || (vals[2] == NULL) ) {
ERROR("Couldn't allocate memory.\n");
return -1;
@@ -164,7 +164,7 @@ static int test_gradients(struct image *image, double incr_val, int refine,
refl = next_refl(refl, iter) )
{
- double grad1, grad2, grad;
+ long double grad1, grad2, grad;
double cgrad;
signed int h, k, l;
@@ -182,15 +182,16 @@ static int test_gradients(struct image *image, double incr_val, int refine,
image->profile_radius);
if ( !within_tolerance(grad, cgrad, 10.0) ) {
- STATUS("!- %s %5.2f %5.2f %5.2f"
- " -> %10.2e %10.2e -> %10.2e %10.2e\n",
- str, vals[0][i], vals[1][i], vals[2][i],
+ STATUS("!- %s %3i %3i %3i %5.2Lf %5.2Lf %5.2Lf"
+ " -> %10.2Le %10.2Le"
+ " -> %10.2Le %10.2e\n", str, h, k, l,
+ vals[0][i], vals[1][i], vals[2][i],
grad1, grad2, grad, cgrad);
} else {
//STATUS("OK %s %5.2f %5.2f %5.2f"
- // " -> %10.2e %10.2e"
- // " -> %10.2e %10.2e\n",
- // str, vals[0][i], vals[1][i], vals[2][i],
+ // " -> %10.2Le %10.2Le"
+ // " -> %10.2Le %10.2e\n", str,
+ // vals[0][i], vals[1][i], vals[2][i],
// grad1, grad2, grad, cgrad);
n_acc++;
}