2008-01-28 19:15:21 -05:00
|
|
|
! Copyright (C) 2008 Slava Pestov.
|
|
|
|
! See http://factorcode.org/license.txt for BSD license.
|
|
|
|
USING: arrays kernel kernel.private math sequences
|
2008-04-19 23:56:28 -04:00
|
|
|
sequences.private growable float-arrays prettyprint.backend
|
2008-04-20 03:30:52 -04:00
|
|
|
parser accessors ;
|
2008-01-28 19:15:21 -05:00
|
|
|
IN: float-vectors
|
|
|
|
|
2008-06-28 03:36:20 -04:00
|
|
|
TUPLE: float-vector
|
2008-07-02 03:03:30 -04:00
|
|
|
{ underlying float-array initial: F{ } }
|
2008-06-29 22:37:57 -04:00
|
|
|
{ length array-capacity } ;
|
2008-04-20 01:18:27 -04:00
|
|
|
|
2008-01-28 19:15:21 -05:00
|
|
|
: <float-vector> ( n -- float-vector )
|
2008-07-02 03:03:30 -04:00
|
|
|
<float-array> 0 float-vector boa ; inline
|
2008-01-28 19:15:21 -05:00
|
|
|
|
2008-04-20 01:18:27 -04:00
|
|
|
: >float-vector ( seq -- float-vector )
|
|
|
|
T{ float-vector f F{ } 0 } clone-like ;
|
2008-01-28 19:15:21 -05:00
|
|
|
|
|
|
|
M: float-vector like
|
|
|
|
drop dup float-vector? [
|
|
|
|
dup float-array?
|
2008-07-01 21:19:03 -04:00
|
|
|
[ dup length float-vector boa ] [ >float-vector ] if
|
2008-01-28 19:15:21 -05:00
|
|
|
] unless ;
|
|
|
|
|
2008-04-13 13:54:58 -04:00
|
|
|
M: float-vector new-sequence
|
2008-07-02 03:03:30 -04:00
|
|
|
drop [ <float-array> ] [ >fixnum ] bi float-vector boa ;
|
2008-01-28 19:15:21 -05:00
|
|
|
|
|
|
|
M: float-vector equal?
|
|
|
|
over float-vector? [ sequence= ] [ 2drop f ] if ;
|
|
|
|
|
2008-01-30 02:42:51 -05:00
|
|
|
M: float-array new-resizable drop <float-vector> ;
|
|
|
|
|
2008-01-28 19:15:21 -05:00
|
|
|
INSTANCE: float-vector growable
|
2008-04-19 23:56:28 -04:00
|
|
|
|
|
|
|
: FV{ \ } [ >float-vector ] parse-literal ; parsing
|
|
|
|
|
2008-04-20 01:18:27 -04:00
|
|
|
M: float-vector >pprint-sequence ;
|
|
|
|
|
2008-04-19 23:56:28 -04:00
|
|
|
M: float-vector pprint-delims drop \ FV{ \ } ;
|