source: src/Descriptors/AtomsWithinDistanceOfDescriptor_impl.hpp@ 775f3f

Adding_MD_integration_tests Adding_StructOpt_integration_tests AutomationFragmentation_failures Candidate_v1.6.1 ChemicalSpaceEvaluator Enhanced_StructuralOptimization Enhanced_StructuralOptimization_continued Exclude_Hydrogens_annealWithBondGraph ForceAnnealing_with_BondGraph ForceAnnealing_with_BondGraph_contraction-expansion Gui_displays_atomic_force_velocity JobMarket_RobustOnKillsSegFaults JobMarket_StableWorkerPool PythonUI_with_named_parameters StoppableMakroAction TremoloParser_IncreasedPrecision
Last change on this file since 775f3f was 795c0f, checked in by Frederik Heber <heber@…>, 10 years ago

World::getAtoms() now has const versions as well.

  • this in turn required to adapt all AtomDescriptors and some fixes, e.g. predicate is now const member and works on const atom ptr.
  • Property mode set to 100644
File size: 918 bytes
Line 
1#ifndef ATOMSWITHINDISTANCEOFDESCRIPTOR_IMPL_HPP
2#define ATOMSWITHINDISTANCEOFDESCRIPTOR_IMPL_HPP
3
4// include config.h
5#ifdef HAVE_CONFIG_H
6#include <config.h>
7#endif
8
9#include "LinearAlgebra/Vector.hpp"
10
11#include "Descriptors/AtomDescriptor_impl.hpp"
12
13class AtomsWithinDistanceOfDescriptor_impl : public AtomDescriptor_impl
14{
15public:
16 AtomsWithinDistanceOfDescriptor_impl(const double _distance, const Vector &_position);
17 virtual ~AtomsWithinDistanceOfDescriptor_impl();
18
19 bool predicate(std::pair<atomId_t,const atom*> atom) const;
20
21protected:
22 // need to overide more than the standard methods to make this fast
23 virtual atom *find();
24 virtual const atom *find() const;
25 virtual std::vector<atom*> findAll();
26 virtual std::vector<const atom*> findAll() const;
27
28private:
29 const double distance;
30 const double distanceSquared;
31 const Vector position;
32};
33
34#endif //ATOMSWITHINDISTANCEOFDESCRIPTOR_IMPL_HPP
Note: See TracBrowser for help on using the repository browser.