/usr/include/BALL/MOLMEC/COMMON/gradient.h is in libball1.4-dev 1.4.3~beta1-4.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 | // -*- Mode: C++; tab-width: 2; -*-
// vi: set ts=2:
//
// $Id: gradient.h,v 1.20.20.1 2007/05/18 12:02:44 oliver Exp $
//
// Author:
// Oliver Kohlbacher
//
// A conjugate gradient minimizer for geometry optimisation
#ifndef BALL_MOLMEC_COMMON_GRADIENT_H
#define BALL_MOLMEC_COMMON_GRADIENT_H
#ifndef BALL_COMMON_H
# include <BALL/common.h>
#endif
#ifndef BALL_MATHS_VECTOR3_H
# include <BALL/MATHS/vector3.h>
#endif
#include <vector>
namespace BALL
{
class AtomVector;
/** Gradient class.
This class is used in the Minimizers to represent gradients and
directions.
These gradients are extracted from a vector of atom pointers, if the
forces of the atoms are correctly set (e.g. using ForceField::updateForces()).
The gradient contains the negative forces from each atom. Forces are converted from Newton (N)
to units of f$kJ/(mol \AA)f$.
A gradient may be invalidated by calling \link invalidate invalidate \endlink . This method only
flags the gradient as invalid, the data is untouched. This may be used to
initiate automatic recalculations of the gradient.
This class is used by all minimizer classes. \par
\ingroup MolmecCommon
*/
class BALL_EXPORT Gradient
: private std::vector<Vector3>
{
public:
BALL_CREATE_DEEP(Gradient)
/** Type definitions
*/
//@{
/** Iterator type
*/
typedef std::vector<Vector3>::iterator Iterator;
/** Const iterator type
*/
typedef std::vector<Vector3>::const_iterator ConstIterator;
/** Iterator type
*/
typedef std::vector<Vector3>::reverse_iterator ReverseIterator;
/** Const iterator type
*/
typedef std::vector<Vector3>::const_reverse_iterator ConstReverseIterator;
//@}
/** @name Constructors and Destructors
*/
//@{
/** Default constructor.
*/
Gradient();
/** Construct from atom forces
*/
Gradient(const AtomVector& atoms);
/** Copy constructor
*/
Gradient(const Gradient& gradient, bool deep = true);
/** Destructor.
*/
virtual ~Gradient();
//@}
/** @name Assignments
*/
//@{
/** Assignment operator
*/
Gradient& operator = (const Gradient& rhs);
/** Assign from an array of atom pointers.
*/
Gradient& operator = (const AtomVector& rhs);
/** Assign from another gradient
*/
void set(const Gradient& gradient);
/** Assign from an array of atom pointers.
*/
void set(const AtomVector& atoms);
/** Negate the gradient.
Iterate over all force vectors of the gradient and
invert the signs.
*/
void negate();
/** Normalize the gradient.
Rescale to unity length
*/
void normalize();
/** Dot product operator
@exception InvalidRange if the two gradients have different sizes
*/
double operator * (const Gradient& gradient) const;
//@}
/** @name Accessors
*/
//@{
/* Return the number of components of the gradient.
*/
using std::vector<Vector3>::size;
/* Return the component for an atom.
*/
//?????: GCC3 using std::vector<Vector3>::operator [];
const Vector3& operator [] (int i) const { return std::vector<Vector3>::operator [] (i); }
Vector3& operator [] (int i) { return std::vector<Vector3>::operator [] (i); }
/** Invalidate the gradient.
*/
void invalidate();
/** Return the validity flag.
*/
bool isValid() const;
//@}
/** @name Iteration
*/
//@{
/** Return an iterator to the begining of the vector
*/
//?????: GCC3 using std::vector<Vector3>::begin;
Iterator begin() { return vector<Vector3>::begin(); }
ConstIterator begin() const { return vector<Vector3>::begin(); }
/** Return a past-the-end vector.
*/
//?????: GCC3 using std::vector<Vector3>::end;
Iterator end() { return vector<Vector3>::end(); }
ConstIterator end() const { return vector<Vector3>::end(); }
/** Return an iterator to the reverse begining of the vector
*/
//?????: GCC3 using std::vector<Vector3>::begin;
ReverseIterator rbegin() { return vector<Vector3>::rbegin(); }
ConstReverseIterator rbegin() const { return vector<Vector3>::rbegin(); }
/** Return a reverse past-the-end vector.
*/
//?????: GCC3 using std::vector<Vector3>::end;
ReverseIterator rend() { return vector<Vector3>::rend(); }
ConstReverseIterator rend() const { return vector<Vector3>::rend(); }
//@}
/** @name Public Attributes
*/
//@{
/** The gradient norm.
*/
double norm;
/** The inverse of the gradient norm.
*/
double inv_norm;
/** The root mean square of the gradient.
*/
double rms;
//@}
protected:
/*_ The validity flag.
*/
bool valid_;
};
} // end of namespace BALL
#endif // BALL_MOLMEC_COMMON_GRADIENT_H
|