FFmpeg
Data Structures | Macros | Enumerations | Functions | Variables
vsrc_mandelbrot.c File Reference
#include "avfilter.h"
#include "video.h"
#include "internal.h"
#include "libavutil/imgutils.h"
#include "libavutil/opt.h"
#include <float.h>
#include <math.h>

Go to the source code of this file.

Data Structures

struct  Point
 
struct  MBContext
 

Macros

#define SQR(a)   ((a)*(a))
 
#define OFFSET(x)   offsetof(MBContext, x)
 
#define FLAGS   AV_OPT_FLAG_VIDEO_PARAM|AV_OPT_FLAG_FILTERING_PARAM
 
#define Z_Z2_C(outr, outi, inr, ini)
 
#define Z_Z2_C_ZYKLUS(outr, outi, inr, ini, Z)
 

Enumerations

enum  Outer { ITERATION_COUNT, NORMALIZED_ITERATION_COUNT, WHITE, OUTZ }
 
enum  Inner { BLACK, PERIOD, CONVTIME, MINCOL }
 

Functions

 AVFILTER_DEFINE_CLASS (mandelbrot)
 
static av_cold int init (AVFilterContext *ctx)
 
static av_cold void uninit (AVFilterContext *ctx)
 
static int config_props (AVFilterLink *outlink)
 
static void fill_from_cache (AVFilterContext *ctx, uint32_t *color, int *in_cidx, int *out_cidx, double py, double scale)
 
static int interpol (MBContext *s, uint32_t *color, int x, int y, int linesize)
 
static void draw_mandelbrot (AVFilterContext *ctx, uint32_t *color, int linesize, int64_t pts)
 
static int request_frame (AVFilterLink *link)
 

Variables

static const AVOption mandelbrot_options []
 
static const AVFilterPad mandelbrot_outputs []
 
const AVFilter ff_vsrc_mandelbrot
 

Detailed Description

Mandelbrot fractal renderer

Definition in file vsrc_mandelbrot.c.

Macro Definition Documentation

◆ SQR

#define SQR (   a)    ((a)*(a))

Definition at line 37 of file vsrc_mandelbrot.c.

◆ OFFSET

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

Definition at line 84 of file vsrc_mandelbrot.c.

◆ FLAGS

Definition at line 85 of file vsrc_mandelbrot.c.

◆ Z_Z2_C

#define Z_Z2_C (   outr,
  outi,
  inr,
  ini 
)
Value:
outr= inr*inr - ini*ini + cr;\
outi= 2*inr*ini + ci;

◆ Z_Z2_C_ZYKLUS

#define Z_Z2_C_ZYKLUS (   outr,
  outi,
  inr,
  ini,
 
)
Value:
Z_Z2_C(outr,outi,inr,ini)\
if(use_zyklus){\
if(Z && fabs(s->zyklus[i>>1][0]-outr)+fabs(s->zyklus[i>>1][1]-outi) <= epsilon)\
break;\
}\
s->zyklus[i][0]= outr;\
s->zyklus[i][1]= outi;\

Enumeration Type Documentation

◆ Outer

enum Outer
Enumerator
ITERATION_COUNT 
NORMALIZED_ITERATION_COUNT 
WHITE 
OUTZ 

Definition at line 39 of file vsrc_mandelbrot.c.

◆ Inner

enum Inner
Enumerator
BLACK 
PERIOD 
CONVTIME 
MINCOL 

Definition at line 46 of file vsrc_mandelbrot.c.

Function Documentation

◆ AVFILTER_DEFINE_CLASS()

AVFILTER_DEFINE_CLASS ( mandelbrot  )

◆ init()

static av_cold int init ( AVFilterContext ctx)
static

Definition at line 120 of file vsrc_mandelbrot.c.

◆ uninit()

static av_cold void uninit ( AVFilterContext ctx)
static

Definition at line 141 of file vsrc_mandelbrot.c.

◆ config_props()

static int config_props ( AVFilterLink outlink)
static

Definition at line 150 of file vsrc_mandelbrot.c.

◆ fill_from_cache()

static void fill_from_cache ( AVFilterContext ctx,
uint32_t *  color,
int in_cidx,
int out_cidx,
double  py,
double  scale 
)
static

Definition at line 166 of file vsrc_mandelbrot.c.

Referenced by draw_mandelbrot().

◆ interpol()

static int interpol ( MBContext s,
uint32_t *  color,
int  x,
int  y,
int  linesize 
)
static

