FFmpeg
Data Structures | Macros | Enumerations | Functions | Variables
vf_bm3d.c File Reference
#include <float.h>
#include "libavutil/cpu.h"
#include "libavutil/imgutils.h"
#include "libavutil/opt.h"
#include "libavutil/pixdesc.h"
#include "libavutil/tx.h"
#include "avfilter.h"
#include "filters.h"
#include "framesync.h"
#include "internal.h"
#include "video.h"

Go to the source code of this file.

Data Structures

struct  ThreadData
 Used for passing data between threads. More...
 
struct  PosCode
 
struct  PosPairCode
 
struct  SliceContext
 
struct  BM3DContext
 

Macros

#define MAX_NB_THREADS   32
 
#define OFFSET(x)   offsetof(BM3DContext, x)
 
#define FLAGS   AV_OPT_FLAG_FILTERING_PARAM|AV_OPT_FLAG_VIDEO_PARAM
 
#define SQR(x)   ((x) * (x))
 

Enumerations

enum  FilterModes {
  BASIC, FINAL, NB_MODES, BASIC,
  FAST, NB_MODES
}
 

Functions

 AVFILTER_DEFINE_CLASS (bm3d)
 
static int do_search_boundary (int pos, int plane_boundary, int search_range, int search_step)
 
static int search_boundary (int plane_boundary, int search_range, int search_step, int vertical, int y, int x)
 
static int cmp_scores (const void *a, const void *b)
 
static double do_block_ssd (BM3DContext *s, PosCode *pos, const uint8_t *src, int src_stride, int r_y, int r_x)
 
static double do_block_ssd16 (BM3DContext *s, PosCode *pos, const uint8_t *src, int src_stride, int r_y, int r_x)
 
static void do_block_matching_multi (BM3DContext *s, const uint8_t *src, int src_stride, int src_range, const PosCode *search_pos, int search_size, float th_mse, int r_y, int r_x, int plane, int jobnr)
 
static void block_matching_multi (BM3DContext *s, const uint8_t *ref, int ref_linesize, int y, int x, int exclude_cur_pos, int plane, int jobnr)
 
static void block_matching (BM3DContext *s, const uint8_t *ref, int ref_linesize, int j, int i, int plane, int jobnr)
 
static void get_block_row (const uint8_t *srcp, int src_linesize, int y, int x, int block_size, float *dst)
 
static void get_block_row16 (const uint8_t *srcp, int src_linesize, int y, int x, int block_size, float *dst)
 
static void basic_block_filtering (BM3DContext *s, const uint8_t *src, int src_linesize, const uint8_t *ref, int ref_linesize, int y, int x, int plane, int jobnr)
 
static void final_block_filtering (BM3DContext *s, const uint8_t *src, int src_linesize, const uint8_t *ref, int ref_linesize, int y, int x, int plane, int jobnr)
 
static void do_output (BM3DContext *s, uint8_t *dst, int dst_linesize, int plane, int nb_jobs)
 
static void do_output16 (BM3DContext *s, uint8_t *dst, int dst_linesize, int plane, int nb_jobs)
 
static int filter_slice (AVFilterContext *ctx, void *arg, int jobnr, int nb_jobs)
 
static int filter_frame (AVFilterContext *ctx, AVFrame **out, AVFrame *in, AVFrame *ref)
 
static int config_input (AVFilterLink *inlink)
 
static int activate (AVFilterContext *ctx)
 
static int process_frame (FFFrameSync *fs)
 
static av_cold int init (AVFilterContext *ctx)
 
static int config_output (AVFilterLink *outlink)
 
static av_cold void uninit (AVFilterContext *ctx)
 

Variables

static const AVOption bm3d_options []
 
static enum AVPixelFormat pix_fmts []
 
static const AVFilterPad bm3d_outputs []
 
const AVFilter ff_vf_bm3d
 

Macro Definition Documentation

◆ MAX_NB_THREADS

#define MAX_NB_THREADS   32
Todo:
  • opponent color space
  • temporal support

Definition at line 45 of file vf_bm3d.c.

◆ OFFSET

#define OFFSET (   x)    offsetof(BM3DContext, x)

Definition at line 131 of file vf_bm3d.c.

◆ FLAGS

Definition at line 132 of file vf_bm3d.c.

◆ SQR

