34 #if CONFIG_LIBFREETYPE
36 #include FT_FREETYPE_H
41 #define BASEFREQ 20.01523126408007475
42 #define ENDFREQ 20495.59681441799654
43 #define TLENGTH "384*tc/(384+tc*f)"
44 #define TLENGTH_MIN 0.001
45 #define VOLUME_MAX 100.0
46 #define FONTCOLOR "st(0, (midi(f)-59.5)/12);" \
47 "st(1, if(between(ld(0),0,1), 0.5-0.5*cos(2*PI*ld(0)), 0));" \
48 "r(1-ld(1)) + b(ld(1))"
50 #define PTS_TOLERANCE 1
52 #define OFFSET(x) offsetof(ShowCQTContext, x)
53 #define FLAGS (AV_OPT_FLAG_FILTERING_PARAM|AV_OPT_FLAG_VIDEO_PARAM)
117 av_log(s->
ctx, level,
"plot_time = %16.3f s.\n", plot_time * 1e-6);
124 for (k = 0; k < 4; k++)
133 for (k = 0; k < s->
cqt_len; k++)
149 double log_base, log_end;
150 double rcp_n = 1.0 /
n;
158 log_base = log(base);
160 for (x = 0; x <
n; x++) {
161 double log_freq = log_base + (x + 0.5) * (log_end - log_base) * rcp_n;
162 freq[x] =
exp(log_freq);
168 double val,
double min,
double max,
169 double nan_replace,
int idx)
173 av_log(log_ctx, level,
"[%d] %s is nan, setting it to %g.\n",
174 idx, name, nan_replace);
176 }
else if (val < min) {
177 av_log(log_ctx, level,
"[%d] %s is too low (%g), setting it to %g.\n",
178 idx, name, val, min);
180 }
else if (val > max) {
181 av_log(log_ctx, level,
"[%d] %s it too high (%g), setting it to %g.\n",
182 idx, name, val, max);
190 double ret = 12200.0*12200.0 * (f*f*f*f);
191 ret /= (f*f + 20.6*20.6) * (f*f + 12200.0*12200.0) *
192 sqrt((f*f + 107.7*107.7) * (f*f + 737.9*737.9));
198 double ret = 12200.0*12200.0 * (f*f*f);
199 ret /= (f*f + 20.6*20.6) * (f*f + 12200.0*12200.0) * sqrt(f*f + 158.5*158.5);
205 double ret = 12200.0*12200.0 * (f*f);
206 ret /= (f*f + 20.6*20.6) * (f*f + 12200.0*12200.0);
212 const char *func_names[] = {
"a_weighting",
"b_weighting",
"c_weighting",
NULL };
213 const char *sono_names[] = {
"timeclamp",
"tc",
"frequency",
"freq",
"f",
"bar_v",
NULL };
214 const char *bar_names[] = {
"timeclamp",
"tc",
"frequency",
"freq",
"f",
"sono_v",
NULL };
230 for (x = 0; x < s->
cqt_len; x++) {
253 int len,
int fft_len)
256 for (k = 0; k <
len; k++) {
259 for (x = 0; x < coeffs[k].
len; x++) {
261 i = coeffs[k].
start + x;
263 a.
re += u * src[i].
re;
264 a.
im += u * src[i].
im;
265 b.re += u * src[j].
re;
266 b.im += u * src[j].
im;
281 const char *
var_names[] = {
"timeclamp",
"tc",
"frequency",
"freq",
"f",
NULL };
284 int nb_cqt_coeffs = 0;
294 for (k = 0; k < s->
cqt_len; k++) {
296 double flen, center, tlength;
299 if (s->
freq[k] > 0.5 * rate)
304 flen = 8.0 * s->
fft_len / (tlength * rate);
306 start =
FFMAX(0, ceil(center - 0.5 * flen));
315 for (x = start; x <=
end; x++) {
316 int sign = (x & 1) ? (-1) : 1;
317 double y = 2.0 *
M_PI * (x - center) * (1.0 / flen);
319 double w = 0.355768 + 0.487396 * cos(y) + 0.144232 * cos(2*y) + 0.012604 * cos(3*y);
320 w *= sign * (1.0 / s->
fft_len);
335 for (k = 0; k < s->
cqt_len; k++)
390 int tmp_w, tmp_h, ret;
392 if ((ret =
ff_load_image(tmp_data, tmp_linesize, &tmp_w, &tmp_h, &tmp_format,
402 tmp_format, s->
ctx)) < 0)
417 static double midi(
void *p,
double f)
419 return log2(f/440.0) * 12.0 + 69.0;
424 x = av_clipd(x, 0.0, 1.0);
425 return lrint(x*255.0) << 16;
430 x = av_clipd(x, 0.0, 1.0);
431 return lrint(x*255.0) << 8;
436 x = av_clipd(x, 0.0, 1.0);
437 return lrint(x*255.0);
442 const char *
var_names[] = {
"timeclamp",
"tc",
"frequency",
"freq",
"f",
NULL };
443 const char *func_names[] = {
"midi",
"r",
"g",
"b",
NULL };
448 int width = half ? 1920/2 : 1920,
height = half ? 16 : 32;
449 int step = half ? 2 : 1;
453 " please use axisfile option instead.\n");
468 for (x = 0, xs = 0; x <
width; x++, xs += step) {
471 uint8_t r = (color >> 16) & 0xFF,
g = (color >> 8) & 0xFF,
b = color & 0xFF;
474 for (y = 0; y <
height; y++) {
475 data[linesize * y + 4 * x] =
r;
476 data[linesize * y + 4 * x + 1] =
g;
477 data[linesize * y + 4 * x + 2] =
b;
489 #if CONFIG_LIBFREETYPE
490 const char *str =
"EF G A BC D ";
493 FT_Library lib =
NULL;
495 int font_width = 16, font_height = 32;
496 int font_repeat = font_width * 12;
497 int linear_hori_advance = font_width * 65536;
498 int non_monospace_warning = 0;
504 if (FT_Init_FreeType(&lib))
507 if (FT_New_Face(lib, s->
fontfile, 0, &face))
510 if (FT_Set_Char_Size(face, 16*64, 0, 0, 0))
513 if (FT_Load_Char(face,
'A', FT_LOAD_RENDER))
516 if (FT_Set_Char_Size(face, 16*64 * linear_hori_advance / face->glyph->linearHoriAdvance, 0, 0, 0))
519 for (x = 0; x < 12; x++) {
520 int sx, sy, rx, bx, by, dx, dy;
525 if (FT_Load_Char(face, str[x], FT_LOAD_RENDER))
528 if (face->glyph->advance.x != font_width*64 && !non_monospace_warning) {
530 non_monospace_warning = 1;
533 sy = font_height - 8 - face->glyph->bitmap_top;
534 for (rx = 0; rx < 10; rx++) {
535 sx = rx * font_repeat + x * font_width + face->glyph->bitmap_left;
536 for (by = 0; by < face->glyph->bitmap.rows; by++) {
540 if (dy >= font_height)
543 for (bx = 0; bx < face->glyph->bitmap.width; bx++) {
549 data[dy*linesize+4*dx+3] = face->glyph->bitmap.buffer[by*face->glyph->bitmap.width+bx];
556 FT_Done_FreeType(lib);
562 FT_Done_FreeType(lib);
573 const char *str =
"EF G A BC D ";
579 for (x = 0; x <
width; x += width/10) {
580 uint8_t *startptr = data + 4 * x;
581 for (u = 0; u < 12; u++) {
582 for (v = 0; v <
height; v++) {
583 uint8_t *p = startptr + v * linesize + height/2 * 4 *
u;
584 for (mask = 0x80;
mask; mask >>= 1, p += 4) {
602 int default_font = 0;
645 return sqrtf(sqrtf(v));
646 return expf(logf(v) / g);
652 for (x = 0; x <
len; x++) {
662 for (x = 0; x <
len; x++) {
667 c[x].
yuv.
y = 65.481f * r + 128.553f * g + 24.966f *
b;
668 c[x].
yuv.
u = -37.797f * r - 74.203f * g + 112.0f *
b;
669 c[x].
yuv.
v = 112.0f * r - 93.786f * g - 18.214 *
b;
676 int x, y, w = out->
width;
677 float mul, ht, rcp_bar_h = 1.0f / bar_h;
681 for (y = 0; y < bar_h; y++) {
682 ht = (bar_h - y) * rcp_bar_h;
684 for (x = 0; x < w; x++) {
690 mul = (h[x] - ht) * rcp_h[x];
691 *lp++ =
lrintf(mul * c[x].rgb.r);
692 *lp++ =
lrintf(mul * c[x].rgb.g);
693 *lp++ =
lrintf(mul * c[x].rgb.b);
699 #define DRAW_BAR_WITH_CHROMA(x) \
706 mul = (h[x] - ht) * rcp_h[x]; \
707 *lpy++ = lrintf(mul * c[x].yuv.y + 16.0f); \
708 *lpu++ = lrintf(mul * c[x].yuv.u + 128.0f); \
709 *lpv++ = lrintf(mul * c[x].yuv.v + 128.0f); \
713 #define DRAW_BAR_WITHOUT_CHROMA(x) \
718 mul = (h[x] - ht) * rcp_h[x]; \
719 *lpy++ = lrintf(mul * c[x].yuv.y + 16.0f); \
726 int x, y, yh, w = out->
width;
727 float mul, ht, rcp_bar_h = 1.0f / bar_h;
733 for (y = 0; y < bar_h; y += 2) {
735 ht = (bar_h - y) * rcp_bar_h;
740 for (x = 0; x < w; x += 2) {
745 for (x = 0; x < w; x += 2) {
751 ht = (bar_h - (y+1)) * rcp_bar_h;
752 lpy = vy + (y+1) * lsy;
753 lpu = vu + (y+1) * lsu;
754 lpv = vv + (y+1) * lsv;
756 for (x = 0; x < w; x += 2) {
761 for (x = 0; x < w; x += 2) {
766 for (x = 0; x < w; x += 2) {
777 float a, rcp_255 = 1.0f / 255.0f;
780 for (y = 0; y <
h; y++) {
783 for (x = 0; x < w; x++) {
785 *lp++ =
lrintf(c[x].rgb.r);
786 *lp++ =
lrintf(c[x].rgb.g);
787 *lp++ =
lrintf(c[x].rgb.b);
788 }
else if (lpa[3] == 255) {
793 a = rcp_255 * lpa[3];
794 *lp++ =
lrintf(a * lpa[0] + (1.0f - a) * c[x].rgb.r);
795 *lp++ =
lrintf(a * lpa[1] + (1.0f - a) * c[x].rgb.g);
796 *lp++ =
lrintf(a * lpa[2] + (1.0f - a) * c[x].rgb.b);
803 #define BLEND_WITH_CHROMA(c) \
806 *lpy = lrintf(c.yuv.y + 16.0f); \
807 *lpu = lrintf(c.yuv.u + 128.0f); \
808 *lpv = lrintf(c.yuv.v + 128.0f); \
809 } else if (255 == *lpaa) { \
814 float a = (1.0f/255.0f) * (*lpaa); \
815 *lpy = lrintf(a * (*lpay) + (1.0f - a) * (c.yuv.y + 16.0f)); \
816 *lpu = lrintf(a * (*lpau) + (1.0f - a) * (c.yuv.u + 128.0f)); \
817 *lpv = lrintf(a * (*lpav) + (1.0f - a) * (c.yuv.v + 128.0f)); \
819 lpy++; lpu++; lpv++; \
820 lpay++; lpau++; lpav++; lpaa++; \
823 #define BLEND_WITHOUT_CHROMA(c, alpha_inc) \
826 *lpy = lrintf(c.yuv.y + 16.0f); \
827 } else if (255 == *lpaa) { \
830 float a = (1.0f/255.0f) * (*lpaa); \
831 *lpy = lrintf(a * (*lpay) + (1.0f - a) * (c.yuv.y + 16.0f)); \
834 lpay++; lpaa += alpha_inc; \
837 #define BLEND_CHROMA2(c) \
839 if (!lpaa[0] && !lpaa[1]) { \
840 *lpu = lrintf(c.yuv.u + 128.0f); \
841 *lpv = lrintf(c.yuv.v + 128.0f); \
842 } else if (255 == lpaa[0] && 255 == lpaa[1]) { \
843 *lpu = *lpau; *lpv = *lpav; \
845 float a0 = (0.5f/255.0f) * lpaa[0]; \
846 float a1 = (0.5f/255.0f) * lpaa[1]; \
847 float b = 1.0f - a0 - a1; \
848 *lpu = lrintf(a0 * lpau[0] + a1 * lpau[1] + b * (c.yuv.u + 128.0f)); \
849 *lpv = lrintf(a0 * lpav[0] + a1 * lpav[1] + b * (c.yuv.v + 128.0f)); \
851 lpau += 2; lpav += 2; lpaa++; lpu++; lpv++; \
854 #define BLEND_CHROMA2x2(c) \
856 if (!lpaa[0] && !lpaa[1] && !lpaa[lsaa] && !lpaa[lsaa+1]) { \
857 *lpu = lrintf(c.yuv.u + 128.0f); \
858 *lpv = lrintf(c.yuv.v + 128.0f); \
859 } else if (255 == lpaa[0] && 255 == lpaa[1] && \
860 255 == lpaa[lsaa] && 255 == lpaa[lsaa+1]) { \
861 *lpu = *lpau; *lpv = *lpav; \
863 float a0 = (0.25f/255.0f) * lpaa[0]; \
864 float a1 = (0.25f/255.0f) * lpaa[1]; \
865 float a2 = (0.25f/255.0f) * lpaa[lsaa]; \
866 float a3 = (0.25f/255.0f) * lpaa[lsaa+1]; \
867 float b = 1.0f - a0 - a1 - a2 - a3; \
868 *lpu = lrintf(a0 * lpau[0] + a1 * lpau[1] + a2 * lpau[lsau] + a3 * lpau[lsau+1] \
869 + b * (c.yuv.u + 128.0f)); \
870 *lpv = lrintf(a0 * lpav[0] + a1 * lpav[1] + a2 * lpav[lsav] + a3 * lpav[lsav+1] \
871 + b * (c.yuv.v + 128.0f)); \
873 lpau += 2; lpav += 2; lpaa++; lpu++; lpv++; \
884 uint8_t *lpy, *lpu, *lpv, *lpay, *lpau, *lpav, *lpaa;
886 for (y = 0; y <
h; y += 2) {
888 lpy = vy + (off + y) * lsy;
889 lpu = vu + (offh + yh) * lsu;
890 lpv = vv + (offh + yh) * lsv;
891 lpay = vay + y * lsay;
892 lpau = vau + y * lsau;
893 lpav = vav + y * lsav;
894 lpaa = vaa + y * lsaa;
896 for (x = 0; x < w; x += 2) {
901 for (x = 0; x < w; x += 2) {
907 for (x = 0; x < w; x += 2) {
914 lpy = vy + (off + y + 1) * lsy;
915 lpu = vu + (off + y + 1) * lsu;
916 lpv = vv + (off + y + 1) * lsv;
917 lpay = vay + (y + 1) * lsay;
918 lpau = vau + (y + 1) * lsau;
919 lpav = vav + (y + 1) * lsav;
920 lpaa = vaa + (y + 1) * lsaa;
922 for (x = 0; x < w; x += 2) {
927 for (x = 0; x < w; x += 2) {
933 for (x = 0; x < w; x += 2) {
950 for (y = 0; y <
h; y++) {
955 for (i = 1; i < nb_planes; i++) {
957 for (y = 0; y <
h; y += inc) {
967 int x, w = sono->
width;
970 for (x = 0; x < w; x++) {
971 *lp++ =
lrintf(c[x].rgb.r);
972 *lp++ =
lrintf(c[x].rgb.g);
973 *lp++ =
lrintf(c[x].rgb.b);
984 for (x = 0; x < w; x += 2) {
985 *lpy++ =
lrintf(c[x].yuv.y + 16.0f);
986 *lpu++ =
lrintf(c[x].yuv.u + 128.0f);
987 *lpv++ =
lrintf(c[x].yuv.v + 128.0f);
988 *lpy++ =
lrintf(c[x+1].yuv.y + 16.0f);
990 *lpu++ =
lrintf(c[x+1].yuv.u + 128.0f);
991 *lpv++ =
lrintf(c[x+1].yuv.v + 128.0f);
1000 for (x = 0; x < s->
cqt_len; x++) {
1004 float rcp_fcount = 1.0f / s->
fcount;
1005 for (x = 0; x < s->
width; x++) {
1007 for (i = 0; i < s->
fcount; i++)
1009 s->
h_buf[x] = rcp_fcount * h;
1012 for (x = 0; x < s->
width; x++) {
1018 for (x = 0; x < s->
cqt_len; x++) {
1024 float rcp_fcount = 1.0f / s->
fcount;
1025 for (x = 0; x < s->
width; x++) {
1027 for (i = 0; i < s->
fcount; i++) {
1048 #define UPDATE_TIME(t) \
1049 cur_time = av_gettime(); \
1050 t += cur_time - last_time; \
1051 last_time = cur_time
1214 av_log(ctx,
AV_LOG_INFO,
"video: %dx%d %s %d/%d fps, bar_h = %d, axis_h = %d, sono_h = %d.\n",
1317 int remaining, step, ret, x, i, j,
m;
1330 for (x = 0; x < (s->
fft_len-step); x++)
1341 audio_data = (
float*) insamples->
data[0];
1362 av_log(ctx,
AV_LOG_DEBUG,
"changing pts from %"PRId64
" (%.3f) to %"PRId64
" (%.3f).\n",
1377 for (m = 0; m < s->
fft_len-step; m++)
1381 for (m = 0; m < remaining; m++) {
1425 .description =
NULL_IF_CONFIG_SMALL(
"Convert input audio to a CQT (Constant/Clamped Q Transform) spectrum video output."),
1430 .
inputs = showcqt_inputs,
1432 .priv_class = &showcqt_class,
const char const char void * val
This structure describes decoded (raw) audio or video data.
void(* update_sono)(AVFrame *sono, const ColorFloat *c, int idx)
ptrdiff_t const GLvoid * data
av_cold void av_fft_end(FFTContext *s)
static const AVOption showcqt_options[]
planar YUV 4:4:4, 24bpp, (1 Cr & Cb sample per 1x1 Y samples)
#define AV_LOG_WARNING
Something somehow does not look correct.
Main libavfilter public API header.
packed RGB 8:8:8, 24bpp, RGBRGB...
AVBufferRef * buf[AV_NUM_DATA_POINTERS]
AVBuffer references backing the data for this frame.
static int init_cqt(ShowCQTContext *s)
int h
agreed upon image height
static av_cold int init(AVFilterContext *ctx)
Miscellaneous utilities which make use of the libswscale library.
static enum AVSampleFormat formats[]
#define BLEND_CHROMA2x2(c)
static av_cold void uninit(AVFilterContext *ctx)
const uint8_t avpriv_vga16_font[4096]
static void yuv_from_cqt(ColorFloat *c, const FFTComplex *v, float gamma, int len)
void av_fft_permute(FFTContext *s, FFTComplex *z)
Do the permutation needed BEFORE calling ff_fft_calc().
int av_expr_parse(AVExpr **expr, const char *s, const char *const *const_names, const char *const *func1_names, double(*const *funcs1)(void *, double), const char *const *func2_names, double(*const *funcs2)(void *, double, double), int log_offset, void *log_ctx)
Parse an expression.
static int render_default_font(AVFrame *tmp)
AVFrame * ff_get_video_buffer(AVFilterLink *link, int w, int h)
Request a picture buffer with a specific set of permissions.
#define AV_CH_LAYOUT_STEREO
static AVRational av_make_q(int num, int den)
Create a rational.
const char * name
Pad name.
static int render_freetype(ShowCQTContext *s, AVFrame *tmp)
AVFilterLink ** inputs
array of pointers to input links
#define DRAW_BAR_WITHOUT_CHROMA(x)
int ff_filter_frame(AVFilterLink *link, AVFrame *frame)
Send a frame of data to the next filter.
planar YUV 4:2:0, 20bpp, (1 Cr & Cb sample per 2x2 Y & A samples)
AVFrame * av_frame_alloc(void)
Allocate an AVFrame and set its fields to default values.
static int init_axis_empty(ShowCQTContext *s)
static av_cold int end(AVCodecContext *avctx)
int64_t pts
Presentation timestamp in time_base units (time when frame should be shown to user).
static double a_weighting(void *p, double f)
int ff_scale_image(uint8_t *dst_data[4], int dst_linesize[4], int dst_w, int dst_h, enum AVPixelFormat dst_pix_fmt, uint8_t *const src_data[4], int src_linesize[4], int src_w, int src_h, enum AVPixelFormat src_pix_fmt, void *log_ctx)
Scale image using libswscale.
static double av_q2d(AVRational a)
Convert rational to double.
static void draw_axis_rgb(AVFrame *out, AVFrame *axis, const ColorFloat *c, int off)
AVRational av_mul_q(AVRational b, AVRational c)
Multiply two rationals.
static enum AVPixelFormat convert_axis_pixel_format(enum AVPixelFormat format)
#define AVERROR_EOF
End of file.
static const char *const var_names[]
static double b_func(void *p, double x)
static void update_sono_rgb(AVFrame *sono, const ColorFloat *c, int idx)
void av_frame_set_color_range(AVFrame *frame, enum AVColorRange val)
A filter pad used for either input or output.
int64_t av_rescale_q(int64_t a, AVRational bq, AVRational cq)
Rescale a 64-bit integer by 2 rational numbers.
A link between two filters.
int width
width and height of the video frame
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
AVRational frame_rate
Frame rate of the stream on the link, or 1/0 if unknown or variable; if left to 0/0, will be automatically copied from the first input of the source filter if it exists.
int sample_rate
samples per second
static const uint16_t mask[17]
#define BLEND_WITH_CHROMA(c)
void av_frame_free(AVFrame **frame)
Free the frame and any dynamically allocated objects in it, e.g.
#define NULL_IF_CONFIG_SMALL(x)
Return NULL if CONFIG_SMALL is true, otherwise the argument without modification. ...
AVRational av_div_q(AVRational b, AVRational c)
Divide one rational by another.
void * priv
private data for use by the filter
#define AV_LOG_DEBUG
Stuff which is only useful for libav* developers.
static int init_axis_from_file(ShowCQTContext *s)
static double b_weighting(void *p, double f)
AVRational time_base
Define the time base used by the PTS of the frames/samples which will pass through this link...
simple assert() macros that are a bit more flexible than ISO C assert().
struct AVFilterChannelLayouts * out_channel_layouts
FFTContext * av_fft_init(int nbits, int inverse)
Set up a complex FFT.
static void cqt_calc(FFTComplex *dst, const FFTComplex *src, const Coeffs *coeffs, int len, int fft_len)
AVFilterFormats * in_formats
Lists of formats and channel layouts supported by the input and output filters respectively.
static const AVFilterPad showcqt_outputs[]
void(* cqt_calc)(FFTComplex *dst, const FFTComplex *src, const Coeffs *coeffs, int len, int fft_len)
packed RGBA 8:8:8:8, 32bpp, RGBARGBA...
planar YUV 4:2:2, 16bpp, (1 Cr & Cb sample per 2x1 Y samples)
static const AVFilterPad showcqt_inputs[]
int w
agreed upon image width
static void update_sono_yuv(AVFrame *sono, const ColorFloat *c, int idx)
#define AV_CH_LAYOUT_STEREO_DOWNMIX
#define FFABS(a)
Absolute value, Note, INT_MIN / INT64_MIN result in undefined behavior as they are not representable ...
int ff_load_image(uint8_t *data[4], int linesize[4], int *w, int *h, enum AVPixelFormat *pix_fmt, const char *filename, void *log_ctx)
Load image from filename and put the resulting image in data.
static int init_axis_from_font(ShowCQTContext *s)
static void rgb_from_cqt(ColorFloat *c, const FFTComplex *v, float g, int len)
AVFilterContext * src
source filter
static double r_func(void *p, double x)
static const AVFilterPad outputs[]
AVFilterFormats * out_samplerates
static int init_axis_color(ShowCQTContext *s, AVFrame *tmp, int half)
int format
agreed upon media format
static double g_func(void *p, double x)
#define BLEND_WITHOUT_CHROMA(c, alpha_inc)
A list of supported channel layouts.
int64_t av_gettime(void)
Get the current time in microseconds.
int format
format of the frame, -1 if unknown or unset Values correspond to enum AVPixelFormat for video frames...
static const uint8_t vars[2][12]
static void draw_sono(AVFrame *out, AVFrame *sono, int off, int idx)
#define AV_LOG_INFO
Standard information.
static const AVFilterPad inputs[]
AVSampleFormat
Audio sample formats.
void av_expr_free(AVExpr *e)
Free a parsed expression previously created with av_expr_parse().
int linesize[AV_NUM_DATA_POINTERS]
For video, size in bytes of each picture line.
static AVFrame * alloc_frame_empty(enum AVPixelFormat format, int w, int h)
planar YUV 4:4:4 32bpp, (1 Cr & Cb sample per 1x1 Y & A samples)
AVRational sample_aspect_ratio
Sample aspect ratio for the video frame, 0/1 if unknown/unspecified.
AVFILTER_DEFINE_CLASS(showcqt)
static av_always_inline float cbrtf(float x)
static double * create_freq_table(double base, double end, int n)
static const char * format
static const uint16_t channel_layouts[7]
static double clip_with_log(void *log_ctx, const char *name, double val, double min, double max, double nan_replace, int idx)
static double midi(void *p, double f)
void ff_showcqt_init_x86(ShowCQTContext *s)
offset must point to AVRational
const char * name
Filter name.
AVRational sample_aspect_ratio
agreed upon sample aspect ratio
static void draw_bar_yuv(AVFrame *out, const float *h, const float *rcp_h, const ColorFloat *c, int bar_h)
static void common_uninit(ShowCQTContext *s)
#define DRAW_BAR_WITH_CHROMA(x)
offset must point to two consecutive integers
static int filter_frame(AVFilterLink *inlink, AVFrame *insamples)
AVFilterLink ** outputs
array of pointers to output links
enum MovChannelLayoutTag * layouts
static enum AVPixelFormat pix_fmts[]
int av_frame_get_buffer(AVFrame *frame, int align)
Allocate new buffer(s) for audio or video data.
static int config_output(AVFilterLink *outlink)
void * av_calloc(size_t nmemb, size_t size)
Allocate a block of nmemb * size bytes with alignment suitable for all memory accesses (including vec...
static int64_t pts
Global timestamp for the audio frames.
static av_always_inline AVRational av_inv_q(AVRational q)
Invert a rational.
uint8_t * data[AV_NUM_DATA_POINTERS]
pointer to the picture/channel planes.
static int request_frame(AVFilterLink *outlink)
the normal 219*2^(n-8) "MPEG" YUV ranges
static int plot_cqt(AVFilterContext *ctx, AVFrame **frameout)
planar YUV 4:2:0, 12bpp, (1 Cr & Cb sample per 2x2 Y samples)
void(* draw_bar)(AVFrame *out, const float *h, const float *rcp_h, const ColorFloat *c, int bar_h)
enum AVPixelFormat format
static int query_formats(AVFilterContext *ctx)
static const int16_t coeffs[]
double av_expr_eval(AVExpr *e, const double *const_values, void *opaque)
Evaluate a previously parsed expression.
AVFilterContext * dst
dest filter
void(* permute_coeffs)(float *v, int len)
static int init_volume(ShowCQTContext *s)
static double c_weighting(void *p, double f)
static enum AVSampleFormat sample_fmts[]
static void draw_axis_yuv(AVFrame *out, AVFrame *axis, const ColorFloat *c, int off)
static float calculate_gamma(float v, float g)
static void process_cqt(ShowCQTContext *s)
void(* draw_sono)(AVFrame *out, AVFrame *sono, int off, int idx)
#define av_malloc_array(a, b)
int ff_request_frame(AVFilterLink *link)
Request an input frame from the filter at the other end of the link.
const char * av_get_pix_fmt_name(enum AVPixelFormat pix_fmt)
Return the short name for a pixel format, NULL in case pix_fmt is unknown.
void av_fft_calc(FFTContext *s, FFTComplex *z)
Do a complex FFT with the parameters defined in av_fft_init().
AVPixelFormat
Pixel format.
static void draw_bar_rgb(AVFrame *out, const float *h, const float *rcp_h, const ColorFloat *c, int bar_h)
int nb_samples
number of audio samples (per channel) described by this frame
CGA/EGA/VGA ROM font data.
AVFilterFormats * out_formats
void(* draw_axis)(AVFrame *out, AVFrame *axis, const ColorFloat *c, int off)
Miscellaneous utilities which make use of the libavformat library.
simple arithmetic expression evaluator