/usr/include/BALL/STRUCTURE/geometricTransformations.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 | // -*- Mode: C++; tab-width: 2; -*-
// vi: set ts=2:
//
#ifndef BALL_STRUCTURE_GEOMETRICTRANSFORMATIONS_H
#define BALL_STRUCTURE_GEOMETRICTRANSFORMATIONS_H
#ifndef BALL_COMMON_H
# include <BALL/common.h>
#endif
#ifndef BALL_KERNEL_ATOM_H
# include <BALL/KERNEL/atom.h>
#endif
#ifndef BALL_MATHS_VECTOR3_H
# include <BALL/MATHS/vector3.h>
#endif
#ifndef BALL_MATHS_MATRIX44_H
# include <BALL/MATHS/matrix44.h>
#endif
#ifndef BALL_CONCEPT_PROCESSOR_H
# include <BALL/CONCEPT/processor.h>
#endif
namespace BALL
{
/** @name Geometric transformation applicators
*/
//@{
/** Translation processor.
This processor executes a translation on each atom of a given Composite object.
The translation may be given in the constructor, or by calling setTranslation.
Applying the processor to a given Composite object will add the given
translation vector to the coordinates of each Atom object (and derived classes). \par
\ingroup StructureGeometric
*/
class BALL_EXPORT TranslationProcessor
: public UnaryProcessor<Atom>
{
public:
/** Default constructor.
The translation applicator object is initialized and the
transformation is set to (0, 0, 0).
*/
TranslationProcessor();
/** Constructor.
Creates a new instance of a TranslationProcessor and sets
the translation vector.
@param translation the new translation vector
*/
TranslationProcessor(const Vector3& translation);
/** Sets a new translation.
@param translation the new translation vector
*/
void setTranslation(const Vector3& translation);
/** Returns the translation vector.
@return the current translation vector
*/
const Vector3& getTranslation() const;
/// Applicator method
virtual Processor::Result operator()(Atom& atom);
private:
Vector3 translation_;
};
/** Transformation applicator.
This applicator executes a transformation on each atom of a given Composite object.
The transformation may be given in the constructor, or by calling setTransformation.
Applying the applicator to a given Composite object will multiply the coordinates
of each Atom object (or objects derived from Atom) with the given transformation
matrix. \par
\ingroup StructureMiscellaneous
*/
class BALL_EXPORT TransformationProcessor
:public UnaryProcessor<Atom>
{
public:
/** Default constructor.
The transformation applicator is initialized and the transformation
is set to identity:
\[
\left( \begin{array}{cccc}
1 & 0 & 0 & 0 \par
0 & 1 & 0 & 0 \par
0 & 0 & 1 & 0 \par
0 & 0 & 0 & 1 \par
\end{array}
\right)
\]
*/
TransformationProcessor();
/** Constructor.
Creates a new instance of a TransformationProcessor and sets
the transformation matrix.
@param transformation the new transformation matrix
*/
TransformationProcessor(const Matrix4x4& transformation);
/** Sets a new transformation.
@param transformation the new transformation matrix
*/
void setTransformation(const Matrix4x4& transformation);
/** Returns the transformation vector.
@return the current transformation matrix
*/
const Matrix4x4& getTransformation() const;
/// Applicator method
virtual Processor::Result operator()(Atom& atom);
protected:
Matrix4x4 transformation_;
};
//@}
} // namespace BALL
#endif // BALL_STRUCTURE_GEOMETRICTRANSFORMATIONS_H
|