aboutsummaryrefslogtreecommitdiff
path: root/src/detector.h
blob: df40d05b328f625c7c061ca1b7da65f871f8040e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
/*
 * detector.h
 *
 * Detector properties
 *
 * (c) 2006-2010 Thomas White <taw@physics.org>
 *
 * Part of CrystFEL - crystallography with a FEL
 *
 */

#ifdef HAVE_CONFIG_H
#include <config.h>
#endif

#ifndef DETECTOR_H
#define DETECTOR_H

struct image;

#include "image.h"

struct panel
{
	int      min_x;    /* Smallest x value considered to be in this panel */
	int      max_x;    /* Largest x value considered to be in this panel */
	int      min_y;    /* ... and so on */
	int      max_y;
	float    cx;       /* Location of centre */
	float    cy;
	float    clen;     /* Camera length */
	float    res;      /* Resolution */
	char     badrow;   /* 'x' or 'y' */
	int      no_index; /* Don't index peaks in this panel if non-zero */
};

struct detector
{
	struct panel *panels;
	int           n_panels;
};


/* x,y in pixels relative to central beam */
extern int map_position(struct image *image, double x, double y,
                        double *rx, double *ry, double *rz);

extern struct rvec get_q(struct image *image, unsigned int xs, unsigned int ys,
                         unsigned int sampling, float *ttp, float k);

extern double get_tt(struct image *image, unsigned int xs, unsigned int ys);

extern void record_image(struct image *image, int do_poisson);

extern struct panel *find_panel(struct detector *det, int x, int y);

extern struct detector *get_detector_geometry(const char *filename);

#endif	/* DETECTOR_H */