#define SQR (   x)    ((x) * (x))

Definition at line 760 of file vf_bm3d.c.

Enumeration Type Documentation

◆ FilterModes

Enumerator
BASIC 
FINAL 
NB_MODES 
BASIC 
FAST 
NB_MODES 

Definition at line 47 of file vf_bm3d.c.

Function Documentation

◆ AVFILTER_DEFINE_CLASS()

AVFILTER_DEFINE_CLASS ( bm3d  )

◆ do_search_boundary()

static int do_search_boundary ( int  pos,
int  plane_boundary,
int  search_range,
int  search_step 
)
static

Definition at line 192 of file vf_bm3d.c.

Referenced by search_boundary().

◆ search_boundary()

static int search_boundary ( int  plane_boundary,
int  search_range,
int  search_step,
int  vertical,
int  y,
int  x 
)
static

Definition at line 217 of file vf_bm3d.c.

Referenced by block_matching_multi(), and do_search_boundary().

◆ cmp_scores()

static int cmp_scores ( const void *  a,
const void *  b 
)
static

Definition at line 222 of file vf_bm3d.c.

Referenced by do_block_matching_multi().

◆ do_block_ssd()

static double do_block_ssd ( BM3DContext s,
PosCode pos,
const uint8_t *  src,
int  src_stride,
int  r_y,
int  r_x 
)
static

Definition at line 229 of file vf_bm3d.c.

Referenced by config_input().

◆ do_block_ssd16()

static double do_block_ssd16 ( BM3DContext s,
PosCode pos,
const uint8_t *  src,
int  src_stride,
int  r_y,
int  r_x 
)
static

Definition at line 250 of file vf_bm3d.c.

Referenced by config_input().

◆ do_block_matching_multi()

static void do_block_matching_multi ( BM3DContext s,
const uint8_t *  src,
int  src_stride,
int  src_range,
const PosCode search_pos,
int  search_size,
float  th_mse,
int  r_y,
int  r_x,
int  plane,
int  jobnr 
)
static

Definition at line 271 of file vf_bm3d.c.

Referenced by block_matching_multi().

◆ block_matching_multi()

static void block_matching_multi ( BM3DContext s,
const uint8_t *  ref,
int  ref_linesize,
int  y,
int  x,
int  exclude_cur_pos,
int  plane,
int  jobnr 
)
static

Definition at line 309 of file vf_bm3d.c.

Referenced by block_matching().

◆ block_matching()

static void block_matching ( BM3DContext s,
const uint8_t *  ref,
int  ref_linesize,
int  j,
int  i,
int  plane,
int  jobnr 
)
static

Definition at line 349 of file vf_bm3d.c.

Referenced by filter_slice().

◆ get_block_row()

static void get_block_row ( const uint8_t *  srcp,
int  src_linesize,
int  y,
int  x,
int  block_size,
float dst 
)
static

Definition at line 366 of file vf_bm3d.c.

Referenced by config_input().

◆ get_block_row16()

static void get_block_row16 ( const uint8_t *  srcp,
int  src_linesize,
int  y,
int  x,
int  block_size,
float dst 
)
static

Definition at line 375 of file vf_bm3d.c.

Referenced by config_input().

◆ basic_block_filtering()

static void basic_block_filtering ( BM3DContext s,
const uint8_t *  src,
int  src_linesize,
const uint8_t *  ref,
int  ref_linesize,
int  y,
int  x,
int  plane,
int  jobnr 
)
static

Definition at line 384 of file vf_bm3d.c.

Referenced by init().

◆ final_block_filtering()

static void final_block_filtering ( BM3DContext s,
const uint8_t *  src,
int  src_linesize,
const uint8_t *  ref,
int  ref_linesize,
int  y,
int  x,
int  plane,
int  jobnr 
)
static

Definition at line 498 of file vf_bm3d.c.

Referenced by init().

◆ do_output()

static void do_output ( BM3DContext s,
uint8_t *  dst,
int  dst_linesize,
int  plane,
int  nb_jobs 
)
static

Definition at line 630 of file vf_bm3d.c.

Referenced by config_input().

◆ do_output16()

static void do_output16 ( BM3DContext s,
uint8_t *  dst,
int  dst_linesize,
int  plane,
int  nb_jobs 
)
static

Definition at line 656 of file vf_bm3d.c.

