51 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Factor
		
	
	
			
		
		
	
	
			51 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Factor
		
	
	
| ! Copyright (C) 2009 Doug Coleman.
 | |
| ! See http://factorcode.org/license.txt for BSD license.
 | |
| USING: accessors fry generalizations kernel macros math.order
 | |
| stack-checker math sequences ;
 | |
| IN: combinators.smart
 | |
| 
 | |
| MACRO: drop-outputs ( quot -- quot' )
 | |
|     dup infer out>> '[ @ _ ndrop ] ;
 | |
| 
 | |
| MACRO: keep-inputs ( quot -- quot' )
 | |
|     dup infer in>> '[ _ _ nkeep ] ;
 | |
| 
 | |
| MACRO: output>sequence ( quot exemplar -- newquot )
 | |
|     [ dup infer out>> ] dip
 | |
|     '[ @ _ _ nsequence ] ;
 | |
| 
 | |
| MACRO: output>array ( quot -- newquot )
 | |
|     '[ _ { } output>sequence ] ;
 | |
| 
 | |
| MACRO: input<sequence ( quot -- newquot )
 | |
|     [ infer in>> ] keep
 | |
|     '[ _ firstn @ ] ;
 | |
| 
 | |
| MACRO: input<sequence-unsafe ( quot -- newquot )
 | |
|     [ infer in>> ] keep
 | |
|     '[ _ firstn-unsafe @ ] ;
 | |
| 
 | |
| MACRO: reduce-outputs ( quot operation -- newquot )
 | |
|     [ dup infer out>> 1 [-] ] dip n*quot compose ;
 | |
| 
 | |
| MACRO: sum-outputs ( quot -- n )
 | |
|     '[ _ [ + ] reduce-outputs ] ;
 | |
| 
 | |
| MACRO: map-reduce-outputs ( quot mapper reducer -- newquot )
 | |
|     [ dup infer out>> ] 2dip
 | |
|     [ swap '[ _ _ napply ] ]
 | |
|     [ [ 1 [-] ] dip n*quot ] bi-curry* bi
 | |
|     '[ @ @ @ ] ;
 | |
| 
 | |
| MACRO: append-outputs-as ( quot exemplar -- newquot )
 | |
|     [ dup infer out>> ] dip '[ @ _ _ nappend-as ] ;
 | |
| 
 | |
| MACRO: append-outputs ( quot -- seq )
 | |
|     '[ _ { } append-outputs-as ] ;
 | |
| 
 | |
| MACRO: preserving ( quot -- )
 | |
|     [ infer in>> length ] keep '[ _ ndup @ ] ;
 | |
| 
 | |
| MACRO: smart-if ( pred true false -- )
 | |
|     '[ _ preserving _ _ if ] ; inline
 |