| 
									
										
										
										
											2008-02-12 16:52:32 -05:00
										 |  |  | ! Copyright (C) 2006, 2008 Slava Pestov. | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | ! See http://factorcode.org/license.txt for BSD license. | 
					
						
							| 
									
										
										
										
											2008-07-12 23:27:28 -04:00
										 |  |  | USING: classes io kernel kernel.private math.parser namespaces | 
					
						
							|  |  |  | optimizer prettyprint prettyprint.backend sequences words arrays | 
					
						
							|  |  |  | match macros assocs sequences.private generic combinators | 
					
						
							| 
									
										
										
										
											2008-07-20 02:13:14 -04:00
										 |  |  | sorting math quotations accessors inference inference.backend | 
					
						
							|  |  |  | inference.dataflow optimizer.specializers generator ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | IN: optimizer.debugger | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! A simple tool for turning dataflow IR into quotations, for | 
					
						
							|  |  |  | ! debugging purposes. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | GENERIC: node>quot ( ? node -- )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TUPLE: comment node text ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: comment pprint* | 
					
						
							|  |  |  |     "( " over comment-text " )" 3append
 | 
					
						
							|  |  |  |     swap comment-node present-text ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : comment, ( ? node text -- )
 | 
					
						
							| 
									
										
										
										
											2008-04-13 16:06:27 -04:00
										 |  |  |     rot [ \ comment boa , ] [ 2drop ] if ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : values% ( prefix values -- )
 | 
					
						
							|  |  |  |     swap [ | 
					
						
							|  |  |  |         % | 
					
						
							|  |  |  |         dup value? [ | 
					
						
							|  |  |  |             value-literal unparse % | 
					
						
							|  |  |  |         ] [ | 
					
						
							|  |  |  |             "@" % unparse % | 
					
						
							|  |  |  |         ] if
 | 
					
						
							|  |  |  |     ] curry each ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : effect-str ( node -- str )
 | 
					
						
							|  |  |  |     [ | 
					
						
							| 
									
										
										
										
											2008-06-08 16:32:55 -04:00
										 |  |  |         " " over in-d>> values% | 
					
						
							|  |  |  |         " r: " over in-r>> values% | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |         " --" % | 
					
						
							| 
									
										
										
										
											2008-06-08 16:32:55 -04:00
										 |  |  |         " " over out-d>> values% | 
					
						
							|  |  |  |         " r: " swap out-r>> values% | 
					
						
							| 
									
										
										
										
											2008-04-26 03:01:43 -04:00
										 |  |  |     ] "" make rest ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | MACRO: match-choose ( alist -- )
 | 
					
						
							|  |  |  |     [ [ ] curry ] assoc-map [ match-cond ] curry ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | MATCH-VARS: ?a ?b ?c ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : pretty-shuffle ( in out -- word/f )
 | 
					
						
							|  |  |  |     2array { | 
					
						
							| 
									
										
										
										
											2008-07-11 21:05:32 -04:00
										 |  |  |         { { { ?a } { ?a } } [ ] } | 
					
						
							|  |  |  |         { { { ?a ?b } { ?a ?b } } [ ] } | 
					
						
							|  |  |  |         { { { ?a ?b ?c } { ?a ?b ?c } } [ ] } | 
					
						
							|  |  |  |         { { { ?a } { } } [ drop ] } | 
					
						
							|  |  |  |         { { { ?a ?b } { } } [ 2drop ] } | 
					
						
							|  |  |  |         { { { ?a ?b ?c } { } } [ 3drop ] } | 
					
						
							|  |  |  |         { { { ?a } { ?a ?a } } [ dup ] } | 
					
						
							|  |  |  |         { { { ?a ?b } { ?a ?b ?a ?b } } [ 2dup ] } | 
					
						
							|  |  |  |         { { { ?a ?b ?c } { ?a ?b ?c ?a ?b ?c } } [ 3dup ] } | 
					
						
							|  |  |  |         { { { ?a ?b } { ?a ?b ?a } } [ over ] } | 
					
						
							|  |  |  |         { { { ?b ?a } { ?a ?b } } [ swap ] } | 
					
						
							| 
									
										
										
										
											2008-07-13 04:53:34 -04:00
										 |  |  |         { { { ?a ?b } { ?b ?a ?b } } [ tuck ] } | 
					
						
							| 
									
										
										
										
											2008-07-11 21:05:32 -04:00
										 |  |  |         { { { ?a ?b ?c } { ?a ?b ?c ?a } } [ pick ] } | 
					
						
							|  |  |  |         { { { ?a ?b ?c } { ?c ?a ?b } } [ -rot ] } | 
					
						
							|  |  |  |         { { { ?a ?b ?c } { ?b ?c ?a } } [ rot ] } | 
					
						
							|  |  |  |         { { { ?a ?b } { ?b } } [ nip ] } | 
					
						
							|  |  |  |         { { { ?a ?b ?c } { ?c } } [ 2nip ] } | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |         { _ f } | 
					
						
							|  |  |  |     } match-choose ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: #shuffle node>quot | 
					
						
							| 
									
										
										
										
											2008-06-08 16:32:55 -04:00
										 |  |  |     dup [ in-d>> ] [ out-d>> ] bi pretty-shuffle | 
					
						
							| 
									
										
										
										
											2008-07-11 21:05:32 -04:00
										 |  |  |     [ % ] [ >r drop t r> ] if*
 | 
					
						
							| 
									
										
										
										
											2008-03-19 20:15:32 -04:00
										 |  |  |     dup effect-str "#shuffle: " prepend comment, ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-08 16:32:55 -04:00
										 |  |  | : pushed-literals ( node -- seq )
 | 
					
						
							|  |  |  |     out-d>> [ value-literal literalize ] map ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | M: #push node>quot nip pushed-literals % ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | DEFER: dataflow>quot | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : #call>quot ( ? node -- )
 | 
					
						
							| 
									
										
										
										
											2008-06-08 16:32:55 -04:00
										 |  |  |     dup param>> dup , | 
					
						
							| 
									
										
										
										
											2007-12-26 21:21:12 -05:00
										 |  |  |     [ dup effect-str ] [ "empty call" ] if comment, ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | M: #call node>quot #call>quot ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: #call-label node>quot #call>quot ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: #label node>quot | 
					
						
							| 
									
										
										
										
											2008-02-14 21:28:16 -05:00
										 |  |  |     [ | 
					
						
							| 
									
										
										
										
											2008-06-08 16:32:55 -04:00
										 |  |  |         dup param>> literalize , | 
					
						
							| 
									
										
										
										
											2008-02-14 21:28:16 -05:00
										 |  |  |         dup #label-loop? "#loop: " "#label: " ?
 | 
					
						
							| 
									
										
										
										
											2008-06-28 03:36:20 -04:00
										 |  |  |         over param>> name>> append comment, | 
					
						
							| 
									
										
										
										
											2008-02-14 21:28:16 -05:00
										 |  |  |     ] 2keep
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     node-child swap dataflow>quot , \ call ,  ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: #if node>quot | 
					
						
							|  |  |  |     [ "#if" comment, ] 2keep
 | 
					
						
							| 
									
										
										
										
											2008-06-08 16:32:55 -04:00
										 |  |  |     children>> swap [ dataflow>quot ] curry map % | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     \ if , ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: #dispatch node>quot | 
					
						
							|  |  |  |     [ "#dispatch" comment, ] 2keep
 | 
					
						
							| 
									
										
										
										
											2008-06-08 16:32:55 -04:00
										 |  |  |     children>> swap [ dataflow>quot ] curry map , | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     \ dispatch , ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-08 16:32:55 -04:00
										 |  |  | M: #>r node>quot nip in-d>> length \ >r <array> % ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-08 16:32:55 -04:00
										 |  |  | M: #r> node>quot nip out-d>> length \ r> <array> % ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-02-13 19:43:05 -05:00
										 |  |  | M: object node>quot | 
					
						
							|  |  |  |     [ | 
					
						
							| 
									
										
										
										
											2008-06-28 03:36:20 -04:00
										 |  |  |         dup class name>> % | 
					
						
							| 
									
										
										
										
											2008-02-13 19:43:05 -05:00
										 |  |  |         " " % | 
					
						
							| 
									
										
										
										
											2008-06-08 16:32:55 -04:00
										 |  |  |         dup param>> unparse % | 
					
						
							| 
									
										
										
										
											2008-02-13 19:43:05 -05:00
										 |  |  |         " " % | 
					
						
							|  |  |  |         dup effect-str % | 
					
						
							|  |  |  |     ] "" make comment, ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : (dataflow>quot) ( ? node -- )
 | 
					
						
							|  |  |  |     dup [ | 
					
						
							| 
									
										
										
										
											2008-06-08 16:32:55 -04:00
										 |  |  |         2dup node>quot successor>> (dataflow>quot) | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     ] [ | 
					
						
							|  |  |  |         2drop
 | 
					
						
							|  |  |  |     ] if ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : dataflow>quot ( node ? -- quot )
 | 
					
						
							|  |  |  |     [ swap (dataflow>quot) ] [ ] make ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-02-12 16:52:32 -05:00
										 |  |  | : optimized-quot. ( quot ? -- )
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     #! Print dataflow IR for a quotation. Flag indicates if | 
					
						
							|  |  |  |     #! annotations should be printed or not. | 
					
						
							|  |  |  |     >r dataflow optimize r> dataflow>quot pprint nl ;
 | 
					
						
							| 
									
										
										
										
											2008-02-12 16:52:32 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | : optimized-word. ( word ? -- ) >r specialized-def r> optimized-quot. ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-07-20 02:13:14 -04:00
										 |  |  | SYMBOL: pass-count | 
					
						
							| 
									
										
										
										
											2008-02-12 16:52:32 -05:00
										 |  |  | SYMBOL: words-called | 
					
						
							|  |  |  | SYMBOL: generics-called | 
					
						
							|  |  |  | SYMBOL: methods-called | 
					
						
							|  |  |  | SYMBOL: intrinsics-called | 
					
						
							|  |  |  | SYMBOL: node-count | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-07-20 02:13:14 -04:00
										 |  |  | : count-optimization-passes ( node n -- node n )
 | 
					
						
							|  |  |  |     >r optimize-1 | 
					
						
							|  |  |  |     [ r> 1+ count-optimization-passes ] [ r> ] if ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : make-report ( word -- assoc )
 | 
					
						
							| 
									
										
										
										
											2008-02-12 16:52:32 -05:00
										 |  |  |     [ | 
					
						
							| 
									
										
										
										
											2008-07-20 02:13:14 -04:00
										 |  |  |         word-dataflow nip 1 count-optimization-passes pass-count set
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-02-12 16:52:32 -05:00
										 |  |  |         H{ } clone words-called set
 | 
					
						
							|  |  |  |         H{ } clone generics-called set
 | 
					
						
							|  |  |  |         H{ } clone methods-called set
 | 
					
						
							|  |  |  |         H{ } clone intrinsics-called set
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         0 swap [ | 
					
						
							|  |  |  |             >r 1+ r> | 
					
						
							|  |  |  |             dup #call? [ | 
					
						
							| 
									
										
										
										
											2008-06-08 16:32:55 -04:00
										 |  |  |                 param>> { | 
					
						
							| 
									
										
										
										
											2008-02-12 16:52:32 -05:00
										 |  |  |                     { [ dup "intrinsics" word-prop over "if-intrinsics" word-prop or ] [ intrinsics-called ] } | 
					
						
							|  |  |  |                     { [ dup generic? ] [ generics-called ] } | 
					
						
							|  |  |  |                     { [ dup method-body? ] [ methods-called ] } | 
					
						
							| 
									
										
										
										
											2008-04-11 13:56:48 -04:00
										 |  |  |                     [ words-called ] | 
					
						
							| 
									
										
										
										
											2008-02-12 16:52:32 -05:00
										 |  |  |                 } cond 1 -rot get at+
 | 
					
						
							|  |  |  |             ] [ | 
					
						
							|  |  |  |                 drop
 | 
					
						
							|  |  |  |             ] if
 | 
					
						
							|  |  |  |         ] each-node | 
					
						
							|  |  |  |         node-count set
 | 
					
						
							|  |  |  |     ] H{ } make-assoc ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : report. ( report -- )
 | 
					
						
							|  |  |  |     [ | 
					
						
							| 
									
										
										
										
											2008-07-20 02:13:14 -04:00
										 |  |  |         "==== Optimization passes:" print
 | 
					
						
							|  |  |  |         pass-count get .
 | 
					
						
							|  |  |  |         nl
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-02-12 16:52:32 -05:00
										 |  |  |         "==== Total number of dataflow nodes:" print
 | 
					
						
							|  |  |  |         node-count get .
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             { generics-called "==== Generic word calls:" } | 
					
						
							|  |  |  |             { words-called "==== Ordinary word calls:" } | 
					
						
							|  |  |  |             { methods-called "==== Non-inlined method calls:" } | 
					
						
							|  |  |  |             { intrinsics-called "==== Open-coded intrinsic calls:" } | 
					
						
							|  |  |  |         } [ | 
					
						
							|  |  |  |             nl print get keys natural-sort stack. | 
					
						
							|  |  |  |         ] assoc-each
 | 
					
						
							|  |  |  |     ] bind ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : optimizer-report. ( word -- )
 | 
					
						
							| 
									
										
										
										
											2008-07-20 02:13:14 -04:00
										 |  |  |     make-report report. ;
 |