FFmpeg  4.0
Macros | Functions | Variables
mathops.h File Reference
#include <stdint.h>
#include "libavutil/common.h"
#include "libavutil/reverse.h"
#include "config.h"

Go to the source code of this file.

Macros

#define MAX_NEG_CROP   1024
 
#define MUL64(a, b)   ((int64_t)(a) * (int64_t)(b))
 
#define MULL(a, b, s)   (MUL64(a, b) >> (s))
 
#define MAC64(d, a, b)   ((d) += MUL64(a, b))
 
#define MLS64(d, a, b)   ((d) -= MUL64(a, b))
 
#define MAC16(rt, ra, rb)   rt += (ra) * (rb)
 
#define MUL16(ra, rb)   ((ra) * (rb))
 
#define MLS16(rt, ra, rb)   ((rt) -= (ra) * (rb))
 
#define mid_pred   mid_pred
 
#define median4   median4
 
#define COPY3_IF_LT(x, y, a, b, c, d)
 
#define MASK_ABS(mask, level)
 
#define NEG_SSR32(a, s)   ((( int32_t)(a))>>(32-(s)))
 
#define NEG_USR32(a, s)   (((uint32_t)(a))>>(32-(s)))
 
#define PACK_2U8(a, b)   (((b) << 8) | (a))
 
#define PACK_4U8(a, b, c, d)   (((d) << 24) | ((c) << 16) | ((b) << 8) | (a))
 
#define PACK_2U16(a, b)   (((b) << 16) | (a))
 
#define PACK_2S8(a, b)   PACK_2U8((a)&255, (b)&255)
 
#define PACK_4S8(a, b, c, d)   PACK_4U8((a)&255, (b)&255, (c)&255, (d)&255)
 
#define PACK_2S16(a, b)   PACK_2U16((a)&0xffff, (b)&0xffff)
 
#define FASTDIV(a, b)   ((uint32_t)((((uint64_t)a) * ff_inverse[b]) >> 32))
 
#define ff_sqrt   ff_sqrt
 

Functions

static av_always_inline int MULH (int a, int b)
 
static av_always_inline unsigned UMULH (unsigned a, unsigned b)
 
static av_const int mid_pred (int a, int b, int c)
 
static av_const int median4 (int a, int b, int c, int d)
 
static av_const int sign_extend (int val, unsigned bits)
 
static av_const unsigned zero_extend (unsigned val, unsigned bits)
 
static av_const unsigned int ff_sqrt (unsigned int a)
 
static av_const float ff_sqrf (float a)
 
static int8_t ff_u8_to_s8 (uint8_t a)
 
static av_always_inline uint32_t bitswap_32 (uint32_t x)
 

Variables

const uint32_t ff_inverse [257]
 
const uint8_t ff_sqrt_tab [256]
 
const uint8_t ff_crop_tab [256+2 *MAX_NEG_CROP]
 
const uint8_t ff_zigzag_direct [64]
 
const uint8_t ff_zigzag_scan [16+1]
 

Macro Definition Documentation

◆ MAX_NEG_CROP

#define MAX_NEG_CROP   1024

◆ MUL64

#define MUL64 (   a,
  b 
)    ((int64_t)(a) * (int64_t)(b))

◆ MULL

#define MULL (   a,
  b,
  s 
)    (MUL64(a, b) >> (s))

Definition at line 58 of file mathops.h.

Referenced by long_term_filter(), lsp2poly(), and silk_is_lpc_stable().

◆ MAC64

#define MAC64 (   d,
  a,
  b 
)    ((d) += MUL64(a, b))

Definition at line 74 of file mathops.h.

Referenced by ac3_sum_square_butterfly_int32_c().

◆ MLS64

#define MLS64 (   d,
  a,
  b 
)    ((d) -= MUL64(a, b))

Definition at line 78 of file mathops.h.

◆ MAC16

#define MAC16 (   rt,
  ra,
  rb 
)    rt += (ra) * (rb)

Definition at line 83 of file mathops.h.

Referenced by g722_apply_qmf().

◆ MUL16

#define MUL16 (   ra,
  rb 
)    ((ra) * (rb))

◆ MLS16

#define MLS16 (   rt,
  ra,
  rb 
)    ((rt) -= (ra) * (rb))

Definition at line 92 of file mathops.h.

◆ mid_pred

#define mid_pred   mid_pred

◆ median4

#define median4   median4

Definition at line 116 of file mathops.h.

Referenced by get_chroma_mv(), and get_luma_mv().

◆ COPY3_IF_LT

#define COPY3_IF_LT (   x,
  y,
  a,
  b,
  c,
 
)
Value:
if ((y) < (x)) {\
(x) = (y);\
(a) = (b);\
(c) = (d);\
}
const char * b
Definition: vf_curves.c:113
static double c[64]

