2005-10-25 22:40:04 -04:00
|
|
|
IN: polynomials-internals
|
2005-10-31 13:13:06 -05:00
|
|
|
USING: kernel sequences vectors math math-internals namespaces arrays ;
|
2005-10-19 23:19:42 -04:00
|
|
|
|
2005-11-01 01:21:55 -05:00
|
|
|
! Polynomials are vectors with the highest powers on the right:
|
|
|
|
! { 1 1 0 1 } -> 1 + x + x^3
|
2005-11-01 01:28:29 -05:00
|
|
|
! { } -> 0
|
2005-11-01 01:21:55 -05:00
|
|
|
|
2005-10-19 23:19:42 -04:00
|
|
|
: 2length ( seq seq -- ) [ length ] 2apply ;
|
|
|
|
|
2006-01-02 00:51:03 -05:00
|
|
|
: zero-vector ( n -- vector ) 0 <array> >vector ;
|
2005-10-19 23:19:42 -04:00
|
|
|
|
|
|
|
: zero-pad ( n seq -- seq )
|
|
|
|
#! extend seq by n zeros
|
|
|
|
>r zero-vector r> swap append ;
|
|
|
|
|
|
|
|
: zero-pad-front ( n seq -- seq )
|
|
|
|
>r zero-vector r> append ;
|
|
|
|
|
2005-10-30 17:59:51 -05:00
|
|
|
: nzero-pad ( n seq -- )
|
|
|
|
#! extend seq by n zeros
|
|
|
|
>r zero-vector r> swap nappend ;
|
|
|
|
|
2005-10-19 23:19:42 -04:00
|
|
|
: zero-extend ( n seq -- )
|
|
|
|
#! extend seq to max(n,length) with 0s
|
|
|
|
[ length ] keep -rot - swap nzero-pad ;
|
|
|
|
|
|
|
|
: 2zero-extend ( seq seq -- )
|
|
|
|
2dup max-length [ swap zero-extend ] keep swap zero-extend ;
|
|
|
|
|
|
|
|
: pextend ( p p -- p p )
|
2005-11-01 01:21:55 -05:00
|
|
|
#! make two polynomials the same length, if empty, make length 1
|
|
|
|
[ >vector ] 2apply 2dup 2zero-extend ;
|
|
|
|
|
2005-11-01 01:28:29 -05:00
|
|
|
: unempty ( seq seq -- )
|
|
|
|
#! turn { } into { 0 }
|
|
|
|
dup empty? [ 1 swap zero-pad ] when ;
|
|
|
|
|
|
|
|
: 2unempty ( seq seq -- )
|
|
|
|
[ unempty ] 2apply ;
|
2005-10-19 23:19:42 -04:00
|
|
|
|
2005-10-23 19:07:16 -04:00
|
|
|
IN: math-contrib
|
2005-10-19 23:19:42 -04:00
|
|
|
|
|
|
|
: p= ( p p -- )
|
|
|
|
pextend = ;
|
|
|
|
|
|
|
|
: ptrim ( p -- p )
|
2005-10-31 13:13:06 -05:00
|
|
|
>vector
|
2005-10-19 23:19:42 -04:00
|
|
|
dup length 1 > [ dup peek 0 = [ dup pop drop ptrim ] when ] when ;
|
|
|
|
|
|
|
|
: 2ptrim ( p -- p )
|
|
|
|
[ ptrim ] 2apply ;
|
|
|
|
|
|
|
|
: p+ ( p p -- p )
|
|
|
|
pextend v+ ;
|
|
|
|
|
|
|
|
: p- ( p p -- p )
|
|
|
|
pextend v- ;
|
|
|
|
|
|
|
|
: n*p ( n p -- n*p )
|
|
|
|
n*v ;
|
|
|
|
|
|
|
|
! convolution
|
|
|
|
: (conv*a)
|
|
|
|
2dup swap length - rot zero-pad-front ;
|
|
|
|
|
|
|
|
: conv*a ( seq seq -- seq seq )
|
|
|
|
2dup 2length + 1- (conv*a) reverse -rot (conv*a) swap ;
|
|
|
|
|
|
|
|
: conv*b ( seq -- seq )
|
|
|
|
rot dup pop drop 1 zero-vector swap append -rot ;
|
|
|
|
|
|
|
|
: p* ( p p -- p )
|
2005-10-30 17:59:51 -05:00
|
|
|
#! Multiply two polynomials.
|
2005-11-01 01:28:29 -05:00
|
|
|
2unempty conv*a [ 3dup -rot v* sum >r pick r> -rot set-nth conv*b ] repeat nip ;
|
2005-10-19 23:19:42 -04:00
|
|
|
|
|
|
|
: p-sq ( p -- p-sq )
|
|
|
|
dup p* ;
|
|
|
|
|
2005-10-30 17:59:51 -05:00
|
|
|
IN: polynomials-internals
|
2005-10-19 23:19:42 -04:00
|
|
|
|
|
|
|
: pop-front ( seq -- seq )
|
|
|
|
1 swap tail ;
|
|
|
|
|
|
|
|
: /-last ( seq seq -- a )
|
|
|
|
#! divide the last two numbers in the sequences
|
|
|
|
[ peek ] 2apply /i ;
|
|
|
|
|
|
|
|
: p/mod-setup
|
|
|
|
2ptrim 2dup 2length - dup 1 < [ drop 1 ] when
|
|
|
|
dup >r swap zero-pad-front pextend r> 1+ ;
|
|
|
|
|
|
|
|
: (p/mod)
|
|
|
|
2dup /-last 2dup , n*p swapd p- dup pop drop swap pop-front ;
|
|
|
|
|
2005-10-30 17:59:51 -05:00
|
|
|
IN: math-contrib
|
2005-10-19 23:19:42 -04:00
|
|
|
|
|
|
|
: p/mod
|
2005-10-30 17:59:51 -05:00
|
|
|
p/mod-setup [ [ (p/mod) ] times ] V{ } make
|
|
|
|
reverse nip swap 2ptrim pextend ;
|
2005-10-19 23:19:42 -04:00
|
|
|
|
|
|
|
: (pgcd) ( b a y x -- a d )
|
2005-10-30 17:59:51 -05:00
|
|
|
dup V{ 0 } clone p= [
|
2005-10-19 23:19:42 -04:00
|
|
|
drop nip
|
|
|
|
] [
|
|
|
|
tuck p/mod >r pick p* swap >r swapd p- r> r> (pgcd)
|
|
|
|
] if ;
|
|
|
|
|
|
|
|
: pgcd ( p p -- p )
|
2005-10-30 17:59:51 -05:00
|
|
|
swap V{ 0 } clone V{ 1 } clone 2swap (pgcd) ;
|
2005-10-19 23:19:42 -04:00
|
|
|
|
2005-10-30 17:59:51 -05:00
|
|
|
: pdiff ( p -- p' )
|
|
|
|
#! Polynomial derivative.
|
2005-10-31 19:54:03 -05:00
|
|
|
dup empty? [ [ length ] keep v* 1 swap tail ] unless ;
|
2005-11-01 01:21:55 -05:00
|
|
|
|
2005-12-07 19:43:29 -05:00
|
|
|
: polyval ( x p -- p[x] )
|
|
|
|
#! Evaluate a polynomial.
|
|
|
|
[ powers ] keep v. ;
|