[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: Fun-O Basic Edition Compiler
Scott McKay wrote:
>
> "Scott McKay" <swm@mediaone.net> wrote in message
> iQkW7.39099$5W5.14789627@typhoon.ne.mediaone.net">news:iQkW7.39099$5W5.14789627@typhoon.ne.mediaone.net...
> >
> > "Carl Gay" <carlgay@mediaone.net> wrote in message
> > news:3C2938A6.4242FE86@mediaone.net...
> >
> > >
> > > define method tak (x :: <integer>, y :: <integer>, z :: <integer>)
> > > if (y >= x)
> > > z
> > > else
> > > tak(tak(x - 1, y, z),
> > > tak(y - 1, z, x),
> > > tak(z - 1, x, y))
> > > end if
> > > end;
> > >
> >
> > Try adding '=> (r :: <integer>)' as the return result of 'tak'. I'll bet
> > that your use of the implicit return type of <object> is defeating some
> > of FD's optimizations.
> >
> >
>
> Oh, and the timing loop should be for (i :: <integer> from 0 below 2000).
Actually FunDev gets this right (according to dispatch coloring)
even without the type decl in this case. I vaguely remember
this optimization being added back at Harlequin since it's so
common to do a loop with constant limits.
> You should add a fixnum decl to the Lisp code, too.
>
> Then you'll be comparing apples to apples in all the code, because the
> Java code is fully typed as 'int'...
I wrote:
> FunDev Lispworks Java Java
> Prod Mode static[1]
> ---------------------------------------------
> 11.314s 6.8s 4.297s 3.795s
> 1.0 1.7x 2.6x 3.0x
New numbers after adding a return type decl to the Dylan
code:
FunDev Lispworks Java
8.343s 6.8s 4.297s
1.0 1.2x 1.9x