Definition at line 146 of file mathops.h.

◆ MASK_ABS

#define MASK_ABS (   mask,
  level 
)
Value:
do { \
mask = level >> 31; \
level = (level ^ mask) - mask; \
} while (0)
static const uint16_t mask[17]
Definition: lzw.c:38
uint8_t level
Definition: svq3.c:207

Definition at line 155 of file mathops.h.

Referenced by dnxhd_init_vlc(), and mpeg1_encode_block().

◆ NEG_SSR32

#define NEG_SSR32 (   a,
  s 
)    ((( int32_t)(a))>>(32-(s)))

Definition at line 162 of file mathops.h.

◆ NEG_USR32

#define NEG_USR32 (   a,
  s 
)    (((uint32_t)(a))>>(32-(s)))

◆ PACK_2U8

#define PACK_2U8 (   a,
  b 
)    (((b) << 8) | (a))

Definition at line 181 of file mathops.h.

◆ PACK_4U8

#define PACK_4U8 (   a,
  b,
  c,
 
)    (((d) << 24) | ((c) << 16) | ((b) << 8) | (a))

Definition at line 184 of file mathops.h.

Referenced by pred4x4_vertical_vp8_c().

◆ PACK_2U16

#define PACK_2U16 (   a,
  b 
)    (((b) << 16) | (a))

Definition at line 187 of file mathops.h.

◆ PACK_2S8

#define PACK_2S8 (   a,
  b 
)    PACK_2U8((a)&255, (b)&255)

Definition at line 192 of file mathops.h.

◆ PACK_4S8

#define PACK_4S8 (   a,
  b,
  c,
 
)    PACK_4U8((a)&255, (b)&255, (c)&255, (d)&255)

Definition at line 195 of file mathops.h.

◆ PACK_2S16

#define PACK_2S16 (   a,
  b 
)    PACK_2U16((a)&0xffff, (b)&0xffff)

Definition at line 198 of file mathops.h.

◆ FASTDIV

#define FASTDIV (   a,
  b 
)    ((uint32_t)((((uint64_t)a) * ff_inverse[b]) >> 32))

◆ ff_sqrt

#define ff_sqrt   ff_sqrt

Function Documentation

◆ MULH()

static av_always_inline int MULH ( int  a,
int  b 
)
static

Definition at line 62 of file mathops.h.

◆ UMULH()

static av_always_inline unsigned UMULH ( unsigned  a,
unsigned  b 
)
static

Definition at line 68 of file mathops.h.

Referenced by pRNG().

◆ mid_pred()

static av_const int mid_pred ( int  a,
int  b,
int  c 
)
inlinestatic

Definition at line 98 of file mathops.h.

◆ median4()

static av_const int median4 ( int  a,
int  b,
int  c,
int  d 
)
inlinestatic

Definition at line 117 of file mathops.h.

◆ sign_extend()

static av_const int sign_extend ( int  val,
unsigned  bits 
)
inlinestatic

◆ zero_extend()

static av_const unsigned zero_extend ( unsigned  val,
unsigned  bits 
)
inlinestatic

Definition at line 139 of file mathops.h.

Referenced by get_xbits_le().

◆ ff_sqrt()

static av_const unsigned int ff_sqrt ( unsigned int  a)
inlinestatic

Definition at line 207 of file mathops.h.

◆ ff_sqrf()

static av_const float ff_sqrf ( float  a)
inlinestatic

Definition at line 228 of file mathops.h.

Referenced by search_for_quantizers_twoloop().

◆ ff_u8_to_s8()

static int8_t ff_u8_to_s8 ( uint8_t  a)
inlinestatic

Definition at line 233 of file mathops.h.

Referenced by color_transform_delta().

◆ bitswap_32()

static av_always_inline uint32_t bitswap_32 ( uint32_t  x)
static

Definition at line 243 of file mathops.h.

Referenced by build_table(), and reverse().

Variable Documentation

◆ ff_inverse

const uint32_t ff_inverse[257]

Definition at line 27 of file mathtables.c.

Referenced by dct_quantize(), ff_msmpeg4_pred_dc(), and setup_classifs().

◆ ff_sqrt_tab

const uint8_t ff_sqrt_tab[256]

Definition at line 63 of file mathtables.c.

Referenced by ff_sqrt().

◆ ff_crop_tab

const uint8_t ff_crop_tab[256+2 *MAX_NEG_CROP]

Definition at line 77 of file mathtables.c.

◆ ff_zigzag_direct

const uint8_t ff_zigzag_direct[64]

◆ ff_zigzag_scan

const uint8_t ff_zigzag_scan[16+1]