| 
									
										
										
										
											2011-02-18 13:58:08 +00:00
										 |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  |  * This program is free software; you can redistribute it and/or | 
					
						
							|  |  |  |  * modify it under the terms of the GNU General Public License | 
					
						
							|  |  |  |  * as published by the Free Software Foundation; either version 2 | 
					
						
							| 
									
										
										
										
											2008-04-16 22:40:48 +00:00
										 |  |  |  * of the License, or (at your option) any later version. | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * This program is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  |  * GNU General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU General Public License | 
					
						
							|  |  |  |  * along with this program; if not, write to the Free Software Foundation, | 
					
						
							| 
									
										
										
										
											2010-02-12 13:34:04 +00:00
										 |  |  |  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * The Original Code is Copyright (C) 2001-2002 by NaN Holding BV. | 
					
						
							|  |  |  |  * All rights reserved. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2018-06-17 16:32:54 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-17 18:59:41 +00:00
										 |  |  | #ifndef __BLI_RAND_H__
 | 
					
						
							|  |  |  | #define __BLI_RAND_H__
 | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-10 13:54:57 +01:00
										 |  |  | #include "BLI_compiler_attrs.h"
 | 
					
						
							| 
									
										
										
										
											2020-05-15 12:48:10 +02:00
										 |  |  | #include "BLI_sys_types.h"
 | 
					
						
							| 
									
										
										
										
											2020-02-10 13:54:57 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-02-18 08:08:12 +11:00
										 |  |  | /** \file
 | 
					
						
							|  |  |  |  * \ingroup bli | 
					
						
							|  |  |  |  * \brief Random number functions. | 
					
						
							| 
									
										
										
										
											2011-02-18 13:58:08 +00:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-14 23:36:50 +02:00
										 |  |  | #ifdef __cplusplus
 | 
					
						
							|  |  |  | extern "C" { | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-15 23:12:40 +00:00
										 |  |  | /* RNG is an abstract random number generator type that avoids using globals.
 | 
					
						
							|  |  |  |  * Always use this instead of the global RNG unless you have a good reason, | 
					
						
							|  |  |  |  * the global RNG is not thread safe and will not give repeatable results. | 
					
						
							| 
									
										
										
										
											2011-02-18 13:58:08 +00:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2005-07-25 20:33:10 +00:00
										 |  |  | struct RNG; | 
					
						
							| 
									
										
										
										
											2005-07-25 20:56:48 +00:00
										 |  |  | typedef struct RNG RNG; | 
					
						
							| 
									
										
										
										
											2005-07-25 20:33:10 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Fix T42139, vertical noise stripe patterns in noise texture.
Two fixes here (only the second one is strictly needed to fix the issue,
but both make the system better).
First is introduction of a random generator array for use with threaded
systems where each thread needs to access its own number generator.
The random texture now uses this so it should not be influenced by other
random generator reseedings of the main random generator like it did
before.
Second, I reshuffled the texture code to resample the upper bits of the
random number first. According to Numerical Recipes, this is where the
most variance can be found, so by sampling those we avoid correlation
issues. Also, multiplying here is not ideal because if a pair of bits
are zero, then the whole result will also be zero.
Overall this is much more random (tm) than before, however result will
also be brighter, since we now have less black spots. Tweaking the
brightness/contrast should somewhat fix that, generally having the same
result as before is not possible anyway if we are to really fix this.
Also, seems like exposing procedural depth might be nice here since it
influences the precision of the texture lookup.
											
										 
											2014-10-09 15:48:38 +02:00
										 |  |  | struct RNG_THREAD_ARRAY; | 
					
						
							|  |  |  | typedef struct RNG_THREAD_ARRAY RNG_THREAD_ARRAY; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-10-23 13:50:44 +00:00
										 |  |  | struct RNG *BLI_rng_new(unsigned int seed); | 
					
						
							| 
									
										
										
										
											2013-04-15 23:12:40 +00:00
										 |  |  | struct RNG *BLI_rng_new_srandom(unsigned int seed); | 
					
						
							| 
									
										
										
										
											2019-02-18 16:59:31 +01:00
										 |  |  | struct RNG *BLI_rng_copy(struct RNG *rng) ATTR_NONNULL(1); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | void BLI_rng_free(struct RNG *rng) ATTR_NONNULL(1); | 
					
						
							| 
									
										
										
										
											2005-07-25 20:33:10 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | void BLI_rng_seed(struct RNG *rng, unsigned int seed) ATTR_NONNULL(1); | 
					
						
							|  |  |  | void BLI_rng_srandom(struct RNG *rng, unsigned int seed) ATTR_NONNULL(1); | 
					
						
							|  |  |  | void BLI_rng_get_char_n(RNG *rng, char *bytes, size_t bytes_len) ATTR_NONNULL(1, 2); | 
					
						
							|  |  |  | int BLI_rng_get_int(struct RNG *rng) ATTR_WARN_UNUSED_RESULT ATTR_NONNULL(1); | 
					
						
							| 
									
										
										
										
											2014-07-17 18:56:13 +10:00
										 |  |  | unsigned int BLI_rng_get_uint(struct RNG *rng) ATTR_WARN_UNUSED_RESULT ATTR_NONNULL(1); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | double BLI_rng_get_double(struct RNG *rng) ATTR_WARN_UNUSED_RESULT ATTR_NONNULL(1); | 
					
						
							|  |  |  | float BLI_rng_get_float(struct RNG *rng) ATTR_WARN_UNUSED_RESULT ATTR_NONNULL(1); | 
					
						
							|  |  |  | void BLI_rng_get_float_unit_v2(struct RNG *rng, float v[2]) ATTR_NONNULL(1, 2); | 
					
						
							|  |  |  | void BLI_rng_get_float_unit_v3(struct RNG *rng, float v[3]) ATTR_NONNULL(1, 2); | 
					
						
							|  |  |  | void BLI_rng_get_tri_sample_float_v2(struct RNG *rng, | 
					
						
							|  |  |  |                                      const float v1[2], | 
					
						
							|  |  |  |                                      const float v2[2], | 
					
						
							|  |  |  |                                      const float v3[2], | 
					
						
							|  |  |  |                                      float r_pt[2]) ATTR_NONNULL(); | 
					
						
							|  |  |  | void BLI_rng_shuffle_array(struct RNG *rng, | 
					
						
							|  |  |  |                            void *data, | 
					
						
							|  |  |  |                            unsigned int elem_size_i, | 
					
						
							|  |  |  |                            unsigned int elem_tot) ATTR_NONNULL(1, 2); | 
					
						
							| 
									
										
										
										
											2005-07-25 20:33:10 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-12 20:39:39 +00:00
										 |  |  | /** Note that skipping is as slow as generating n numbers! */ | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | void BLI_rng_skip(struct RNG *rng, int n) ATTR_NONNULL(1); | 
					
						
							| 
									
										
										
										
											2007-12-04 13:57:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-31 10:22:19 +02:00
										 |  |  | /* fill an array with random numbers */ | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | void BLI_array_frand(float *ar, int count, unsigned int seed); | 
					
						
							| 
									
										
										
										
											2018-07-31 10:22:19 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-15 23:12:40 +00:00
										 |  |  | /** Return a pseudo-random (hash) float from an integer value */ | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | float BLI_hash_frand(unsigned int seed) ATTR_WARN_UNUSED_RESULT; | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-25 01:14:39 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Shuffle an array randomly using the given seed contents. | 
					
						
							|  |  |  |  * This routine does not use nor modify the state of the BLI random number generator. | 
					
						
							| 
									
										
										
										
											2012-05-12 20:39:39 +00:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | void BLI_array_randomize(void *data, | 
					
						
							|  |  |  |                          unsigned int elem_size, | 
					
						
							|  |  |  |                          unsigned int elem_tot, | 
					
						
							|  |  |  |                          unsigned int seed); | 
					
						
							| 
									
										
										
										
											2005-08-25 13:11:04 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-12 20:39:39 +00:00
										 |  |  | /** Better seed for the random number generator, using noise.c hash[] */ | 
					
						
							|  |  |  | /** Allows up to BLENDER_MAX_THREADS threads to address */ | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | void BLI_thread_srandom(int thread, unsigned int seed); | 
					
						
							| 
									
										
										
										
											2005-08-25 13:11:04 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-12 20:39:39 +00:00
										 |  |  | /** Return a pseudo-random number N where 0<=N<(2^31) */ | 
					
						
							|  |  |  | /** Allows up to BLENDER_MAX_THREADS threads to address */ | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | int BLI_thread_rand(int thread) ATTR_WARN_UNUSED_RESULT; | 
					
						
							| 
									
										
										
										
											2005-08-25 13:11:04 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-12 20:39:39 +00:00
										 |  |  | /** Return a pseudo-random number N where 0.0f<=N<1.0f */ | 
					
						
							|  |  |  | /** Allows up to BLENDER_MAX_THREADS threads to address */ | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | float BLI_thread_frand(int thread) ATTR_WARN_UNUSED_RESULT; | 
					
						
							| 
									
										
										
										
											2005-08-25 13:11:04 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Fix T42139, vertical noise stripe patterns in noise texture.
