| 
									
										
										
										
											2009-07-02 22:58:49 -04:00
										 |  |  | ! Copyright (C) 2009 Slava Pestov. | 
					
						
							|  |  |  | ! See http://factorcode.org/license.txt for BSD license. | 
					
						
							| 
									
										
										
										
											2010-12-27 22:22:36 -05:00
										 |  |  | USING: kernel accessors sequences byte-arrays bit-arrays math | 
					
						
							|  |  |  | math.bitwise hints sets ;
 | 
					
						
							| 
									
										
										
										
											2009-07-02 22:58:49 -04:00
										 |  |  | IN: bit-sets | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-16 16:14:32 -05:00
										 |  |  | TUPLE: bit-set { table bit-array read-only } ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : <bit-set> ( capacity -- bit-set )
 | 
					
						
							|  |  |  |     <bit-array> bit-set boa ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | INSTANCE: bit-set set | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: bit-set in? | 
					
						
							|  |  |  |     over integer? [ table>> ?nth ] [ 2drop f ] if ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: bit-set adjoin | 
					
						
							| 
									
										
										
										
											2010-12-27 23:10:37 -05:00
										 |  |  |     ! This is allowed to throw an error when the elt couldn't | 
					
						
							|  |  |  |     ! go in the set | 
					
						
							| 
									
										
										
										
											2010-02-16 16:14:32 -05:00
										 |  |  |     [ t ] 2dip table>> set-nth ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: bit-set delete | 
					
						
							| 
									
										
										
										
											2010-12-27 23:10:37 -05:00
										 |  |  |     ! This isn't allowed to throw an error if the elt wasn't | 
					
						
							|  |  |  |     ! in the set | 
					
						
							| 
									
										
										
										
											2010-02-16 16:14:32 -05:00
										 |  |  |     over integer? [ | 
					
						
							|  |  |  |         table>> 2dup bounds-check? [ | 
					
						
							|  |  |  |             [ f ] 2dip set-nth
 | 
					
						
							|  |  |  |         ] [ 2drop ] if
 | 
					
						
							|  |  |  |     ] [ 2drop ] if ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-27 23:10:37 -05:00
										 |  |  | ! If you do binary set operations with a bit-set, it's expected | 
					
						
							|  |  |  | ! that the other thing can also be represented as a bit-set | 
					
						
							| 
									
										
										
										
											2010-02-16 16:14:32 -05:00
										 |  |  | ! of the same length. | 
					
						
							| 
									
										
										
										
											2009-07-02 22:58:49 -04:00
										 |  |  | <PRIVATE
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-17 21:38:06 -04:00
										 |  |  | ERROR: check-bit-set-failed ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : check-bit-set ( bit-set -- bit-set )
 | 
					
						
							|  |  |  |     dup bit-set? [ check-bit-set-failed ] unless ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-02 22:58:49 -04:00
										 |  |  | : bit-set-map ( seq1 seq2 quot -- seq )
 | 
					
						
							|  |  |  |     [ 2drop length>> ] | 
					
						
							|  |  |  |     [ | 
					
						
							|  |  |  |         [ | 
					
						
							|  |  |  |             [ [ length ] bi@ assert= ] | 
					
						
							|  |  |  |             [ [ underlying>> ] bi@ ] 2bi
 | 
					
						
							|  |  |  |         ] dip 2map
 | 
					
						
							|  |  |  |     ] 3bi bit-array boa ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-16 16:14:32 -05:00
										 |  |  | : (bit-set-op) ( set1 set2 -- table1 table2 )
 | 
					
						
							|  |  |  |     [ set-like ] keep [ table>> ] bi@ ; inline
 | 
					
						
							| 
									
										
										
										
											2009-07-02 22:58:49 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-16 16:14:32 -05:00
										 |  |  | : bit-set-op ( set1 set2 quot: ( a b -- c ) -- bit-set )
 | 
					
						
							|  |  |  |     [ (bit-set-op) ] dip bit-set-map bit-set boa ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | PRIVATE>
 | 
					
						
							| 
									
										
										
										
											2009-07-02 22:58:49 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-16 16:14:32 -05:00
										 |  |  | M: bit-set union | 
					
						
							|  |  |  |     [ bitor ] bit-set-op ;
 | 
					
						
							| 
									
										
										
										
											2009-07-02 22:58:49 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-16 16:14:32 -05:00
										 |  |  | M: bit-set intersect | 
					
						
							|  |  |  |     [ bitand ] bit-set-op ;
 | 
					
						
							| 
									
										
										
										
											2009-07-02 22:58:49 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-16 16:14:32 -05:00
										 |  |  | M: bit-set diff | 
					
						
							|  |  |  |     [ bitnot bitand ] bit-set-op ;
 | 
					
						
							| 
									
										
										
										
											2009-07-02 22:58:49 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-16 16:14:32 -05:00
										 |  |  | M: bit-set subset? | 
					
						
							|  |  |  |     [ intersect ] keep = ;
 | 
					
						
							| 
									
										
										
										
											2009-07-02 22:58:49 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-16 16:14:32 -05:00
										 |  |  | M: bit-set members | 
					
						
							|  |  |  |     [ table>> length iota ] keep [ in? ] curry filter ;
 | 
					
						
							| 
									
										
										
										
											2009-07-28 12:14:57 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-17 21:38:06 -04:00
										 |  |  | <PRIVATE
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : bit-set-like ( set bit-set -- bit-set' )
 | 
					
						
							| 
									
										
										
										
											2010-12-27 23:10:37 -05:00
										 |  |  |     ! Throws an error if there are keys that can't be put | 
					
						
							|  |  |  |     ! in the bit set | 
					
						
							| 
									
										
										
										
											2012-07-21 13:22:44 -04:00
										 |  |  |     over bit-set? [ 2dup [ table>> length ] same? ] [ f ] if
 | 
					
						
							| 
									
										
										
										
											2010-02-16 16:14:32 -05:00
										 |  |  |     [ drop ] [ | 
					
						
							|  |  |  |         [ members ] dip table>> length <bit-set> | 
					
						
							|  |  |  |         [ [ adjoin ] curry each ] keep
 | 
					
						
							|  |  |  |     ] if ;
 | 
					
						
							| 
									
										
										
										
											2010-02-16 16:48:07 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-17 21:38:06 -04:00
										 |  |  | PRIVATE>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: bit-set set-like | 
					
						
							|  |  |  |     bit-set-like check-bit-set ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-16 16:48:07 -05:00
										 |  |  | M: bit-set clone | 
					
						
							|  |  |  |     table>> clone bit-set boa ;
 | 
					
						
							| 
									
										
										
										
											2010-12-27 22:22:36 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | M: bit-set cardinality | 
					
						
							| 
									
										
										
										
											2010-12-27 23:10:37 -05:00
										 |  |  |     table>> bit-count ;
 |