Coverage Report

Created: 2025-11-16 07:20

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/libvpx/vp8/common/quant_common.c
Line
Count
Source
1
/*
2
 *  Copyright (c) 2010 The WebM project authors. All Rights Reserved.
3
 *
4
 *  Use of this source code is governed by a BSD-style license
5
 *  that can be found in the LICENSE file in the root of the source
6
 *  tree. An additional intellectual property rights grant can be found
7
 *  in the file PATENTS.  All contributing project authors may
8
 *  be found in the AUTHORS file in the root of the source tree.
9
 */
10
11
#include "quant_common.h"
12
13
static const int dc_qlookup[QINDEX_RANGE] = {
14
  4,   5,   6,   7,   8,   9,   10,  10,  11,  12,  13,  14,  15,  16,  17,
15
  17,  18,  19,  20,  20,  21,  21,  22,  22,  23,  23,  24,  25,  25,  26,
16
  27,  28,  29,  30,  31,  32,  33,  34,  35,  36,  37,  37,  38,  39,  40,
17
  41,  42,  43,  44,  45,  46,  46,  47,  48,  49,  50,  51,  52,  53,  54,
18
  55,  56,  57,  58,  59,  60,  61,  62,  63,  64,  65,  66,  67,  68,  69,
19
  70,  71,  72,  73,  74,  75,  76,  76,  77,  78,  79,  80,  81,  82,  83,
20
  84,  85,  86,  87,  88,  89,  91,  93,  95,  96,  98,  100, 101, 102, 104,
21
  106, 108, 110, 112, 114, 116, 118, 122, 124, 126, 128, 130, 132, 134, 136,
22
  138, 140, 143, 145, 148, 151, 154, 157,
23
};
24
25
static const int ac_qlookup[QINDEX_RANGE] = {
26
  4,   5,   6,   7,   8,   9,   10,  11,  12,  13,  14,  15,  16,  17,  18,
27
  19,  20,  21,  22,  23,  24,  25,  26,  27,  28,  29,  30,  31,  32,  33,
28
  34,  35,  36,  37,  38,  39,  40,  41,  42,  43,  44,  45,  46,  47,  48,
29
  49,  50,  51,  52,  53,  54,  55,  56,  57,  58,  60,  62,  64,  66,  68,
30
  70,  72,  74,  76,  78,  80,  82,  84,  86,  88,  90,  92,  94,  96,  98,
31
  100, 102, 104, 106, 108, 110, 112, 114, 116, 119, 122, 125, 128, 131, 134,
32
  137, 140, 143, 146, 149, 152, 155, 158, 161, 164, 167, 170, 173, 177, 181,
33
  185, 189, 193, 197, 201, 205, 209, 213, 217, 221, 225, 229, 234, 239, 245,
34
  249, 254, 259, 264, 269, 274, 279, 284,
35
};
36
37
10.1M
int vp8_dc_quant(int QIndex, int Delta) {
38
10.1M
  int retval;
39
40
10.1M
  QIndex = QIndex + Delta;
41
42
10.1M
  if (QIndex > 127) {
43
124k
    QIndex = 127;
44
10.0M
  } else if (QIndex < 0) {
45
40.7k
    QIndex = 0;
46
40.7k
  }
47
48
10.1M
  retval = dc_qlookup[QIndex];
49
10.1M
  return retval;
50
10.1M
}
51
52
9.20M
int vp8_dc2quant(int QIndex, int Delta) {
53
9.20M
  int retval;
54
55
9.20M
  QIndex = QIndex + Delta;
56
57
9.20M
  if (QIndex > 127) {
58
78.0k
    QIndex = 127;
59
9.12M
  } else if (QIndex < 0) {
60
262k
    QIndex = 0;
61
262k
  }
62
63
9.20M
  retval = dc_qlookup[QIndex] * 2;
64
9.20M
  return retval;
65
9.20M
}
66
9.20M
int vp8_dc_uv_quant(int QIndex, int Delta) {
67
9.20M
  int retval;
68
69
9.20M
  QIndex = QIndex + Delta;
70
71
9.20M
  if (QIndex > 127) {
72
228k
    QIndex = 127;
73
8.97M
  } else if (QIndex < 0) {
74
80.4k
    QIndex = 0;
75
80.4k
  }
76
77
9.20M
  retval = dc_qlookup[QIndex];
78
79
9.20M
  if (retval > 132) retval = 132;
80
81
9.20M
  return retval;
82
9.20M
}
83
84
9.20M
int vp8_ac_yquant(int QIndex) {
85
9.20M
  int retval;
86
87
9.20M
  if (QIndex > 127) {
88
0
    QIndex = 127;
89
9.20M
  } else if (QIndex < 0) {
90
0
    QIndex = 0;
91
0
  }
92
93
9.20M
  retval = ac_qlookup[QIndex];
94
9.20M
  return retval;
95
9.20M
}
96
97
9.20M
int vp8_ac2quant(int QIndex, int Delta) {
98
9.20M
  int retval;
99
100
9.20M
  QIndex = QIndex + Delta;
101
102
9.20M
  if (QIndex > 127) {
103
25.7k
    QIndex = 127;
104
9.17M
  } else if (QIndex < 0) {
105
153k
    QIndex = 0;
106
153k
  }
107
108
  /* For all x in [0..284], x*155/100 is bitwise equal to (x*101581) >> 16.
109
   * The smallest precision for that is '(x*6349) >> 12' but 16 is a good
110
   * word size. */
111
9.20M
  retval = (ac_qlookup[QIndex] * 101581) >> 16;
112
113
9.20M
  if (retval < 8) retval = 8;
114
115
9.20M
  return retval;
116
9.20M
}
117
9.20M
int vp8_ac_uv_quant(int QIndex, int Delta) {
118
9.20M
  int retval;
119
120
9.20M
  QIndex = QIndex + Delta;
121
122
9.20M
  if (QIndex > 127) {
123
370k
    QIndex = 127;
124
8.83M
  } else if (QIndex < 0) {
125
44.8k
    QIndex = 0;
126
44.8k
  }
127
128
9.20M
  retval = ac_qlookup[QIndex];
129
9.20M
  return retval;
130
9.20M
}