◆ draw_mandelbrot()

static void draw_mandelbrot ( AVFilterContext ctx,
uint32_t *  color,
int  linesize,
int64_t  pts 
)
static

Definition at line 238 of file vsrc_mandelbrot.c.

Referenced by request_frame().

◆ request_frame()

static int request_frame ( AVFilterLink link)
static

Definition at line 387 of file vsrc_mandelbrot.c.

Variable Documentation

◆ mandelbrot_options

const AVOption mandelbrot_options[]
static
Initial value:
= {
{"size", "set frame size", OFFSET(w), AV_OPT_TYPE_IMAGE_SIZE, {.str="640x480"}, 0, 0, FLAGS },
{"s", "set frame size", OFFSET(w), AV_OPT_TYPE_IMAGE_SIZE, {.str="640x480"}, 0, 0, FLAGS },
{"rate", "set frame rate", OFFSET(frame_rate), AV_OPT_TYPE_VIDEO_RATE, {.str="25"}, 0, INT_MAX, FLAGS },
{"r", "set frame rate", OFFSET(frame_rate), AV_OPT_TYPE_VIDEO_RATE, {.str="25"}, 0, INT_MAX, FLAGS },
{"maxiter", "set max iterations number", OFFSET(maxiter), AV_OPT_TYPE_INT, {.i64=7189}, 1, INT_MAX, FLAGS },
{"start_x", "set the initial x position", OFFSET(start_x), AV_OPT_TYPE_DOUBLE, {.dbl=-0.743643887037158704752191506114774}, -100, 100, FLAGS },
{"start_y", "set the initial y position", OFFSET(start_y), AV_OPT_TYPE_DOUBLE, {.dbl=-0.131825904205311970493132056385139}, -100, 100, FLAGS },
{"start_scale", "set the initial scale value", OFFSET(start_scale), AV_OPT_TYPE_DOUBLE, {.dbl=3.0}, 0, FLT_MAX, FLAGS },
{"end_scale", "set the terminal scale value", OFFSET(end_scale), AV_OPT_TYPE_DOUBLE, {.dbl=0.3}, 0, FLT_MAX, FLAGS },
{"end_pts", "set the terminal pts value", OFFSET(end_pts), AV_OPT_TYPE_DOUBLE, {.dbl=400}, 0, INT64_MAX, FLAGS },
{"bailout", "set the bailout value", OFFSET(bailout), AV_OPT_TYPE_DOUBLE, {.dbl=10}, 0, FLT_MAX, FLAGS },
{"morphxf", "set morph x frequency", OFFSET(morphxf), AV_OPT_TYPE_DOUBLE, {.dbl=0.01}, -FLT_MAX, FLT_MAX, FLAGS },
{"morphyf", "set morph y frequency", OFFSET(morphyf), AV_OPT_TYPE_DOUBLE, {.dbl=0.0123}, -FLT_MAX, FLT_MAX, FLAGS },
{"morphamp", "set morph amplitude", OFFSET(morphamp), AV_OPT_TYPE_DOUBLE, {.dbl=0}, -FLT_MAX, FLT_MAX, FLAGS },
{"outer", "set outer coloring mode", OFFSET(outer), AV_OPT_TYPE_INT, {.i64=NORMALIZED_ITERATION_COUNT}, 0, INT_MAX, FLAGS, "outer" },
{"iteration_count", "set iteration count mode", 0, AV_OPT_TYPE_CONST, {.i64=ITERATION_COUNT}, INT_MIN, INT_MAX, FLAGS, "outer" },
{"normalized_iteration_count", "set normalized iteration count mode", 0, AV_OPT_TYPE_CONST, {.i64=NORMALIZED_ITERATION_COUNT}, INT_MIN, INT_MAX, FLAGS, "outer" },
{"white", "set white mode", 0, AV_OPT_TYPE_CONST, {.i64=WHITE}, INT_MIN, INT_MAX, FLAGS, "outer" },
{"outz", "set outz mode", 0, AV_OPT_TYPE_CONST, {.i64=OUTZ}, INT_MIN, INT_MAX, FLAGS, "outer" },
{"inner", "set inner coloring mode", OFFSET(inner), AV_OPT_TYPE_INT, {.i64=MINCOL}, 0, INT_MAX, FLAGS, "inner" },
{"black", "set black mode", 0, AV_OPT_TYPE_CONST, {.i64=BLACK}, INT_MIN, INT_MAX, FLAGS, "inner"},
{"period", "set period mode", 0, AV_OPT_TYPE_CONST, {.i64=PERIOD}, INT_MIN, INT_MAX, FLAGS, "inner"},
{"convergence", "show time until convergence", 0, AV_OPT_TYPE_CONST, {.i64=CONVTIME}, INT_MIN, INT_MAX, FLAGS, "inner"},
{"mincol", "color based on point closest to the origin of the iterations", 0, AV_OPT_TYPE_CONST, {.i64=MINCOL}, INT_MIN, INT_MAX, FLAGS, "inner"},
{NULL},
}

