! Copyright (C) 2008 Doug Coleman. ! See http://factorcode.org/license.txt for BSD license. USING: tools.test math.floating-point kernel math.constants fry sequences math random ; IN: math.floating-point.tests [ t ] [ pi >double< >double pi = ] unit-test [ t ] [ -1.0 >double< >double -1.0 = ] unit-test [ t ] [ 1/0. infinity? ] unit-test [ t ] [ -1/0. infinity? ] unit-test [ f ] [ 0/0. infinity? ] unit-test [ f ] [ 10. infinity? ] unit-test [ f ] [ -10. infinity? ] unit-test [ f ] [ 0. infinity? ] unit-test [ 0 ] [ 0.0 double>ratio ] unit-test [ 1 ] [ 1.0 double>ratio ] unit-test [ 1/2 ] [ 0.5 double>ratio ] unit-test [ 3/4 ] [ 0.75 double>ratio ] unit-test [ 12+1/2 ] [ 12.5 double>ratio ] unit-test [ -12-1/2 ] [ -12.5 double>ratio ] unit-test [ 3+39854788871587/281474976710656 ] [ pi double>ratio ] unit-test : roundtrip ( n -- ) [ '[ _ ] ] keep '[ _ double>ratio >float ] unit-test ; { 1 12 123 1234 } [ bits>double roundtrip ] each 100 [ -10.0 10.0 uniform-random-float roundtrip ] times