Git Inbox Mirror of the ffmpeg-devel mailing list - see https://ffmpeg.org/mailman/listinfo/ffmpeg-devel
 help / color / mirror / Atom feed
From: Anton Khirnov <anton@khirnov.net>
To: FFmpeg development discussions and patches <ffmpeg-devel@ffmpeg.org>
Subject: Re: [FFmpeg-devel] [PATCH 01/13] lavu/frame: extend AVFrame.repeat_pict documentation
Date: Sun, 07 May 2023 20:01:19 +0200
Message-ID: <168348247941.3843.15212772142026603873@lain.khirnov.net> (raw)
In-Reply-To: <CAK+ULv4TPMW=MpUWKLn0Z7YjneK5ngzMC6unumii4ceCneJ4=w@mail.gmail.com>

Quoting Kieran Kunhya (2023-05-07 18:59:22)
> On Sun, 7 May 2023, 14:34 Anton Khirnov, <anton@khirnov.net> wrote:
> 
> > ---
> >  libavutil/frame.h | 18 ++++++++++++++++--
> >  1 file changed, 16 insertions(+), 2 deletions(-)
> >
> > diff --git a/libavutil/frame.h b/libavutil/frame.h
> > index f2b56beebb..ed3f199ce1 100644
> > --- a/libavutil/frame.h
> > +++ b/libavutil/frame.h
> > @@ -491,8 +491,22 @@ typedef struct AVFrame {
> >      void *opaque;
> >
> >      /**
> > -     * When decoding, this signals how much the picture must be delayed.
> > -     * extra_delay = repeat_pict / (2*fps)
> > +     * Number of fields in this frame which should be repeated, i.e. the
> > total
> > +     * duration of this frame should be repeat_pict + 2 normal field
> > durations.
> > +     *
> > +     * For interlaced frames this field may be set to 1, which signals
> > that this
> > +     * frame should be presented as 3 fields: beginning with the first
> > field (as
> > +     * determined by AV_FRAME_FLAG_TOP_FIELD_FIRST being set or not),
> > followed
> > +     * by the second field, and then the first field again.
> > +     *
> > +     * For progressive frames this field may be set to a multiple of 2,
> > which
> > +     * signals that this frame's duration should be (repeat_pict + 2) / 2
> > +     * normal frame durations.
> 
> 
> This isn't correct, a progressive [coded] frame is allowed to have its
> first field repeated.
> 
> There is a difference between the coded type and the display method of a
> frame. The documentation suggests otherwise.

In my understanding the AVFrame interlacing flag relates to how the
decoded frame is supposed to be treated (displayed or processed). It
says nothing about how the frame was coded or what source it comes from.

-- 
Anton Khirnov
_______________________________________________
ffmpeg-devel mailing list
ffmpeg-devel@ffmpeg.org
https://ffmpeg.org/mailman/listinfo/ffmpeg-devel

To unsubscribe, visit link above, or email
ffmpeg-devel-request@ffmpeg.org with subject "unsubscribe".

      reply	other threads:[~2023-05-07 18:01 UTC|newest]

Thread overview: 35+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2023-05-07 13:32 Anton Khirnov
2023-05-07 13:32 ` [FFmpeg-devel] [PATCH 02/13] fftools/ffmpeg: fix computing video frame duration from repeat_pict Anton Khirnov
2023-05-07 13:32 ` [FFmpeg-devel] [PATCH 03/13] lavc/codec_desc: add a property for codecs that support field coding Anton Khirnov
2023-05-07 13:32 ` [FFmpeg-devel] [PATCH 04/13] lavf: use AV_CODEC_PROP_FIELDS where appropriate Anton Khirnov
2023-05-08 14:12   ` Michael Niedermayer
2023-05-09  8:37     ` [FFmpeg-devel] [PATCH v2 " Anton Khirnov
2023-05-08 14:15   ` [FFmpeg-devel] [PATCH " Michael Niedermayer
2023-05-09  8:44     ` Anton Khirnov
2023-05-15 18:59       ` Michael Niedermayer
2023-05-15 20:44         ` Anton Khirnov
2023-05-16 17:41           ` Michael Niedermayer
2023-05-07 13:32 ` [FFmpeg-devel] [PATCH 05/13] lavc/av1*: fix exporting framerate Anton Khirnov
2023-05-10 11:52   ` James Almer
2023-05-14 19:39     ` [FFmpeg-devel] [PATCH] " Anton Khirnov
2023-05-14 19:50       ` James Almer
2023-05-15  8:22         ` Anton Khirnov
2023-05-15 11:41           ` James Almer
2023-05-07 13:32 ` [FFmpeg-devel] [PATCH 06/13] lavc/libdav1d: " Anton Khirnov
2023-05-15  8:22   ` [FFmpeg-devel] [PATCH] " Anton Khirnov
2023-05-15 11:47     ` James Almer
2023-05-15 12:22       ` Anton Khirnov
2023-05-15 12:41         ` James Almer
2023-05-07 13:32 ` [FFmpeg-devel] [PATCH 07/13] lavc/ratecontrol: use AVCodecContext.framerate when available Anton Khirnov
2023-05-07 13:32 ` [FFmpeg-devel] [PATCH 08/13] lavc/msmpeg4enc: " Anton Khirnov
2023-05-07 13:32 ` [FFmpeg-devel] [PATCH 09/13] libaomenc: " Anton Khirnov
2023-05-07 13:32 ` [FFmpeg-devel] [PATCH 10/13] lavc/libkvazaar, libopenh264enc: drop redundant checks Anton Khirnov
2023-05-07 13:32 ` [FFmpeg-devel] [PATCH 11/13] lavc/libvpxenc: send frame durations to the encoder Anton Khirnov
2023-05-09  1:18   ` James Zern
2023-05-09  9:09     ` [FFmpeg-devel] [PATCH v2 " Anton Khirnov
2023-05-09 18:17       ` James Zern
2023-05-10  6:34         ` Anton Khirnov
2023-05-07 13:32 ` [FFmpeg-devel] [PATCH 12/13] lavc: deprecate AVCodecContext.ticks_per_frame Anton Khirnov
2023-05-07 13:32 ` [FFmpeg-devel] [PATCH 13/13] fftools/ffmpeg: stop using deprecated ticks_per_frame Anton Khirnov
2023-05-07 16:59 ` [FFmpeg-devel] [PATCH 01/13] lavu/frame: extend AVFrame.repeat_pict documentation Kieran Kunhya
2023-05-07 18:01   ` Anton Khirnov [this message]

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=168348247941.3843.15212772142026603873@lain.khirnov.net \
    --to=anton@khirnov.net \
    --cc=ffmpeg-devel@ffmpeg.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link

Git Inbox Mirror of the ffmpeg-devel mailing list - see https://ffmpeg.org/mailman/listinfo/ffmpeg-devel

This inbox may be cloned and mirrored by anyone:

	git clone --mirror https://master.gitmailbox.com/ffmpegdev/0 ffmpegdev/git/0.git

	# If you have public-inbox 1.1+ installed, you may
	# initialize and index your mirror using the following commands:
	public-inbox-init -V2 ffmpegdev ffmpegdev/ https://master.gitmailbox.com/ffmpegdev \
		ffmpegdev@gitmailbox.com
	public-inbox-index ffmpegdev

Example config snippet for mirrors.


AGPL code for this site: git clone https://public-inbox.org/public-inbox.git