IMP logo
IMP Reference Guide  develop.5ce362c3b9,2024/09/15
The Integrative Modeling Platform
SingletonModifier.h
Go to the documentation of this file.
1 // Autogenerated by ../../../../tmp/nightly-build-92850/imp-20240915.develop.5ce362c3b9/tools/build/make_containers.py
2 // from ../../../../tmp/nightly-build-92850/imp-20240915.develop.5ce362c3b9/tools/build/container_templates/kernel/ClassnameModifier.h
3 // Do not edit - any changes will be lost!
4 
5 /**
6  * \file IMP/SingletonModifier.h
7  * \brief A Modifier on ParticlesTemp
8  *
9  * Copyright 2007-2022 IMP Inventors. All rights reserved.
10  */
11 
12 #ifndef IMPKERNEL_SINGLETON_MODIFIER_H
13 #define IMPKERNEL_SINGLETON_MODIFIER_H
14 
15 #include <IMP/kernel_config.h>
16 #include "DerivativeAccumulator.h"
17 #include "base_types.h"
18 #include "internal/container_helpers.h"
19 #include "model_object_helpers.h"
20 
21 IMPKERNEL_BEGIN_NAMESPACE
22 
23 //! A base class for modifiers of ParticlesTemp
24 /** The primary function of such a class is to change
25  the passed particles.
26 
27  \see IMP::SingletonPredicate
28 
29  Implementers should see IMP_SINGLETON_MODIFIER(). Also see
30  SingletonDerivativeModifier.
31  */
32 class IMPKERNELEXPORT SingletonModifier : public ParticleInputs,
33  public ParticleOutputs,
34  public Object {
35  public:
36  typedef Particle* Argument;
38  SingletonModifier(std::string name = "SingletonModifier %1%");
39 
40  /** Apply the function to a single value*/
41  virtual void apply_index(Model *m, ParticleIndex v) const = 0;
42 
43  /** Apply the function to a collection of ParticlesTemp */
44  /** If bounds are passed, only apply to ones between the upper and
45  lower bounds.*/
46  virtual void apply_indexes(Model *m, const ParticleIndexes &o,
47  unsigned int lower_bound,
48  unsigned int upper_bound) const {
49  for (unsigned int i = lower_bound; i < upper_bound; ++i) {
50  apply_index(m, o[i]);
51  }
52  }
53 
54  /** Apply the function to a collection of ParticlesTemp */
55  /** Information on particles that moved since the last scoring function
56  evaluation is also passed, which may be used to accelerate the
57  computation. */
58  virtual void apply_indexes_moved(
59  Model *m, const ParticleIndexes &o,
60  unsigned int lower_bound, unsigned int upper_bound,
61  const ParticleIndexes &moved_pis,
62  const ParticleIndexes &reset_pis) const {
63  IMP_UNUSED(moved_pis);
64  IMP_UNUSED(reset_pis);
65  apply_indexes(m, o, lower_bound, upper_bound);
66  }
67 };
68 
69 IMPKERNEL_END_NAMESPACE
70 
71 #endif /* IMPKERNEL_SINGLETON_MODIFIER_H */
A base class for modifiers of ParticlesTemp.
Basic types used by IMP.
Base class for objects that take particle arguments and modify them.
Class for adding derivatives from restraints to the model.
Base class for objects that take particle arguments and read from them.
Class for storing model, its restraints, constraints, and particles.
Definition: Model.h:86
Common base class for heavy weight IMP objects.
Definition: Object.h:111
#define IMP_UNUSED(variable)
Classes used in the construction of ModelObjects.
virtual void apply_indexes_moved(Model *m, const ParticleIndexes &o, unsigned int lower_bound, unsigned int upper_bound, const ParticleIndexes &moved_pis, const ParticleIndexes &reset_pis) const
virtual void apply_indexes(Model *m, const ParticleIndexes &o, unsigned int lower_bound, unsigned int upper_bound) const
Class to handle individual particles of a Model object.
Definition: Particle.h:43