1
0
mirror of https://github.com/FFmpeg/FFmpeg.git synced 2025-01-03 05:10:03 +02:00
FFmpeg/libavfilter
Guo, Yejun aa9ffdaa1e lavfi: add filter dnn_detect for object detection
Below are the example steps to do object detection:

1. download and install l_openvino_toolkit_p_2021.1.110.tgz from
https://software.intel.com/content/www/us/en/develop/tools/openvino-toolkit/download.html
  or, we can get source code (tag 2021.1), build and install.
2. export LD_LIBRARY_PATH with openvino settings, for example:
.../deployment_tools/inference_engine/lib/intel64/:.../deployment_tools/inference_engine/external/tbb/lib/
3. rebuild ffmpeg from source code with configure option:
--enable-libopenvino
--extra-cflags='-I.../deployment_tools/inference_engine/include/'
--extra-ldflags='-L.../deployment_tools/inference_engine/lib/intel64'
4. download model files and test image
wget https://github.com/guoyejun/ffmpeg_dnn/raw/main/models/openvino/2021.1/face-detection-adas-0001.bin
wget https://github.com/guoyejun/ffmpeg_dnn/raw/main/models/openvino/2021.1/face-detection-adas-0001.xml
wget
https://github.com/guoyejun/ffmpeg_dnn/raw/main/models/openvino/2021.1/face-detection-adas-0001.label
wget https://github.com/guoyejun/ffmpeg_dnn/raw/main/images/cici.jpg
5. run ffmpeg with:
./ffmpeg -i cici.jpg -vf dnn_detect=dnn_backend=openvino:model=face-detection-adas-0001.xml:input=data:output=detection_out:confidence=0.6:labels=face-detection-adas-0001.label,showinfo -f null -

We'll see the detect result as below:
[Parsed_showinfo_1 @ 0x560c21ecbe40]   side data - detection bounding boxes:
[Parsed_showinfo_1 @ 0x560c21ecbe40] source: face-detection-adas-0001.xml
[Parsed_showinfo_1 @ 0x560c21ecbe40] index: 0,  region: (1005, 813) -> (1086, 905), label: face, confidence: 10000/10000.
[Parsed_showinfo_1 @ 0x560c21ecbe40] index: 1,  region: (888, 839) -> (967, 926), label: face, confidence: 6917/10000.

There are two faces detected with confidence 100% and 69.17%.

