1 ! Copyright (C) 2008 Doug Coleman.
2 ! See http://factorcode.org/license.txt for BSD license.
3 USING: arrays kernel make math math.order math.vectors sequences shuffle
9 : 2pad-left ( p q n -- p q ) [ 0 pad-left ] curry bi@ ;
10 : 2pad-right ( p q n -- p q ) [ 0 pad-right ] curry bi@ ;
11 : pextend ( p q -- p q ) 2dup [ length ] bi@ max 2pad-right ;
12 : pextend-left ( p q -- p q ) 2dup [ length ] bi@ max 2pad-left ;
13 : unempty ( seq -- seq ) [ { 0 } ] when-empty ;
14 : 2unempty ( seq seq -- seq seq ) [ unempty ] bi@ ;
18 : powers ( n x -- seq )
19 <array> 1 [ * ] accumulate nip ;
21 : p= ( p q -- ? ) pextend = ;
24 dup length 1 = [ [ zero? ] trim-right ] unless ;
26 : 2ptrim ( p q -- p q ) [ ptrim ] bi@ ;
27 : p+ ( p q -- r ) pextend v+ ;
28 : p- ( p q -- r ) pextend v- ;
29 : n*p ( n p -- n*p ) n*v ;
31 : pextend-conv ( p q -- p q )
32 2dup [ length ] bi@ + 1- 2pad-right [ >vector ] bi@ ;
35 2unempty pextend-conv <reversed> dup length
36 [ over length pick <slice> pick [ * ] 2map sum ] map 2nip reverse ;
43 : p/mod-setup ( p p -- p p n )
46 dup 1 < [ drop 1 ] when
47 [ over length + 0 pad-left pextend ] keep 1+ ;
49 : /-last ( seq seq -- a )
50 #! divide the last two numbers in the sequences
53 : (p/mod) ( p p -- p p )
57 dup pop* swap rest-slice ;
61 : p/mod ( p q -- z w )
62 p/mod-setup [ [ (p/mod) ] times ] V{ } make
63 reverse nip swap 2ptrim pextend ;
67 : (pgcd) ( b a y x -- a d )
72 [ pick p* swap [ swapd p- ] dip ] dip (pgcd)
78 swap V{ 0 } clone V{ 1 } clone 2swap (pgcd) [ >array ] bi@ ;
81 dup length v* { 0 } ?head drop ;
83 : polyval ( p x -- p[x] )
84 [ dup length ] dip powers v. ;