double
result;
+ register ssize_t
+ i;
+
result=0.0;
switch (op)
{
}
case LeftShiftEvaluateOperator:
{
- result=(double) ((ssize_t) pixel << (ssize_t) (value+0.5));
+ result=(double) pixel;
+ for (i=0; i < (ssize_t) value; i++)
+ result*=2.0;
break;
}
case LogEvaluateOperator:
}
case RightShiftEvaluateOperator:
{
- result=(double) ((ssize_t) pixel >> (ssize_t) (value+0.5));
+ result=(double) pixel;
+ for (i=0; i < (ssize_t) value; i++)
+ result/=2.0;
break;
}
case RootMeanSquareEvaluateOperator: