aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorThomas White <taw@physics.org>2020-07-10 14:53:07 +0200
committerThomas White <taw@physics.org>2020-07-29 18:53:45 +0200
commit234ebec9ac60c645b4118004a6e95a0ff73b08ec (patch)
tree14b4cd5c9e759be9adea6cf2a5f55f95abac80ae
parent865959d6b3adaae1f80fb50da4bebdd9b5d31830 (diff)
Unify creation of blank image data arrays
-rw-r--r--libcrystfel/src/image-msgpack.c113
-rw-r--r--libcrystfel/src/image.c80
-rw-r--r--libcrystfel/src/image.h11
-rw-r--r--libcrystfel/src/stream.c2
4 files changed, 73 insertions, 133 deletions
diff --git a/libcrystfel/src/image-msgpack.c b/libcrystfel/src/image-msgpack.c
index c4f0ffe4..d6757a9a 100644
--- a/libcrystfel/src/image-msgpack.c
+++ b/libcrystfel/src/image-msgpack.c
@@ -150,25 +150,17 @@ ImageFeatureList *image_msgpack_read_peaks(const DataTemplate *dtempl,
}
-static struct image *unpack_slab(const DataTemplate *dtempl,
- double *data,
- int data_width, int data_height)
+static int unpack_slab(struct image *image,
+ const DataTemplate *dtempl,
+ double *data,
+ int data_width, int data_height)
{
- uint16_t *flags = NULL;
- float *sat = NULL;
int pi;
- struct image *image;
-
- image = image_new();
- if ( image == NULL ) return NULL;
image->dp = malloc(dtempl->n_panels*sizeof(float *));
- image->bad = malloc(dtempl->n_panels*sizeof(int *));
- image->sat = malloc(dtempl->n_panels*sizeof(float *));
- if ( (image->dp == NULL) || (image->bad == NULL) || (image->sat == NULL) ) {
+ if ( image->dp == NULL ) {
ERROR("Failed to allocate data arrays.\n");
- image_free(image);
- return NULL;
+ return 1;
}
for ( pi=0; pi<dtempl->n_panels; pi++ ) {
@@ -182,13 +174,9 @@ static struct image *unpack_slab(const DataTemplate *dtempl,
p_h = p->orig_max_ss - p->orig_min_ss + 1;
image->dp[pi] = malloc(p_w*p_h*sizeof(float));
- image->bad[pi] = malloc(p_w*p_h*sizeof(int));
- image->sat[pi] = malloc(p_w*p_h*sizeof(float));
- if ( (image->dp[pi] == NULL) || (image->bad[pi] == NULL)
- || (image->sat[pi] == NULL) )
- {
+ if ( image->dp[pi] == NULL ) {
ERROR("Failed to allocate panel\n");
- return NULL;
+ return 1;
}
if ( (p->orig_min_fs + p_w > data_width)
@@ -196,7 +184,7 @@ static struct image *unpack_slab(const DataTemplate *dtempl,
{
ERROR("Panel %s is outside range of data provided\n",
p->name);
- return NULL;
+ return 1;
}
for ( ss=0; ss<p_h; ss++) {
@@ -204,7 +192,6 @@ static struct image *unpack_slab(const DataTemplate *dtempl,
int idx;
int cfs, css;
- int bad = 0;
cfs = fs+p->orig_min_fs;
css = ss+p->orig_min_ss;
@@ -212,37 +199,6 @@ static struct image *unpack_slab(const DataTemplate *dtempl,
image->dp[pi][fs+p_w*ss] = data[idx];
- if ( sat != NULL ) {
- image->sat[pi][fs+p_w*ss] = sat[idx];
- } else {
- image->sat[pi][fs+p_w*ss] = INFINITY;
- }
-
- if ( p->bad ) bad = 1;
-
- if ( data_template_in_bad_region(dtempl, pi,
- fs, ss)
- || isnan(image->dp[pi][fs+ss*p_w])
- || isinf(image->dp[pi][fs+ss*p_w]) )
- {
- bad = 1;
- }
-
- if ( isnan(data[idx]) || isinf(data[idx]) ) bad = 1;
-
- if ( flags != NULL ) {
-
- int f;
-
- f = flags[idx];
-
- if ( (f & dtempl->mask_good)
- != dtempl->mask_good ) bad = 1;
-
- if ( f & dtempl->mask_bad ) bad = 1;
-
- }
- image->bad[pi][fs+p_w*ss] = bad;
}
}
@@ -300,29 +256,6 @@ static double *find_msgpack_data(msgpack_object *obj, int *width, int *height)
}
-static double *zero_array(const DataTemplate *dtempl, int *dw, int *dh)
-{
- int max_fs = 0;
- int max_ss = 0;
- int pi;
- double *data;
-
- for ( pi=0; pi<dtempl->n_panels; pi++ ) {
- if ( dtempl->panels[pi].orig_max_fs > max_fs ) {
- max_fs = dtempl->panels[pi].orig_max_fs;
- }
- if ( dtempl->panels[pi].orig_max_ss > max_ss ) {
- max_ss = dtempl->panels[pi].orig_max_ss;
- }
- }
-
- data = calloc((max_fs+1)*(max_ss+1), sizeof(double));
- *dw = max_fs+1;
- *dh = max_ss+1;
- return data;
-}
-
-
/* Unpacks the raw panel data from a msgpack_object, applies panel geometry,
* and stores the resulting data in an image struct. Object has structure
* {
@@ -340,7 +273,8 @@ static double *zero_array(const DataTemplate *dtempl, int *dw, int *dh)
*/
struct image *image_msgpack_read(DataTemplate *dtempl,
msgpack_object *obj,
- int no_image_data)
+ int no_image_data,
+ int no_mask_data)
{
struct image *image;
int data_width, data_height;
@@ -351,22 +285,31 @@ struct image *image_msgpack_read(DataTemplate *dtempl,
return NULL;
}
+ if ( dtempl == NULL ) {
+ ERROR("NULL data template!\n");
+ return NULL;
+ }
+
+ image = image_new();
+ if ( image == NULL ) {
+ ERROR("Couldn't allocate image structure.\n");
+ return NULL;
+ }
+
if ( !no_image_data ) {
- data = find_msgpack_data(obj, &data_width, &data_height);
+ data = find_msgpack_data(obj,
+ &data_width, &data_height);
if ( data == NULL ) {
ERROR("No image data in MessagePack object.\n");
return NULL;
}
+ unpack_slab(image, dtempl, data,
+ data_width, data_height);
} else {
- data = zero_array(dtempl, &data_width, &data_height);
+ image_set_zero_data(image, dtempl);
}
- image = unpack_slab(dtempl, data, data_width, data_height);
-
- if ( image == NULL ) {
- ERROR("Failed to unpack data slab.\n");
- return NULL;
- }
+ image_set_zero_mask(image, dtempl);
return image;
}
diff --git a/libcrystfel/src/image.c b/libcrystfel/src/image.c
index b41364d4..2b6f5b16 100644
--- a/libcrystfel/src/image.c
+++ b/libcrystfel/src/image.c
@@ -474,8 +474,8 @@ void create_detgeom(struct image *image, const DataTemplate *dtempl)
}
-static int zero_data_arrays(struct image *image,
- const DataTemplate *dtempl)
+int image_set_zero_data(struct image *image,
+ const DataTemplate *dtempl)
{
int pi;
@@ -504,6 +504,40 @@ static int zero_data_arrays(struct image *image,
}
+int image_set_zero_mask(struct image *image,
+ const DataTemplate *dtempl)
+{
+ int pi;
+
+ image->bad = malloc(dtempl->n_panels*sizeof(int *));
+ image->sat = malloc(dtempl->n_panels*sizeof(float *));
+ if ( (image->bad == NULL) || (image->sat == NULL) ) return 1;
+
+ for ( pi=0; pi<dtempl->n_panels; pi++ ) {
+
+ struct panel_template *p;
+ int p_w, p_h;
+ long int i;
+
+ p = &dtempl->panels[pi];
+ p_w = p->orig_max_fs - p->orig_min_fs + 1;
+ p_h = p->orig_max_ss - p->orig_min_ss + 1;
+
+ image->bad[pi] = malloc(p_w*p_h*sizeof(int));
+ image->sat[pi] = malloc(p_w*p_h*sizeof(float));
+ if ( image->bad[pi] == NULL ) return 1;
+ if ( image->sat[pi] == NULL ) return 1;
+
+ for ( i=0; i<p_w*p_h; i++ ) {
+ image->bad[pi][i] = 0;
+ image->sat[pi][i] = INFINITY;
+ }
+ }
+
+ return 0;
+}
+
+
struct image *image_read(DataTemplate *dtempl,
const char *filename,
const char *event,
@@ -543,7 +577,7 @@ struct image *image_read(DataTemplate *dtempl,
} else {
- r = zero_data_arrays(image, dtempl);
+ r = image_set_zero_data(image, dtempl);
}
@@ -705,46 +739,6 @@ struct image *image_new()
}
-int create_blank_arrays(struct image *image)
-{
- int pn;
- int num_panels = image->detgeom->n_panels;
-
- image->dp = malloc(num_panels*sizeof(float *));
- image->bad = malloc(num_panels*sizeof(int *));
- image->sat = malloc(num_panels*sizeof(float *));
-
- if ( (image->dp == NULL) || (image->bad == NULL)
- || (image->sat == NULL) ) return 1;
-
- for ( pn=0; pn<num_panels; pn++ ) {
-
- long int i;
- struct detgeom_panel *p = &image->detgeom->panels[pn];
-
- image->dp[pn] = malloc(p->w*p->h*sizeof(float));
- image->bad[pn] = malloc(p->w*p->h*sizeof(int));
- image->sat[pn] = malloc(p->w*p->h*sizeof(float));
-
- if ( (image->dp[pn] == NULL)
- || (image->bad[pn] == NULL)
- || (image->sat[pn] == NULL) )
- {
- return 1;
- }
-
- for ( i=0; i<p->w*p->h; i++ ) {
- image->dp[pn][i] = 0.0;
- image->bad[pn][i] = 0;
- image->sat[pn][i] = INFINITY;
- }
-
- }
-
- return 0;
-}
-
-
ImageFeatureList *image_read_peaks(const DataTemplate *dtempl,
const char *filename,
const char *event,
diff --git a/libcrystfel/src/image.h b/libcrystfel/src/image.h
index bbddadb3..45a75f1e 100644
--- a/libcrystfel/src/image.h
+++ b/libcrystfel/src/image.h
@@ -205,13 +205,16 @@ extern ImageFeatureList *image_read_peaks(const DataTemplate *dtempl,
extern char **image_expand_frames(const DataTemplate *dtempl,
const char *filename, int *nframes);
-/* The following functions are not part of the public API -
- * use within libcrystfel only */
+extern int image_set_zero_data(struct image *image,
+ const DataTemplate *dtempl);
+
+extern int image_set_zero_mask(struct image *image,
+ const DataTemplate *dtempl);
+
+/* Use within libcrystfel only */
extern void create_detgeom(struct image *image,
const DataTemplate *dtempl);
-extern int create_blank_arrays(struct image *image);
-
#ifdef __cplusplus
}
#endif
diff --git a/libcrystfel/src/stream.c b/libcrystfel/src/stream.c
index 36eedb2d..f9a75e9d 100644
--- a/libcrystfel/src/stream.c
+++ b/libcrystfel/src/stream.c
@@ -1013,7 +1013,7 @@ struct image *stream_read_chunk(Stream *st, const DataTemplate *dtempl,
if ( have_filename && have_ev ) {
/* Success */
create_detgeom(image, dtempl);
- create_blank_arrays(image);
+ image_set_zero_data(image, dtempl);
return image;
}
ERROR("Incomplete chunk found in input file.\n");