| 
									
										
										
										
											1994-01-02 01:22:07 +00:00
										 |  |  | \section{Standard Module \sectcode{whrandom}} | 
					
						
							| 
									
										
										
										
											1997-07-17 16:34:52 +00:00
										 |  |  | \label{module-whrandom} | 
					
						
							| 
									
										
										
										
											1994-01-02 01:22:07 +00:00
										 |  |  | \stmodindex{whrandom} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1997-04-03 22:41:49 +00:00
										 |  |  | This module implements a Wichmann-Hill pseudo-random number generator | 
					
						
							|  |  |  | class that is also named \code{whrandom}.  Instances of the | 
					
						
							|  |  |  | \code{whrandom} class have the following methods: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | \begin{funcdesc}{choice}{seq} | 
					
						
							|  |  |  | Chooses a random element from the non-empty sequence \var{seq} and returns it. | 
					
						
							|  |  |  | \end{funcdesc} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-03-17 06:33:25 +00:00
										 |  |  | \begin{funcdesc}{randint}{a, b} | 
					
						
							| 
									
										
										
										
											1997-04-03 22:41:49 +00:00
										 |  |  | Returns a random integer \var{N} such that \code{\var{a}<=\var{N}<=\var{b}}. | 
					
						
							|  |  |  | \end{funcdesc} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1994-01-02 01:22:07 +00:00
										 |  |  | \begin{funcdesc}{random}{} | 
					
						
							|  |  |  | Returns the next random floating point number in the range [0.0 ... 1.0). | 
					
						
							|  |  |  | \end{funcdesc} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-03-17 06:33:25 +00:00
										 |  |  | \begin{funcdesc}{seed}{x, y, z} | 
					
						
							| 
									
										
										
										
											1994-01-02 01:22:07 +00:00
										 |  |  | Initializes the random number generator from the integers | 
					
						
							|  |  |  | \var{x}, | 
					
						
							|  |  |  | \var{y} | 
					
						
							|  |  |  | and | 
					
						
							|  |  |  | \var{z}. | 
					
						
							|  |  |  | When the module is first imported, the random number is initialized | 
					
						
							|  |  |  | using values derived from the current time. | 
					
						
							|  |  |  | \end{funcdesc} | 
					
						
							| 
									
										
										
										
											1997-04-03 22:41:49 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1998-03-17 06:33:25 +00:00
										 |  |  | \begin{funcdesc}{uniform}{a, b} | 
					
						
							| 
									
										
										
										
											1997-04-03 22:41:49 +00:00
										 |  |  | Returns a random real number \var{N} such that \code{\var{a}<=\var{N}<\var{b}}. | 
					
						
							|  |  |  | \end{funcdesc} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | When imported, the \code{whrandom} module also creates an instance of | 
					
						
							|  |  |  | the \code{whrandom} class, and makes the methods of that instance | 
					
						
							|  |  |  | available at the module level.  Therefore one can write either  | 
					
						
							|  |  |  | \code{N = whrandom.random()} or: | 
					
						
							| 
									
										
										
										
											1998-02-13 06:58:54 +00:00
										 |  |  | \begin{verbatim} | 
					
						
							| 
									
										
										
										
											1997-04-03 22:41:49 +00:00
										 |  |  | generator = whrandom.whrandom() | 
					
						
							|  |  |  | N = generator.random() | 
					
						
							| 
									
										
										
										
											1998-02-13 06:58:54 +00:00
										 |  |  | \end{verbatim} | 
					
						
							| 
									
										
										
										
											1997-07-17 16:34:52 +00:00
										 |  |  | %
 | 
					
						
							|  |  |  | \begin{seealso} | 
					
						
							|  |  |  | \seemodule{random}{generators for various random distributions} | 
					
						
							|  |  |  | \seetext{Wichmann, B. A. \& Hill, I. D., ``Algorithm AS 183:  | 
					
						
							|  |  |  | An efficient and portable pseudo-random number generator'',  | 
					
						
							| 
									
										
										
										
											1998-03-08 08:02:58 +00:00
										 |  |  | \emph{Applied Statistics} 31 (1982) 188-190} | 
					
						
							| 
									
										
										
										
											1997-07-17 16:34:52 +00:00
										 |  |  | \end{seealso} |