IMP
2.0.1
The Integrative Modeling Platform
Main Page
Related Pages
Modules
Namespaces
Classes
Files
Examples
File List
File Members
EnvelopeFitRestraint.h
Go to the documentation of this file.
1
/**
2
* \file EnvelopeFitRestraint.h
3
* \brief score envelope fit based on map distance transform
4
*
5
* \authors Dina Schneidman
6
* Copyright 2007-2013 IMP Inventors. All rights reserved.
7
*
8
*/
9
10
#ifndef IMPEM_ENVELOPE_FIT_RESTRAINT_H
11
#define IMPEM_ENVELOPE_FIT_RESTRAINT_H
12
13
#include <IMP/em/em_config.h>
14
#include <
IMP/em/PCAAligner.h
>
15
#include <
IMP/em/MapDistanceTransform.h
>
16
#include <
IMP/em/EnvelopeScore.h
>
17
#include <
IMP/base/object_macros.h
>
18
19
#include <
IMP/Restraint.h
>
20
21
IMPEM_BEGIN_NAMESPACE
22
23
//! A restraint for envelope-based scoring of particles in the density map
24
/**
25
The restraint fits the particles into the density map by alignment
26
of principal components of the particles with principal components
27
of the map. Therefore, the particle set should comprise all
28
subunits that fill the map. The aligned particles are scored using
29
EnvelopeScore. This is a fast alignment and scoring that works well
30
for low resolution density maps.
31
*/
32
class
IMPEMEXPORT
EnvelopeFitRestraint
:
public
IMP::Restraint
{
33
public
:
34
//! Constructor
35
/**
36
\param[in] particles The particles participating in the score
37
\param[in] em_map The density map used in the fitting score
38
\param[in] density_threshold Density map threshold
39
\param[in] penetration_threshold A distance for which penetration
40
of particles out of the map envelope (as defined by density_threshold)
41
is allowed. Recommended value is approximately map resolution
42
*/
43
EnvelopeFitRestraint
(Particles particles,
44
DensityMap
*em_map,
45
double
density_threshold,
46
double
penetration_threshold);
47
48
double
unprotected_evaluate(
IMP::DerivativeAccumulator
*accum)
const
;
49
50
// compute and return best scoring transofrmation
51
algebra::Transformation3D
get_transformation()
const
{
52
unprotected_evaluate(
nullptr
);
53
return
transformation_;
54
}
55
56
// compute best scoring transformation and apply it on the particles
57
void
apply_transformation();
58
59
IMP::ModelObjectsTemp
do_get_inputs
()
const
{
return
ps_; }
60
IMP_OBJECT_METHODS
(
EnvelopeFitRestraint
);
61
62
private
:
63
Particles ps_;
64
PCAAligner
pca_aligner_;
65
double
penetration_threshold_;
66
MapDistanceTransform
distance_transform_;
67
EnvelopeScore
envelope_score_;
68
69
// best scoring trans from last evaluate
70
IMP::algebra::Transformation3D
transformation_;
71
};
72
73
IMPEM_END_NAMESPACE
74
75
#endif
/* IMPEM_ENVELOPE_FIT_RESTRAINT_H */