| 
									
										
										
										
											2008-01-12 04:25:16 -05:00
										 |  |  | ! Copyright (C) 2004, 2008 Slava Pestov. | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | ! See http://factorcode.org/license.txt for BSD license. | 
					
						
							|  |  |  | USING: arrays generic assocs inference inference.class | 
					
						
							| 
									
										
										
										
											2008-01-12 04:25:16 -05:00
										 |  |  | inference.dataflow inference.backend inference.state io kernel | 
					
						
							|  |  |  | math namespaces sequences vectors words quotations hashtables | 
					
						
							| 
									
										
										
										
											2008-04-19 21:39:58 -04:00
										 |  |  | combinators classes optimizer.def-use accessors ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | IN: optimizer.backend | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | SYMBOL: class-substitutions | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | SYMBOL: literal-substitutions | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | SYMBOL: value-substitutions | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | SYMBOL: optimizer-changed | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | GENERIC: optimize-node* ( node -- node/t changed? )
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-19 21:39:58 -04:00
										 |  |  | : ?union ( assoc assoc/f -- assoc' )
 | 
					
						
							|  |  |  |     dup assoc-empty? [ drop ] [ swap assoc-union ] if ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-19 21:39:58 -04:00
										 |  |  | : add-node-literals ( node assoc -- )
 | 
					
						
							|  |  |  |     [ ?union ] curry change-literals drop ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-19 21:39:58 -04:00
										 |  |  | : add-node-classes ( node assoc -- )
 | 
					
						
							|  |  |  |     [ ?union ] curry change-classes drop ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-19 21:39:58 -04:00
										 |  |  | : substitute-values ( node assoc -- )
 | 
					
						
							|  |  |  |     dup assoc-empty? [ | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |         2drop
 | 
					
						
							|  |  |  |     ] [ | 
					
						
							| 
									
										
										
										
											2008-04-19 21:39:58 -04:00
										 |  |  |         { | 
					
						
							|  |  |  |             [ >r  in-d>> r> substitute-here ] | 
					
						
							|  |  |  |             [ >r  in-r>> r> substitute-here ] | 
					
						
							|  |  |  |             [ >r out-d>> r> substitute-here ] | 
					
						
							|  |  |  |             [ >r out-r>> r> substitute-here ] | 
					
						
							|  |  |  |         } 2cleave
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     ] if ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : perform-substitutions ( node -- )
 | 
					
						
							| 
									
										
										
										
											2008-04-19 21:39:58 -04:00
										 |  |  |     [   class-substitutions get add-node-classes  ] | 
					
						
							|  |  |  |     [ literal-substitutions get add-node-literals ] | 
					
						
							|  |  |  |     [   value-substitutions get substitute-values ] | 
					
						
							|  |  |  |     tri ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | DEFER: optimize-nodes | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : optimize-children ( node -- )
 | 
					
						
							| 
									
										
										
										
											2008-04-04 01:33:06 -04:00
										 |  |  |     [ optimize-nodes ] map-children ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : optimize-node ( node -- node )
 | 
					
						
							|  |  |  |     dup [ | 
					
						
							|  |  |  |         dup perform-substitutions | 
					
						
							|  |  |  |         dup optimize-node* [ | 
					
						
							|  |  |  |             nip optimizer-changed on optimize-node | 
					
						
							|  |  |  |         ] [ | 
					
						
							|  |  |  |             dup t eq? [ | 
					
						
							|  |  |  |                 drop dup optimize-children | 
					
						
							|  |  |  |             ] [ | 
					
						
							|  |  |  |                 nip optimize-node | 
					
						
							|  |  |  |             ] if
 | 
					
						
							|  |  |  |         ] if
 | 
					
						
							|  |  |  |     ] when ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : optimize-nodes ( node -- newnode )
 | 
					
						
							|  |  |  |     [ | 
					
						
							|  |  |  |         class-substitutions [ clone ] change
 | 
					
						
							|  |  |  |         literal-substitutions [ clone ] change
 | 
					
						
							| 
									
										
										
										
											2008-02-10 21:32:48 -05:00
										 |  |  |         [ optimize-node ] transform-nodes | 
					
						
							|  |  |  |         optimizer-changed get
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     ] with-scope optimizer-changed set ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: node optimize-node* drop t f ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-02-13 19:42:55 -05:00
										 |  |  | ! Post-inlining cleanup | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | : follow ( key assoc -- value )
 | 
					
						
							|  |  |  |     2dup at* [ swap follow nip ] [ 2drop ] if ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : union* ( assoc1 assoc2 -- assoc )
 | 
					
						
							| 
									
										
										
										
											2008-04-13 23:58:07 -04:00
										 |  |  |     assoc-union [ keys ] keep
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     [ dupd follow ] curry
 | 
					
						
							|  |  |  |     H{ } map>assoc ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : update* ( assoc1 assoc2 -- )
 | 
					
						
							|  |  |  |     #! Not very efficient. | 
					
						
							|  |  |  |     dupd union* update ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-19 21:39:58 -04:00
										 |  |  | : compute-value-substitutions ( #call/#merge #return/#values -- assoc )
 | 
					
						
							|  |  |  |     [ out-d>> ] [ in-d>> ] bi* 2array unify-lengths flip
 | 
					
						
							| 
									
										
										
										
											2008-04-26 00:12:44 -04:00
										 |  |  |     [ = not ] assoc-filter >hashtable ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-02-13 19:42:55 -05:00
										 |  |  | : cleanup-inlining ( #return/#values -- newnode changed? )
 | 
					
						
							| 
									
										
										
										
											2008-04-19 21:39:58 -04:00
										 |  |  |     dup node-successor [ | 
					
						
							|  |  |  |         [ node-successor ] keep
 | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             [ nip classes>> class-substitutions get swap update ] | 
					
						
							|  |  |  |             [ nip literals>> literal-substitutions get swap update ] | 
					
						
							|  |  |  |             [ compute-value-substitutions value-substitutions get swap update* ] | 
					
						
							|  |  |  |             [ drop node-successor ] | 
					
						
							|  |  |  |         } 2cleave t
 | 
					
						
							| 
									
										
										
										
											2008-02-13 19:42:55 -05:00
										 |  |  |     ] [ | 
					
						
							| 
									
										
										
										
											2008-04-19 21:39:58 -04:00
										 |  |  |         drop t f
 | 
					
						
							| 
									
										
										
										
											2008-02-13 19:42:55 -05:00
										 |  |  |     ] if ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! #return | 
					
						
							|  |  |  | M: #return optimize-node* cleanup-inlining ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! #values | 
					
						
							|  |  |  | M: #values optimize-node* cleanup-inlining ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: f set-node-successor 2drop ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : splice-node ( old new -- )
 | 
					
						
							|  |  |  |     dup splice-def-use last-node set-node-successor ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : drop-inputs ( node -- #shuffle )
 | 
					
						
							|  |  |  |     node-in-d clone \ #shuffle in-node ;
 | 
					
						
							| 
									
										
										
										
											2008-07-02 01:20:01 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : optimizer-hooks ( node -- conditions )
 | 
					
						
							|  |  |  |     param>> "optimizer-hooks" word-prop ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : optimizer-hook ( node -- pair/f )
 | 
					
						
							|  |  |  |     dup optimizer-hooks [ first call ] find 2nip ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : optimize-hook ( node -- )
 | 
					
						
							|  |  |  |     dup optimizer-hook second call ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : define-optimizers ( word optimizers -- )
 | 
					
						
							|  |  |  |     "optimizer-hooks" set-word-prop ;
 |