[FFmpeg-devel] [PATCH 2/2] libavfilter/scale2ref: Maintain main input's DAR

Kevin Mark kmark937 at gmail.com
Mon Jun 12 08:08:35 EEST 2017


I've been using this patch for the past week now and I believe it's
good to go. Does someone want to take a second look before merging?

On Mon, Jun 5, 2017 at 6:55 AM, Kevin Mark <kmark937 at gmail.com> wrote:
> The scale2ref filter will now maintain the DAR of the main input and
> not the DAR of the reference input. This previous behavior was deemed
> counterintuitive for most (all?) use-cases.
>
> Before:
> scale2ref=iw/4:ow/mdar
> in  w:320 h:240 fmt:rgb24 sar:1/1
> ref w:640 h:360 fmt:rgb24 sar:1/1
> out w:160 h:120 fmt:rgb24 sar:4/3 flags:0x2
> SAR: ((120 * 640) / (160 * 360)) * (1 / 1) = 4 / 3
> DAR: (160 / 120) * (4 / 3) = 16 / 9
> (main out now same DAR as ref)
>
> Now:
> scale2ref=iw/4:ow/mdar
> in  w:320 h:240 fmt:rgb24 sar:1/1
> ref w:640 h:360 fmt:rgb24 sar:1/1
> out w:160 h:120 fmt:rgb24 sar:1/1 flags:0x2
> SAR: ((120 * 320) / (160 * 240)) * (1 / 1) = 1 / 1
> DAR: (160 / 120) * (1 / 1) = 4 / 3
> (main out same DAR as main in)
>
> The scale2ref FATE test has also been updated.
>
> Signed-off-by: Kevin Mark <kmark937 at gmail.com>
> ---
>  libavfilter/vf_scale.c                      | 6 +++---
>  tests/ref/fate/filter-scale2ref_keep_aspect | 2 +-
>  2 files changed, 4 insertions(+), 4 deletions(-)
>
> diff --git a/libavfilter/vf_scale.c b/libavfilter/vf_scale.c
> index 9232bc4439..5e55f9344b 100644
> --- a/libavfilter/vf_scale.c
> +++ b/libavfilter/vf_scale.c
> @@ -337,10 +337,10 @@ static int config_props(AVFilterLink *outlink)
>          }
>      }
>
> -    if (inlink->sample_aspect_ratio.num){
> -        outlink->sample_aspect_ratio = av_mul_q((AVRational){outlink->h * inlink->w, outlink->w * inlink->h}, inlink->sample_aspect_ratio);
> +    if (inlink0->sample_aspect_ratio.num){
> +        outlink->sample_aspect_ratio = av_mul_q((AVRational){outlink->h * inlink0->w, outlink->w * inlink0->h}, inlink0->sample_aspect_ratio);
>      } else
> -        outlink->sample_aspect_ratio = inlink->sample_aspect_ratio;
> +        outlink->sample_aspect_ratio = inlink0->sample_aspect_ratio;
>
>      if (ctx->filter == &ff_vf_scale2ref) {
>          av_log(ctx, AV_LOG_VERBOSE, "in  w:%d h:%d fmt:%s sar:%d/%d\n",
> diff --git a/tests/ref/fate/filter-scale2ref_keep_aspect b/tests/ref/fate/filter-scale2ref_keep_aspect
> index ca03277446..8dd0dbb13b 100644
> --- a/tests/ref/fate/filter-scale2ref_keep_aspect
> +++ b/tests/ref/fate/filter-scale2ref_keep_aspect
> @@ -5,7 +5,7 @@
>  #media_type 0: video
>  #codec_id 0: rawvideo
>  #dimensions 0: 160x120
> -#sar 0: 4/3
> +#sar 0: 1/1
>  #stream#, dts,        pts, duration,     size, hash
>  0,          0,          0,        1,    57600, 9a19c23dc3a557786840d0098606d5f1
>  0,          1,          1,        1,    57600, e6fbdabaf1bb0d28afc648ed4d27e9f0
> --
> 2.13.0
>


More information about the ffmpeg-devel mailing list