]> git.sesse.net Git - ffmpeg/commitdiff
avfilter/vf_median: implement percentile option
authorPaul B Mahol <onemda@gmail.com>
Wed, 12 Feb 2020 10:25:25 +0000 (11:25 +0100)
committerPaul B Mahol <onemda@gmail.com>
Wed, 12 Feb 2020 10:27:28 +0000 (11:27 +0100)
doc/filters.texi
libavfilter/median.h
libavfilter/vf_median.c

index 7c25bbaf975ecf221861a42d6848eb59d04356ec..c2af80dd5135835ef44989a8885b3d81192fad9f 100644 (file)
@@ -13289,6 +13289,11 @@ Set which planes to process. Default is @code{15}, which is all available planes
 Set vertical radius size. Default value is @code{0}.
 Allowed range is integer from 0 to 127.
 If it is 0, value will be picked from horizontal @code{radius} option.
+
+@item percentile
+Set median percentile. Default value is @code{0.5}.
+Default value of @code{0.5} will pick always median values, while @code{0} will pick
+minimum values, and @code{1} maximum values.
 @end table
 
 @subsection Commands
index 89ae0472b0912fa8ffd79e9ba557f3848b9289a3..672607caa8383664e6ac621ab14b05095d634a19 100644 (file)
@@ -31,6 +31,7 @@ typedef struct MedianContext {
     int planes;
     int radius;
     int radiusV;
+    float percentile;
 
     int planewidth[4];
     int planeheight[4];
index ee264e1a74c5a74095803218cfe7082296bd68bf..0189fabd07b2e033ad69fd2ed4c2a09ae6e1c8ef 100644 (file)
@@ -60,6 +60,7 @@ static const AVOption median_options[] = {
     { "radius", "set median radius",    OFFSET(radius), AV_OPT_TYPE_INT,   {.i64=1},     1,  127, FLAGS },
     { "planes", "set planes to filter", OFFSET(planes), AV_OPT_TYPE_INT,   {.i64=0xF},   0,  0xF, FLAGS },
     { "radiusV", "set median vertical radius", OFFSET(radiusV), AV_OPT_TYPE_INT, {.i64=0},0, 127, FLAGS },
+    { "percentile", "set median percentile", OFFSET(percentile), AV_OPT_TYPE_FLOAT, {.dbl=.5}, 0., 1., FLAGS },
     { NULL }
 };
 
@@ -127,7 +128,7 @@ static void check_params(MedianContext *s, AVFilterLink *inlink)
         }
     }
 
-    s->t = 2 * s->radius * s->radiusV + 2 * s->radius;
+    s->t = (2 * s->radius * s->radiusV + s->radiusV + s->radius) * 2.f * s->percentile;
 }
 
 static int config_input(AVFilterLink *inlink)