factor/extra/benchmark/splay/splay.factor

21 lines
549 B
Factor

! Copyright (C) 2011 John Benediktsson
! See http://factorcode.org/license.txt for BSD license
USING: arrays assocs kernel math.ranges random sequences sets
sorting trees.splay ;
IN: benchmark.splay
: initial-alist ( n -- alist )
iota >array randomize dup zip ;
: change-random ( newkeys splay keys -- splay' )
swapd [ first pick delete-at first2 pick set-at ] 2each ;
: run-splay ( -- )
100,000 initial-alist 10,000 cut
[ >splay ] [ randomize 10,000 head ] bi
change-random keys dup natural-sort assert= ;
MAIN: run-splay