remove wrap word, add circular to mersenne twister
							parent
							
								
									7b457218ab
								
							
						
					
					
						commit
						6ac0d4692f
					
				|  | @ -4,7 +4,7 @@ | ||||||
| ! http://www.math.sci.hiroshima-u.ac.jp/~m-mat/MT/MT2002/CODES/mt19937ar.c | ! http://www.math.sci.hiroshima-u.ac.jp/~m-mat/MT/MT2002/CODES/mt19937ar.c | ||||||
| 
 | 
 | ||||||
| USING: arrays kernel math namespaces sequences system init | USING: arrays kernel math namespaces sequences system init | ||||||
| accessors math.ranges random ; | accessors math.ranges random circular ; | ||||||
| IN: random.mersenne-twister | IN: random.mersenne-twister | ||||||
| 
 | 
 | ||||||
| <PRIVATE | <PRIVATE | ||||||
|  | @ -16,8 +16,6 @@ TUPLE: mersenne-twister seq i ; | ||||||
| : mt-a HEX: 9908b0df ; inline | : mt-a HEX: 9908b0df ; inline | ||||||
| : mt-hi HEX: 80000000 bitand ; inline | : mt-hi HEX: 80000000 bitand ; inline | ||||||
| : mt-lo HEX: 7fffffff bitand ; inline | : mt-lo HEX: 7fffffff bitand ; inline | ||||||
| : wrap ( x n -- y ) 2dup >= [ - ] [ drop ] if ; inline |  | ||||||
| : mt-wrap ( x -- y ) mt-n wrap ; inline |  | ||||||
| 
 | 
 | ||||||
| : set-generated ( y from-elt to seq -- ) | : set-generated ( y from-elt to seq -- ) | ||||||
|     >r >r >r [ 2/ ] [ odd? mt-a 0 ? ] bi |     >r >r >r [ 2/ ] [ odd? mt-a 0 ? ] bi | ||||||
|  | @ -27,8 +25,8 @@ TUPLE: mersenne-twister seq i ; | ||||||
|     tuck [ nth mt-hi ] [ nth mt-lo ] 2bi* bitor ; inline |     tuck [ nth mt-hi ] [ nth mt-lo ] 2bi* bitor ; inline | ||||||
| 
 | 
 | ||||||
| : (mt-generate) ( n mt-seq -- y to from-elt ) | : (mt-generate) ( n mt-seq -- y to from-elt ) | ||||||
|     [ >r dup 1+ mt-wrap r> calculate-y ] |     [ >r dup 1+ r> calculate-y ] | ||||||
|     [ >r mt-m + mt-wrap r> nth ] |     [ >r mt-m + r> nth ] | ||||||
|     [ drop ] 2tri ; |     [ drop ] 2tri ; | ||||||
| 
 | 
 | ||||||
| : mt-generate ( mt -- ) | : mt-generate ( mt -- ) | ||||||
|  | @ -36,7 +34,7 @@ TUPLE: mersenne-twister seq i ; | ||||||
|     [ 0 >>i drop ] bi ; |     [ 0 >>i drop ] bi ; | ||||||
| 
 | 
 | ||||||
| : init-mt-first ( seed -- seq ) | : init-mt-first ( seed -- seq ) | ||||||
|     >r mt-n 0 <array> r> |     >r mt-n 0 <array> <circular> r> | ||||||
|     HEX: ffffffff bitand 0 pick set-nth ; |     HEX: ffffffff bitand 0 pick set-nth ; | ||||||
| 
 | 
 | ||||||
| : init-mt-formula ( seq i -- f(seq[i]) ) | : init-mt-formula ( seq i -- f(seq[i]) ) | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue