# HG changeset patch # User reimar # Date 1200419960 0 # Node ID 9a96fd14d1c594e2e5262636d56b3909dd16aca0 # Parent df6e9b54ecaa4fa20f1e033051c66fcfe9f74c22 Add experimental unsharp-mask OpenGL scaler. Certainly not yet perfect. diff -r df6e9b54ecaa -r 9a96fd14d1c5 DOCS/man/en/mplayer.1 --- a/DOCS/man/en/mplayer.1 Tue Jan 15 17:54:48 2008 +0000 +++ b/DOCS/man/en/mplayer.1 Tue Jan 15 17:59:20 2008 +0000 @@ -3654,6 +3654,8 @@ Works on a few more cards than method 1. .br 3: Same as 1 but does not use a lookup texture. Might be faster on some cards. +.br +4: Use unsharp masking with 3x3 support and a strength of 0.5. Experimental. .RE .IPs cscale= Select the scaling function to use for chrominance scaling. diff -r df6e9b54ecaa -r 9a96fd14d1c5 libvo/gl_common.c --- a/libvo/gl_common.c Tue Jan 15 17:54:48 2008 +0000 +++ b/libvo/gl_common.c Tue Jan 15 17:59:20 2008 +0000 @@ -756,6 +756,26 @@ "MUL cdelta.xz, parmx.rrgg, {-1, 0, 1, 0};" BICUB_X_FILT_MAIN("RECT"); +#define UNSHARP_FILT_MAIN(textype) \ + "TEX a.r, fragment.texcoord[%c], texture[%c], "textype";" \ + "TEX b.r, coord.xyxy, texture[%c], "textype";" \ + "TEX b.g, coord.zwzw, texture[%c], "textype";" \ + "TEX b.b, coord2.xyxy, texture[%c], "textype";" \ + "TEX b.a, coord2.zwzw, texture[%c], "textype";" \ + "DP4 b, b, {0.25, 0.25, 0.25, 0.25};" \ + "SUB b.r, a.r, b.r;" \ + "MAD yuv.%c, b.r, %s, a.r;" + +static const char *unsharp_filt_template_2D = + "ADD coord, fragment.texcoord[%c].xyxy, {%f, %f, -%f, -%f};" + "ADD coord2, fragment.texcoord[%c].xyxy, {%f, -%f, -%f, %f};" + UNSHARP_FILT_MAIN("2D"); + +static const char *unsharp_filt_template_RECT = + "ADD coord, fragment.texcoord[%c].xyxy, {0.5, 0.5, -0.5, -0.5};" + "ADD coord2, fragment.texcoord[%c].xyxy, {0.5, -0.5, -0.5, 0.5};" + UNSHARP_FILT_MAIN("RECT"); + static const char *yuv_prog_template = "PARAM ycoef = {%.4f, %.4f, %.4f};" "PARAM ucoef = {%.4f, %.4f, %.4f};" @@ -812,6 +832,7 @@ switch (scaler) { case YUV_SCALER_BILIN: case YUV_SCALER_BICUB_NOTEX: + case YUV_SCALER_UNSHARP: break; case YUV_SCALER_BICUB: case YUV_SCALER_BICUB_X: @@ -1033,6 +1054,20 @@ (float)1.0 / texh, (float)1.0 / texh, in_tex, in_tex, in_tex, in_tex, in_tex, in_tex, out_comp); break; + case YUV_SCALER_UNSHARP: + if (rect) + snprintf(*prog_pos, *remain, unsharp_filt_template_RECT, + in_tex, + in_tex, + in_tex, in_tex, in_tex, in_tex, in_tex, in_tex, out_comp, + "{0.5}"); + else + snprintf(*prog_pos, *remain, unsharp_filt_template_2D, + in_tex, (float)0.5 / texw, (float)0.5 / texh, (float)0.5 / texw, (float)0.5 / texh, + in_tex, (float)0.5 / texw, (float)0.5 / texh, (float)0.5 / texw, (float)0.5 / texh, + in_tex, in_tex, in_tex, in_tex, in_tex, in_tex, out_comp, + "{0.5}"); + break; } *remain -= strlen(*prog_pos); *prog_pos += strlen(*prog_pos); diff -r df6e9b54ecaa -r 9a96fd14d1c5 libvo/gl_common.h --- a/libvo/gl_common.h Tue Jan 15 17:54:48 2008 +0000 +++ b/libvo/gl_common.h Tue Jan 15 17:59:20 2008 +0000 @@ -243,6 +243,7 @@ #define YUV_SCALER_BICUB_X 2 //! use cubic scaling without additional lookup texture #define YUV_SCALER_BICUB_NOTEX 3 +#define YUV_SCALER_UNSHARP 4 //! mask for conversion type #define YUV_CONVERSION_MASK 0xF //! mask for scaler type diff -r df6e9b54ecaa -r 9a96fd14d1c5 libvo/vo_gl.c --- a/libvo/vo_gl.c Tue Jan 15 17:54:48 2008 +0000 +++ b/libvo/vo_gl.c Tue Jan 15 17:59:20 2008 +0000 @@ -856,6 +856,7 @@ " 1: use improved bicubic scaling for luma.\n" " 2: use cubic in X, linear in Y direction scaling for luma.\n" " 3: as 1 but without using a lookup texture.\n" + " 4: experimental unsharp masking.\n" " cscale=\n" " as lscale but for chroma (2x slower with little visible effect).\n" " customprog=\n"