12 #ifndef IMPKERNEL_QUAD_CONTAINER_H
13 #define IMPKERNEL_QUAD_CONTAINER_H
15 #include <IMP/kernel_config.h>
16 #include "internal/IndexingIterator.h"
18 #include "container_base.h"
19 #include "internal/container_helpers.h"
20 #include "DerivativeAccumulator.h"
30 IMPKERNEL_BEGIN_NAMESPACE
61 if (get_provides_access())
65 if (contents_hash_ != nhash || !cache_initialized_) {
66 contents_hash_ = nhash;
67 cache_initialized_ =
true;
70 return contents_cache_;
85 return IMP::internal::get_particle(get_model(),
get_indexes());
89 return IMP::internal::get_particle(get_model(),
get_indexes()[i]);
91 unsigned int get_number()
const {
return get_indexes().size(); }
93 bool get_provides_access()
const;
98 template <
class Functor>
99 Functor for_each(Functor f) {
102 return std::for_each(vs.begin(), vs.end(), f);
114 IMPKERNEL_DEPRECATED_METHOD_DECL(2.1)
119 std::string name =
"QuadContainer %1%");
121 virtual void do_apply(
const QuadModifier *sm)
const = 0;
122 virtual bool do_get_provides_access()
const {
return false; }
127 mutable std::size_t contents_hash_;
129 mutable bool cache_initialized_;
136 #if !defined(SWIG) && !defined(IMP_DOXYGEN)
170 void set_name_if_default(std::string name);
173 IMPKERNEL_END_NAMESPACE
Control display of deprecation information.
Various general useful macros for IMP.
A class to store an fixed array of same-typed values.
std::size_t get_contents_hash() const
Classes to handle individual model particles.
A smart pointer to a reference counted object.
Class for storing model, its restraints, constraints, and particles.
QuadContainerAdaptor(IMP::internal::PointerBase< C > c)
Various general useful macros for IMP.
An exception for a request for an invalid member of a container.
A shared container for Quads.
Classes to handle individual model particles. (Note that implementation of inline functions is in int...
#define IMP_THROW(message, exception_name)
Throw an exception with a message.
A nullptr-initialized pointer to an IMP Object.
Exception definitions and assertions.
#define IMP_REF_COUNTED_NONTRIVIAL_DESTRUCTOR(Name)
A base class for modifiers of ParticleQuadsTemp.
ParticleIndexes get_indexes(const ParticlesTemp &ps)
Abstract class for containers of particles.