parent
a005a99c16
commit
526adb02f9
|
@ -1,4 +1,4 @@
|
||||||
USING: kernel sequences vectors math math-internals ;
|
USING: kernel sequences vectors math math-internals namespaces ;
|
||||||
|
|
||||||
USING: prettyprint inspector io test ;
|
USING: prettyprint inspector io test ;
|
||||||
|
|
||||||
|
@ -9,11 +9,10 @@ IN: math
|
||||||
[ length ] 2apply max ; flushable
|
[ length ] 2apply max ; flushable
|
||||||
|
|
||||||
IN: math-internals
|
IN: math-internals
|
||||||
: 2length ( seq seq -- ) >r length r> length ;
|
: 2length ( seq seq -- ) [ length ] 2apply ;
|
||||||
|
|
||||||
: zero-vector ( n -- vector ) 0 <repeated> >vector ;
|
: zero-vector ( n -- vector ) 0 <repeated> >vector ;
|
||||||
|
|
||||||
|
|
||||||
: nzero-pad ( n seq -- seq )
|
: nzero-pad ( n seq -- seq )
|
||||||
#! extend seq by n zeros
|
#! extend seq by n zeros
|
||||||
>r zero-vector r> swap nappend ;
|
>r zero-vector r> swap nappend ;
|
||||||
|
@ -32,15 +31,19 @@ IN: math-internals
|
||||||
: 2zero-extend ( seq seq -- )
|
: 2zero-extend ( seq seq -- )
|
||||||
2dup max-length [ swap zero-extend ] keep swap zero-extend ;
|
2dup max-length [ swap zero-extend ] keep swap zero-extend ;
|
||||||
|
|
||||||
|
: pextend ( p p -- p p )
|
||||||
|
2dup 2zero-extend ;
|
||||||
|
|
||||||
IN: math
|
IN: math
|
||||||
|
|
||||||
|
: p= ( p p -- )
|
||||||
|
pextend = ;
|
||||||
|
|
||||||
: ptrim ( p -- p )
|
: ptrim ( p -- p )
|
||||||
dup length 1 > [ dup peek 0 = [ dup pop drop ptrim ] when ] when ;
|
dup length 1 > [ dup peek 0 = [ dup pop drop ptrim ] when ] when ;
|
||||||
: 2ptrim ( p -- p )
|
|
||||||
ptrim >r ptrim r> ;
|
|
||||||
|
|
||||||
: pextend ( p p -- p p )
|
: 2ptrim ( p -- p )
|
||||||
2dup 2zero-extend ;
|
[ ptrim ] 2apply ;
|
||||||
|
|
||||||
: p+ ( p p -- p )
|
: p+ ( p p -- p )
|
||||||
pextend v+ ;
|
pextend v+ ;
|
||||||
|
@ -72,48 +75,31 @@ IN: math
|
||||||
dup p* ;
|
dup p* ;
|
||||||
|
|
||||||
IN: math-internals
|
IN: math-internals
|
||||||
: (nth-div) ( n v1 v2 -- a )
|
|
||||||
#! get nth from end
|
|
||||||
rot 1+ >r 2dup 2length r> swap over - >r - r> rot nth >r swap nth r> ;
|
|
||||||
|
|
||||||
: nth-divi ( n v1 v2 -- a )
|
: pop-front ( seq -- seq )
|
||||||
#! get nth from end
|
reverse dup pop drop reverse ;
|
||||||
(nth-div) /i ;
|
|
||||||
|
|
||||||
: nth-div
|
: /-last ( seq seq -- a )
|
||||||
(nth-div) / ;
|
#! divide the last two numbers in the sequences
|
||||||
|
[ peek ] 2apply /i ;
|
||||||
|
|
||||||
: shift-seq-left ( seq -- seq )
|
: p/mod-setup
|
||||||
! 1 over [ length ] keep <slice> [ change-nth ]
|
|
||||||
reverse dup pop drop reverse 0 over push ;
|
|
||||||
|
|
||||||
: p/mod-a ( u v -- q u v i )
|
|
||||||
#! set up the stack
|
|
||||||
2ptrim 2dup 2length - dup 1 < [ drop 1 ] when
|
2ptrim 2dup 2length - dup 1 < [ drop 1 ] when
|
||||||
dup >r swap zero-pad-front r> 1+ dup >r zero-vector -rot pextend r> ;
|
dup >r swap zero-pad-front pextend r> 1+ ;
|
||||||
|
|
||||||
: p/mod-b
|
: (p/mod)
|
||||||
>r >r pick r> r> swapd pick pick length swap - 1- rot
|
2dup /-last 2dup , n*p swapd p- dup pop drop swap pop-front ;
|
||||||
pick >r set-nth r> swap >r over n*p rot swap v- swap shift-seq-left r> ;
|
|
||||||
|
|
||||||
IN: math
|
IN: math
|
||||||
|
|
||||||
: p/modi ( u v -- q r )
|
: p/mod
|
||||||
#! integer coefficients
|
p/mod-setup [ [ (p/mod) ] times ] { } make reverse nip swap 2ptrim pextend ;
|
||||||
p/mod-a [ 3dup -rot nth-divi p/mod-b ] repeat drop 2ptrim pextend ;
|
|
||||||
|
|
||||||
: p/mod ( u v -- q r )
|
|
||||||
#! non-integer coefficients
|
|
||||||
p/mod-a [ 3dup -rot nth-div p/mod-b ] repeat drop 2ptrim pextend ;
|
|
||||||
|
|
||||||
: p= ( p p -- )
|
|
||||||
pextend = ;
|
|
||||||
|
|
||||||
: (pgcd) ( b a y x -- a d )
|
: (pgcd) ( b a y x -- a d )
|
||||||
dup { 0 } p= [
|
dup { 0 } p= [
|
||||||
drop nip
|
drop nip
|
||||||
] [
|
] [
|
||||||
tuck p/modi >r pick p* swap >r swapd p- r> r> (pgcd)
|
tuck p/mod >r pick p* swap >r swapd p- r> r> (pgcd)
|
||||||
] if ;
|
] if ;
|
||||||
|
|
||||||
: pgcd ( p p -- p )
|
: pgcd ( p p -- p )
|
||||||
|
@ -136,12 +122,13 @@ IN: math
|
||||||
[ { 4 8 0 12 } ] [ 4 { 1 2 0 3 } n*p ] unit-test
|
[ { 4 8 0 12 } ] [ 4 { 1 2 0 3 } n*p ] unit-test
|
||||||
[ { 1 4 7 6 0 0 0 0 0 } ] [ { 1 2 3 0 0 0 } { 1 2 0 0 } conv ] unit-test
|
[ { 1 4 7 6 0 0 0 0 0 } ] [ { 1 2 3 0 0 0 } { 1 2 0 0 } conv ] unit-test
|
||||||
[ { 1 4 7 6 0 0 0 0 0 } ] [ { 1 2 3 0 0 0 } { 1 2 0 0 } p* ] unit-test
|
[ { 1 4 7 6 0 0 0 0 0 } ] [ { 1 2 3 0 0 0 } { 1 2 0 0 } p* ] unit-test
|
||||||
[ { 7 -2 1 } { -20 0 0 } ] [ { 1 1 1 1 } { 3 1 } p/modi ] unit-test
|
[ { 7 -2 1 } { -20 0 0 } ] [ { 1 1 1 1 } { 3 1 } p/mod ] unit-test
|
||||||
[ { 1 0 1 } { 0 0 0 } ] [ { 1 1 1 1 } { 1 1 } p/modi ] unit-test
|
[ { 0 0 } { 1 1 } ] [ { 1 1 } { 1 1 1 1 } p/mod ] unit-test
|
||||||
[ { 1 0 1 } { 0 0 0 } ] [ { 1 1 1 1 } { 1 1 0 0 0 0 0 0 } p/modi ] unit-test
|
[ { 1 0 1 } { 0 0 0 } ] [ { 1 1 1 1 } { 1 1 } p/mod ] unit-test
|
||||||
[ { 1 0 1 } { 0 0 0 } ] [ { 1 1 1 1 0 0 0 0 } { 1 1 0 0 } p/modi ] unit-test
|
[ { 1 0 1 } { 0 0 0 } ] [ { 1 1 1 1 } { 1 1 0 0 0 0 0 0 } p/mod ] unit-test
|
||||||
[ { 5.0 } { 0.0 } ] [ { 10.0 } { 2.0 } p/mod ] unit-test
|
[ { 1 0 1 } { 0 0 0 } ] [ { 1 1 1 1 0 0 0 0 } { 1 1 0 0 } p/mod ] unit-test
|
||||||
[ { 15/16 } { 0 } ] [ { 3/4 } { 4/5 } p/mod ] unit-test
|
! [ { 5.0 } { 0.0 } ] [ { 10.0 } { 2.0 } p/mod ] unit-test
|
||||||
|
! [ { 15/16 } { 0 } ] [ { 3/4 } { 4/5 } p/mod ] unit-test
|
||||||
[ t ] [ { 0 1 } { 0 1 0 } p= ] unit-test
|
[ t ] [ { 0 1 } { 0 1 0 } p= ] unit-test
|
||||||
[ f ] [ { 0 0 1 } { 0 1 0 } p= ] unit-test
|
[ f ] [ { 0 0 1 } { 0 1 0 } p= ] unit-test
|
||||||
[ t ] [ { 1 1 1 } { 1 1 1 } p= ] unit-test
|
[ t ] [ { 1 1 1 } { 1 1 1 } p= ] unit-test
|
||||||
|
|
Loading…
Reference in New Issue