This file is indexed.

/usr/include/BALL/MATHS/randomNumberGenerator.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
// -*- Mode: C++; tab-width: 2; -*-
// vi: set ts=2 sw=2
//
// $Id: randomNumberGenerator.h,v 1.1.18.1 2007/03/25 21:23:46 oliver Exp $
//

#ifndef BALL_MATHS_RANDOMNUMBERGENERATOR_H
#define BALL_MATHS_RANDOMNUMBERGENERATOR_H

#ifndef BALL_COMMON_GLOBAL_H
# include <BALL/COMMON/global.h>
#endif

#include<vector>

namespace BALL
{

	/** The following code is taken (and adapted to BALL's C++ interface)
		from the code provided at
		
		 	http://astronomy.swin.edu.au/~pbourke/other/random/

		The following comment stems from the original C source code:

		This Random Number Generator is based on the algorithm in a FORTRAN
		version published by George Marsaglia and Arif Zaman, Florida State
		University; ref.: see original comments below. 
		At the fhw (Fachhochschule Wiesbaden, W.Germany), Dept. of Computer
		Science, we have written sources in further languages (C, Modula-2
		Turbo-Pascal(3.0, 5.0), Basic and Ada) to get exactly the same test
		results compared with the original FORTRAN version. 
		pril 1989
		Karl-L. Noell <NOELL@DWIFH1.BITNET>
    		and  Helmut  Weber <WEBER@DWIFH1.BITNET>

		This random number generator originally appeared in "Toward a Universal
		Random Number Generator" by George Marsaglia and Arif Zaman.
		Florida State University Report: FSU-SCRI-87-50 (1987)
		It was later modified by F. James and published in "A Review of Pseudo-
		random Number Generators"
		THIS IS THE BEST KNOWN RANDOM NUMBER GENERATOR AVAILABLE.
		(However, a newly discovered technique can yield
		a period of 10^600. But that is still in the development stage.)
		It passes ALL of the tests for random number generators and has a period
		of 2^144, is completely portable (gives bit identical results on all
		machines with at least 24-bit mantissas in the floating point
		representation).
		The algorithm is a combination of a Fibonacci sequence (with lags of 97
		and 33, and operation "subtraction plus one, modulo one") and an
		"arithmetic sequence" (using subtraction).
		
		Use IJ = 1802 & KL = 9373 to test the random number generator. The
		subroutine RANMAR should be used to generate 20000 random numbers.
		Then display the next six random numbers generated multiplied by *4096
		If the random number generator is working properly, the random numbers
		should be:
			6533892.0  14220222.0  7275067.0
			6172232.0  8354498.0   10633180.0

	*/

	class BALL_EXPORT BALL_DEPRECATED RandomNumberGenerator
	{

		public:

			/// 
			RandomNumberGenerator();

			///
			RandomNumberGenerator(const RandomNumberGenerator& rng);

			///
			~RandomNumberGenerator();

			void setup(int ij = 1802, int kl = 9373);

			/**
				This is the random number generator proposed by George Marsaglia in
				Florida State University Report: FSU-SCRI-87-50
			*/
			double randomUniform();

			/** Random number generator from
				ALGORITHM 712, COLLECTED ALGORITHMS FROM ACM. THIS WORK PUBLISHED
				IN TRANSACTIONS ON MATHEMATICAL SOFTWARE, VOL. 18, NO. 4, DECEMBER,
				1992, PP. 434-435. The function returns a normally distributed
				pseudo-random number with a given mean and standard deviation.
				Calls are made to a function subprogram which must return
				independent random numbers uniform in the interval (0,1). The
				algorithm uses the ratio of uniforms method of A.J. Kinderman and
				J.F. Monahan augmented with quadratic bounding curves.
			*/
			double randomGaussian(double mean, double stddev);

			/** Generate a random integer in the interval [lower, upper]
			*/
			int randomInteger(int lower, int upper);

			/** Generate a random double in the interval (lower, upper)
			*/
			double randomDouble(double lower, double upper);

			///
			bool isValid() const
				
			{
				return(valid_);
			}

		private:

			//_
			std::vector<double> u_;

			//_
			double c_;

			//_
			double cd_;

			//_
			double cm_;

			//_
			int i97_;

			//_
			int j97_;

			//_ 
			bool valid_;


	};
}

#endif //  BALL_MATHS_RANDOMNUMBERGENERATOR_H