diff options
author | Thomas White <taw@physics.org> | 2016-10-10 16:51:50 +0200 |
---|---|---|
committer | Thomas White <taw@physics.org> | 2016-10-10 16:51:50 +0200 |
commit | 31235652b5cf1c1f040c762c707a5c869a3722de (patch) | |
tree | 99f841a6b811ef096fd6f34e8d0d2175917b993d | |
parent | 89ff2319f1875ac73ec30fc89c837cf2715d4d8e (diff) |
Fix bad regions
Previously, this was broken when not using a mask
-rw-r--r-- | libcrystfel/src/hdf5-file.c | 29 |
1 files changed, 20 insertions, 9 deletions
diff --git a/libcrystfel/src/hdf5-file.c b/libcrystfel/src/hdf5-file.c index a9a85ce3..6542b360 100644 --- a/libcrystfel/src/hdf5-file.c +++ b/libcrystfel/src/hdf5-file.c @@ -1049,11 +1049,11 @@ static int *make_badmask(int *flags, struct panel *p, struct detector *det) return NULL; } + /* Defaults, then bad pixels arising from bad regions or panels */ for ( ss=0; ss<p->h; ss++ ) { for ( fs=0; fs<p->w; fs++ ) { int bad = 0; - int f; if ( p->no_index ) bad = 1; @@ -1061,17 +1061,28 @@ static int *make_badmask(int *flags, struct panel *p, struct detector *det) bad = 1; } - f = flags[fs+p->w*ss]; + badmap[fs+p->w*ss] = bad; + } + } - /* Bad if it's missing any of the "good" bits */ - if ( (f & det->mask_good) != det->mask_good ) bad = 1; + /* Bad pixels from mask */ + if ( flags != NULL ) { + for ( ss=0; ss<p->h; ss++ ) { + for ( fs=0; fs<p->w; fs++ ) { - /* Bad if it has any of the "bad" bits. */ - if ( f & det->mask_bad ) bad = 1; + int f = flags[fs+p->w*ss]; + int bad = badmap[fs+p->w*ss]; - badmap[fs+p->w*ss] = bad; + /* Bad if it's missing any of the "good" bits */ + if ( (f & det->mask_good) != det->mask_good ) bad = 1; - } + /* Bad if it has any of the "bad" bits. */ + if ( f & det->mask_bad ) bad = 1; + + badmap[fs+p->w*ss] = bad; + + } + } } return badmap; @@ -1722,7 +1733,7 @@ int hdf5_read2(struct hdfile *f, struct image *image, struct event *ev, image->bad[pi] = make_badmask(flags, p, image->det); free(flags); } else { - image->bad[pi] = calloc(p->w*p->h, sizeof(int)); + image->bad[pi] = make_badmask(NULL, p, image->det); } if ( p->satmap != NULL ) { |