add natural? to the known predicates with generators

This commit is contained in:
Robby Findler 2017-03-05 21:14:51 -06:00
parent 7bd7ec5aaf
commit dbddb3785e
4 changed files with 48 additions and 26 deletions

View File

@ -3,6 +3,7 @@
(require racket/contract
racket/contract/private/generate-base
rackunit
racket/math
(for-syntax racket/base))
;; this is expected to never have a generator.
@ -41,6 +42,8 @@
(check-not-exn (λ () (test-contract-generation (listof number?))))
(check-not-exn (λ () (test-contract-generation (integer-in 0 100))))
(check-not-exn (λ () (test-contract-generation exact-nonnegative-integer?)))
(check-not-exn (λ () (test-contract-generation natural?)))
(check-not-exn (λ () (test-contract-generation (integer-in 0 (expt 2 1000)))))
(check-not-exn (λ () (test-contract-generation (char-in #\a #\z))))
(check-not-exn (λ () (test-contract-generation #\a)))

View File

@ -1,5 +1,6 @@
#lang racket/base
(require "rand.rkt")
(require "rand.rkt"
"../../private/math-predicates.rkt")
(provide
contract-random-generate-fail
@ -71,6 +72,9 @@
exact-integer?
exact-integer-gen
natural?
exact-nonnegative-integer-gen
exact-nonnegative-integer?
exact-nonnegative-integer-gen

View File

@ -5,7 +5,8 @@
#lang racket/base
(require "unsafe/ops.rkt"
"performance-hint.rkt")
"performance-hint.rkt"
"private/math-predicates.rkt")
(provide pi pi.f
nan? infinite?
@ -26,30 +27,6 @@
(begin-encourage-inline
;; real predicates
(define (nan? x)
(unless (real? x) (raise-argument-error 'nan? "real?" x))
(or (eqv? x +nan.0) (eqv? x +nan.f)))
(define (infinite? x)
(unless (real? x) (raise-argument-error 'infinite? "real?" x))
(or (= x +inf.0) (= x -inf.0)))
(define (positive-integer? x)
(and (integer? x) (positive? x)))
(define (negative-integer? x)
(and (integer? x) (negative? x)))
(define (nonpositive-integer? x)
(and (integer? x) (not (positive? x))))
(define (nonnegative-integer? x)
(and (integer? x) (not (negative? x))))
(define (natural? x)
(exact-nonnegative-integer? x))
;; z^2
(define (sqr z)
(unless (number? z) (raise-argument-error 'sqr "number?" z))

View File

@ -0,0 +1,38 @@
#lang racket/base
(require "performance-hint.rkt")
(provide nan?
infinite?
positive-integer?
negative-integer?
nonpositive-integer?
nonnegative-integer?
natural?)
;; these are broken out from racket/math
;; so that racket/contract can depend on them
(begin-encourage-inline
;; real predicates
(define (nan? x)
(unless (real? x) (raise-argument-error 'nan? "real?" x))
(or (eqv? x +nan.0) (eqv? x +nan.f)))
(define (infinite? x)
(unless (real? x) (raise-argument-error 'infinite? "real?" x))
(or (= x +inf.0) (= x -inf.0)))
(define (positive-integer? x)
(and (integer? x) (positive? x)))
(define (negative-integer? x)
(and (integer? x) (negative? x)))
(define (nonpositive-integer? x)
(and (integer? x) (not (positive? x))))
(define (nonnegative-integer? x)
(and (integer? x) (not (negative? x))))
(define (natural? x)
(exact-nonnegative-integer? x)))