Definition at line 87 of file vsrc_mandelbrot.c.

◆ mandelbrot_outputs

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

Definition at line 402 of file vsrc_mandelbrot.c.

◆ ff_vsrc_mandelbrot

const AVFilter ff_vsrc_mandelbrot
Initial value:
= {
.name = "mandelbrot",
.description = NULL_IF_CONFIG_SMALL("Render a Mandelbrot fractal."),
.priv_size = sizeof(MBContext),
.priv_class = &mandelbrot_class,
.init = init,
}

Definition at line 411 of file vsrc_mandelbrot.c.

init
static av_cold int init(AVFilterContext *ctx)
Definition: vsrc_mandelbrot.c:120
NORMALIZED_ITERATION_COUNT
@ NORMALIZED_ITERATION_COUNT
Definition: vsrc_mandelbrot.c:41
AV_OPT_TYPE_VIDEO_RATE
@ AV_OPT_TYPE_VIDEO_RATE
offset must point to AVRational
Definition: opt.h:238
w
uint8_t w
Definition: llviddspenc.c:38
FLAGS
#define FLAGS
Definition: vsrc_mandelbrot.c:85
MBContext
Definition: vsrc_mandelbrot.c:58
PERIOD
@ PERIOD
Definition: vsrc_mandelbrot.c:48
mandelbrot_outputs
static const AVFilterPad mandelbrot_outputs[]
Definition: vsrc_mandelbrot.c:402
Z_Z2_C
#define Z_Z2_C(outr, outi, inr, ini)
BLACK
@ BLACK
Definition: vsrc_mandelbrot.c:47
s
#define s(width, name)
Definition: cbs_vp9.c:198
AV_PIX_FMT_0BGR32
#define AV_PIX_FMT_0BGR32
Definition: pixfmt.h:446
AV_OPT_TYPE_DOUBLE
@ AV_OPT_TYPE_DOUBLE
Definition: opt.h:227
CONVTIME
@ CONVTIME
Definition: vsrc_mandelbrot.c:49
request_frame
static int request_frame(AVFilterLink *link)
Definition: vsrc_mandelbrot.c:387
fabs
static __device__ float fabs(float a)
Definition: cuda_runtime.h:182
NULL
#define NULL
Definition: coverity.c:32
ITERATION_COUNT
@ ITERATION_COUNT
Definition: vsrc_mandelbrot.c:40
AV_OPT_TYPE_IMAGE_SIZE
@ AV_OPT_TYPE_IMAGE_SIZE
offset must point to two consecutive integers
Definition: opt.h:235
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
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
MINCOL
@ MINCOL
Definition: vsrc_mandelbrot.c:50
uninit
static av_cold void uninit(AVFilterContext *ctx)
Definition: vsrc_mandelbrot.c:141
FILTER_SINGLE_PIXFMT
#define FILTER_SINGLE_PIXFMT(pix_fmt_)
Definition: internal.h:182
i
#define i(width, name, range_min, range_max)
Definition: cbs_h2645.c:255
OUTZ
@ OUTZ
Definition: vsrc_mandelbrot.c:43
AV_OPT_TYPE_INT
@ AV_OPT_TYPE_INT
Definition: opt.h:225
OFFSET
#define OFFSET(x)
Definition: vsrc_mandelbrot.c:84
AVMEDIA_TYPE_VIDEO
@ AVMEDIA_TYPE_VIDEO
Definition: avutil.h:201
cr
static double cr(void *priv, double x, double y)
Definition: vf_geq.c:242
FILTER_OUTPUTS
#define FILTER_OUTPUTS(array)
Definition: internal.h:193
config_props
static int config_props(AVFilterLink *outlink)
Definition: vsrc_mandelbrot.c:150
AV_OPT_TYPE_CONST
@ AV_OPT_TYPE_CONST
Definition: opt.h:234
WHITE
@ WHITE
Definition: vsrc_mandelbrot.c:42