| 
									
										
										
										
											2008-05-10 19:09:05 -04:00
										 |  |  | ! Copyright (C) 2004, 2008 Slava Pestov. | 
					
						
							|  |  |  | ! See http://factorcode.org/license.txt for BSD license. | 
					
						
							| 
									
										
										
										
											2009-08-07 23:30:57 -04:00
										 |  |  | USING: words accessors sequences kernel assocs combinators classes | 
					
						
							| 
									
										
										
										
											2009-11-10 18:41:47 -05:00
										 |  |  | classes.algebra classes.algebra.private classes.builtin | 
					
						
							|  |  |  | namespaces arrays math quotations ;
 | 
					
						
							| 
									
										
										
										
											2008-05-10 19:09:05 -04:00
										 |  |  | IN: classes.intersection | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | PREDICATE: intersection-class < class | 
					
						
							|  |  |  |     "metaclass" word-prop intersection-class eq? ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : intersection-predicate-quot ( members -- quot )
 | 
					
						
							| 
									
										
										
										
											2008-09-06 18:10:32 -04:00
										 |  |  |     [ | 
					
						
							|  |  |  |         [ drop t ] | 
					
						
							| 
									
										
										
										
											2008-05-10 19:09:05 -04:00
										 |  |  |     ] [ | 
					
						
							|  |  |  |         unclip "predicate" word-prop swap [ | 
					
						
							| 
									
										
										
										
											2008-12-06 19:42:41 -05:00
										 |  |  |             "predicate" word-prop [ dup ] [ not ] surround
 | 
					
						
							| 
									
										
										
										
											2008-05-10 19:09:05 -04:00
										 |  |  |             [ drop f ] | 
					
						
							|  |  |  |         ] { } map>assoc alist>quot
 | 
					
						
							| 
									
										
										
										
											2008-09-06 18:10:32 -04:00
										 |  |  |     ] if-empty ;
 | 
					
						
							| 
									
										
										
										
											2008-05-10 19:09:05 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : define-intersection-predicate ( class -- )
 | 
					
						
							|  |  |  |     dup participants intersection-predicate-quot define-predicate ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: intersection-class update-class define-intersection-predicate ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-05-11 03:12:36 -04:00
										 |  |  | : define-intersection-class ( class participants -- )
 | 
					
						
							| 
									
										
										
										
											2008-11-30 23:21:37 -05:00
										 |  |  |     [ [ f f ] dip intersection-class define-class ] | 
					
						
							| 
									
										
										
										
											2008-05-10 19:09:05 -04:00
										 |  |  |     [ drop update-classes ] | 
					
						
							|  |  |  |     2bi ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: intersection-class rank-class drop 2 ;
 | 
					
						
							| 
									
										
										
										
											2008-06-29 03:12:44 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | M: intersection-class instance? | 
					
						
							|  |  |  |     "participants" word-prop [ instance? ] with all? ;
 | 
					
						
							| 
									
										
										
										
											2008-07-05 18:08:01 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | M: intersection-class (flatten-class) | 
					
						
							|  |  |  |     participants <anonymous-intersection> (flatten-class) ;
 | 
					
						
							| 
									
										
										
										
											2009-08-07 23:30:57 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | ! Horribly inefficient and inaccurate | 
					
						
							|  |  |  | : intersect-flattened-classes ( seq1 seq2 -- seq3 )
 | 
					
						
							|  |  |  |     ! Only keep those in seq1 that intersect something in seq2. | 
					
						
							|  |  |  |     [ [ classes-intersect? ] with any? ] curry filter ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: anonymous-intersection (flatten-class) | 
					
						
							|  |  |  |     participants>> [ full-cover ] [ | 
					
						
							|  |  |  |         [ flatten-class keys ] | 
					
						
							|  |  |  |         [ intersect-flattened-classes ] map-reduce
 | 
					
						
							|  |  |  |         [ dup set ] each
 | 
					
						
							|  |  |  |     ] if-empty ;
 |