///////////////////////////////////////////////////////////////////////////////
+class FixedMathBench : public SkBenchmark {
+ enum {
+ N = SkBENCHLOOP(1000),
+ NN = SkBENCHLOOP(1000),
+ };
+ float fData[N];
+ SkFixed fResult[N];
+public:
+
+ FixedMathBench(void* param) : INHERITED(param) {
+ SkRandom rand;
+ for (int i = 0; i < N; ++i) {
+ fData[i] = rand.nextSScalar1();
+ }
+
+ fIsRendering = false;
+ }
+
+protected:
+ virtual void onDraw(SkCanvas*) {
+ for (int j = 0; j < NN; ++j) {
+ for (int i = 0; i < N - 4; ++i) {
+ fResult[i] = SkFloatToFixed(fData[i]);
+ }
+ }
+
+ SkPaint paint;
+ if (paint.getAlpha() == 0) {
+ SkDebugf("%d\n", fResult[0]);
+ }
+ }
+
+ virtual const char* onGetName() {
+ return "float_to_fixed";
+ }
+
+private:
+ typedef SkBenchmark INHERITED;
+};
+
+///////////////////////////////////////////////////////////////////////////////
+
DEF_BENCH( return new NoOpMathBench(p); )
DEF_BENCH( return new SlowISqrtMathBench(p); )
DEF_BENCH( return new FastISqrtMathBench(p); )
DEF_BENCH( return new CLZBench(p, true); )
DEF_BENCH( return new NormalizeBench(p); )
+
+DEF_BENCH( return new FixedMathBench(p); )
float val;
for (float angle = -720; angle < 720; angle += 30) {
float radian = angle * 3.1415925358f / 180.0f;
- SkFixed f_angle = (int) (radian * 65536.0f);
+ SkFixed f_angle = SkFloatToFixed(radian);
// sincos
float sine = sinf(radian);
float cosine = cosf(radian);
SkDebugf("tan error : angle = %g ; tan = %g ; cordic = %g\n", angle, _tan, tan2);
}
for (val = -1; val <= 1; val += .1f) {
- SkFixed f_val = (int) (val * 65536.0f);
+ SkFixed f_val = SkFloatToFixed(val);
// asin
float arcsine = asinf(val);
SkFixed f_arcsine = SkCordicASin(f_val);
#else
val = .5; {
#endif
- SkFixed f_val = (int) (val * 65536.0f);
+ SkFixed f_val = SkFloatToFixed(val);
// acos
float arccos = acosf(val);
SkFixed f_arccos = SkCordicACos(f_val);
val = 0; {
float val2 = -1000; {
#endif
- SkFixed f_val = (int) (val * 65536.0f);
- SkFixed f_val2 = (int) (val2 * 65536.0f);
+ SkFixed f_val = SkFloatToFixed(val);
+ SkFixed f_val2 = SkFloatToFixed(val2);
float arctan = atan2f(val, val2);
SkFixed f_arctan = SkCordicATan2(f_val, f_val2);
float arctan2 = (float) f_arctan / 65536.0f;
#else
val = .5; {
#endif
- SkFixed f_val = (int) (val * 65536.0f);
+ SkFixed f_val = SkFloatToFixed(val);
// acos
float log = logf(val);
SkFixed f_log = SkCordicLog(f_val);