Two fixes here (only the second one is strictly needed to fix the issue,
but both make the system better).
First is introduction of a random generator array for use with threaded
systems where each thread needs to access its own number generator.
The random texture now uses this so it should not be influenced by other
random generator reseedings of the main random generator like it did
before.
Second, I reshuffled the texture code to resample the upper bits of the
random number first. According to Numerical Recipes, this is where the
most variance can be found, so by sampling those we avoid correlation
issues. Also, multiplying here is not ideal because if a pair of bits
are zero, then the whole result will also be zero.
Overall this is much more random (tm) than before, however result will
also be brighter, since we now have less black spots. Tweaking the
brightness/contrast should somewhat fix that, generally having the same
result as before is not possible anyway if we are to really fix this.
Also, seems like exposing procedural depth might be nice here since it
influences the precision of the texture lookup.
											
										 
											2014-10-09 15:48:38 +02:00
										 |  |  | /** array versions for thread safe random generation */ | 
					
						
							|  |  |  | RNG_THREAD_ARRAY *BLI_rng_threaded_new(void); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | void BLI_rng_threaded_free(struct RNG_THREAD_ARRAY *rngarr) ATTR_NONNULL(1); | 
					
						
							|  |  |  | int BLI_rng_thread_rand(RNG_THREAD_ARRAY *rngarr, int thread) ATTR_WARN_UNUSED_RESULT; | 
					
						
							| 
									
										
											  
											
												Fix T42139, vertical noise stripe patterns in noise texture.