Referenced by config_input().

◆ filter_slice()

static int filter_slice ( AVFilterContext ctx,
void *  arg,
int  jobnr,
int  nb_jobs 
)
static

Definition at line 683 of file vf_bm3d.c.

Referenced by filter_frame().

◆ filter_frame()

static int filter_frame ( AVFilterContext ctx,
AVFrame **  out,
AVFrame in,
AVFrame ref 
)
static

Definition at line 725 of file vf_bm3d.c.

Referenced by activate(), and process_frame().

◆ config_input()

static int config_input ( AVFilterLink inlink)
static

Definition at line 762 of file vf_bm3d.c.

Referenced by init().

◆ activate()

static int activate ( AVFilterContext ctx)
static

Definition at line 845 of file vf_bm3d.c.

◆ process_frame()

static int process_frame ( FFFrameSync fs)
static

Definition at line 879 of file vf_bm3d.c.

Referenced by config_output().

◆ init()

static av_cold int init ( AVFilterContext ctx)
static

Definition at line 899 of file vf_bm3d.c.

◆ config_output()

static int config_output ( AVFilterLink outlink)
static

Definition at line 953 of file vf_bm3d.c.

◆ uninit()

static av_cold void uninit ( AVFilterContext ctx)
static

Definition at line 1003 of file vf_bm3d.c.

Variable Documentation

◆ bm3d_options

const AVOption bm3d_options[]
static
Initial value:
= {
{ "sigma", "set denoising strength",
OFFSET(sigma), AV_OPT_TYPE_FLOAT, {.dbl=1}, 0, 99999.9, FLAGS },
{ "block", "set size of local patch",
OFFSET(block_size), AV_OPT_TYPE_INT, {.i64=16}, 8, 64, FLAGS },
{ "bstep", "set sliding step for processing blocks",
OFFSET(block_step), AV_OPT_TYPE_INT, {.i64=4}, 1, 64, FLAGS },
{ "group", "set maximal number of similar blocks",
OFFSET(group_size), AV_OPT_TYPE_INT, {.i64=1}, 1, 256, FLAGS },
{ "range", "set block matching range",
OFFSET(bm_range), AV_OPT_TYPE_INT, {.i64=9}, 1, INT32_MAX, FLAGS },
{ "mstep", "set step for block matching",
OFFSET(bm_step), AV_OPT_TYPE_INT, {.i64=1}, 1, 64, FLAGS },
{ "thmse", "set threshold of mean square error for block matching",
OFFSET(th_mse), AV_OPT_TYPE_FLOAT, {.dbl=0}, 0, INT32_MAX, FLAGS },
{ "hdthr", "set hard threshold for 3D transfer domain",
OFFSET(hard_threshold), AV_OPT_TYPE_FLOAT, {.dbl=2.7}, 0, INT32_MAX, FLAGS },
{ "estim", "set filtering estimation mode",
OFFSET(mode), AV_OPT_TYPE_INT, {.i64=BASIC}, 0, NB_MODES-1, FLAGS, "mode" },
{ "basic", "basic estimate",
0, AV_OPT_TYPE_CONST, {.i64=BASIC}, 0, 0, FLAGS, "mode" },
{ "final", "final estimate",
0, AV_OPT_TYPE_CONST, {.i64=FINAL}, 0, 0, FLAGS, "mode" },
{ "ref", "have reference stream",
OFFSET(ref), AV_OPT_TYPE_BOOL, {.i64=0}, 0, 1, FLAGS },
{ "planes", "set planes to filter",
OFFSET(planes), AV_OPT_TYPE_INT, {.i64=7}, 0, 15, FLAGS },
{ NULL }
}

Definition at line 134 of file vf_bm3d.c.

◆ pix_fmts

enum AVPixelFormat pix_fmts[]
static

◆ bm3d_outputs

const AVFilterPad bm3d_outputs[]
static
Initial value:
= {
{
.name = "default",
.config_props = config_output,
},
}

Definition at line 1035 of file vf_bm3d.c.

◆ ff_vf_bm3d

const AVFilter ff_vf_bm3d
Initial value:
= {
.name = "bm3d",
.description = NULL_IF_CONFIG_SMALL("Block-Matching 3D denoiser."),
.priv_size = sizeof(BM3DContext),
.init = init,
.priv_class = &bm3d_class,
}

