changeset 24318:e6e8bf060dae

Add a bicubic scaler that needs a lot more instruction but no extra texture lookup
author reimar
date Tue, 04 Sep 2007 10:46:31 +0000
parents d6d9d3388a21
children 033b9debbec4
files libvo/gl_common.c libvo/gl_common.h
diffstat 2 files changed, 42 insertions(+), 0 deletions(-) [+]
line wrap: on
line diff
--- a/libvo/gl_common.c	Mon Sep 03 21:11:41 2007 +0000
+++ b/libvo/gl_common.c	Tue Sep 04 10:46:31 2007 +0000
@@ -708,6 +708,34 @@
   "MUL cdelta.yw, parmy.rrgg, {0, -1, 0, 1};"
   BICUB_FILT_MAIN("RECT");
 
+#define CALCWEIGHTS(t, s) \
+  "MAD "t", {-0.5, 0.1666, 0.3333, -0.3333}, "s", {1, 0, -0.5, 0.5};" \
+  "MAD "t", "t", "s", {0, 0, -0.5, 0.5};" \
+  "MAD "t", "t", "s", {-0.6666, 0, 0.8333, 0.1666};" \
+  "RCP a.x, "t".z;" \
+  "RCP a.y, "t".w;" \
+  "MAD "t".xy, "t".xyxy, a.xyxy, {1, 1, 0, 0};" \
+  "ADD "t".x, "t".xxxx, "s";" \
+  "SUB "t".y, "t".yyyy, "s";"
+
+static const char *bicub_notex_filt_template_2D =
+  "MAD coord.xy, fragment.texcoord[%c], {%f, %f}, {0.5, 0.5};"
+  "FRC coord.xy, coord.xyxy;"
+  CALCWEIGHTS("parmx", "coord.xxxx")
+  "MUL cdelta.xz, parmx.rrgg, {-%f, 0, %f, 0};"
+  CALCWEIGHTS("parmy", "coord.yyyy")
+  "MUL cdelta.yw, parmy.rrgg, {0, -%f, 0, %f};"
+  BICUB_FILT_MAIN("2D");
+
+static const char *bicub_notex_filt_template_RECT =
+  "ADD coord, fragment.texcoord[%c], {0.5, 0.5};"
+  "FRC coord.xy, coord.xyxy;"
+  CALCWEIGHTS("parmx", "coord.xxxx")
+  "MUL cdelta.xz, parmx.rrgg, {-1, 0, 1, 0};"
+  CALCWEIGHTS("parmy", "coord.yyyy")
+  "MUL cdelta.yw, parmy.rrgg, {0, -1, 0, 1};"
+  BICUB_FILT_MAIN("RECT");
+
 #define BICUB_X_FILT_MAIN(textype) \
   "ADD coord, fragment.texcoord[%c].xyxy, cdelta.xyxw;" \
   "ADD coord2, fragment.texcoord[%c].xyxy, cdelta.zyzw;" \
@@ -992,6 +1020,18 @@
                  texs[0], (float)1.0 / texw, (float)1.0 / texw,
                  in_tex, in_tex, in_tex, in_tex, out_comp);
       break;
+    case YUV_SCALER_BICUB_NOTEX:
+      if (rect)
+        snprintf(*prog_pos, *remain, bicub_notex_filt_template_RECT,
+                 in_tex,
+                 in_tex, in_tex, in_tex, in_tex, in_tex, in_tex, out_comp);
+      else
+        snprintf(*prog_pos, *remain, bicub_notex_filt_template_2D,
+                 in_tex, (float)texw, (float)texh,
+                 (float)1.0 / texw, (float)1.0 / texw,
+                 (float)1.0 / texh, (float)1.0 / texh,
+                 in_tex, in_tex, in_tex, in_tex, in_tex, in_tex, out_comp);
+      break;
   }
   *remain -= strlen(*prog_pos);
   *prog_pos += strlen(*prog_pos);
--- a/libvo/gl_common.h	Mon Sep 03 21:11:41 2007 +0000
+++ b/libvo/gl_common.h	Tue Sep 04 10:46:31 2007 +0000
@@ -241,6 +241,8 @@
 #define YUV_SCALER_BICUB 1
 //! use cubic scaling in X and normal linear scaling in Y direction
 #define YUV_SCALER_BICUB_X 2
+//! use cubic scaling without additional lookup texture
+#define YUV_SCALER_BICUB_NOTEX 3
 //! mask for conversion type
 #define YUV_CONVERSION_MASK 0xF
 //! mask for scaler type