mirror of
				https://github.com/python/cpython.git
				synced 2025-10-26 19:24:34 +00:00 
			
		
		
		
	Closes patch 529408 deprecating random.stdgamma().
This commit is contained in:
		
							parent
							
								
									bdc8289e06
								
							
						
					
					
						commit
						b760efb08d
					
				
					 1 changed files with 35 additions and 11 deletions
				
			
		|  | @ -445,14 +445,15 @@ def vonmisesvariate(self, mu, kappa): | ||||||
| ## -------------------- gamma distribution -------------------- | ## -------------------- gamma distribution -------------------- | ||||||
| 
 | 
 | ||||||
|     def gammavariate(self, alpha, beta): |     def gammavariate(self, alpha, beta): | ||||||
|         # beta times standard gamma |          | ||||||
|         return beta * self.stdgamma(alpha) |         # alpha > 0, beta > 0, mean is alpha*beta, variance is alpha*beta**2 | ||||||
| 
 |          | ||||||
|     def stdgamma(self, alpha, *args):  # *args for Py2.2 compatiblity | 	# Warning: a few older sources define the gamma distribution in terms | ||||||
|  | 	# of alpha > -1.0 | ||||||
|  | 	if alpha <= 0.0 or beta <= 0.0: | ||||||
|  | 	    raise ValueError, 'gammavariate: alpha and beta must be > 0.0' | ||||||
|  |          | ||||||
|         random = self.random |         random = self.random | ||||||
|         if alpha <= 0.0: |  | ||||||
|             raise ValueError, 'stdgamma: alpha must be > 0.0' |  | ||||||
| 
 |  | ||||||
|         if alpha > 1.0: |         if alpha > 1.0: | ||||||
| 
 | 
 | ||||||
|             # Uses R.C.H. Cheng, "The generation of Gamma |             # Uses R.C.H. Cheng, "The generation of Gamma | ||||||
|  | @ -471,14 +472,14 @@ def stdgamma(self, alpha, *args):  # *args for Py2.2 compatiblity | ||||||
|                 z = u1*u1*u2 |                 z = u1*u1*u2 | ||||||
|                 r = bbb+ccc*v-x |                 r = bbb+ccc*v-x | ||||||
|                 if r + SG_MAGICCONST - 4.5*z >= 0.0 or r >= _log(z): |                 if r + SG_MAGICCONST - 4.5*z >= 0.0 or r >= _log(z): | ||||||
|                     return x |                     return x * beta | ||||||
| 
 | 
 | ||||||
|         elif alpha == 1.0: |         elif alpha == 1.0: | ||||||
|             # expovariate(1) |             # expovariate(1) | ||||||
|             u = random() |             u = random() | ||||||
|             while u <= 1e-7: |             while u <= 1e-7: | ||||||
|                 u = random() |                 u = random() | ||||||
|             return -_log(u) |             return -_log(u) * beta | ||||||
| 
 | 
 | ||||||
|         else:   # alpha is between 0 and 1 (exclusive) |         else:   # alpha is between 0 and 1 (exclusive) | ||||||
| 
 | 
 | ||||||
|  | @ -497,7 +498,27 @@ def stdgamma(self, alpha, *args):  # *args for Py2.2 compatiblity | ||||||
|                 if not (((p <= 1.0) and (u1 > _exp(-x))) or |                 if not (((p <= 1.0) and (u1 > _exp(-x))) or | ||||||
|                           ((p > 1)  and  (u1 > pow(x, alpha - 1.0)))): |                           ((p > 1)  and  (u1 > pow(x, alpha - 1.0)))): | ||||||
|                     break |                     break | ||||||
|             return x |             return x * beta | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |     def stdgamma(self, alpha, ainv, bbb, ccc): | ||||||
|  |         # This method was (and shall remain) undocumented. | ||||||
|  |         # This method is deprecated | ||||||
|  |         # for the following reasons: | ||||||
|  |         # 1. Returns same as .gammavariate(alpha, 1.0) | ||||||
|  |         # 2. Requires caller to provide 3 extra arguments | ||||||
|  |         #    that are functions of alpha anyway | ||||||
|  |         # 3. Can't be used for alpha < 0.5 | ||||||
|  | 
 | ||||||
|  |         # ainv = sqrt(2 * alpha - 1) | ||||||
|  |         # bbb = alpha - log(4) | ||||||
|  |         # ccc = alpha + ainv | ||||||
|  |         import warnings | ||||||
|  |         warnings.warn("The stdgamma function is deprecated; " | ||||||
|  |                       "use gammavariate() instead", | ||||||
|  |                       DeprecationWarning) | ||||||
|  |         return self.gammavariate(alpha, 1.0) | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| ## -------------------- Gauss (faster alternative) -------------------- | ## -------------------- Gauss (faster alternative) -------------------- | ||||||
|  | @ -596,7 +617,7 @@ def _test_generator(n, funccall): | ||||||
|     print 'avg %g, stddev %g, min %g, max %g' % \ |     print 'avg %g, stddev %g, min %g, max %g' % \ | ||||||
|               (avg, stddev, smallest, largest) |               (avg, stddev, smallest, largest) | ||||||
| 
 | 
 | ||||||
| def _test(N=200): | def _test(N=20000): | ||||||
|     print 'TWOPI         =', TWOPI |     print 'TWOPI         =', TWOPI | ||||||
|     print 'LOG4          =', LOG4 |     print 'LOG4          =', LOG4 | ||||||
|     print 'NV_MAGICCONST =', NV_MAGICCONST |     print 'NV_MAGICCONST =', NV_MAGICCONST | ||||||
|  | @ -607,6 +628,9 @@ def _test(N=200): | ||||||
|     _test_generator(N, 'cunifvariate(0.0, 1.0)') |     _test_generator(N, 'cunifvariate(0.0, 1.0)') | ||||||
|     _test_generator(N, 'expovariate(1.0)') |     _test_generator(N, 'expovariate(1.0)') | ||||||
|     _test_generator(N, 'vonmisesvariate(0.0, 1.0)') |     _test_generator(N, 'vonmisesvariate(0.0, 1.0)') | ||||||
|  |     _test_generator(N, 'gammavariate(0.01, 1.0)') | ||||||
|  |     _test_generator(N, 'gammavariate(0.1, 1.0)') | ||||||
|  |     _test_generator(N, 'gammavariate(0.1, 2.0)')     | ||||||
|     _test_generator(N, 'gammavariate(0.5, 1.0)') |     _test_generator(N, 'gammavariate(0.5, 1.0)') | ||||||
|     _test_generator(N, 'gammavariate(0.9, 1.0)') |     _test_generator(N, 'gammavariate(0.9, 1.0)') | ||||||
|     _test_generator(N, 'gammavariate(1.0, 1.0)') |     _test_generator(N, 'gammavariate(1.0, 1.0)') | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Raymond Hettinger
						Raymond Hettinger