Signed-off-by: Guo, Yejun <yejun.guo@intel.com>
2021-04-17 17:27:02 +08:00
..
aarch64
cuda
dnn lavfi/dnn: add post process for detection 2021-04-08 09:23:02 +08:00
opencl
tests
x86 x86/vf_gblur: fix reg name in UNIX64 prologue 2021-02-17 15:51:28 -03:00
.gitignore
aeval.c
af_acontrast.c
af_acopy.c
af_acrossover.c
af_acrusher.c
af_adeclick.c avfilter/af_adeclick: add more descriptive options names 2021-02-11 11:39:55 +01:00
af_adelay.c
af_adenorm.c
af_aderivative.c
af_aecho.c
af_aemphasis.c
af_aexciter.c avfilter: add aexciter audio filter 2021-02-10 19:21:01 +01:00
af_afade.c avfilter/af_afade: remove uneeded '.' from durations in options 2021-02-21 13:42:40 +01:00
af_afftdn.c
af_afftfilt.c
af_afir.c
af_afir.h
af_aformat.c
af_afreqshift.c
af_agate.c
af_aiir.c Remove double ';' 2021-03-01 06:10:44 +01:00
af_alimiter.c
af_amerge.c
af_amix.c avfilter/af_amix: rename sum option to normalize 2021-02-12 23:01:52 +01:00
af_amultiply.c
af_anequalizer.c
af_anlmdn.c
af_anlmdndsp.h
af_anlms.c
af_anull.c
af_apad.c
af_aphaser.c
af_apulsator.c
af_aresample.c
af_arnndn.c avfilter/af_arnndn: skip array extra entries by looking for new line 2021-02-10 14:15:42 +01:00
af_asetnsamples.c
af_asetrate.c
af_ashowinfo.c
af_asoftclip.c
af_asr.c
af_astats.c
af_asubboost.c
af_asupercut.c
af_atempo.c
af_axcorrelate.c
af_biquads.c
af_bs2b.c
af_channelmap.c
af_channelsplit.c
af_chorus.c
af_compand.c
af_compensationdelay.c
af_crossfeed.c
af_crystalizer.c
af_dcshift.c
af_deesser.c
af_drmeter.c
af_dynaudnorm.c avfilter/af_dynaudnorm: make better check for available samples 2021-03-10 23:52:07 +01:00
af_earwax.c
af_extrastereo.c
af_firequalizer.c
af_flanger.c
af_haas.c
af_hdcd.c avfilter/af_hdcd: Fix undefined shifts 2021-04-01 14:06:02 +02:00
af_headphone.c
af_join.c
af_ladspa.c
af_loudnorm.c
af_lv2.c
af_mcompand.c
af_pan.c
af_replaygain.c
af_resample.c
af_rubberband.c
af_sidechaincompress.c
af_silencedetect.c
af_silenceremove.c
af_sofalizer.c
af_speechnorm.c
af_stereotools.c
af_stereowiden.c
af_superequalizer.c
af_surround.c
af_tremolo.c
af_vibrato.c
af_volume.c
af_volume.h
af_volumedetect.c
allfilters.c lavfi: add filter dnn_detect for object detection 2021-04-17 17:27:02 +08:00
asink_anullsink.c
asrc_afirsrc.c
asrc_anoisesrc.c
asrc_anullsrc.c
asrc_flite.c
asrc_hilbert.c
asrc_sinc.c
asrc_sine.c avfilter/asrc_sine: Fix invalid left shift of negative number 2021-03-28 18:45:20 +02:00
atadenoise.h
audio.c
audio.h
avf_abitscope.c
avf_ahistogram.c
avf_aphasemeter.c
avf_avectorscope.c
avf_concat.c
avf_showcqt.c avfilter/avf_showcqt: use av_gettime_relative() instead of av_gettime() 2021-02-27 21:30:41 +01:00
avf_showcqt.h
avf_showfreqs.c
avf_showspatial.c
avf_showspectrum.c
avf_showvolume.c
avf_showwaves.c
avfilter.c avfilter/avfilter: Remove avfilter_link_set_closed() on bump 2021-03-07 15:18:35 +01:00
avfilter.h avfilter/avfilter: Remove avfilter_link_set_closed() on bump 2021-03-07 15:18:35 +01:00
avfiltergraph.c
avfilterres.rc
bbox.c
bbox.h
blend.h
boxblur.c
boxblur.h
bufferqueue.h
buffersink.c avfilter/buffersink: Postpone removal of av_[a]buffersink_params_alloc 2021-03-07 15:19:10 +01:00
buffersink.h avfilter/buffersink: Postpone removal of av_[a]buffersink_params_alloc 2021-03-07 15:19:10 +01:00
buffersrc.c avfilter/buffersrc: simplify av_buffersrc_add_frame_flags() 2021-02-16 12:36:37 -03:00
buffersrc.h
bwdif.h
colorspace.c
colorspace.h
colorspacedsp_template.c
colorspacedsp_yuv2yuv_template.c
colorspacedsp.c
colorspacedsp.h
convolution.h avfilter/vf_convolution: add 16-column operation for filter_column() 2021-02-13 14:45:48 +01:00
deshake.h
dnn_filter_common.c lavfi/dnn: add post process for detection 2021-04-08 09:23:02 +08:00
dnn_filter_common.h lavfi/dnn: add post process for detection 2021-04-08 09:23:02 +08:00
dnn_interface.h lavfi/dnn: add post process for detection 2021-04-08 09:23:02 +08:00
drawutils.c avfilter/vf_extractplanes: add float formats support 2021-02-07 21:45:26 +01:00
drawutils.h
ebur128.c avfilter/ebur128: Remove unused functions 2021-02-02 23:53:30 +01:00
ebur128.h avfilter/ebur128: Remove unused functions 2021-02-02 23:53:30 +01:00
f_bench.c
f_cue.c
f_drawgraph.c
f_ebur128.c
f_graphmonitor.c
f_interleave.c
f_loop.c
f_metadata.c
f_perms.c
f_realtime.c
f_reverse.c
f_select.c
f_sendcmd.c
f_sidedata.c lavfi: show side data of detection bounding boxes 2021-04-17 17:27:02 +08:00
f_streamselect.c
f_zmq.c
fifo.c
filters.h
formats.c
formats.h
framepool.c avfilter: use the buffer_size_t typedef where required 2021-03-10 20:26:36 -03:00
framepool.h avfilter: use the buffer_size_t typedef where required 2021-03-10 20:26:36 -03:00
framequeue.c
framequeue.h
framerate.h
framesync.c
framesync.h
gblur.h avfilter/vf_gblur: factor out postscale function 2021-02-16 21:12:11 +01:00
generate_wave_table.c
generate_wave_table.h
glslang.cpp
glslang.h
gradfun.h
graphdump.c
graphparser.c
hermite.h
hflip.h
internal.h avfilter/avfilter: mark enable as runtime option too 2021-02-03 15:51:40 +01:00
lavfutils.c avfilter/lavfutils.h: Don't include avformat.h 2021-02-25 22:03:32 +01:00
lavfutils.h avfilter/lavfutils.h: Don't include avformat.h 2021-02-25 22:03:32 +01:00
libavfilter.v
limiter.h
log2_tab.c
lswsutils.c
lswsutils.h
Makefile lavfi: add filter dnn_detect for object detection 2021-04-17 17:27:02 +08:00
maskedclamp.h
maskedmerge.h
median_template.c
median.h
motion_estimation.c
motion_estimation.h
opencl_source.h
opencl.c
opencl.h
phase_template.c
psnr.h
pthread.c
qp_table.c
qp_table.h
qsvvpp.c lavfi/qsvvpp: support async depth 2021-04-11 23:18:20 +08:00
qsvvpp.h lavfi/qsvvpp: support async depth 2021-04-11 23:18:20 +08:00
removegrain.h
scale_eval.c
scale_eval.h
scene_sad.c
scene_sad.h
setpts.c
settb.c
signature_lookup.c
signature.h
split.c
src_movie.c
ssim.h
stereo3d.h
thread.h
threshold.h
tinterlace.h
transform.c
transform.h
transpose.h
trim.c
unsharp.h
v360.h
vaapi_vpp.c
vaapi_vpp.h
vaf_spectrumsynth.c
version.h Bump minor versions after release branch 2021-03-20 01:02:11 +01:00
vf_addroi.c
vf_alphamerge.c
vf_amplify.c
vf_aspect.c
vf_atadenoise.c
vf_avgblur_opencl.c
vf_avgblur_vulkan.c
vf_avgblur.c
vf_bbox.c
vf_bilateral.c
vf_bitplanenoise.c
vf_blackdetect.c
vf_blackframe.c
vf_blend.c avfilter/vf_blend: add support for commands 2021-02-04 21:44:31 +01:00
vf_bm3d.c
vf_boxblur.c
vf_bwdif.c
vf_cas.c
vf_chromaber_vulkan.c
vf_chromakey.c
vf_chromanr.c
vf_chromashift.c
vf_ciescope.c
vf_codecview.c avfilter/vf_codecview: Fix undefined left shifts of negative numbers 2021-04-01 14:49:41 +02:00
vf_colorbalance.c
vf_colorchannelmixer.c
vf_colorconstancy.c
vf_colorcontrast.c avfilter: add colorcontrast filter 2021-02-02 14:27:06 +01:00
vf_colorcorrect.c avfilter: add colorcorrect filter 2021-02-03 15:49:13 +01:00
vf_colorize.c avfilter: add colorize filter 2021-02-07 11:48:28 +01:00
vf_colorkey_opencl.c
vf_colorkey.c
vf_colorlevels.c avfilter/vf_colorlevels: call execute once per frame 2021-02-02 17:53:29 +01:00
vf_colormatrix.c
vf_colorspace.c
vf_colortemperature.c
vf_convolution_opencl.c
vf_convolution.c avfilter/vf_convolution: add 16-column operation for filter_column() 2021-02-13 14:45:48 +01:00
vf_convolve.c
vf_copy.c
vf_coreimage.m
vf_cover_rect.c
vf_crop.c
vf_cropdetect.c
vf_curves.c avfilter/vf_curves: add commands support 2021-02-09 18:20:15 +01:00
vf_datascope.c avfilter/vf_datascope: pixscope: add commands support 2021-02-13 12:38:15 +01:00
vf_dblur.c
vf_dctdnoiz.c
vf_deband.c avfilter/vf_deband: add support for commands 2021-02-08 16:10:51 +01:00
vf_deblock.c avfilter/vf_deblock: add support for commands 2021-02-06 15:26:39 +01:00
vf_decimate.c
vf_dedot.c
vf_deflicker.c
vf_deinterlace_qsv.c lavfi/qsvvpp: support async depth 2021-04-11 23:18:20 +08:00
vf_deinterlace_vaapi.c
vf_dejudder.c
vf_delogo.c
vf_derain.c dnn: add function type for model 2021-02-18 09:59:37 +08:00
vf_deshake_opencl.c
vf_deshake.c
vf_despill.c
vf_detelecine.c
vf_displace.c
vf_dnn_detect.c lavfi: add filter dnn_detect for object detection 2021-04-17 17:27:02 +08:00
vf_dnn_processing.c dnn: add function type for model 2021-02-18 09:59:37 +08:00
vf_drawbox.c avfilter/drawbox: fix formatting after d64cbd4fda 2021-02-05 17:29:59 +05:30
vf_drawtext.c lavfi/drawtext: ignore final LF of textfile. 2021-02-17 11:53:51 +01:00
vf_edgedetect.c
vf_elbg.c
vf_entropy.c
vf_epx.c
vf_eq.c
vf_eq.h
vf_estdif.c
vf_exposure.c avfilter: add exposure video filter 2021-02-10 19:23:48 +01:00
vf_extractplanes.c avfilter/vf_extractplanes: add float formats support 2021-02-07 21:45:26 +01:00
vf_fade.c
vf_fftdnoiz.c
vf_fftfilt.c
vf_field.c
vf_fieldhint.c
vf_fieldmatch.c
vf_fieldorder.c
vf_fillborders.c
vf_find_rect.c avfilter/vf_find_rect: Use correct format specifier 2021-04-04 12:02:45 +02:00
vf_floodfill.c
vf_format.c
vf_fps.c
vf_framepack.c avfilter/vf_framepack: add >8 format support 2021-02-09 12:29:04 +01:00
vf_framerate.c
vf_framestep.c
vf_freezedetect.c
vf_freezeframes.c
vf_frei0r.c avfilter/vf_frei0r: add timeline support 2021-02-05 13:18:21 +01:00
vf_fspp.c
vf_fspp.h
vf_gblur.c avfilter/vf_gblur: add missing arch check 2021-02-17 15:45:40 -03:00
vf_geq.c
vf_gradfun.c
vf_hflip.c
vf_histeq.c
vf_histogram.c
vf_hqdn3d.c
vf_hqdn3d.h
vf_hqx.c
vf_hue.c
vf_hwdownload.c
vf_hwmap.c
vf_hwupload_cuda.c avfilter/hwupload_cuda: add YUVA420P format support 2021-03-25 04:30:50 +01:00
vf_hwupload.c
vf_hysteresis.c
vf_identity.c avfilter: add msad video filter 2021-03-06 12:42:16 +01:00
vf_idet.c
vf_idet.h
vf_il.c
vf_kerndeint.c
vf_lagfun.c avfilter/vf_lagfun: use macro 2021-02-11 00:45:08 +01:00
vf_lenscorrection.c
vf_lensfun.c avfilter/vf_lensfun: display list of possible values if user supplied none 2021-02-05 15:27:50 +01:00
vf_libopencv.c
vf_libvmaf.c
vf_limiter.c
vf_lumakey.c
vf_lut2.c avfilter/vf_lut2: add support for commands 2021-02-07 22:41:49 +01:00
vf_lut3d.c avfilter/vf_lut3d: lut3d, haldclut: add support for commands 2021-02-08 00:55:07 +01:00
vf_lut.c avfilter/vf_lut: add support for commands 2021-02-08 16:37:23 +01:00
vf_maskedclamp.c
vf_maskedmerge.c
vf_maskedminmax.c
vf_maskedthreshold.c
vf_maskfun.c avfilter/vf_maskfun: add support for commands 2021-02-09 11:24:31 +01:00
vf_mcdeint.c avfilter/vf_mcdeint: use av_packet_alloc() to allocate packets 2021-03-17 15:19:36 -03:00
vf_median.c
vf_mergeplanes.c
vf_mestimate.c
vf_midequalizer.c
vf_minterpolate.c
vf_misc_vaapi.c
vf_mix.c avfilter/vf_mix: add support for commands 2021-02-06 11:34:28 +01:00
vf_monochrome.c avfilter: add monochrome video filter 2021-02-12 00:08:39 +01:00
vf_mpdecimate.c
vf_neighbor_opencl.c
vf_neighbor.c
vf_nlmeans_opencl.c
vf_nlmeans.c
vf_nlmeans.h
vf_nnedi.c avfilter/vf_nnedi: Fix use of uninitialized value 2021-03-10 21:00:21 +01:00
vf_noise.c
vf_noise.h
vf_normalize.c
vf_null.c
vf_ocr.c avfilter/vf_ocr: add white space to whitelist 2021-03-19 23:00:04 +01:00
vf_overlay_cuda.c avfilter/overlay_cuda: check av_buffer_ref result 2021-04-11 10:22:01 +02:00
vf_overlay_cuda.cu
vf_overlay_opencl.c
vf_overlay_qsv.c
vf_overlay_vulkan.c
vf_overlay.c
vf_overlay.h
vf_owdenoise.c
vf_pad_opencl.c
vf_pad.c
vf_palettegen.c
vf_paletteuse.c avfilter/vf_paletteuse: Fix left shift outside of range of int 2021-03-28 18:47:15 +02:00
vf_perspective.c
vf_phase.c
vf_photosensitivity.c
vf_pixdesctest.c
vf_pp7.c
vf_pp7.h
vf_pp.c vf_pp: remove unnecessary free 2021-02-08 11:06:29 +01:00
vf_premultiply.c
vf_procamp_vaapi.c
vf_program_opencl.c
vf_pseudocolor.c avfilter/vf_pseudocolor: Add missing braces 2021-02-17 23:09:40 +00:00
vf_psnr.c avfilter/vf_psnr: add support for slice threading 2021-02-19 21:15:08 +01:00
vf_pullup.c
vf_pullup.h
vf_qp.c
vf_random.c
vf_readeia608.c
vf_readvitc.c
vf_remap.c
vf_removegrain.c
vf_removelogo.c
vf_repeatfields.c
vf_rotate.c
vf_sab.c
vf_scale_cuda_bicubic.cu
vf_scale_cuda.c
vf_scale_cuda.cu
vf_scale_cuda.h
vf_scale_npp.c
vf_scale_qsv.c
vf_scale_vaapi.c
vf_scale_vulkan.c
vf_scale.c avfilter/vf_scale: Fix adding 0 to NULL (which is UB) in scale_slice() 2021-03-31 23:09:35 +02:00
vf_scdet.c
vf_scroll.c
vf_selectivecolor.c
vf_separatefields.c
vf_setparams.c
vf_shear.c
vf_showinfo.c lavfi: show side data of detection bounding boxes 2021-04-17 17:27:02 +08:00
vf_showpalette.c
vf_shuffleframes.c
vf_shufflepixels.c
vf_shuffleplanes.c
vf_signalstats.c
vf_signature.c Avoid intermediate bitcount for number of bytes in PutBitContext 2021-03-30 12:36:32 +02:00
vf_smartblur.c
vf_spp.c
vf_spp.h
vf_sr.c dnn: add function type for model 2021-02-18 09:59:37 +08:00
vf_ssim.c avfilter/vf_ssim.c: fix build warning for [-Wmain] 2021-02-25 11:43:56 +01:00
vf_stack.c
vf_stereo3d.c
vf_subtitles.c
vf_super2xsai.c
vf_swaprect.c avfilter/vf_swaprect: add support for commands 2021-02-09 11:39:26 +01:00
vf_swapuv.c
vf_telecine.c
vf_threshold.c
vf_thumbnail_cuda.c
vf_thumbnail_cuda.cu
vf_thumbnail.c avfilter/vf_thumbnail: add support for rest of packed rgb formats 2021-02-08 13:01:28 +01:00
vf_tile.c avfilter/vf_tile: remove extra whitespace in option description 2021-02-06 11:40:59 +01:00
vf_tinterlace.c
vf_tmidequalizer.c
vf_tonemap_opencl.c
vf_tonemap_vaapi.c
vf_tonemap.c
vf_tpad.c
vf_transpose_npp.c
vf_transpose_opencl.c
vf_transpose_vaapi.c
vf_transpose.c
vf_unsharp_opencl.c
vf_unsharp.c
vf_untile.c
vf_uspp.c avfilter/vf_uspp: use av_packet_alloc() to allocate packets 2021-03-17 15:19:36 -03:00
vf_v360.c avfilter/vf_v360: unbreak fov_from_dfov() for (d)fisheye when width != height 2021-04-11 10:12:11 +02:00
vf_vaguedenoiser.c
vf_vectorscope.c
vf_vflip.c lavfi/vflip: Support Bayer vertical flip. 2021-02-15 00:12:38 +01:00
vf_vfrdet.c
vf_vibrance.c
vf_vidstabdetect.c
vf_vidstabtransform.c
vf_vif.c avfilter/vf_vif: add support for more formats 2021-02-25 16:38:27 +01:00
vf_vignette.c
vf_vmafmotion.c
vf_vpp_qsv.c lavfi/qsvvpp: support async depth 2021-04-11 23:18:20 +08:00
vf_w3fdif.c
vf_waveform.c
vf_weave.c
vf_xbr.c
vf_xfade_opencl.c
vf_xfade.c avfilter/vf_xfade: drop unused frames from inactive inputs 2021-03-14 13:15:21 +01:00
vf_xmedian.c
vf_yadif_cuda.c
vf_yadif_cuda.cu
vf_yadif.c
vf_yaepblur.c
vf_zoompan.c
vf_zscale.c avfilter/vf_zscale: add support for setting scaling filter parameters 2021-02-11 20:45:56 +02:00
video.c
video.h
vidstabutils.c
vidstabutils.h
vif.h avfilter/vif: Include avfilter.h 2021-02-16 22:26:56 +01:00
vmaf_motion.h
vsink_nullsink.c
vsrc_cellauto.c
vsrc_gradients.c Remove double ';' 2021-03-01 06:10:44 +01:00
vsrc_life.c
vsrc_mandelbrot.c
vsrc_mptestsrc.c
vsrc_sierpinski.c
vsrc_testsrc.c
vulkan.c
vulkan.h
w3fdif.h
window_func.h
yadif_common.c
yadif.h