On Fri, 17 Jul 2009 13:51:35 +0200
Szabolcs Nagy <nszabo...@gmail.com> wrote:

> On 7/17/09, Szabolcs Nagy <nszabo...@gmail.com> wrote:
> > it turns out the result of those inequalities depend on compiler
> > optimization flags (compiler might choose to use double division and
> > comparison instead of float one) so with -O0 there are no updates,
> > with -Os there are always updates unless the aspect is a "nice"
> > ratio.
> 
> hm it's worse than that, even -O0 uses double comparison there, a
> float cast is not enough.
> 
> one can get expected behaviour with using -O0 flag and something like
> 
>               if(c->mina > 0 && c->maxa > 0) {
> +                     float a1 = (float)*w / *h;
> +                     float a2 = (float)*h / *w;
> +
> -                     if(c->maxa < (float)*w / *h)
> +                     if(c->maxa < a1)
>                               *w = *h * c->maxa;
> -                     else if(c->mina < (float)*h / *w)
> +                     else if(c->mina < a2)
>                               *h = *w * c->mina;
>               }
> 
> and then indeed no unnecessary updates occur
> 
> moral of the story: don't rely on (float)a/b == (float)a/b

But of course!

(float)*w/(float)*h != (float) (w/h) in most cases also...

assuming w and h are ints.


-- 
Preben Randhol

Reply via email to