trying to fix benchmark for list-length, which is failing badly

This commit is contained in:
Danny Yoo 2012-02-10 13:27:26 -05:00
parent e6877c3e19
commit 6d035504af
7 changed files with 54 additions and 15 deletions

View File

@ -525,13 +525,13 @@
(: compile-branch (Branch CompileTimeEnvironment Target Linkage -> InstructionSequence))
;; Compiles a conditional branch.
(define (compile-branch exp cenv target linkage)
(let: ([f-branch : Symbol (make-label 'falseBranch)]
[after-if : Symbol (make-label 'afterIf)])
(let: ([f-branch: : Symbol (make-label 'falseBranch)]
[after-if: : Symbol (make-label 'afterIf)])
(let ([consequent-linkage
(cond
[(NextLinkage? linkage)
(let ([context (NextLinkage-context linkage)])
(make-LabelLinkage after-if context))]
(make-LabelLinkage after-if: context))]
[(ReturnLinkage? linkage)
linkage]
[(LabelLinkage? linkage)
@ -542,11 +542,12 @@
(append-instruction-sequences
p-code
(make-TestAndJumpStatement (make-TestFalse (make-Reg 'val))
f-branch)
f-branch:)
c-code
f-branch
a-code
after-if)))))
f-branch: a-code
(if (NextLinkage? linkage)
after-if:
empty-instruction-sequence))))))
(: compile-sequence ((Listof Expression) CompileTimeEnvironment Target Linkage -> InstructionSequence))

11
examples/list-length.rkt Normal file
View File

@ -0,0 +1,11 @@
#lang planet dyoo/whalesong
(define (mylen x)
(cond
[(empty? x)
0]
[else
(add1 (mylen (rest x)))]))
"computing length"
(mylen (build-list 100000 (lambda (i) i)))
"done computing length"

View File

@ -30,7 +30,8 @@
assemble-location
assemble-numeric-constant
block-looks-like-context-expected-values?)
block-looks-like-context-expected-values?
block-looks-like-pop-multiple-values-and-continue?)
(require/typed typed/racket/base
[regexp-split (Regexp String -> (Listof String))])
@ -429,6 +430,13 @@
#f]))
(: block-looks-like-pop-multiple-values-and-continue? (BasicBlock -> (U False)))
(define (block-looks-like-pop-multiple-values-and-continue? a-block)
;; FIXME!
#f)

View File

@ -208,6 +208,13 @@ EOF
(munge-label-name (make-Label (BasicBlock-name a-basic-block)))
expected)
'ok]))]
[(block-looks-like-pop-multiple-values-and-continue? a-basic-block)
=>
(lambda (target)
(fprintf op "~a=RT.si_pop_multiple-values-and-continue(~a);"
(munge-label-name (make-Label (BasicBlock-name a-basic-block)))
target))]
[else
(default-assemble-basic-block a-basic-block blockht entry-points function-entry-and-exit-names op)]))

View File

@ -263,10 +263,16 @@
var isList = function (x) {
var tortoise, hare;
tortoise = hare = x;
if (hare === EMPTY) { return true; }
if (hare === EMPTY) {
tortoise._isList = true;
return true;
}
while (true) {
if (!(hare instanceof Cons)) { return false; }
if (tortoise instanceof Cons) { tortoise = tortoise.rest; }
if (tortoise instanceof Cons) {
if (tortoise._isList === true) { return true; }
tortoise = tortoise.rest;
}
hare = hare.rest;
if (hare instanceof Cons) { hare = hare.rest; }
if (hare === EMPTY) { return true; }

View File

@ -790,10 +790,16 @@
};
var si_context_expected_1 = function(M) { raiseContextExpectedValuesError(M, 1); }
// A block that omits the multiple values returned on the stack and
// continues on with the target function f.
var si_pop_multiple_values_and_continue = function(target) {
var f = function(M) {
if(--M.cbt<0) { throw f; }
M.e.length -= (M.a-1);
return target(M);
};
return f;
};

View File

@ -7,4 +7,4 @@
(provide version)
(: version String)
(define version "1.113")
(define version "1.114")