IMP logo
IMP Reference Guide  develop.63b38c487d,2024/12/21
The Integrative Modeling Platform
InContainerPairFilter.h
Go to the documentation of this file.
1 // Autogenerated by ../../../../tmp/nightly-build-465/imp-20241221.develop.63b38c487d/tools/build/make_containers.py
2 // from ../../../../tmp/nightly-build-465/imp-20241221.develop.63b38c487d/tools/build/container_templates/container/InContainerClassnameFilter.h
3 // Do not edit - any changes will be lost!
4 
5 /**
6  * \file IMP/container/InContainerPairFilter.h
7  * \brief A filter for Pairs.
8  *
9  * Copyright 2007-2022 IMP Inventors. All rights reserved.
10  */
11 
12 #ifndef IMPCONTAINER_IN_CONTAINER_PAIR_FILTER_H
13 #define IMPCONTAINER_IN_CONTAINER_PAIR_FILTER_H
14 
15 #include <IMP/container/container_config.h>
16 #include <IMP/PairPredicate.h>
17 #include <IMP/PairContainer.h>
18 #include <IMP/internal/container_helpers.h>
19 #include "internal/PairContainerIndex.h"
20 #include <IMP/pair_macros.h>
21 #include <IMP/object_macros.h>
22 #include <IMP/warning_macros.h>
23 
24 IMPCONTAINER_BEGIN_NAMESPACE
25 
26 //! A filter which returns true if a container contains the Pair
27 /** This predicate returns 1 if the passed tuple is in the container.
28  \note Use the handle_permutations parameter to the constructor to
29  determine whether only exact matches, or matches under permutation
30  are considered matching. By default permutations are allowed.
31  */
32 class IMPCONTAINEREXPORT InContainerPairFilter
33  : public PairPredicate {
35 
36  public:
38  std::string name = "PairFilter %1%");
39  InContainerPairFilter(PairContainer *c, bool handle_permutations,
40  std::string name = "PairFilter %1%");
41 
42  virtual int get_value_index(Model *, const ParticleIndexPair& vt) const
43  override {
44  return c_->get_contains(vt);
45  }
47  Model *m, const ParticleIndexes &pi) const override {
49  ret.push_back(c_);
50  return ret;
51  }
54 };
55 
57 
58 IMPCONTAINER_END_NAMESPACE
59 
60 #endif /* IMPCONTAINER_IN_CONTAINER_PAIR_FILTER_H */
A filter which returns true if a container contains the Pair.
A shared container for Pairs.
Definition: PairContainer.h:39
Helper macros for implementing IMP Objects.
virtual int get_value_index(Model *, const ParticleIndexPair &vt) const override
Compute the predicate and the derivative if needed.
Macros for various classes.
#define IMP_OBJECT_METHODS(Name)
Define the basic things needed by any Object.
Definition: object_macros.h:25
ParticlesTemp get_particles(Model *m, const ParticleIndexes &ps)
Get the particles from a list of indexes.
A more IMP-like version of the std::vector.
Definition: Vector.h:50
Class for storing model, its restraints, constraints, and particles.
Definition: Model.h:86
A container for Pairs.
Macros to control compiler warnings.
Define PairPredicate.
virtual ModelObjectsTemp do_get_inputs(Model *m, const ParticleIndexes &pi) const override
Overload this method to specify the inputs.
#define IMP_OBJECTS(Name, PluralName)
Define the types for storing lists of object pointers.
Definition: object_macros.h:44
Abstract predicate function.
Definition: PairPredicate.h:31
#define IMP_PAIR_PREDICATE_METHODS(Name)
Define extra the functions needed for a PairPredicate.
Definition: pair_macros.h:78