Definition at line 1043 of file vf_bm3d.c.

AV_PIX_FMT_YUVA422P16
#define AV_PIX_FMT_YUVA422P16
Definition: pixfmt.h:512
AV_PIX_FMT_GBRAP16
#define AV_PIX_FMT_GBRAP16
Definition: pixfmt.h:491
FLAGS
#define FLAGS
Definition: vf_bm3d.c:132
FILTER_PIXFMTS_ARRAY
#define FILTER_PIXFMTS_ARRAY(array)
Definition: internal.h:172
AV_PIX_FMT_YUVA422P9
#define AV_PIX_FMT_YUVA422P9
Definition: pixfmt.h:504
AV_PIX_FMT_YUVA420P16
#define AV_PIX_FMT_YUVA420P16
Definition: pixfmt.h:511
AV_PIX_FMT_YUVA420P10
#define AV_PIX_FMT_YUVA420P10
Definition: pixfmt.h:506
BASIC
@ BASIC
Definition: vf_bm3d.c:48
NB_MODES
@ NB_MODES
Definition: vf_bm3d.c:50
AV_PIX_FMT_YUV420P10
#define AV_PIX_FMT_YUV420P10
Definition: pixfmt.h:468
AV_PIX_FMT_YUV440P
@ AV_PIX_FMT_YUV440P
planar YUV 4:4:0 (1 Cr & Cb sample per 1x2 Y samples)
Definition: pixfmt.h:99
AV_PIX_FMT_YUVA422P10
#define AV_PIX_FMT_YUVA422P10
Definition: pixfmt.h:507
AV_PIX_FMT_GRAY9
#define AV_PIX_FMT_GRAY9
Definition: pixfmt.h:448
AV_PIX_FMT_YUVA420P9
#define AV_PIX_FMT_YUVA420P9
Definition: pixfmt.h:503
pix_fmts
static enum AVPixelFormat pix_fmts[]
Definition: vf_bm3d.c:166
AV_PIX_FMT_GBRP14
#define AV_PIX_FMT_GBRP14
Definition: pixfmt.h:486
AV_PIX_FMT_GBRAP
@ AV_PIX_FMT_GBRAP
planar GBRA 4:4:4:4 32bpp
Definition: pixfmt.h:205
AV_PIX_FMT_GBRP10
#define AV_PIX_FMT_GBRP10
Definition: pixfmt.h:484
AV_PIX_FMT_YUVA444P16
#define AV_PIX_FMT_YUVA444P16
Definition: pixfmt.h:513
AV_PIX_FMT_YUV422P9
#define AV_PIX_FMT_YUV422P9
Definition: pixfmt.h:466
AV_PIX_FMT_GRAY16
#define AV_PIX_FMT_GRAY16
Definition: pixfmt.h:452
AVFILTER_FLAG_DYNAMIC_INPUTS
#define AVFILTER_FLAG_DYNAMIC_INPUTS
The number of the filter inputs is not determined just by AVFilter.inputs.
Definition: avfilter.h:106
AV_PIX_FMT_YUV444P10
#define AV_PIX_FMT_YUV444P10
Definition: pixfmt.h:471
AV_PIX_FMT_YUVJ411P
@ AV_PIX_FMT_YUVJ411P
planar YUV 4:1:1, 12bpp, (1 Cr & Cb sample per 4x1 Y samples) full scale (JPEG), deprecated in favor ...
Definition: pixfmt.h:276
AV_PIX_FMT_YUV422P16
#define AV_PIX_FMT_YUV422P16
Definition: pixfmt.h:480
AV_PIX_FMT_YUVJ422P
@ AV_PIX_FMT_YUVJ422P
planar YUV 4:2:2, 16bpp, full scale (JPEG), deprecated in favor of AV_PIX_FMT_YUV422P and setting col...
Definition: pixfmt.h:79
AV_PIX_FMT_GBRAP10
#define AV_PIX_FMT_GBRAP10
Definition: pixfmt.h:488
AV_PIX_FMT_GBRAP12
#define AV_PIX_FMT_GBRAP12
Definition: pixfmt.h:489
AV_PIX_FMT_YUVA420P
@ AV_PIX_FMT_YUVA420P
planar YUV 4:2:0, 20bpp, (1 Cr & Cb sample per 2x2 Y & A samples)
Definition: pixfmt.h:101
AV_PIX_FMT_YUV444P16
#define AV_PIX_FMT_YUV444P16
Definition: pixfmt.h:481
AV_PIX_FMT_YUVA444P12
#define AV_PIX_FMT_YUVA444P12
Definition: pixfmt.h:510
AV_PIX_FMT_YUV420P9
#define AV_PIX_FMT_YUV420P9
Definition: pixfmt.h:465
AV_PIX_FMT_YUV420P16
#define AV_PIX_FMT_YUV420P16
Definition: pixfmt.h:479
AV_PIX_FMT_GRAY14
#define AV_PIX_FMT_GRAY14
Definition: pixfmt.h:451
AV_PIX_FMT_YUV420P
@ AV_PIX_FMT_YUV420P
planar YUV 4:2:0, 12bpp, (1 Cr & Cb sample per 2x2 Y samples)
Definition: pixfmt.h:66
AV_PIX_FMT_YUVJ444P
@ AV_PIX_FMT_YUVJ444P
planar YUV 4:4:4, 24bpp, full scale (JPEG), deprecated in favor of AV_PIX_FMT_YUV444P and setting col...
Definition: pixfmt.h:80
AV_PIX_FMT_GRAY10
#define AV_PIX_FMT_GRAY10
Definition: pixfmt.h:449
AV_PIX_FMT_GBRP16
#define AV_PIX_FMT_GBRP16
Definition: pixfmt.h:487
NULL
#define NULL
Definition: coverity.c:32
AV_PIX_FMT_YUVJ420P
@ AV_PIX_FMT_YUVJ420P
planar YUV 4:2:0, 12bpp, full scale (JPEG), deprecated in favor of AV_PIX_FMT_YUV420P and setting col...
Definition: pixfmt.h:78
AV_PIX_FMT_YUV440P10
#define AV_PIX_FMT_YUV440P10
Definition: pixfmt.h:470
AV_PIX_FMT_YUV422P10
#define AV_PIX_FMT_YUV422P10
Definition: pixfmt.h:469
inputs
these buffered frames must be flushed immediately if a new input produces new the filter must not call request_frame to get more It must just process the frame or queue it The task of requesting more frames is left to the filter s request_frame method or the application If a filter has several inputs
Definition: filter_design.txt:243
AV_PIX_FMT_GRAY8
@ AV_PIX_FMT_GRAY8
Y , 8bpp.
Definition: pixfmt.h:74
AV_PIX_FMT_GBRP9
#define AV_PIX_FMT_GBRP9
Definition: pixfmt.h:483
uninit
static av_cold void uninit(AVFilterContext *ctx)
Definition: vf_bm3d.c:1003
FINAL
@ FINAL
Definition: vf_bm3d.c:49
OFFSET
#define OFFSET(x)
Definition: vf_bm3d.c:131
NULL_IF_CONFIG_SMALL
#define NULL_IF_CONFIG_SMALL(x)
Return NULL if CONFIG_SMALL is true, otherwise the argument without modification.
Definition: internal.h:106
AV_PIX_FMT_YUV422P12
#define AV_PIX_FMT_YUV422P12
Definition: pixfmt.h:473
bm3d_outputs
static const AVFilterPad bm3d_outputs[]
Definition: vf_bm3d.c:1035
AV_PIX_FMT_YUV444P12
#define AV_PIX_FMT_YUV444P12
Definition: pixfmt.h:475
AV_PIX_FMT_YUVA444P
@ AV_PIX_FMT_YUVA444P
planar YUV 4:4:4 32bpp, (1 Cr & Cb sample per 1x1 Y & A samples)
Definition: pixfmt.h:167
AV_PIX_FMT_YUVA444P10
#define AV_PIX_FMT_YUVA444P10
Definition: pixfmt.h:508
AV_OPT_TYPE_FLOAT
@ AV_OPT_TYPE_FLOAT
Definition: opt.h:228
AV_PIX_FMT_GBRP12
#define AV_PIX_FMT_GBRP12
Definition: pixfmt.h:485
planes
static const struct @363 planes[]
AV_PIX_FMT_YUVJ440P
@ AV_PIX_FMT_YUVJ440P
planar YUV 4:4:0 full scale (JPEG), deprecated in favor of AV_PIX_FMT_YUV440P and setting color_range
Definition: pixfmt.h:100
AV_PIX_FMT_YUV444P9
#define AV_PIX_FMT_YUV444P9
Definition: pixfmt.h:467
AV_PIX_FMT_YUVA444P9
#define AV_PIX_FMT_YUVA444P9
Definition: pixfmt.h:505
AV_PIX_FMT_YUV420P12
#define AV_PIX_FMT_YUV420P12
Definition: pixfmt.h:472
AV_PIX_FMT_YUV422P14
#define AV_PIX_FMT_YUV422P14
Definition: pixfmt.h:477
init
static av_cold int init(AVFilterContext *ctx)
Definition: vf_bm3d.c:899
mode
mode
Definition: ebur128.h:83
AV_PIX_FMT_NONE
@ AV_PIX_FMT_NONE
Definition: pixfmt.h:65
AV_PIX_FMT_YUVA422P12
#define AV_PIX_FMT_YUVA422P12
Definition: pixfmt.h:509
AV_OPT_TYPE_INT
@ AV_OPT_TYPE_INT
Definition: opt.h:225
config_output
static int config_output(AVFilterLink *outlink)
Definition: vf_bm3d.c:953
ref
static int ref[MAX_W *MAX_W]
Definition: jpeg2000dwt.c:112
AV_PIX_FMT_YUV444P
@ AV_PIX_FMT_YUV444P
planar YUV 4:4:4, 24bpp, (1 Cr & Cb sample per 1x1 Y samples)
Definition: pixfmt.h:71
AV_PIX_FMT_GBRP
@ AV_PIX_FMT_GBRP
planar GBR 4:4:4 24bpp
Definition: pixfmt.h:158
AVFILTER_FLAG_SLICE_THREADS
#define AVFILTER_FLAG_SLICE_THREADS
The filter supports multithreading by splitting frames into multiple parts and processing them concur...
Definition: avfilter.h:117
AVMEDIA_TYPE_VIDEO
@ AVMEDIA_TYPE_VIDEO
Definition: avutil.h:201
AV_PIX_FMT_YUV422P
@ AV_PIX_FMT_YUV422P
planar YUV 4:2:2, 16bpp, (1 Cr & Cb sample per 2x1 Y samples)
Definition: pixfmt.h:70
AV_OPT_TYPE_BOOL
@ AV_OPT_TYPE_BOOL
Definition: opt.h:244
FILTER_OUTPUTS
#define FILTER_OUTPUTS(array)
Definition: internal.h:193
AV_PIX_FMT_YUV411P
@ AV_PIX_FMT_YUV411P
planar YUV 4:1:1, 12bpp, (1 Cr & Cb sample per 4x1 Y samples)
Definition: pixfmt.h:73
AVFILTER_FLAG_SUPPORT_TIMELINE_INTERNAL
#define AVFILTER_FLAG_SUPPORT_TIMELINE_INTERNAL
Same as AVFILTER_FLAG_SUPPORT_TIMELINE_GENERIC, except that the filter will have its filter_frame() c...
Definition: avfilter.h:155
AV_PIX_FMT_YUV410P
@ AV_PIX_FMT_YUV410P
planar YUV 4:1:0, 9bpp, (1 Cr & Cb sample per 4x4 Y samples)
Definition: pixfmt.h:72
AV_PIX_FMT_YUV440P12
#define AV_PIX_FMT_YUV440P12
Definition: pixfmt.h:474
AV_PIX_FMT_YUV444P14
#define AV_PIX_FMT_YUV444P14
Definition: pixfmt.h:478
AV_PIX_FMT_GRAY12
#define AV_PIX_FMT_GRAY12
Definition: pixfmt.h:450
BM3DContext
Definition: vf_bm3d.c:90
AV_OPT_TYPE_CONST
@ AV_OPT_TYPE_CONST
Definition: opt.h:234
AV_PIX_FMT_YUVA422P
@ AV_PIX_FMT_YUVA422P
planar YUV 4:2:2 24bpp, (1 Cr & Cb sample per 2x1 Y & A samples)
Definition: pixfmt.h:166
AV_PIX_FMT_YUV420P14
#define AV_PIX_FMT_YUV420P14
Definition: pixfmt.h:476
activate
static int activate(AVFilterContext *ctx)
Definition: vf_bm3d.c:845