blob: 85430b6fe8d0778c1f51895a268850433c21510a (
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
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
|
/*
* crystal.c
*
* A class representing a single crystal
*
* Copyright © 2013 Deutsches Elektronen-Synchrotron DESY,
* a research centre of the Helmholtz Association.
*
* Authors:
* 2013 Thomas White <taw@physics.org>
*
* This file is part of CrystFEL.
*
* CrystFEL is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* CrystFEL is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with CrystFEL. If not, see <http://www.gnu.org/licenses/>.
*
*/
#ifdef HAVE_CONFIG_H
#include <config.h>
#endif
#include "crystal.h"
#include "utils.h"
/**
* SECTION:crystal
* @short_description: Crystal
* @title: Crystal
* @section_id:
* @see_also:
* @include: "crystal.h"
* @Image:
*
* This structure represents a single crystal.
*/
struct _crystal
{
/* Information about the crystal */
UnitCell *indexed_cell;
UnitCell *candidate_cells[MAX_CELL_CANDIDATES];
int ncells;
double m; /* Mosaicity in radians */
double osf;
double profile_radius;
int pr_dud;
double diffracting_resolution;
/* Integrated (or about-to-be-integrated) reflections */
RefList *reflections;
long long int n_saturated; /* Number of overloads */
};
/************************** Setters and Constructors **************************/
/**
* crystal_new:
*
* Create a new %Crystal.
*
* Returns: the new unit cell, or NULL on failure.
*
*/
Crystal *crystal_new()
{
Crystal *cryst;
cryst = malloc(sizeof(Crystal));
if ( cryst == NULL ) return NULL;
return cryst;
}
/**
* crystal_free:
* @cryst: A %Crystal to free.
*
* Frees a %Crystal, and all internal resources concerning that crystal.
*
*/
void crystal_free(UnitCell *cryst)
{
if ( cryst == NULL ) return;
free(crysta);
}
/********************************** Getters ***********************************/
|