home
about
news
download
doc
source
systems
tests
bugs
contact
IMP Reference Guide
develop.330bebda01,2025/01/21
The Integrative Modeling Platform
IMP Manual
Reference Guide
Tutorial Index
Modules
Classes
Examples
include
IMP
version 20250121.develop.330bebda01
SingletonScore.h
Go to the documentation of this file.
1
// Autogenerated by ../../../../tmp/nightly-build-474/imp-20250121.develop.330bebda01/tools/build/make_containers.py
2
// from ../../../../tmp/nightly-build-474/imp-20250121.develop.330bebda01/tools/build/container_templates/kernel/ClassnameScore.h
3
// Do not edit - any changes will be lost!
4
5
/**
6
* \file IMP/SingletonScore.h
7
* \brief Define SingletonScore.
8
*
9
* Copyright 2007-2022 IMP Inventors. All rights reserved.
10
*/
11
12
#ifndef IMPKERNEL_SINGLETON_SCORE_H
13
#define IMPKERNEL_SINGLETON_SCORE_H
14
15
#include <IMP/kernel_config.h>
16
#include "
base_types.h
"
17
#include "
DerivativeAccumulator.h
"
18
#include "internal/container_helpers.h"
19
#include <
IMP/utility_macros.h
>
20
#include <cereal/access.hpp>
21
#include <cereal/types/base_class.hpp>
22
#include "
model_object_helpers.h
"
23
24
IMPKERNEL_BEGIN_NAMESPACE
25
26
//! Abstract class for scoring object(s) of type ParticleIndex.
27
/** SingletonScore will evaluate the score and derivatives
28
for passed object(s) of type ParticleIndex.
29
30
Use in conjunction with various
31
restraints such as IMP::container::SingletonsRestraint or
32
IMP::core::SingletonRestraint. The restraints couple the score
33
functions with appropriate lists of object(s) of type ParticleIndex.
34
35
It is possible to call the various evaluate* methods directly, but
36
this is not recommended as they do not ensure that Model invariants
37
(e.g. ScoreStates) are preserved. Use a Restraint or ScoringFunction
38
to score the model instead.
39
40
Implementers should check out IMP_SINGLETON_SCORE_METHODS().
41
42
\see PredicateSingletonRestraint
43
*/
44
class
IMPKERNELEXPORT
SingletonScore
:
public
ParticleInputs
,
45
public
Object
{
46
public
:
47
typedef
Particle
*
Argument
;
48
typedef
ParticleIndex
IndexArgument
;
49
typedef
Particle
*
PassArgument
;
50
typedef
ParticleIndex
PassIndexArgument
;
51
typedef
SingletonModifier
Modifier
;
52
SingletonScore
(std::string name =
"SingletonScore %1%"
);
53
54
//! Compute the score and the derivative if needed.
55
/** @param m the model of vt
56
@param vt the index in m of an object of type Particle
57
@param da a DerivativeAccumulator that weights
58
computed derivatives. If nullptr, derivatives
59
will not be computed.
60
*/
61
virtual
double
evaluate_index(
Model
*m,
ParticleIndex
vt,
62
DerivativeAccumulator
*da)
const
= 0;
63
64
//! Compute the score and the derivative if needed over a set.
65
/** @param m the model of o
66
@param o objects of type Particle, specified by index
67
@param da a derivative accumulator that weights
68
computed derivatives. If nullptr, derivatives
69
will not be computed.
70
@param lower_bound index of first item in o to evaluate
71
@param upper_bound index one past last item in o to evaluate
72
73
@note An implementation for this is provided by
74
the IMP_SINGLETON_SCORE_METHODS() macro.
75
*/
76
virtual
double
evaluate_indexes(
Model
*m,
const
ParticleIndexes
&o,
77
DerivativeAccumulator
*da,
78
unsigned
int
lower_bound,
79
unsigned
int
upper_bound)
const
;
80
81
//! Compute the score and the derivative if needed over a set.
82
/** Like regular evaluate_indexes(), but the score for each o[x] is also
83
returned as score[x].
84
85
@note An implementation for this is provided by
86
the IMP_SINGLETON_SCORE_METHODS() macro.
87
*/
88
virtual
double
evaluate_indexes_scores(
89
Model
*m,
const
ParticleIndexes
&o,
90
DerivativeAccumulator
*da,
91
unsigned
int
lower_bound,
92
unsigned
int
upper_bound,
93
std::vector<double> &score)
const
;
94
95
//! Compute the change in score and the derivative if needed over a set.
96
/** The score for each o[indexes[x]] is updated in score[indexes[x]]
97
and the total difference between the old and new score values (over the
98
set) is returned.
99
100
@note An implementation for this is provided by
101
the IMP_SINGLETON_SCORE_METHODS() macro.
102
*/
103
virtual
double
evaluate_indexes_delta(
104
Model
*m,
const
ParticleIndexes
&o,
105
DerivativeAccumulator
*da,
106
const
std::vector<unsigned> &indexes,
107
std::vector<double> &score)
const
;
108
109
//! Compute the score and the derivative if needed, only if "good".
110
/** This functions similarly to evaluate_index(),
111
but may terminate the computation early if the score is higher than max.
112
113
@return the score if score<= max or some arbitrary value > max otherwise.
114
*/
115
virtual
double
evaluate_if_good_index(
Model
*m,
ParticleIndex
vt,
116
DerivativeAccumulator
*da,
117
double
max)
const
;
118
119
/** Compute the score and the derivative if needed over a set, only if "good".
120
This functions similarly to evaluate_indexes(), but may terminate
121
the computation early if the total score is higher than max.
122
123
@return the score if score<= max or some arbitrary value > max otherwise.
124
125
@note An implementation for this is provided by
126
the IMP_SINGLETON_SCORE_METHODS() macro.
127
*/
128
virtual
double
evaluate_if_good_indexes(
Model
*m,
129
const
ParticleIndexes
&o,
130
DerivativeAccumulator
*da,
double
max,
131
unsigned
int
lower_bound,
132
unsigned
int
upper_bound)
const
;
133
134
//! Decompose this SingletonScore into a set of
135
//! currently positive restraints over vt.
136
/** The scoring function and derivatives should
137
be equal to the current score. The default implementation
138
returns a single restraint with this score bound to vt,
139
or zero restraints if the score equals zero.
140
*/
141
Restraints
create_current_decomposition(
Model
*m,
142
ParticleIndex
vt)
const
;
143
144
protected
:
145
//! Override this to return your own decomposition.
146
virtual
Restraints
do_create_current_decomposition(
Model
*m,
147
ParticleIndex
vt)
const
;
148
149
IMP_REF_COUNTED_DESTRUCTOR
(
SingletonScore
);
150
151
private
:
152
friend
class
cereal::access;
153
154
template
<
class
Archive>
void
serialize(Archive &ar) {
155
// Neither we nor ParticleInputs stores data, but Object does
156
ar(cereal::base_class<Object>(
this
));
157
}
158
};
159
160
IMPKERNEL_END_NAMESPACE
161
162
#endif
/* IMPKERNEL_SINGLETON_SCORE_H */
IMP::SingletonModifier
A base class for modifiers of ParticlesTemp.
Definition:
SingletonModifier.h:32
base_types.h
Basic types used by IMP.
DerivativeAccumulator.h
Class for adding derivatives from restraints to the model.
IMP::Index< ParticleIndexTag >
IMP::ParticleInputs
Base class for objects that take particle arguments and read from them.
Definition:
model_object_helpers.h:18
IMP_REF_COUNTED_DESTRUCTOR
#define IMP_REF_COUNTED_DESTRUCTOR(Name)
Set up destructor for a ref counted object.
Definition:
ref_counted_macros.h:25
IMP::Vector< ParticleIndex, std::allocator< ParticleIndex > >
IMP::Model
Class for storing model, its restraints, constraints, and particles.
Definition:
Model.h:86
IMP::Object
Common base class for heavy weight IMP objects.
Definition:
Object.h:111
IMP::SingletonScore
Abstract class for scoring object(s) of type ParticleIndex.
Definition:
SingletonScore.h:44
model_object_helpers.h
Classes used in the construction of ModelObjects.
utility_macros.h
Various general useful macros for IMP.
IMP::Particle
Class to handle individual particles of a Model object.
Definition:
Particle.h:43
IMP::DerivativeAccumulator
Class for adding derivatives from restraints to the model.
Definition:
DerivativeAccumulator.h:24