prefix-bigloo-int.scm 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204
  1. ;------------------------------------------------------------------------------
  2. (module prefix (main main-entry))
  3. ;INSERTCODE
  4. (define (time* thunk)
  5. (thunk))
  6. (define (run-bench name count ok? run)
  7. (let loop ((i 0) (result (list 'undefined)))
  8. (if (< i count)
  9. (loop (+ i 1) (run))
  10. result)))
  11. (define (run-benchmark name count ok? run-maker . args)
  12. (newline)
  13. (let* ((run (apply run-maker args))
  14. (result (time* (lambda () (run-bench name count ok? run)))))
  15. (if (not (ok? result))
  16. (begin
  17. (display "*** wrong result ***")
  18. (newline)
  19. (display "*** got: ")
  20. (write result)
  21. (newline))))
  22. (exit 0))
  23. (define (fatal-error . args)
  24. (for-each display args)
  25. (newline)
  26. (exit 1))
  27. (define (call-with-output-file/truncate filename proc)
  28. (call-with-output-file filename proc))
  29. (define (main-entry args)
  30. (main))
  31. ;------------------------------------------------------------------------------
  32. ; Macros...
  33. (define-macro (def-macro form . body)
  34. `(define-macro ,form (let () ,@body)))
  35. (if-fixflo
  36. (begin
  37. ; Specialize fixnum and flonum arithmetic.
  38. (def-macro (FLOATvector-const . lst) `',(list->vector lst))
  39. (def-macro (FLOATvector? x) `(vector? ,x))
  40. (def-macro (FLOATvector . lst) `(vector ,@lst))
  41. (def-macro (FLOATmake-vector n . init) `(make-vector ,n ,@init))
  42. (def-macro (FLOATvector-ref v i) `(vector-ref ,v ,i))
  43. (def-macro (FLOATvector-set! v i x) `(vector-set! ,v ,i ,x))
  44. (def-macro (FLOATvector-length v) `(vector-length ,v))
  45. (def-macro (nuc-const . lst)
  46. `',(list->vector lst))
  47. (def-macro (FLOAT+ . lst)
  48. (cond ((null? lst) `0.0)
  49. ((null? (cdr lst)) (car lst))
  50. (else `(+fl ,(car lst) (FLOAT+ ,@(cdr lst))))))
  51. (def-macro (FLOAT- . lst)
  52. (cond ((null? (cdr lst)) `(negfl ,(car lst)))
  53. (else `(-fl ,(car lst) (FLOAT+ ,@(cdr lst))))))
  54. (def-macro (FLOAT* . lst)
  55. (cond ((null? lst) `1.0)
  56. ((null? (cdr lst)) (car lst))
  57. (else `(*fl ,(car lst) (FLOAT* ,@(cdr lst))))))
  58. (def-macro (FLOAT/ . lst)
  59. (cond ((null? (cdr lst)) `(/fl 1.0 ,(car lst)))
  60. (else `(/fl ,(car lst) (FLOAT* ,@(cdr lst))))))
  61. (def-macro (FLOAT= . lst) `(=fl ,@lst))
  62. (def-macro (FLOAT< . lst) `(<fl ,@lst))
  63. (def-macro (FLOAT<= . lst) `(<=fl ,@lst))
  64. (def-macro (FLOAT> . lst) `(>fl ,@lst))
  65. (def-macro (FLOAT>= . lst) `(>=fl ,@lst))
  66. (def-macro (FLOATnegative? . lst) `(negativefl? ,@lst))
  67. (def-macro (FLOATpositive? . lst) `(positivefl? ,@lst))
  68. (def-macro (FLOATzero? . lst) `(zerofl? ,@lst))
  69. (def-macro (FLOATabs . lst) `(abs ,@lst))
  70. (def-macro (FLOATsin . lst) `(sin ,@lst))
  71. (def-macro (FLOATcos . lst) `(cos ,@lst))
  72. (def-macro (FLOATatan . lst) `(atan ,@lst))
  73. (def-macro (FLOATsqrt . lst) `(sqrt ,@lst))
  74. (def-macro (FLOATmin . lst) `(minfl ,@lst))
  75. (def-macro (FLOATmax . lst) `(maxfl ,@lst))
  76. (def-macro (FLOATround . lst) `(roundfl ,@lst))
  77. (def-macro (FLOATinexact->exact . lst) `(inexact->exact ,@lst))
  78. (define (GENERIC+ x y) (+ x y))
  79. (define (GENERIC- x y) (- x y))
  80. (define (GENERIC* x y) (* x y))
  81. (define (GENERIC/ x y) (/ x y))
  82. (define (GENERICquotient x y) (quotient x y))
  83. (define (GENERICremainder x y) (remainder x y))
  84. (define (GENERICmodulo x y) (modulo x y))
  85. (define (GENERIC= x y) (= x y))
  86. (define (GENERIC< x y) (< x y))
  87. (define (GENERIC<= x y) (<= x y))
  88. (define (GENERIC> x y) (> x y))
  89. (define (GENERIC>= x y) (>= x y))
  90. (define (GENERICexpt x y) (expt x y))
  91. (def-macro (+ . lst)
  92. (cond ((null? lst) `0)
  93. ((null? (cdr lst)) (car lst))
  94. (else `(+fx ,(car lst) (+ ,@(cdr lst))))))
  95. (def-macro (- . lst)
  96. (cond ((null? (cdr lst)) `(negfx ,(car lst)))
  97. (else `(-fx ,(car lst) (+ ,@(cdr lst))))))
  98. (def-macro (* . lst)
  99. (cond ((null? lst) `1)
  100. ((null? (cdr lst)) (car lst))
  101. (else `(*fx ,(car lst) (* ,@(cdr lst))))))
  102. ;(def-macro (quotient . lst) `(quotient ,@lst))
  103. ;(def-macro (modulo . lst) `(modulo ,@lst))
  104. ;(def-macro (remainder . lst) `(remainder ,@lst))
  105. (def-macro (= . lst) `(=fx ,@lst))
  106. (def-macro (< . lst) `(<fx ,@lst))
  107. (def-macro (<= . lst) `(<=fx ,@lst))
  108. (def-macro (> . lst) `(>fx ,@lst))
  109. (def-macro (>= . lst) `(>=fx ,@lst))
  110. (def-macro (negative? . lst) `(negativefx? ,@lst))
  111. (def-macro (positive? . lst) `(positivefx? ,@lst))
  112. (def-macro (zero? . lst) `(zerofx? ,@lst))
  113. ;(def-macro (odd? . lst) `(odd? ,@lst))
  114. ;(def-macro (even? . lst) `(even? ,@lst))
  115. (def-macro (bitwise-or . lst) `(bit-or ,@lst))
  116. (def-macro (bitwise-and . lst) `(bit-and ,@lst))
  117. (def-macro (bitwise-not . lst) `(bit-not ,@lst))
  118. )
  119. (begin
  120. ; Don't specialize fixnum and flonum arithmetic.
  121. (def-macro (FLOATvector-const . lst) `',(list->vector lst))
  122. (def-macro (FLOATvector? x) `(vector? ,x))
  123. (def-macro (FLOATvector . lst) `(vector ,@lst))
  124. (def-macro (FLOATmake-vector n . init) `(make-vector ,n ,@init))
  125. (def-macro (FLOATvector-ref v i) `(vector-ref ,v ,i))
  126. (def-macro (FLOATvector-set! v i x) `(vector-set! ,v ,i ,x))
  127. (def-macro (FLOATvector-length v) `(vector-length ,v))
  128. (def-macro (nuc-const . lst)
  129. `',(list->vector lst))
  130. (def-macro (FLOAT+ . lst) `(+ ,@lst))
  131. (def-macro (FLOAT- . lst) `(- ,@lst))
  132. (def-macro (FLOAT* . lst) `(* ,@lst))
  133. (def-macro (FLOAT/ . lst) `(/ ,@lst))
  134. (def-macro (FLOAT= . lst) `(= ,@lst))
  135. (def-macro (FLOAT< . lst) `(< ,@lst))
  136. (def-macro (FLOAT<= . lst) `(<= ,@lst))
  137. (def-macro (FLOAT> . lst) `(> ,@lst))
  138. (def-macro (FLOAT>= . lst) `(>= ,@lst))
  139. (def-macro (FLOATnegative? . lst) `(negative? ,@lst))
  140. (def-macro (FLOATpositive? . lst) `(positive? ,@lst))
  141. (def-macro (FLOATzero? . lst) `(zero? ,@lst))
  142. (def-macro (FLOATabs . lst) `(abs ,@lst))
  143. (def-macro (FLOATsin . lst) `(sin ,@lst))
  144. (def-macro (FLOATcos . lst) `(cos ,@lst))
  145. (def-macro (FLOATatan . lst) `(atan ,@lst))
  146. (def-macro (FLOATsqrt . lst) `(sqrt ,@lst))
  147. (def-macro (FLOATmin . lst) `(min ,@lst))
  148. (def-macro (FLOATmax . lst) `(max ,@lst))
  149. (def-macro (FLOATround . lst) `(round ,@lst))
  150. (def-macro (FLOATinexact->exact . lst) `(inexact->exact ,@lst))
  151. (def-macro (GENERIC+ . lst) `(+ ,@lst))
  152. (def-macro (GENERIC- . lst) `(- ,@lst))
  153. (def-macro (GENERIC* . lst) `(* ,@lst))
  154. (def-macro (GENERIC/ . lst) `(/ ,@lst))
  155. (def-macro (GENERICquotient . lst) `(quotient ,@lst))
  156. (def-macro (GENERICremainder . lst) `(remainder ,@lst))
  157. (def-macro (GENERICmodulo . lst) `(modulo ,@lst))
  158. (def-macro (GENERIC= . lst) `(= ,@lst))
  159. (def-macro (GENERIC< . lst) `(< ,@lst))
  160. (def-macro (GENERIC<= . lst) `(<= ,@lst))
  161. (def-macro (GENERIC> . lst) `(> ,@lst))
  162. (def-macro (GENERIC>= . lst) `(>= ,@lst))
  163. (def-macro (GENERICexpt . lst) `(expt ,@lst))
  164. (def-macro (bitwise-or . lst) `(bit-or ,@lst))
  165. (def-macro (bitwise-and . lst) `(bit-and ,@lst))
  166. (def-macro (bitwise-not . lst) `(bit-not ,@lst))
  167. )
  168. )
  169. ;------------------------------------------------------------------------------