Line | Branch | Exec | Source |
---|---|---|---|
1 | /* | ||
2 | * Copyright (c) 2012 Andrew D'Addesio | ||
3 | * Copyright (c) 2013-2014 Mozilla Corporation | ||
4 | * | ||
5 | * This file is part of FFmpeg. | ||
6 | * | ||
7 | * FFmpeg is free software; you can redistribute it and/or | ||
8 | * modify it under the terms of the GNU Lesser General Public | ||
9 | * License as published by the Free Software Foundation; either | ||
10 | * version 2.1 of the License, or (at your option) any later version. | ||
11 | * | ||
12 | * FFmpeg is distributed in the hope that it will be useful, | ||
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | ||
15 | * Lesser General Public License for more details. | ||
16 | * | ||
17 | * You should have received a copy of the GNU Lesser General Public | ||
18 | * License along with FFmpeg; if not, write to the Free Software | ||
19 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA | ||
20 | */ | ||
21 | |||
22 | #include <stdint.h> | ||
23 | |||
24 | #include "celt.h" | ||
25 | #include "pvq.h" | ||
26 | #include "tab.h" | ||
27 | |||
28 | 29959 | void ff_celt_quant_bands(CeltFrame *f, OpusRangeCoder *rc) | |
29 | { | ||
30 | float lowband_scratch[8 * 22]; | ||
31 | float norm1[2 * 8 * 100]; | ||
32 | 29959 | float *norm2 = norm1 + 8 * 100; | |
33 | |||
34 | 29959 | int totalbits = (f->framebits << 3) - f->anticollapse_needed; | |
35 | |||
36 | 29959 | int update_lowband = 1; | |
37 | 29959 | int lowband_offset = 0; | |
38 | |||
39 | int i, j; | ||
40 | |||
41 |
2/2✓ Branch 0 taken 508886 times.
✓ Branch 1 taken 29959 times.
|
538845 | for (i = f->start_band; i < f->end_band; i++) { |
42 | 508886 | uint32_t cm[2] = { (1 << f->blocks) - 1, (1 << f->blocks) - 1 }; | |
43 | 508886 | int band_offset = ff_celt_freq_bands[i] << f->size; | |
44 | 508886 | int band_size = ff_celt_freq_range[i] << f->size; | |
45 | 508886 | float *X = f->block[0].coeffs + band_offset; | |
46 |
2/2✓ Branch 0 taken 342205 times.
✓ Branch 1 taken 166681 times.
|
508886 | float *Y = (f->channels == 2) ? f->block[1].coeffs + band_offset : NULL; |
47 | float *norm_loc1, *norm_loc2; | ||
48 | |||
49 | 508886 | int consumed = opus_rc_tell_frac(rc); | |
50 | 508886 | int effective_lowband = -1; | |
51 | 508886 | int b = 0; | |
52 | |||
53 | /* Compute how many bits we want to allocate to this band */ | ||
54 |
2/2✓ Branch 0 taken 478927 times.
✓ Branch 1 taken 29959 times.
|
508886 | if (i != f->start_band) |
55 | 478927 | f->remaining -= consumed; | |
56 | 508886 | f->remaining2 = totalbits - consumed - 1; | |
57 |
2/2✓ Branch 0 taken 457920 times.
✓ Branch 1 taken 50966 times.
|
508886 | if (i <= f->coded_bands - 1) { |
58 | 457920 | int curr_balance = f->remaining / FFMIN(3, f->coded_bands-i); | |
59 |
2/2✓ Branch 0 taken 457912 times.
✓ Branch 1 taken 8 times.
|
457920 | b = av_clip_uintp2(FFMIN(f->remaining2 + 1, f->pulses[i] + curr_balance), 14); |
60 | } | ||
61 | |||
62 |
2/2✓ Branch 0 taken 34948 times.
✓ Branch 1 taken 473938 times.
|
508886 | if ((ff_celt_freq_bands[i] - ff_celt_freq_range[i] >= ff_celt_freq_bands[f->start_band] || |
63 |
6/6✓ Branch 0 taken 4989 times.
✓ Branch 1 taken 29959 times.
✓ Branch 2 taken 97835 times.
✓ Branch 3 taken 381092 times.
✓ Branch 4 taken 6526 times.
✓ Branch 5 taken 91309 times.
|
508886 | i == f->start_band + 1) && (update_lowband || lowband_offset == 0)) |
64 | 387618 | lowband_offset = i; | |
65 | |||
66 |
2/2✓ Branch 0 taken 29959 times.
✓ Branch 1 taken 478927 times.
|
508886 | if (i == f->start_band + 1) { |
67 | /* Special Hybrid Folding (RFC 8251 section 9). Copy the first band into | ||
68 | the second to ensure the second band never has to use the LCG. */ | ||
69 | 29959 | int count = (ff_celt_freq_range[i] - ff_celt_freq_range[i-1]) << f->size; | |
70 | |||
71 | 29959 | memcpy(&norm1[band_offset], &norm1[band_offset - count], count * sizeof(float)); | |
72 | |||
73 |
2/2✓ Branch 0 taken 18804 times.
✓ Branch 1 taken 11155 times.
|
29959 | if (f->channels == 2) |
74 | 18804 | memcpy(&norm2[band_offset], &norm2[band_offset - count], count * sizeof(float)); | |
75 | } | ||
76 | |||
77 | /* Get a conservative estimate of the collapse_mask's for the bands we're | ||
78 | going to be folding from. */ | ||
79 |
4/4✓ Branch 0 taken 478927 times.
✓ Branch 1 taken 29959 times.
✓ Branch 2 taken 71137 times.
✓ Branch 3 taken 407790 times.
|
508886 | if (lowband_offset != 0 && (f->spread != CELT_SPREAD_AGGRESSIVE || |
80 |
3/4✓ Branch 0 taken 71137 times.
✗ Branch 1 not taken.
✓ Branch 2 taken 11835 times.
✓ Branch 3 taken 59302 times.
|
71137 | f->blocks > 1 || f->tf_change[i] < 0)) { |
81 | int foldstart, foldend; | ||
82 | |||
83 | /* This ensures we never repeat spectral content within one band */ | ||
84 | 419625 | effective_lowband = FFMAX(ff_celt_freq_bands[f->start_band], | |
85 | ff_celt_freq_bands[lowband_offset] - ff_celt_freq_range[i]); | ||
86 | 419625 | foldstart = lowband_offset; | |
87 |
2/2✓ Branch 0 taken 198000 times.
✓ Branch 1 taken 419625 times.
|
617625 | while (ff_celt_freq_bands[--foldstart] > effective_lowband); |
88 | 419625 | foldend = lowband_offset - 1; | |
89 |
4/4✓ Branch 0 taken 104596 times.
✓ Branch 1 taken 344763 times.
✓ Branch 2 taken 29734 times.
✓ Branch 3 taken 74862 times.
|
449359 | while (++foldend < i && ff_celt_freq_bands[foldend] < effective_lowband + ff_celt_freq_range[i]); |
90 | |||
91 | 419625 | cm[0] = cm[1] = 0; | |
92 |
2/2✓ Branch 0 taken 647359 times.
✓ Branch 1 taken 419625 times.
|
1066984 | for (j = foldstart; j < foldend; j++) { |
93 | 647359 | cm[0] |= f->block[0].collapse_masks[j]; | |
94 | 647359 | cm[1] |= f->block[f->channels - 1].collapse_masks[j]; | |
95 | } | ||
96 | } | ||
97 | |||
98 |
4/4✓ Branch 0 taken 36886 times.
✓ Branch 1 taken 472000 times.
✓ Branch 2 taken 1677 times.
✓ Branch 3 taken 35209 times.
|
508886 | if (f->dual_stereo && i == f->intensity_stereo) { |
99 | /* Switch off dual stereo to do intensity */ | ||
100 | 1677 | f->dual_stereo = 0; | |
101 |
2/2✓ Branch 0 taken 572238 times.
✓ Branch 1 taken 1677 times.
|
573915 | for (j = ff_celt_freq_bands[f->start_band] << f->size; j < band_offset; j++) |
102 | 572238 | norm1[j] = (norm1[j] + norm2[j]) / 2; | |
103 | } | ||
104 | |||
105 |
2/2✓ Branch 0 taken 419625 times.
✓ Branch 1 taken 89261 times.
|
508886 | norm_loc1 = effective_lowband != -1 ? norm1 + (effective_lowband << f->size) : NULL; |
106 |
2/2✓ Branch 0 taken 419625 times.
✓ Branch 1 taken 89261 times.
|
508886 | norm_loc2 = effective_lowband != -1 ? norm2 + (effective_lowband << f->size) : NULL; |
107 | |||
108 |
2/2✓ Branch 0 taken 35209 times.
✓ Branch 1 taken 473677 times.
|
508886 | if (f->dual_stereo) { |
109 | 70418 | cm[0] = f->pvq->quant_band(f->pvq, f, rc, i, X, NULL, band_size, b >> 1, | |
110 | 35209 | f->blocks, norm_loc1, f->size, | |
111 | 35209 | norm1 + band_offset, 0, 1.0f, | |
112 | 35209 | lowband_scratch, cm[0]); | |
113 | |||
114 | 35209 | cm[1] = f->pvq->quant_band(f->pvq, f, rc, i, Y, NULL, band_size, b >> 1, | |
115 | 35209 | f->blocks, norm_loc2, f->size, | |
116 | 35209 | norm2 + band_offset, 0, 1.0f, | |
117 | 35209 | lowband_scratch, cm[1]); | |
118 | } else { | ||
119 | 947354 | cm[0] = f->pvq->quant_band(f->pvq, f, rc, i, X, Y, band_size, b >> 0, | |
120 | 473677 | f->blocks, norm_loc1, f->size, | |
121 | 473677 | norm1 + band_offset, 0, 1.0f, | |
122 | 473677 | lowband_scratch, cm[0] | cm[1]); | |
123 | 473677 | cm[1] = cm[0]; | |
124 | } | ||
125 | |||
126 | 508886 | f->block[0].collapse_masks[i] = (uint8_t)cm[0]; | |
127 | 508886 | f->block[f->channels - 1].collapse_masks[i] = (uint8_t)cm[1]; | |
128 | 508886 | f->remaining += f->pulses[i] + consumed; | |
129 | |||
130 | /* Update the folding position only as long as we have 1 bit/sample depth */ | ||
131 | 508886 | update_lowband = (b > band_size << 3); | |
132 | } | ||
133 | 29959 | } | |
134 | |||
135 | #define NORMC(bits) ((bits) << (f->channels - 1) << f->size >> 2) | ||
136 | |||
137 | 29959 | void ff_celt_bitalloc(CeltFrame *f, OpusRangeCoder *rc, int encode) | |
138 | { | ||
139 | int i, j, low, high, total, done, bandbits, remaining, tbits_8ths; | ||
140 | 29959 | int skip_startband = f->start_band; | |
141 | 29959 | int skip_bit = 0; | |
142 | 29959 | int intensitystereo_bit = 0; | |
143 | 29959 | int dualstereo_bit = 0; | |
144 | 29959 | int dynalloc = 6; | |
145 | 29959 | int extrabits = 0; | |
146 | |||
147 | 29959 | int boost[CELT_MAX_BANDS] = { 0 }; | |
148 | int trim_offset[CELT_MAX_BANDS]; | ||
149 | int threshold[CELT_MAX_BANDS]; | ||
150 | int bits1[CELT_MAX_BANDS]; | ||
151 | int bits2[CELT_MAX_BANDS]; | ||
152 | |||
153 | /* Spread */ | ||
154 |
2/2✓ Branch 1 taken 29812 times.
✓ Branch 2 taken 147 times.
|
29959 | if (opus_rc_tell(rc) + 4 <= f->framebits) { |
155 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 29812 times.
|
29812 | if (encode) |
156 | ✗ | ff_opus_rc_enc_cdf(rc, f->spread, ff_celt_model_spread); | |
157 | else | ||
158 | 29812 | f->spread = ff_opus_rc_dec_cdf(rc, ff_celt_model_spread); | |
159 | } else { | ||
160 | 147 | f->spread = CELT_SPREAD_NORMAL; | |
161 | } | ||
162 | |||
163 | /* Initialize static allocation caps */ | ||
164 |
2/2✓ Branch 0 taken 629139 times.
✓ Branch 1 taken 29959 times.
|
659098 | for (i = 0; i < CELT_MAX_BANDS; i++) |
165 | 629139 | f->caps[i] = NORMC((ff_celt_static_caps[f->size][f->channels - 1][i] + 64) * ff_celt_freq_range[i]); | |
166 | |||
167 | /* Band boosts */ | ||
168 | 29959 | tbits_8ths = f->framebits << 3; | |
169 |
2/2✓ Branch 0 taken 508886 times.
✓ Branch 1 taken 29959 times.
|
538845 | for (i = f->start_band; i < f->end_band; i++) { |
170 | 508886 | int quanta = ff_celt_freq_range[i] << (f->channels - 1) << f->size; | |
171 | 508886 | int b_dynalloc = dynalloc; | |
172 | 508886 | int boost_amount = f->alloc_boost[i]; | |
173 | 508886 | quanta = FFMIN(quanta << 3, FFMAX(6 << 3, quanta)); | |
174 | |||
175 |
3/4✓ Branch 1 taken 522661 times.
✓ Branch 2 taken 2763 times.
✓ Branch 3 taken 522661 times.
✗ Branch 4 not taken.
|
525424 | while (opus_rc_tell_frac(rc) + (b_dynalloc << 3) < tbits_8ths && boost[i] < f->caps[i]) { |
176 | int is_boost; | ||
177 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 522661 times.
|
522661 | if (encode) { |
178 | ✗ | is_boost = boost_amount--; | |
179 | ✗ | ff_opus_rc_enc_log(rc, is_boost, b_dynalloc); | |
180 | } else { | ||
181 | 522661 | is_boost = ff_opus_rc_dec_log(rc, b_dynalloc); | |
182 | } | ||
183 | |||
184 |
2/2✓ Branch 0 taken 506123 times.
✓ Branch 1 taken 16538 times.
|
522661 | if (!is_boost) |
185 | 506123 | break; | |
186 | |||
187 | 16538 | boost[i] += quanta; | |
188 | 16538 | tbits_8ths -= quanta; | |
189 | |||
190 | 16538 | b_dynalloc = 1; | |
191 | } | ||
192 | |||
193 |
2/2✓ Branch 0 taken 12578 times.
✓ Branch 1 taken 496308 times.
|
508886 | if (boost[i]) |
194 | 12578 | dynalloc = FFMAX(dynalloc - 1, 2); | |
195 | } | ||
196 | |||
197 | /* Allocation trim */ | ||
198 |
1/2✓ Branch 0 taken 29959 times.
✗ Branch 1 not taken.
|
29959 | if (!encode) |
199 | 29959 | f->alloc_trim = 5; | |
200 |
2/2✓ Branch 1 taken 29808 times.
✓ Branch 2 taken 151 times.
|
29959 | if (opus_rc_tell_frac(rc) + (6 << 3) <= tbits_8ths) |
201 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 29808 times.
|
29808 | if (encode) |
202 | ✗ | ff_opus_rc_enc_cdf(rc, f->alloc_trim, ff_celt_model_alloc_trim); | |
203 | else | ||
204 | 29808 | f->alloc_trim = ff_opus_rc_dec_cdf(rc, ff_celt_model_alloc_trim); | |
205 | |||
206 | /* Anti-collapse bit reservation */ | ||
207 | 29959 | tbits_8ths = (f->framebits << 3) - opus_rc_tell_frac(rc) - 1; | |
208 | 29959 | f->anticollapse_needed = 0; | |
209 |
6/6✓ Branch 0 taken 4044 times.
✓ Branch 1 taken 25915 times.
✓ Branch 2 taken 3161 times.
✓ Branch 3 taken 883 times.
✓ Branch 4 taken 3158 times.
✓ Branch 5 taken 3 times.
|
29959 | if (f->transient && f->size >= 2 && tbits_8ths >= ((f->size + 2) << 3)) |
210 | 3158 | f->anticollapse_needed = 1 << 3; | |
211 | 29959 | tbits_8ths -= f->anticollapse_needed; | |
212 | |||
213 | /* Band skip bit reservation */ | ||
214 |
2/2✓ Branch 0 taken 29814 times.
✓ Branch 1 taken 145 times.
|
29959 | if (tbits_8ths >= 1 << 3) |
215 | 29814 | skip_bit = 1 << 3; | |
216 | 29959 | tbits_8ths -= skip_bit; | |
217 | |||
218 | /* Intensity/dual stereo bit reservation */ | ||
219 |
2/2✓ Branch 0 taken 18804 times.
✓ Branch 1 taken 11155 times.
|
29959 | if (f->channels == 2) { |
220 | 18804 | intensitystereo_bit = ff_celt_log2_frac[f->end_band - f->start_band]; | |
221 |
2/2✓ Branch 0 taken 18726 times.
✓ Branch 1 taken 78 times.
|
18804 | if (intensitystereo_bit <= tbits_8ths) { |
222 | 18726 | tbits_8ths -= intensitystereo_bit; | |
223 |
2/2✓ Branch 0 taken 18722 times.
✓ Branch 1 taken 4 times.
|
18726 | if (tbits_8ths >= 1 << 3) { |
224 | 18722 | dualstereo_bit = 1 << 3; | |
225 | 18722 | tbits_8ths -= 1 << 3; | |
226 | } | ||
227 | } else { | ||
228 | 78 | intensitystereo_bit = 0; | |
229 | } | ||
230 | } | ||
231 | |||
232 | /* Trim offsets */ | ||
233 |
2/2✓ Branch 0 taken 508886 times.
✓ Branch 1 taken 29959 times.
|
538845 | for (i = f->start_band; i < f->end_band; i++) { |
234 | 508886 | int trim = f->alloc_trim - 5 - f->size; | |
235 | 508886 | int band = ff_celt_freq_range[i] * (f->end_band - i - 1); | |
236 | 508886 | int duration = f->size + 3; | |
237 | 508886 | int scale = duration + f->channels - 1; | |
238 | |||
239 | /* PVQ minimum allocation threshold, below this value the band is | ||
240 | * skipped */ | ||
241 | 508886 | threshold[i] = FFMAX(3 * ff_celt_freq_range[i] << duration >> 4, | |
242 | f->channels << 3); | ||
243 | |||
244 | 508886 | trim_offset[i] = trim * (band << scale) >> 6; | |
245 | |||
246 |
2/2✓ Branch 0 taken 109648 times.
✓ Branch 1 taken 399238 times.
|
508886 | if (ff_celt_freq_range[i] << f->size == 1) |
247 | 109648 | trim_offset[i] -= f->channels << 3; | |
248 | } | ||
249 | |||
250 | /* Bisection */ | ||
251 | 29959 | low = 1; | |
252 | 29959 | high = CELT_VECTORS - 1; | |
253 |
2/2✓ Branch 0 taken 111879 times.
✓ Branch 1 taken 29959 times.
|
141838 | while (low <= high) { |
254 | 111879 | int center = (low + high) >> 1; | |
255 | 111879 | done = total = 0; | |
256 | |||
257 |
2/2✓ Branch 0 taken 1904500 times.
✓ Branch 1 taken 111879 times.
|
2016379 | for (i = f->end_band - 1; i >= f->start_band; i--) { |
258 | 1904500 | bandbits = NORMC(ff_celt_freq_range[i] * ff_celt_static_alloc[center][i]); | |
259 | |||
260 |
2/2✓ Branch 0 taken 1814336 times.
✓ Branch 1 taken 90164 times.
|
1904500 | if (bandbits) |
261 | 1814336 | bandbits = FFMAX(bandbits + trim_offset[i], 0); | |
262 | 1904500 | bandbits += boost[i]; | |
263 | |||
264 |
4/4✓ Branch 0 taken 171772 times.
✓ Branch 1 taken 1732728 times.
✓ Branch 2 taken 21091 times.
✓ Branch 3 taken 150681 times.
|
1904500 | if (bandbits >= threshold[i] || done) { |
265 | 1753819 | done = 1; | |
266 | 1753819 | total += FFMIN(bandbits, f->caps[i]); | |
267 |
2/2✓ Branch 0 taken 31590 times.
✓ Branch 1 taken 119091 times.
|
150681 | } else if (bandbits >= f->channels << 3) { |
268 | 31590 | total += f->channels << 3; | |
269 | } | ||
270 | } | ||
271 | |||
272 |
2/2✓ Branch 0 taken 39998 times.
✓ Branch 1 taken 71881 times.
|
111879 | if (total > tbits_8ths) |
273 | 39998 | high = center - 1; | |
274 | else | ||
275 | 71881 | low = center + 1; | |
276 | } | ||
277 | 29959 | high = low--; | |
278 | |||
279 | /* Bisection */ | ||
280 |
2/2✓ Branch 0 taken 508886 times.
✓ Branch 1 taken 29959 times.
|
538845 | for (i = f->start_band; i < f->end_band; i++) { |
281 | 508886 | bits1[i] = NORMC(ff_celt_freq_range[i] * ff_celt_static_alloc[low][i]); | |
282 |
2/2✓ Branch 0 taken 37784 times.
✓ Branch 1 taken 471102 times.
|
508886 | bits2[i] = high >= CELT_VECTORS ? f->caps[i] : |
283 | 471102 | NORMC(ff_celt_freq_range[i] * ff_celt_static_alloc[high][i]); | |
284 | |||
285 |
2/2✓ Branch 0 taken 465550 times.
✓ Branch 1 taken 43336 times.
|
508886 | if (bits1[i]) |
286 | 465550 | bits1[i] = FFMAX(bits1[i] + trim_offset[i], 0); | |
287 |
2/2✓ Branch 0 taken 496898 times.
✓ Branch 1 taken 11988 times.
|
508886 | if (bits2[i]) |
288 | 496898 | bits2[i] = FFMAX(bits2[i] + trim_offset[i], 0); | |
289 | |||
290 |
2/2✓ Branch 0 taken 486296 times.
✓ Branch 1 taken 22590 times.
|
508886 | if (low) |
291 | 486296 | bits1[i] += boost[i]; | |
292 | 508886 | bits2[i] += boost[i]; | |
293 | |||
294 |
2/2✓ Branch 0 taken 12578 times.
✓ Branch 1 taken 496308 times.
|
508886 | if (boost[i]) |
295 | 12578 | skip_startband = i; | |
296 | 508886 | bits2[i] = FFMAX(bits2[i] - bits1[i], 0); | |
297 | } | ||
298 | |||
299 | /* Bisection */ | ||
300 | 29959 | low = 0; | |
301 | 29959 | high = 1 << CELT_ALLOC_STEPS; | |
302 |
2/2✓ Branch 0 taken 179754 times.
✓ Branch 1 taken 29959 times.
|
209713 | for (i = 0; i < CELT_ALLOC_STEPS; i++) { |
303 | 179754 | int center = (low + high) >> 1; | |
304 | 179754 | done = total = 0; | |
305 | |||
306 |
2/2✓ Branch 0 taken 3053316 times.
✓ Branch 1 taken 179754 times.
|
3233070 | for (j = f->end_band - 1; j >= f->start_band; j--) { |
307 | 3053316 | bandbits = bits1[j] + (center * bits2[j] >> CELT_ALLOC_STEPS); | |
308 | |||
309 |
4/4✓ Branch 0 taken 263385 times.
✓ Branch 1 taken 2789931 times.
✓ Branch 2 taken 51935 times.
✓ Branch 3 taken 211450 times.
|
3053316 | if (bandbits >= threshold[j] || done) { |
310 | 2841866 | done = 1; | |
311 | 2841866 | total += FFMIN(bandbits, f->caps[j]); | |
312 |
2/2✓ Branch 0 taken 52527 times.
✓ Branch 1 taken 158923 times.
|
211450 | } else if (bandbits >= f->channels << 3) |
313 | 52527 | total += f->channels << 3; | |
314 | } | ||
315 |
2/2✓ Branch 0 taken 85870 times.
✓ Branch 1 taken 93884 times.
|
179754 | if (total > tbits_8ths) |
316 | 85870 | high = center; | |
317 | else | ||
318 | 93884 | low = center; | |
319 | } | ||
320 | |||
321 | /* Bisection */ | ||
322 | 29959 | done = total = 0; | |
323 |
2/2✓ Branch 0 taken 508886 times.
✓ Branch 1 taken 29959 times.
|
538845 | for (i = f->end_band - 1; i >= f->start_band; i--) { |
324 | 508886 | bandbits = bits1[i] + (low * bits2[i] >> CELT_ALLOC_STEPS); | |
325 | |||
326 |
4/4✓ Branch 0 taken 45447 times.
✓ Branch 1 taken 463439 times.
✓ Branch 2 taken 9156 times.
✓ Branch 3 taken 36291 times.
|
508886 | if (bandbits >= threshold[i] || done) |
327 | 472595 | done = 1; | |
328 | else | ||
329 | 36291 | bandbits = (bandbits >= f->channels << 3) ? | |
330 |
2/2✓ Branch 0 taken 8853 times.
✓ Branch 1 taken 27438 times.
|
36291 | f->channels << 3 : 0; |
331 | |||
332 | 508886 | bandbits = FFMIN(bandbits, f->caps[i]); | |
333 | 508886 | f->pulses[i] = bandbits; | |
334 | 508886 | total += bandbits; | |
335 | } | ||
336 | |||
337 | /* Band skipping */ | ||
338 | 29959 | for (f->coded_bands = f->end_band; ; f->coded_bands--) { | |
339 | int allocation; | ||
340 | 80925 | j = f->coded_bands - 1; | |
341 | |||
342 |
2/2✓ Branch 0 taken 1661 times.
✓ Branch 1 taken 79264 times.
|
80925 | if (j == skip_startband) { |
343 | /* all remaining bands are not skipped */ | ||
344 | 1661 | tbits_8ths += skip_bit; | |
345 | 1661 | break; | |
346 | } | ||
347 | |||
348 | /* determine the number of bits available for coding "do not skip" markers */ | ||
349 | 79264 | remaining = tbits_8ths - total; | |
350 | 79264 | bandbits = remaining / (ff_celt_freq_bands[j+1] - ff_celt_freq_bands[f->start_band]); | |
351 | 79264 | remaining -= bandbits * (ff_celt_freq_bands[j+1] - ff_celt_freq_bands[f->start_band]); | |
352 | 79264 | allocation = f->pulses[j] + bandbits * ff_celt_freq_range[j]; | |
353 | 79264 | allocation += FFMAX(remaining - (ff_celt_freq_bands[j] - ff_celt_freq_bands[f->start_band]), 0); | |
354 | |||
355 | /* a "do not skip" marker is only coded if the allocation is | ||
356 | * above the chosen threshold */ | ||
357 |
2/2✓ Branch 0 taken 38190 times.
✓ Branch 1 taken 41074 times.
|
79264 | if (allocation >= FFMAX(threshold[j], (f->channels + 1) << 3)) { |
358 | int do_not_skip; | ||
359 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 38190 times.
|
38190 | if (encode) { |
360 | ✗ | do_not_skip = f->coded_bands <= f->skip_band_floor; | |
361 | ✗ | ff_opus_rc_enc_log(rc, do_not_skip, 1); | |
362 | } else { | ||
363 | 38190 | do_not_skip = ff_opus_rc_dec_log(rc, 1); | |
364 | } | ||
365 | |||
366 |
2/2✓ Branch 0 taken 28298 times.
✓ Branch 1 taken 9892 times.
|
38190 | if (do_not_skip) |
367 | 28298 | break; | |
368 | |||
369 | 9892 | total += 1 << 3; | |
370 | 9892 | allocation -= 1 << 3; | |
371 | } | ||
372 | |||
373 | /* the band is skipped, so reclaim its bits */ | ||
374 | 50966 | total -= f->pulses[j]; | |
375 |
2/2✓ Branch 0 taken 34531 times.
✓ Branch 1 taken 16435 times.
|
50966 | if (intensitystereo_bit) { |
376 | 34531 | total -= intensitystereo_bit; | |
377 | 34531 | intensitystereo_bit = ff_celt_log2_frac[j - f->start_band]; | |
378 | 34531 | total += intensitystereo_bit; | |
379 | } | ||
380 | |||
381 |
2/2✓ Branch 0 taken 21880 times.
✓ Branch 1 taken 29086 times.
|
50966 | total += f->pulses[j] = (allocation >= f->channels << 3) ? f->channels << 3 : 0; |
382 | } | ||
383 | |||
384 | /* IS start band */ | ||
385 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 29959 times.
|
29959 | if (encode) { |
386 | ✗ | if (intensitystereo_bit) { | |
387 | ✗ | f->intensity_stereo = FFMIN(f->intensity_stereo, f->coded_bands); | |
388 | ✗ | ff_opus_rc_enc_uint(rc, f->intensity_stereo, f->coded_bands + 1 - f->start_band); | |
389 | } | ||
390 | } else { | ||
391 | 29959 | f->intensity_stereo = f->dual_stereo = 0; | |
392 |
2/2✓ Branch 0 taken 18726 times.
✓ Branch 1 taken 11233 times.
|
29959 | if (intensitystereo_bit) |
393 | 18726 | f->intensity_stereo = f->start_band + ff_opus_rc_dec_uint(rc, f->coded_bands + 1 - f->start_band); | |
394 | } | ||
395 | |||
396 | /* DS flag */ | ||
397 |
2/2✓ Branch 0 taken 13229 times.
✓ Branch 1 taken 16730 times.
|
29959 | if (f->intensity_stereo <= f->start_band) |
398 | 13229 | tbits_8ths += dualstereo_bit; /* no intensity stereo means no dual stereo */ | |
399 |
1/2✓ Branch 0 taken 16730 times.
✗ Branch 1 not taken.
|
16730 | else if (dualstereo_bit) |
400 |
1/2✗ Branch 0 not taken.
✓ Branch 1 taken 16730 times.
|
16730 | if (encode) |
401 | ✗ | ff_opus_rc_enc_log(rc, f->dual_stereo, 1); | |
402 | else | ||
403 | 16730 | f->dual_stereo = ff_opus_rc_dec_log(rc, 1); | |
404 | |||
405 | /* Supply the remaining bits in this frame to lower bands */ | ||
406 | 29959 | remaining = tbits_8ths - total; | |
407 | 29959 | bandbits = remaining / (ff_celt_freq_bands[f->coded_bands] - ff_celt_freq_bands[f->start_band]); | |
408 | 29959 | remaining -= bandbits * (ff_celt_freq_bands[f->coded_bands] - ff_celt_freq_bands[f->start_band]); | |
409 |
2/2✓ Branch 0 taken 457920 times.
✓ Branch 1 taken 29959 times.
|
487879 | for (i = f->start_band; i < f->coded_bands; i++) { |
410 | 457920 | const int bits = FFMIN(remaining, ff_celt_freq_range[i]); | |
411 | 457920 | f->pulses[i] += bits + bandbits * ff_celt_freq_range[i]; | |
412 | 457920 | remaining -= bits; | |
413 | } | ||
414 | |||
415 | /* Finally determine the allocation */ | ||
416 |
2/2✓ Branch 0 taken 457920 times.
✓ Branch 1 taken 29959 times.
|
487879 | for (i = f->start_band; i < f->coded_bands; i++) { |
417 | 457920 | int N = ff_celt_freq_range[i] << f->size; | |
418 | 457920 | int prev_extra = extrabits; | |
419 | 457920 | f->pulses[i] += extrabits; | |
420 | |||
421 |
2/2✓ Branch 0 taken 351369 times.
✓ Branch 1 taken 106551 times.
|
457920 | if (N > 1) { |
422 | int dof; /* degrees of freedom */ | ||
423 | int temp; /* dof * channels * log(dof) */ | ||
424 | int fine_bits; | ||
425 | int max_bits; | ||
426 | int offset; /* fine energy quantization offset, i.e. | ||
427 | * extra bits assigned over the standard | ||
428 | * totalbits/dof */ | ||
429 | |||
430 | 351369 | extrabits = FFMAX(f->pulses[i] - f->caps[i], 0); | |
431 | 351369 | f->pulses[i] -= extrabits; | |
432 | |||
433 | /* intensity stereo makes use of an extra degree of freedom */ | ||
434 |
8/8✓ Branch 0 taken 242758 times.
✓ Branch 1 taken 108611 times.
✓ Branch 2 taken 190421 times.
✓ Branch 3 taken 52337 times.
✓ Branch 4 taken 156074 times.
✓ Branch 5 taken 34347 times.
✓ Branch 6 taken 140074 times.
✓ Branch 7 taken 16000 times.
|
351369 | dof = N * f->channels + (f->channels == 2 && N > 2 && !f->dual_stereo && i < f->intensity_stereo); |
435 | 351369 | temp = dof * (ff_celt_log_freq_range[i] + (f->size << 3)); | |
436 | 351369 | offset = (temp >> 1) - dof * CELT_FINE_OFFSET; | |
437 |
2/2✓ Branch 0 taken 83666 times.
✓ Branch 1 taken 267703 times.
|
351369 | if (N == 2) /* dof=2 is the only case that doesn't fit the model */ |
438 | 83666 | offset += dof << 1; | |
439 | |||
440 | /* grant an additional bias for the first and second pulses */ | ||
441 |
2/2✓ Branch 0 taken 247373 times.
✓ Branch 1 taken 103996 times.
|
351369 | if (f->pulses[i] + offset < 2 * (dof << 3)) |
442 | 247373 | offset += temp >> 2; | |
443 |
2/2✓ Branch 0 taken 50077 times.
✓ Branch 1 taken 53919 times.
|
103996 | else if (f->pulses[i] + offset < 3 * (dof << 3)) |
444 | 50077 | offset += temp >> 3; | |
445 | |||
446 | 351369 | fine_bits = (f->pulses[i] + offset + (dof << 2)) / (dof << 3); | |
447 | 351369 | max_bits = FFMIN((f->pulses[i] >> 3) >> (f->channels - 1), CELT_MAX_FINE_BITS); | |
448 | 351369 | max_bits = FFMAX(max_bits, 0); | |
449 | 351369 | f->fine_bits[i] = av_clip(fine_bits, 0, max_bits); | |
450 | |||
451 | /* If fine_bits was rounded down or capped, | ||
452 | * give priority for the final fine energy pass */ | ||
453 | 351369 | f->fine_priority[i] = (f->fine_bits[i] * (dof << 3) >= f->pulses[i] + offset); | |
454 | |||
455 | /* the remaining bits are assigned to PVQ */ | ||
456 | 351369 | f->pulses[i] -= f->fine_bits[i] << (f->channels - 1) << 3; | |
457 | } else { | ||
458 | /* all bits go to fine energy except for the sign bit */ | ||
459 | 106551 | extrabits = FFMAX(f->pulses[i] - (f->channels << 3), 0); | |
460 | 106551 | f->pulses[i] -= extrabits; | |
461 | 106551 | f->fine_bits[i] = 0; | |
462 | 106551 | f->fine_priority[i] = 1; | |
463 | } | ||
464 | |||
465 | /* hand back a limited number of extra fine energy bits to this band */ | ||
466 |
2/2✓ Branch 0 taken 123205 times.
✓ Branch 1 taken 334715 times.
|
457920 | if (extrabits > 0) { |
467 | 123205 | int fineextra = FFMIN(extrabits >> (f->channels + 2), | |
468 | CELT_MAX_FINE_BITS - f->fine_bits[i]); | ||
469 | 123205 | f->fine_bits[i] += fineextra; | |
470 | |||
471 | 123205 | fineextra <<= f->channels + 2; | |
472 | 123205 | f->fine_priority[i] = (fineextra >= extrabits - prev_extra); | |
473 | 123205 | extrabits -= fineextra; | |
474 | } | ||
475 | } | ||
476 | 29959 | f->remaining = extrabits; | |
477 | |||
478 | /* skipped bands dedicate all of their bits for fine energy */ | ||
479 |
2/2✓ Branch 0 taken 50966 times.
✓ Branch 1 taken 29959 times.
|
80925 | for (; i < f->end_band; i++) { |
480 | 50966 | f->fine_bits[i] = f->pulses[i] >> (f->channels - 1) >> 3; | |
481 | 50966 | f->pulses[i] = 0; | |
482 | 50966 | f->fine_priority[i] = f->fine_bits[i] < 1; | |
483 | } | ||
484 | 29959 | } | |
485 |