typed-racket/typed-racket-test/succeed/pr13339.rkt
2014-12-16 10:07:25 -05:00

29 lines
719 B
Racket

#lang typed/racket
(require racket/flonum
typed/rackunit)
(: neg (Real -> Real))
(define (neg x) (- x))
(: flneg (Flonum -> Flonum))
(define (flneg x) (fl* -1.0 x))
(check-eqv? (neg +inf.0) -inf.0)
(check-eqv? (neg -inf.0) +inf.0)
(check-eqv? (neg +nan.0) +nan.0)
(check-eqv? (neg -0.0) +0.0)
(check-eqv? (neg +0.0) -0.0)
(check-eqv? (flneg +inf.0) (neg +inf.0))
(check-eqv? (flneg -inf.0) (neg -inf.0))
(check-eqv? (flneg +nan.0) (neg +nan.0))
(check-eqv? (flneg -0.0) (neg -0.0))
(check-eqv? (flneg +0.0) (neg +0.0))
(check-eqv? (- +inf.0) (neg +inf.0))
(check-eqv? (- -inf.0) (neg -inf.0))
(check-eqv? (- +nan.0) (neg +nan.0))
(check-eqv? (- -0.0) (neg -0.0))
(check-eqv? (- +0.0) (neg +0.0))