random: support random on sets.
parent
cf3c197743
commit
e8d50a2d08
|
@ -2,11 +2,12 @@
|
|||
! See http://factorcode.org/license.txt for BSD license.
|
||||
USING: accessors alien.data arrays assocs byte-arrays
|
||||
byte-vectors combinators combinators.short-circuit fry
|
||||
hashtables hashtables.private hints io.backend io.binary
|
||||
kernel locals math math.bitwise math.constants math.functions
|
||||
math.order math.ranges namespaces sequences sequences.private
|
||||
sets summary system typed vocabs ;
|
||||
hashtables hashtables.private hash-sets hints io.backend
|
||||
io.binary kernel locals math math.bitwise math.constants
|
||||
math.functions math.order math.ranges namespaces sequences
|
||||
sequences.private sets summary system typed vocabs ;
|
||||
QUALIFIED-WITH: alien.c-types c
|
||||
QUALIFIED-WITH: sets sets
|
||||
IN: random
|
||||
|
||||
SYMBOL: system-random-generator
|
||||
|
@ -83,6 +84,10 @@ M: hashtable random
|
|||
[ array-nth ] [ [ 1 + ] dip array-nth ] 2bi 2array
|
||||
] if-zero ;
|
||||
|
||||
M: sets:set random members random ;
|
||||
|
||||
M: hash-set random table>> random first ;
|
||||
|
||||
: randomize-n-last ( seq n -- seq )
|
||||
[ dup length dup ] dip - 1 max '[ dup _ > ]
|
||||
[ [ random ] [ 1 - ] bi [ pick exchange-unsafe ] keep ]
|
||||
|
|
Loading…
Reference in New Issue