annotate ffmpeg/libavfilter/gradfun.h @ 13:844d341cf643 tip

Back up before ISMIR
author Yading Song <yading.song@eecs.qmul.ac.uk>
date Thu, 31 Oct 2013 13:17:06 +0000
parents 6840f77b83aa
children
rev   line source
yading@10 1 /*
yading@10 2 * Copyright (c) 2010 Nolan Lum <nol888@gmail.com>
yading@10 3 * Copyright (c) 2009 Loren Merritt <lorenm@u.washignton.edu>
yading@10 4 *
yading@10 5 * This file is part of FFmpeg.
yading@10 6 *
yading@10 7 * FFmpeg is free software; you can redistribute it and/or
yading@10 8 * modify it under the terms of the GNU Lesser General Public
yading@10 9 * License as published by the Free Software Foundation; either
yading@10 10 * version 2.1 of the License, or (at your option) any later version.
yading@10 11 *
yading@10 12 * FFmpeg is distributed in the hope that it will be useful,
yading@10 13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
yading@10 14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
yading@10 15 * Lesser General Public License for more details.
yading@10 16 *
yading@10 17 * You should have received a copy of the GNU Lesser General Public
yading@10 18 * License along with FFmpeg; if not, write to the Free Software
yading@10 19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
yading@10 20 */
yading@10 21
yading@10 22 #ifndef AVFILTER_GRADFUN_H
yading@10 23 #define AVFILTER_GRADFUN_H
yading@10 24
yading@10 25 #include "avfilter.h"
yading@10 26
yading@10 27 /// Holds instance-specific information for gradfun.
yading@10 28 typedef struct GradFunContext {
yading@10 29 const AVClass *class;
yading@10 30 float strength;
yading@10 31 int thresh; ///< threshold for gradient algorithm
yading@10 32 int radius; ///< blur radius
yading@10 33 int chroma_w; ///< width of the chroma planes
yading@10 34 int chroma_h; ///< weight of the chroma planes
yading@10 35 int chroma_r; ///< blur radius for the chroma planes
yading@10 36 uint16_t *buf; ///< holds image data for blur algorithm passed into filter.
yading@10 37 /// DSP functions.
yading@10 38 void (*filter_line) (uint8_t *dst, const uint8_t *src, const uint16_t *dc, int width, int thresh, const uint16_t *dithers);
yading@10 39 void (*blur_line) (uint16_t *dc, uint16_t *buf, const uint16_t *buf1, const uint8_t *src, int src_linesize, int width);
yading@10 40 } GradFunContext;
yading@10 41
yading@10 42 void ff_gradfun_init_x86(GradFunContext *gf);
yading@10 43
yading@10 44 void ff_gradfun_filter_line_c(uint8_t *dst, const uint8_t *src, const uint16_t *dc, int width, int thresh, const uint16_t *dithers);
yading@10 45 void ff_gradfun_blur_line_c(uint16_t *dc, uint16_t *buf, const uint16_t *buf1, const uint8_t *src, int src_linesize, int width);
yading@10 46
yading@10 47 #endif /* AVFILTER_GRADFUN_H */