/usr/include/relion-1.3/src/ctf.h is in librelion-dev-common 1.3+dfsg-2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 | /***************************************************************************
*
* Author: "Sjors H.W. Scheres"
* MRC Laboratory of Molecular Biology
*
* This program 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 2 of the License, or
* (at your option) any later version.
*
* This program 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.
*
* This complete copyright notice must be included in any revised version of the
* source code. Additional authorship citations may be added, but existing
* author citations must be preserved.
***************************************************************************/
/***************************************************************************
*
* Authors: Carlos Oscar S. Sorzano (coss@cnb.csic.es)
*
* Unidad de Bioinformatica of Centro Nacional de Biotecnologia , CSIC
*
* This program 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 2 of the License, or
* (at your option) any later version.
*
* This program 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 this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
* 02111-1307 USA
*
* All comments concerning this program package may be sent to the
* e-mail address 'xmipp@cnb.csic.es'
***************************************************************************/
#ifndef _CTF_HH
#define _CTF_HH
#include "src/multidim_array.h"
#include "src/metadata_table.h"
#include <map>
class CTF
{
protected:
// Different constants
double K1;
double K2;
double K3;
double K4;
// Azimuthal angle in radians
double rad_azimuth;
// defocus_average = (defocus_u + defocus_v)/2
double defocus_average;
// defocus_deviation = (defocus_u - defocus_v)/2
double defocus_deviation;
public:
/// Accelerating Voltage (in KiloVolts)
double kV;
/// Defocus in U (in Angstroms). Positive values are underfocused
double DeltafU;
/// Defocus in V (in Angstroms). Postive values are underfocused
double DeltafV;
/// Azimuthal angle (between X and U) in degrees
double azimuthal_angle;
// Electron wavelength (Amstrongs)
double lambda;
// Radius of the aperture (in micras)
// double aperture;
/// Spherical aberration (in milimeters). Typical value 5.6
double Cs;
/// Chromatic aberration (in milimeters). Typical value 2
double Ca;
/** Mean energy loss (eV) due to interaction with sample.
Typical value 1*/
double espr;
/// Objective lens stability (deltaI/I) (ppm). Typical value 1
double ispr;
/// Convergence cone semiangle (in mrad). Typical value 0.5
double alpha;
/// Longitudinal mechanical displacement (Angstrom). Typical value 100
double DeltaF;
/// Transversal mechanical displacement (Angstrom). Typical value 3
double DeltaR;
/// Amplitude contrast. Typical values 0.07 for cryo, 0.2 for negative stain
double Q0;
// B-factor fall-off
double Bfac;
// Overall scale-factor of CTF
double scale;
/** Empty constructor. */
CTF() { clear(); }
/** Read CTF parameters from MetaDataTables MD1 and MD2
* If a parameter is not found in MD1 it is tried to be read from MD2
* Only if it is also not present in the second then a default value is used
* This is useful if micrograph-specific parameters are stored in a separate MD from the image-specific parameters
*/
void read(MetaDataTable &MD1, MetaDataTable &MD2, long int objectID = -1);
/** Just set all values explicitly */
void setValues(double _defU, double _defV, double _defAng,
double _voltage, double _Cs, double _Q0, double _Bfac, double _scale = 1.);
/** Read from a single MetaDataTable */
void read(MetaDataTable &MD);
/** Write to output. */
void write(std::ostream &out);
/// Clear.
void clear();
/// Set up the CTF object, read parameters from MetaDataTables with micrograph and particle information
/// If no MDmic is provided or it does not contain certain parameters, these parameters are tried to be read from MDimg
void initialise();
/// Compute CTF at (U,V). Continuous frequencies
inline double getCTF(double X, double Y,
bool do_abs = false, bool do_only_flip_phases = false, bool do_intact_until_first_peak = false, bool do_damping = true) const
{
double u2 = X * X + Y * Y;
double u = sqrt(u2);
double u4 = u2 * u2;
// if (u2>=ua2) return 0;
double deltaf = getDeltaF(X, Y);
double argument = K1 * deltaf * u2 + K2 * u4;
double retval;
if (do_intact_until_first_peak && ABS(argument) < PI/2.)
{
retval = 1.;
}
else
{
double sine_part,cosine_part;
retval = -(K3*sin(argument) - Q0*cos(argument)); // Q0 should be positive
}
if (do_damping)
{
double E = exp(K4 * u2); // B-factor decay (K4 = -Bfac/4);
retval *= E;
}
if (do_abs)
{
retval = ABS(retval);
}
else if (do_only_flip_phases)
{
retval = (retval < 0.) ? -1. : 1.;
}
return scale * retval;
}
/// Compute Deltaf at a given direction
inline double getDeltaF(double X, double Y) const
{
if (ABS(X) < XMIPP_EQUAL_ACCURACY &&
ABS(Y) < XMIPP_EQUAL_ACCURACY)
return 0;
double ellipsoid_ang = atan2(Y, X) - rad_azimuth;
/*
* For a derivation of this formulae confer
* Principles of Electron Optics page 1380
* in particular term defocus and twofold axial astigmatism
* take into account that a1 and a2 are the coefficient
* of the zernike polynomials difference of defocus at 0
* and at 45 degrees. In this case a2=0
*/
double cos_ellipsoid_ang_2 = cos(2*ellipsoid_ang);
return (defocus_average + defocus_deviation*cos_ellipsoid_ang_2);
}
/// Generate (Fourier-space, i.e. FFTW format) image with all CTF values.
/// The dimensions of the result array should have been set correctly already
void getFftwImage(MultidimArray < double > &result, int orixdim, int oriydim, double angpix,
bool do_abs = false, bool do_only_flip_phases = false, bool do_intact_until_first_peak = false, bool do_damping = true);
/// Generate a centered image (with hermitian symmetry)
void getCenteredImage(MultidimArray < double > &result, double angpix,
bool do_abs = false, bool do_only_flip_phases = false, bool do_intact_until_first_peak = false, bool do_damping = true);
};
//@}
#endif
|