This file is indexed.

/usr/include/BALL/NMR/anisotropyShiftProcessor.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
// -*- Mode: C++; tab-width: 2; -*-
// vi: set ts=2:
//
// $Id: anisotropyShiftProcessor.h,v 1.20.20.1 2007/08/07 17:22:59 aleru Exp $
//

#ifndef BALL_NMR_ANISOTROPYSHIFTPROCESSOR_H
#define BALL_NMR_ANISOTROPYSHIFTPROCESSOR_H

#ifndef BALL_KERNEL_BOND_H
# include <BALL/KERNEL/bond.h>
#endif

#ifndef BALL_KERNEL_ATOM_H
# include<BALL/KERNEL/atom.h>
#endif

#ifndef BALL_NMR_SHIFT_MODULE_H
#	include<BALL/NMR/shiftModule.h>
#endif

#include <list>

namespace BALL 
{		
	/**	Shift assignment processor implementing Anisotropy.
		\ingroup ShiftModulesNMR	
	*/
	class BALL_EXPORT AnisotropyShiftProcessor
		:	public ShiftModule
	{
		public:

    BALL_CREATE(AnisotropyShiftProcessor)

    /** @name Enums and Constants
    */
    //@{

    /** A symbolic name for the electric field contribution to the chemical shift
        @see ShiftModule::PROPERTY__SHIFT
    */
    static const char* PROPERTY__ANISOTROPY_SHIFT;
		
    //@}
 		/** @name	Constructors and Destructors
		*/
		//@{

		/**	Default constructor.
		*/
		AnisotropyShiftProcessor();

		/**	Copy constructor
		*/
		AnisotropyShiftProcessor(const AnisotropyShiftProcessor& processor);
		
		/**	Destructor
		*/
		virtual ~AnisotropyShiftProcessor();
		
		//@}
		/** @name	Processor specific functions.
		*/
		//@{

		/**	Finish method.
				Here chemical shift calculation is done.
				An iteration over every Hydrogen in <tt>proton_list_</tt> is started.
				For each of these Hydrogens an iteration is started over every effector bounds
				in <tt>eff_list_</tt>.
				<tt>c_atom</tt> is assigned the first atom of effector bond and <tt>o_atom</tt> is the second.
				If the actual proton is in another residue then <tt>c_atom</tt> calculation is started.
				The next bounded carbonate atom of <tt>c_atom</tt> is stored in <tt>x_atom</tt>.
				Now we have three atoms with their positions stored in 
				<tt>c_pos</tt> , <tt>o_pos</tt> and <tt>x_pos</tt>.  \par
				We then build a cartesian coordinate system with these vectors.  \par
				<tt>vz</tt> = <tt>o_pos</tt> - <tt>c_pos</tt> and vz is normalized.
				<tt>vy</tt> is the vectorproduct of vz and the difference vector of <tt>x_pos</tt> and <tt>c_pos</tt>
				and is normalized.
				<tt>vx</tt> is the vectorproduct of vz and vy and is normalized.
				Then the center <tt>cen</tt> of the effector bound is set to  \par
 
				<tt>c_pos</tt> + 1.1 * <tt>vz</tt>.  \par
  \par
				Next three vectors are calculated :
				<tt>v1</tt> is the difference vector of the actual hydrogen and <tt>cen</tt>.
				<tt>v2</tt> is the vectorproduct of <tt>v1</tt> and <tt>vy</tt>.
				<tt>v3</tt> is the vectorproduct of <tt>v2</tt> and <tt>vx</tt>.
				<tt>abstand</tt> is assigned the length of vector <tt>v1</tt>.
				Then <tt>stheta</tt> is assigned the sinus of the angle between <tt>v1</tt> and <tt>vy</tt>.
				The sinus of the angle between <tt>v2</tt> and <tt>vx</tt> is assigned to <tt>sgamma</tt>.
				Now preparations have finished and we can start the real shift calculation.  \par
  \par
				<tt>calc1</tt> = <tt>dX1</tt> * ( ( 3.0 * <tt>stheta</tt> * <tt> stheta</tt> ) - 2.0 ).  \par
				<tt>calc2</tt> = <tt>dX2</tt> * ( 1.0 - ( 3.0 * <tt>stheta</tt> * <tt> stheta</tt> * <tt> sgamma</tt> * <tt> sgamma</tt> ) )  \par
				<tt>ts</tt> = ( <tt>calc1</tt> + <tt>calc2</tt> ) / ( 3.0 * <tt> distance</tt> * <tt>distance</tt> * <tt>distance</tt> )  \par
				<tt>ts</tt> is added to <tt>gs</tt>.  \par
  \par
				<tt>dX1</tt> and <tt>dX2</tt> are some constant floats. 
				If the actual Hydrogens name is "H" the constant floats <tt>dXN1</tt> and <tt>dXN2</tt> are used instead.  \par
				If <tt>eff_list_</tt> has finished C=O anisotropy for actual Hydrogen is done and 
				iteration	over all C=N anisotropy effector bounds of <tt>eff_list_2_</tt> is started.  \par
				This calculation is very similar with just some differences :
				We got three position vectors called:
				<tt>c_pos</tt>
				<tt>o_pos</tt> position of 
				<tt>n_pos</tt> position of the Nitrogen bonded to Carbonate.  \par
				The cartesion coordinate system is built on 
				<tt>vz</tt> = <tt>n_pos</tt> - <tt>c_pos</tt>  \par
				<tt>vy</tt> is the vectorproduct of <tt>vz</tt> and the difference vector of <tt>o_pos</tt> and <tt> c_pos</tt>  \par
				<tt>vx</tt> is the vectorproduct of <tt>vz</tt> and <tt>vy</tt>.  \par
				The center of the effector bond is set to:  \par
				<tt>cen</tt> = <tt>c_pos</tt> + ( <tt>vz</tt> * ( 0.85 * length of <tt> vz</tt> ) )	 \par
  \par
				The final calculation is just the same as above, except the use of different constants.
				Use <tt>ndX1</tt> and <tt>ndX2</tt> instead of <tt>dX1</tt> and <tt> dX2</tt>
				and <tt>ndXN1</tt> and <tt>ndXN2</tt> intead of <tt>dXN1</tt> and <tt> dXN2</tt>.
				Finally C=N anisotropy has finished and <tt>gs</tt> is added to the actual hydrogens shift.
				Then iteration goes on with the next hydrogen.
		*/
		virtual bool finish();

		/**	Application method.
				Atoms are stored in three different lists , named  \par
				<tt>proton_list_</tt> that contains all Hydrogens,  \par
				<tt>eff_list_</tt> that contains all effectors of C=O anisotropy	and  \par
				<tt>eff_list_2_</tt> that contains all effectors of C=N anisotropy.
				Effectors of C=O anisotropy are all bounds between atoms named "C" and "O",
				as well as bounds between atoms named "CG" and "OD1" in residues called
				"ASP" or "ASN, and finally bounds between atoms named "CD" and "OE1" in 
				residues called "GLU" and "GLN".
				Effectors of C=N anisotropy are all bounds between atoms named "C" and "N".
		*/
		virtual Processor::Result operator() (Composite& composite);

		//@}
		/**	@name	Accessors
		*/
		//@{

		/**	Module initialization
		*/
		virtual void init();

		//@}
		
		protected:
		std::list<const Atom*> proton_list_;	
		std::list<const Bond*> eff_list_;
		std::list<const Bond*> eff_list_2_;
		bool ignore_other_chain_;
	};
  
} // namespace BALL

#endif // BALL_NMR_ANISOTROPYSHIFTPROCESSOR_H