Two fixes here (only the second one is strictly needed to fix the issue,
but both make the system better).
First is introduction of a random generator array for use with threaded
systems where each thread needs to access its own number generator.
The random texture now uses this so it should not be influenced by other
random generator reseedings of the main random generator like it did
before.
Second, I reshuffled the texture code to resample the upper bits of the
random number first. According to Numerical Recipes, this is where the
most variance can be found, so by sampling those we avoid correlation
issues. Also, multiplying here is not ideal because if a pair of bits
are zero, then the whole result will also be zero.
Overall this is much more random (tm) than before, however result will
also be brighter, since we now have less black spots. Tweaking the
brightness/contrast should somewhat fix that, generally having the same
result as before is not possible anyway if we are to really fix this.
Also, seems like exposing procedural depth might be nice here since it
influences the precision of the texture lookup.
											
										 
											2014-10-09 15:48:38 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-19 15:17:46 +11:00
										 |  |  | /* Low-discrepancy sequences. */ | 
					
						
							| 
									
										
										
										
											2017-09-26 20:54:27 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | /** Return the _n_th number of the given low-discrepancy sequence. */ | 
					
						
							| 
									
										
										
										
											2019-03-20 18:17:16 +11:00
										 |  |  | void BLI_halton_1d(unsigned int prime, double offset, int n, double *r); | 
					
						
							| 
									
										
										
										
											2020-07-13 11:27:09 +02:00
										 |  |  | void BLI_halton_2d(const unsigned int prime[2], double offset[2], int n, double *r); | 
					
						
							|  |  |  | void BLI_halton_3d(const unsigned int prime[3], double offset[3], int n, double *r); | 
					
						
							| 
									
										
										
										
											2019-03-20 18:17:16 +11:00
										 |  |  | void BLI_hammersley_1d(unsigned int n, double *r); | 
					
						
							| 
									
										
										
										
											2017-09-26 20:54:27 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | /** Return the whole low-discrepancy sequence up to _n_. */ | 
					
						
							| 
									
										
										
										
											2020-07-13 11:27:09 +02:00
										 |  |  | void BLI_halton_2d_sequence(const unsigned int prime[2], double offset[2], int n, double *r); | 
					
						
							| 
									
										
										
										
											2019-03-20 18:17:16 +11:00
										 |  |  | void BLI_hammersley_2d_sequence(unsigned int n, double *r); | 
					
						
							| 
									
										
										
										
											2017-09-26 20:54:27 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-14 23:36:50 +02:00
										 |  |  | #ifdef __cplusplus
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | #endif /* __BLI_RAND_H__ */
 |