From: Paul B Mahol <onemda@gmail.com> To: FFmpeg development discussions and patches <ffmpeg-devel@ffmpeg.org> Subject: Re: [FFmpeg-devel] [PATCH] avfilter/vf_cropdetect: add ability to change limit/reset at runtime Date: Tue, 17 Jan 2023 13:34:54 +0100 Message-ID: <CAPYw7P7eB=BREmdd5-40kQFrgsAEKi_iaxWaDG7piNw_JYK8Ew@mail.gmail.com> (raw) In-Reply-To: <b3206127-a7d4-ad56-2d97-01f0298432eb@gmail.com> On 1/17/23, Jeffrey Chapuis <ashyni1987@gmail.com> wrote: > On 17/01/2023 12:52, Paul B Mahol wrote: >> On 1/17/23, Jeffrey Chapuis <ashyni1987@gmail.com> wrote: >>>> Le 10/01/2023 à 16:45, Paul B Mahol a écrit : >>>>> On 1/10/23, Jeffrey CHAPUIS <ashyni1987 at gmail.com> wrote: >>>>>> Hello, >>>>>> I decided to continue on a simpler path without 'reset/reset_count', >>>>>> it >>>>>> was >>>>>> only to experiment anyway, 'limit' is the main goal. >>>>>> 'limit' is added to the metadata to control that the result is >>>>>> associated to >>>>>> a change at runtime, it's after scaling with bitdetph but that's not >>>>>> really >>>>>> a problem (at least for me, we can always store the parameter before >>>>>> any >>>>>> alteration). >>>>>> >>>>>>> + if (!strcmp(cmd, "limit")) { >>>>>>> + if (s->limit < 1.0) >>>>>>> + s->limit *= (1 << s->bitdepth) - 1; >>>>>>> + s->frame_nb = s->reset_count; >>>>>>> + } >>>>>> Should i remove the if statement here ? or keep it for future change >>>>>> eventually. >>>>> >>>>> Split variables, keep one variable settable by user and unchanged by >>>>> filter. >>>>> >>>>>> >>>>>> Notes I didn't think about? >>>>>> >>>>>> Thunderbird altered the patch somehow (remove empty new lines), it's >>>>>> edited >>>>>> manually. >>>>> >>>>> Attach patch instead. >>>>> >>>>> >>>>> Avoid using strcmp to check for this variable change, instead check >>>>> with previous and new value in process function. >>>> >>>>> Here is part of the updated patch, 'limit' exposed in metadata/log is >>>>> now >>>>> coherent with init(). >>>>> Like 'limit/limit_user' is of type float, i've used what's done in >>>>> av_dict_set_int() to print it as float. >>>>> Compare 's->limit_user' and 's->limit' to check for a change instead of >>>>> 'strcmp'. >>>>> Is there anything to adjust ? >>>> >>>> Forgot to update ref file for fate (full patch attached). >>> >>> Is the update code good? >>> >>>> + char limit_str[22]; >>>> + snprintf(limit_str, sizeof(limit_str), "%f", s->limit_user); >>>> + av_dict_set(metadata, "lavfi.cropdetect.limit", limit_str, 0); >>> >>> Should i create a function av_dict_set_float() in libavutil/dict.c and >>> libavutil/dict.h? >> >> Nope. >> >> Shouldnt limit variable be changed if < 1.0 before being used in >> process_command() ? > > You mean before ff_filter_process_command() ? Inside that function. > I thought ff_filter_process_command() was only checking the command flag and > input value. Call to ff_filter_process_command() does update to new values set by user. So if limit is lower than 1.0 have special meaning it needs to be handled properly. The ideal solution is thus to keep user supplied value always constant after its changed by user, and to do operations with it into new variables. > > In that case, i need to store variable and restore them if > ff_filter_process_command() fail ? > > > Sorry for all this stupid question, i'm not a dev, learning stuff on the > way. > > _______________________________________________ > 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". > _______________________________________________ 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".
next prev parent reply other threads:[~2023-01-17 12:35 UTC|newest] Thread overview: 28+ messages / expand[flat|nested] mbox.gz Atom feed top 2023-01-10 13:15 Jeffrey CHAPUIS 2023-01-10 15:45 ` Paul B Mahol 2023-01-11 11:42 ` Jeffrey Chapuis 2023-01-11 17:46 ` Jeffrey Chapuis 2023-01-12 15:53 ` Jeffrey Chapuis 2023-01-17 11:46 ` Jeffrey Chapuis 2023-01-17 11:52 ` Paul B Mahol 2023-01-17 12:27 ` Jeffrey Chapuis 2023-01-17 12:34 ` Paul B Mahol [this message] 2023-01-17 13:31 ` Jeffrey Chapuis 2023-01-17 13:45 ` Paul B Mahol 2023-01-17 14:24 ` Jeffrey Chapuis 2023-01-17 14:29 ` Paul B Mahol 2023-01-17 15:19 ` Jeffrey Chapuis 2023-01-17 16:23 ` Paul B Mahol 2023-01-17 18:00 ` Jeffrey Chapuis 2023-01-17 18:11 ` Paul B Mahol 2023-01-17 22:07 ` Jeffrey Chapuis 2023-01-19 12:11 ` Jeffrey Chapuis 2023-01-19 13:50 ` Jeffrey Chapuis -- strict thread matches above, loose matches on Subject: below -- 2022-12-28 11:02 Jeffrey CHAPUIS 2022-12-28 11:21 ` Marton Balint 2022-12-28 11:51 ` James Almer 2022-12-28 15:37 ` Jeffrey CHAPUIS 2022-12-27 12:33 Jeffrey CHAPUIS 2022-12-27 11:46 Jeffrey CHAPUIS 2022-12-27 12:34 ` James Almer 2022-12-27 12:57 ` Jeffrey CHAPUIS
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='CAPYw7P7eB=BREmdd5-40kQFrgsAEKi_iaxWaDG7piNw_JYK8Ew@mail.gmail.com' \ --to=onemda@gmail.com \ --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