| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | ! Copyright (C) 2006, 2007 Slava Pestov. | 
					
						
							|  |  |  | ! See http://factorcode.org/license.txt for BSD license. | 
					
						
							| 
									
										
										
										
											2009-05-15 00:23:06 -04:00
										 |  |  | USING: accessors arrays hashtables assocs io kernel math | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | math.vectors math.matrices math.matrices.elimination namespaces | 
					
						
							|  |  |  | parser prettyprint sequences words combinators math.parser | 
					
						
							| 
									
										
										
										
											2008-12-17 19:10:01 -05:00
										 |  |  | splitting sorting shuffle sets math.order ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | IN: koszul | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Utilities | 
					
						
							| 
									
										
										
										
											2008-06-09 03:14:14 -04:00
										 |  |  | : -1^ ( m -- n ) odd? -1 1 ? ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : >alt ( obj -- vec )
 | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         { [ dup not ] [ drop 0 >alt ] } | 
					
						
							|  |  |  |         { [ dup number? ] [ { } associate ] } | 
					
						
							|  |  |  |         { [ dup array? ] [ 1 swap associate ] } | 
					
						
							|  |  |  |         { [ dup hashtable? ] [ ] } | 
					
						
							| 
									
										
										
										
											2008-04-11 13:56:48 -04:00
										 |  |  |         [ 1array >alt ] | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     } cond ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-09 03:14:14 -04:00
										 |  |  | : canonicalize ( assoc -- assoc' )
 | 
					
						
							| 
									
										
										
										
											2008-04-26 00:17:08 -04:00
										 |  |  |     [ nip zero? not ] assoc-filter ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | SYMBOL: terms | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : with-terms ( quot -- hash )
 | 
					
						
							|  |  |  |     [ | 
					
						
							|  |  |  |         H{ } clone terms set call terms get canonicalize | 
					
						
							|  |  |  |     ] with-scope ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Printing elements | 
					
						
							|  |  |  | : num-alt. ( n -- str )
 | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2008-04-11 13:56:48 -04:00
										 |  |  |         { 1 [ " + " ] } | 
					
						
							|  |  |  |         { -1 [ " - " ] } | 
					
						
							|  |  |  |         [ number>string " + " prepend ] | 
					
						
							|  |  |  |     } case ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : (alt.) ( basis n -- str )
 | 
					
						
							|  |  |  |     over empty? [ | 
					
						
							|  |  |  |         nip number>string | 
					
						
							|  |  |  |     ] [ | 
					
						
							|  |  |  |         num-alt. | 
					
						
							| 
									
										
										
										
											2008-06-28 03:36:20 -04:00
										 |  |  |         swap [ name>> ] map "." join
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |         append
 | 
					
						
							|  |  |  |     ] if ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : alt. ( assoc -- )
 | 
					
						
							|  |  |  |     dup assoc-empty? [ | 
					
						
							|  |  |  |         drop 0 .
 | 
					
						
							|  |  |  |     ] [ | 
					
						
							|  |  |  |         [ (alt.) ] { } assoc>map concat " + " ?head drop print
 | 
					
						
							|  |  |  |     ] if ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Addition | 
					
						
							|  |  |  | : (alt+) ( x -- )
 | 
					
						
							|  |  |  |     terms get [ [ swap +@ ] assoc-each ] bind ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : alt+ ( x y -- x+y )
 | 
					
						
							| 
									
										
										
										
											2008-03-29 21:36:58 -04:00
										 |  |  |     [ >alt ] bi@ [ (alt+) (alt+) ] with-terms ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | ! Multiplication | 
					
						
							|  |  |  | : alt*n ( vec n -- vec )
 | 
					
						
							|  |  |  |     dup zero? [ | 
					
						
							|  |  |  |         2drop H{ } | 
					
						
							|  |  |  |     ] [ | 
					
						
							|  |  |  |         [ * ] curry assoc-map
 | 
					
						
							|  |  |  |     ] if ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : permutation ( seq -- perm )
 | 
					
						
							|  |  |  |     [ natural-sort ] keep [ index ] curry map ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : (inversions) ( n seq -- n )
 | 
					
						
							| 
									
										
										
										
											2008-04-26 00:17:08 -04:00
										 |  |  |     [ > ] with filter length ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : inversions ( seq -- n )
 | 
					
						
							|  |  |  |     0 swap [ length ] keep [ | 
					
						
							| 
									
										
										
										
											2009-08-13 20:21:44 -04:00
										 |  |  |         [ nth ] 2keep swap 1 + tail-slice (inversions) +
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     ] curry each ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : duplicates? ( seq -- ? )
 | 
					
						
							| 
									
										
										
										
											2008-03-29 21:36:58 -04:00
										 |  |  |     dup prune [ length ] bi@ > ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : (wedge) ( n basis1 basis2 -- n basis )
 | 
					
						
							|  |  |  |     append dup duplicates? [ | 
					
						
							|  |  |  |         2drop 0 { } | 
					
						
							|  |  |  |     ] [ | 
					
						
							|  |  |  |         dup permutation inversions -1^ rot *
 | 
					
						
							|  |  |  |         swap natural-sort | 
					
						
							|  |  |  |     ] if ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : wedge ( x y -- x.y )
 | 
					
						
							| 
									
										
										
										
											2008-03-29 21:36:58 -04:00
										 |  |  |     [ >alt ] bi@ [ | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |         swap [ | 
					
						
							|  |  |  |             [ | 
					
						
							|  |  |  |                 2swap [ | 
					
						
							|  |  |  |                     swapd * -rot (wedge) +@
 | 
					
						
							|  |  |  |                 ] 2keep
 | 
					
						
							|  |  |  |             ] assoc-each 2drop
 | 
					
						
							|  |  |  |         ] curry assoc-each
 | 
					
						
							|  |  |  |     ] H{ } make-assoc canonicalize ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Differential | 
					
						
							|  |  |  | SYMBOL: boundaries | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : d= ( value basis -- )
 | 
					
						
							|  |  |  |     boundaries [ ?set-at ] change ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : ((d)) ( basis -- value ) boundaries get at ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-17 23:29:32 -05:00
										 |  |  | : dx.y ( x y -- vec ) [ ((d)) ] dip wedge ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | DEFER: (d) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : x.dy ( x y -- vec ) (d) wedge -1 alt*n ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : (d) ( product -- value )
 | 
					
						
							| 
									
										
										
										
											2008-09-06 18:15:25 -04:00
										 |  |  |     [ H{ } ] [ unclip swap [ x.dy ] 2keep dx.y alt+ ] if-empty ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : linear-op ( vec quot -- vec )
 | 
					
						
							| 
									
										
										
										
											2008-02-02 01:29:47 -05:00
										 |  |  |         [ | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |         [ | 
					
						
							| 
									
										
										
										
											2008-12-17 23:29:32 -05:00
										 |  |  |             -rot [ swap call ] dip alt*n (alt+) | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |         ] curry assoc-each
 | 
					
						
							|  |  |  |     ] with-terms ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : d ( x -- dx )
 | 
					
						
							|  |  |  |     >alt [ (d) ] linear-op ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Interior product | 
					
						
							|  |  |  | : (interior) ( y basis-elt -- i_y[basis-elt] )
 | 
					
						
							|  |  |  |     2dup index dup [ | 
					
						
							|  |  |  |         -rot remove associate | 
					
						
							|  |  |  |     ] [ | 
					
						
							|  |  |  |         3drop 0
 | 
					
						
							|  |  |  |     ] if ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : interior ( x y -- i_y[x] )
 | 
					
						
							|  |  |  |     #! y is a generator | 
					
						
							|  |  |  |     swap >alt [ dupd (interior) ] linear-op nip ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Computing a basis | 
					
						
							|  |  |  | : graded ( seq -- seq )
 | 
					
						
							| 
									
										
										
										
											2009-08-13 20:21:44 -04:00
										 |  |  |     dup 0 [ length max ] reduce 1 + [ V{ } clone ] replicate
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     [ dup length pick nth push ] reduce ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : nth-basis-elt ( generators n -- elt )
 | 
					
						
							|  |  |  |     over length [ | 
					
						
							|  |  |  |         3dup bit? [ nth ] [ 2drop f ] if
 | 
					
						
							| 
									
										
										
										
											2008-05-14 00:36:55 -04:00
										 |  |  |     ] map sift 2nip ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : basis ( generators -- seq )
 | 
					
						
							| 
									
										
										
										
											2008-01-09 17:36:30 -05:00
										 |  |  |     natural-sort dup length 2^ [ nth-basis-elt ] with map ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : (tensor) ( seq1 seq2 -- seq )
 | 
					
						
							|  |  |  |     [ | 
					
						
							| 
									
										
										
										
											2008-03-19 20:15:32 -04:00
										 |  |  |         [ prepend natural-sort ] curry map
 | 
					
						
							| 
									
										
										
										
											2008-01-09 17:36:30 -05:00
										 |  |  |     ] with map concat ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : tensor ( graded-basis1 graded-basis2 -- bigraded-basis )
 | 
					
						
							| 
									
										
										
										
											2008-01-09 17:36:30 -05:00
										 |  |  |     [ [ swap (tensor) ] curry map ] with map ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | ! Computing cohomology | 
					
						
							|  |  |  | : (op-matrix) ( range quot basis-elt -- row )
 | 
					
						
							|  |  |  |     swap call [ at 0 or ] curry map ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : op-matrix ( domain range quot -- matrix )
 | 
					
						
							| 
									
										
										
										
											2009-04-15 20:03:44 -04:00
										 |  |  |     rot [ (op-matrix) ] with with map ; inline
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : d-matrix ( domain range -- matrix )
 | 
					
						
							|  |  |  |     [ (d) ] op-matrix ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : dim-im/ker-d ( domain range -- null/rank )
 | 
					
						
							|  |  |  |     d-matrix null/rank 2array ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Graded by degree | 
					
						
							|  |  |  | : (graded-ker/im-d) ( n seq -- null/rank )
 | 
					
						
							|  |  |  |     #! d: C(n) ---> C(n+1) | 
					
						
							| 
									
										
										
										
											2009-08-13 20:21:44 -04:00
										 |  |  |     [ ?nth ] [ [ 1 + ] dip ?nth ] 2bi
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     dim-im/ker-d ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : graded-ker/im-d ( graded-basis -- seq )
 | 
					
						
							|  |  |  |     [ length ] keep [ (graded-ker/im-d) ] curry map ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : graded-betti ( generators -- seq )
 | 
					
						
							| 
									
										
										
										
											2008-07-20 02:12:15 -04:00
										 |  |  |     basis graded graded-ker/im-d unzip but-last 0 prefix v- ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | ! Bi-graded for two-step complexes | 
					
						
							|  |  |  | : (bigraded-ker/im-d) ( u-deg z-deg bigraded-basis -- null/rank )
 | 
					
						
							|  |  |  |     #! d: C(u,z) ---> C(u+2,z-1) | 
					
						
							| 
									
										
										
										
											2008-12-17 23:29:32 -05:00
										 |  |  |     [ ?nth ?nth ] 3keep [ [ 2 + ] dip 1 - ] dip ?nth ?nth
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     dim-im/ker-d ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : bigraded-ker/im-d ( bigraded-basis -- seq )
 | 
					
						
							|  |  |  |     dup length [ | 
					
						
							|  |  |  |         over first length [ | 
					
						
							| 
									
										
										
										
											2008-12-17 23:29:32 -05:00
										 |  |  |             [ 2dup ] dip spin (bigraded-ker/im-d) | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |         ] map 2nip
 | 
					
						
							| 
									
										
										
										
											2008-01-09 17:36:30 -05:00
										 |  |  |     ] with map ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : bigraded-betti ( u-generators z-generators -- seq )
 | 
					
						
							| 
									
										
										
										
											2008-03-29 21:36:58 -04:00
										 |  |  |     [ basis graded ] bi@ tensor bigraded-ker/im-d | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     [ [ [ first ] map ] map ] keep
 | 
					
						
							| 
									
										
										
										
											2008-03-19 20:15:32 -04:00
										 |  |  |     [ [ second ] map 2 head* { 0 0 } prepend ] map
 | 
					
						
							| 
									
										
										
										
											2008-04-26 03:01:43 -04:00
										 |  |  |     rest dup first length 0 <array> suffix
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     [ v- ] 2map ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Laplacian | 
					
						
							| 
									
										
										
										
											2008-06-09 03:14:14 -04:00
										 |  |  | : m.m' ( matrix -- matrix' ) dup flip m. ;
 | 
					
						
							|  |  |  | : m'.m ( matrix -- matrix' ) dup flip swap m. ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : empty-matrix? ( matrix -- ? )
 | 
					
						
							| 
									
										
										
										
											2008-09-06 18:15:25 -04:00
										 |  |  |     [ t ] [ first empty? ] if-empty ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : ?m+ ( m1 m2 -- m3 )
 | 
					
						
							|  |  |  |     over empty-matrix? [ | 
					
						
							|  |  |  |         nip
 | 
					
						
							|  |  |  |     ] [ | 
					
						
							|  |  |  |         dup empty-matrix? [ | 
					
						
							|  |  |  |             drop
 | 
					
						
							|  |  |  |         ] [ | 
					
						
							|  |  |  |             m+ | 
					
						
							|  |  |  |         ] if
 | 
					
						
							|  |  |  |     ] if ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : laplacian-matrix ( basis1 basis2 basis3 -- matrix )
 | 
					
						
							| 
									
										
										
										
											2008-12-17 23:29:32 -05:00
										 |  |  |     dupd d-matrix m.m' [ d-matrix m'.m ] dip ?m+ ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : laplacian-betti ( basis1 basis2 basis3 -- n )
 | 
					
						
							|  |  |  |     laplacian-matrix null/rank drop ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : laplacian-kernel ( basis1 basis2 basis3 -- basis )
 | 
					
						
							| 
									
										
										
										
											2008-12-17 23:29:32 -05:00
										 |  |  |     [ tuck ] dip
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     laplacian-matrix dup empty-matrix? [ | 
					
						
							|  |  |  |         2drop f
 | 
					
						
							|  |  |  |     ] [ | 
					
						
							|  |  |  |         nullspace [ | 
					
						
							|  |  |  |             [ [ wedge (alt+) ] 2each ] with-terms | 
					
						
							| 
									
										
										
										
											2008-01-09 17:36:30 -05:00
										 |  |  |         ] with map
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     ] if ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : graded-triple ( seq n -- triple )
 | 
					
						
							| 
									
										
										
										
											2009-08-13 20:21:44 -04:00
										 |  |  |     3 [ 1 - + ] with map swap [ ?nth ] curry map ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : graded-triples ( seq -- triples )
 | 
					
						
							| 
									
										
										
										
											2008-01-09 17:36:30 -05:00
										 |  |  |     dup length [ graded-triple ] with map ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : graded-laplacian ( generators quot -- seq )
 | 
					
						
							| 
									
										
										
										
											2008-12-17 23:29:32 -05:00
										 |  |  |     [ basis graded graded-triples [ first3 ] ] dip compose map ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : graded-laplacian-betti ( generators -- seq )
 | 
					
						
							|  |  |  |     [ laplacian-betti ] graded-laplacian ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : graded-laplacian-kernel ( generators -- seq )
 | 
					
						
							|  |  |  |     [ laplacian-kernel ] graded-laplacian ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : graded-basis. ( seq -- )
 | 
					
						
							| 
									
										
										
										
											2008-07-07 20:36:33 -04:00
										 |  |  |     [ | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |         "=== Degree " write pprint | 
					
						
							|  |  |  |         ": dimension " write dup length .
 | 
					
						
							|  |  |  |         [ alt. ] each
 | 
					
						
							| 
									
										
										
										
											2008-07-07 20:36:33 -04:00
										 |  |  |     ] each-index ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : bigraded-triple ( u-deg z-deg bigraded-basis -- triple )
 | 
					
						
							|  |  |  |     #! d: C(u,z) ---> C(u+2,z-1) | 
					
						
							| 
									
										
										
										
											2008-07-04 12:34:47 -04:00
										 |  |  |     [ [ 2 - ] [ 1 + ] [ ] tri* ?nth ?nth ]  | 
					
						
							|  |  |  |     [ ?nth ?nth ]  | 
					
						
							|  |  |  |     [ [ 2 + ] [ 1 - ] [ ] tri* ?nth ?nth ] | 
					
						
							|  |  |  |     3tri
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     3array ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : bigraded-triples ( grid -- triples )
 | 
					
						
							|  |  |  |     dup length [ | 
					
						
							|  |  |  |         over first length [ | 
					
						
							| 
									
										
										
										
											2008-12-17 23:29:32 -05:00
										 |  |  |             [ 2dup ] dip spin bigraded-triple | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |         ] map 2nip
 | 
					
						
							| 
									
										
										
										
											2008-01-09 17:36:30 -05:00
										 |  |  |     ] with map ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : bigraded-laplacian ( u-generators z-generators quot -- seq )
 | 
					
						
							| 
									
										
										
										
											2008-12-17 23:29:32 -05:00
										 |  |  |     [ [ basis graded ] bi@ tensor bigraded-triples ] dip
 | 
					
						
							| 
									
										
										
										
											2008-04-26 00:17:08 -04:00
										 |  |  |     [ [ first3 ] prepose map ] curry map ; inline
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : bigraded-laplacian-betti ( u-generators z-generators -- seq )
 | 
					
						
							|  |  |  |     [ laplacian-betti ] bigraded-laplacian ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : bigraded-laplacian-kernel ( u-generators z-generators -- seq )
 | 
					
						
							|  |  |  |     [ laplacian-kernel ] bigraded-laplacian ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : bigraded-basis. ( seq -- )
 | 
					
						
							| 
									
										
										
										
											2008-07-07 20:36:33 -04:00
										 |  |  |     [ | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |         "=== U-degree " write .
 | 
					
						
							| 
									
										
										
										
											2008-07-07 20:36:33 -04:00
										 |  |  |         [ | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |             "  === Z-degree " write pprint | 
					
						
							|  |  |  |             ": dimension " write dup length .
 | 
					
						
							|  |  |  |             [ "  " write alt. ] each
 | 
					
						
							| 
									
										
										
										
											2008-07-07 20:36:33 -04:00
										 |  |  |         ] each-index
 | 
					
						
							|  |  |  |     ] each-index ;
 |