diff options
Diffstat (limited to '')
-rw-r--r-- | linden/indra/llmessage/patch_dct.cpp | 770 |
1 files changed, 770 insertions, 0 deletions
diff --git a/linden/indra/llmessage/patch_dct.cpp b/linden/indra/llmessage/patch_dct.cpp new file mode 100644 index 0000000..b404c75 --- /dev/null +++ b/linden/indra/llmessage/patch_dct.cpp | |||
@@ -0,0 +1,770 @@ | |||
1 | /** | ||
2 | * @file patch_dct.cpp | ||
3 | * @brief DCT patch. | ||
4 | * | ||
5 | * Copyright (c) 2000-2007, Linden Research, Inc. | ||
6 | * | ||
7 | * The source code in this file ("Source Code") is provided by Linden Lab | ||
8 | * to you under the terms of the GNU General Public License, version 2.0 | ||
9 | * ("GPL"), unless you have obtained a separate licensing agreement | ||
10 | * ("Other License"), formally executed by you and Linden Lab. Terms of | ||
11 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | ||
12 | * online at http://secondlife.com/developers/opensource/gplv2 | ||
13 | * | ||
14 | * There are special exceptions to the terms and conditions of the GPL as | ||
15 | * it is applied to this Source Code. View the full text of the exception | ||
16 | * in the file doc/FLOSS-exception.txt in this software distribution, or | ||
17 | * online at http://secondlife.com/developers/opensource/flossexception | ||
18 | * | ||
19 | * By copying, modifying or distributing this software, you acknowledge | ||
20 | * that you have read and understood your obligations described above, | ||
21 | * and agree to abide by those obligations. | ||
22 | * | ||
23 | * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO | ||
24 | * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, | ||
25 | * COMPLETENESS OR PERFORMANCE. | ||
26 | */ | ||
27 | |||
28 | #include "linden_common.h" | ||
29 | |||
30 | #include "llmath.h" | ||
31 | //#include "vmath.h" | ||
32 | #include "v3math.h" | ||
33 | #include "patch_dct.h" | ||
34 | |||
35 | typedef struct s_patch_compress_global_data | ||
36 | { | ||
37 | S32 patch_size; | ||
38 | S32 patch_stride; | ||
39 | U32 charptr; | ||
40 | S32 layer_type; | ||
41 | } PCGD; | ||
42 | |||
43 | PCGD gPatchCompressGlobalData; | ||
44 | |||
45 | void reset_patch_compressor(void) | ||
46 | { | ||
47 | PCGD *pcp = &gPatchCompressGlobalData; | ||
48 | |||
49 | pcp->charptr = 0; | ||
50 | } | ||
51 | |||
52 | S32 gCurrentSize = 0; | ||
53 | |||
54 | F32 gPatchQuantizeTable[LARGE_PATCH_SIZE*LARGE_PATCH_SIZE]; | ||
55 | |||
56 | void build_patch_quantize_table(S32 size) | ||
57 | { | ||
58 | S32 i, j; | ||
59 | for (j = 0; j < size; j++) | ||
60 | { | ||
61 | for (i = 0; i < size; i++) | ||
62 | { | ||
63 | gPatchQuantizeTable[j*size + i] = 1.f/(1.f + 2.f*(i+j)); | ||
64 | } | ||
65 | } | ||
66 | } | ||
67 | |||
68 | F32 gPatchCosines[LARGE_PATCH_SIZE*LARGE_PATCH_SIZE]; | ||
69 | |||
70 | void setup_patch_cosines(S32 size) | ||
71 | { | ||
72 | S32 n, u; | ||
73 | F32 oosob = F_PI*0.5f/size; | ||
74 | |||
75 | for (u = 0; u < size; u++) | ||
76 | { | ||
77 | for (n = 0; n < size; n++) | ||
78 | { | ||
79 | gPatchCosines[u*size+n] = cosf((2.f*n+1.f)*u*oosob); | ||
80 | } | ||
81 | } | ||
82 | } | ||
83 | |||
84 | S32 gCopyMatrix[LARGE_PATCH_SIZE*LARGE_PATCH_SIZE]; | ||
85 | |||
86 | void build_copy_matrix(S32 size) | ||
87 | { | ||
88 | S32 i, j, count; | ||
89 | BOOL b_diag = FALSE; | ||
90 | BOOL b_right = TRUE; | ||
91 | |||
92 | i = 0; | ||
93 | j = 0; | ||
94 | count = 0; | ||
95 | |||
96 | while ( (i < size) | ||
97 | &&(j < size)) | ||
98 | { | ||
99 | gCopyMatrix[j*size + i] = count; | ||
100 | |||
101 | count++; | ||
102 | |||
103 | if (!b_diag) | ||
104 | { | ||
105 | if (b_right) | ||
106 | { | ||
107 | if (i < size - 1) | ||
108 | i++; | ||
109 | else | ||
110 | j++; | ||
111 | b_right = FALSE; | ||
112 | b_diag = TRUE; | ||
113 | } | ||
114 | else | ||
115 | { | ||
116 | if (j < size - 1) | ||
117 | j++; | ||
118 | else | ||
119 | i++; | ||
120 | b_right = TRUE; | ||
121 | b_diag = TRUE; | ||
122 | } | ||
123 | } | ||
124 | else | ||
125 | { | ||
126 | if (b_right) | ||
127 | { | ||
128 | i++; | ||
129 | j--; | ||
130 | if ( (i == size - 1) | ||
131 | ||(j == 0)) | ||
132 | { | ||
133 | b_diag = FALSE; | ||
134 | } | ||
135 | } | ||
136 | else | ||
137 | { | ||
138 | i--; | ||
139 | j++; | ||
140 | if ( (i == 0) | ||
141 | ||(j == size - 1)) | ||
142 | { | ||
143 | b_diag = FALSE; | ||
144 | } | ||
145 | } | ||
146 | } | ||
147 | } | ||
148 | } | ||
149 | |||
150 | |||
151 | void init_patch_compressor(S32 patch_size, S32 patch_stride, S32 layer_type) | ||
152 | { | ||
153 | PCGD *pcp = &gPatchCompressGlobalData; | ||
154 | |||
155 | pcp->charptr = 0; | ||
156 | |||
157 | pcp->patch_size = patch_size; | ||
158 | pcp->patch_stride = patch_stride; | ||
159 | pcp->layer_type = layer_type; | ||
160 | |||
161 | if (patch_size != gCurrentSize) | ||
162 | { | ||
163 | gCurrentSize = patch_size; | ||
164 | build_patch_quantize_table(patch_size); | ||
165 | setup_patch_cosines(patch_size); | ||
166 | build_copy_matrix(patch_size); | ||
167 | } | ||
168 | } | ||
169 | |||
170 | void prescan_patch(F32 *patch, LLPatchHeader *php, F32 &zmax, F32 &zmin) | ||
171 | { | ||
172 | S32 i, j; | ||
173 | PCGD *pcp = &gPatchCompressGlobalData; | ||
174 | S32 stride = pcp->patch_stride; | ||
175 | S32 size = pcp->patch_size; | ||
176 | S32 jstride; | ||
177 | |||
178 | zmax = -99999999.f; | ||
179 | zmin = 99999999.f; | ||
180 | |||
181 | for (j = 0; j < size; j++) | ||
182 | { | ||
183 | jstride = j*stride; | ||
184 | for (i = 0; i < size; i++) | ||
185 | { | ||
186 | if (*(patch + jstride + i) > zmax) | ||
187 | { | ||
188 | zmax = *(patch + jstride + i); | ||
189 | } | ||
190 | if (*(patch + jstride + i) < zmin) | ||
191 | { | ||
192 | zmin = *(patch + jstride + i); | ||
193 | } | ||
194 | } | ||
195 | } | ||
196 | |||
197 | php->dc_offset = zmin; | ||
198 | php->range = (U16) ((zmax - zmin) + 1.f); | ||
199 | } | ||
200 | |||
201 | void dct_line(F32 *linein, F32 *lineout, S32 line) | ||
202 | { | ||
203 | S32 u; | ||
204 | F32 total; | ||
205 | F32 *pcp = gPatchCosines; | ||
206 | S32 line_size = line*NORMAL_PATCH_SIZE; | ||
207 | |||
208 | #ifdef _PATCH_SIZE_16_AND_32_ONLY | ||
209 | F32 *tlinein, *tpcp; | ||
210 | |||
211 | tlinein = linein + line_size; | ||
212 | |||
213 | total = *(tlinein++); | ||
214 | total += *(tlinein++); | ||
215 | total += *(tlinein++); | ||
216 | total += *(tlinein++); | ||
217 | |||
218 | total += *(tlinein++); | ||
219 | total += *(tlinein++); | ||
220 | total += *(tlinein++); | ||
221 | total += *(tlinein++); | ||
222 | |||
223 | total += *(tlinein++); | ||
224 | total += *(tlinein++); | ||
225 | total += *(tlinein++); | ||
226 | total += *(tlinein++); | ||
227 | |||
228 | total += *(tlinein++); | ||
229 | total += *(tlinein++); | ||
230 | total += *(tlinein++); | ||
231 | total += *(tlinein); | ||
232 | |||
233 | *(lineout + line_size) = OO_SQRT2*total; | ||
234 | |||
235 | for (u = 1; u < NORMAL_PATCH_SIZE; u++) | ||
236 | { | ||
237 | tlinein = linein + line_size; | ||
238 | tpcp = pcp + (u<<4); | ||
239 | |||
240 | total = *(tlinein++)*(*(tpcp++)); | ||
241 | total += *(tlinein++)*(*(tpcp++)); | ||
242 | total += *(tlinein++)*(*(tpcp++)); | ||
243 | total += *(tlinein++)*(*(tpcp++)); | ||
244 | |||
245 | total += *(tlinein++)*(*(tpcp++)); | ||
246 | total += *(tlinein++)*(*(tpcp++)); | ||
247 | total += *(tlinein++)*(*(tpcp++)); | ||
248 | total += *(tlinein++)*(*(tpcp++)); | ||
249 | |||
250 | total += *(tlinein++)*(*(tpcp++)); | ||
251 | total += *(tlinein++)*(*(tpcp++)); | ||
252 | total += *(tlinein++)*(*(tpcp++)); | ||
253 | total += *(tlinein++)*(*(tpcp++)); | ||
254 | |||
255 | total += *(tlinein++)*(*(tpcp++)); | ||
256 | total += *(tlinein++)*(*(tpcp++)); | ||
257 | total += *(tlinein++)*(*(tpcp++)); | ||
258 | total += *(tlinein)*(*tpcp); | ||
259 | |||
260 | *(lineout + line_size + u) = total; | ||
261 | } | ||
262 | #else | ||
263 | S32 n; | ||
264 | S32 size = gPatchCompressGlobalData.patch_size; | ||
265 | total = 0.f; | ||
266 | for (n = 0; n < size; n++) | ||
267 | { | ||
268 | total += linein[line_size + n]; | ||
269 | } | ||
270 | lineout[line_size] = OO_SQRT2*total; | ||
271 | |||
272 | for (u = 1; u < size; u++) | ||
273 | { | ||
274 | total = 0.f; | ||
275 | for (n = 0; n < size; n++) | ||
276 | { | ||
277 | total += linein[line_size + n]*pcp[u*size+n]; | ||
278 | } | ||
279 | lineout[line_size + u] = total; | ||
280 | } | ||
281 | #endif | ||
282 | } | ||
283 | |||
284 | void dct_line_large(F32 *linein, F32 *lineout, S32 line) | ||
285 | { | ||
286 | S32 u; | ||
287 | F32 total; | ||
288 | F32 *pcp = gPatchCosines; | ||
289 | S32 line_size = line*LARGE_PATCH_SIZE; | ||
290 | |||
291 | F32 *tlinein, *tpcp; | ||
292 | |||
293 | tlinein = linein + line_size; | ||
294 | |||
295 | total = *(tlinein++); | ||
296 | total += *(tlinein++); | ||
297 | total += *(tlinein++); | ||
298 | total += *(tlinein++); | ||
299 | |||
300 | total += *(tlinein++); | ||
301 | total += *(tlinein++); | ||
302 | total += *(tlinein++); | ||
303 | total += *(tlinein++); | ||
304 | |||
305 | total += *(tlinein++); | ||
306 | total += *(tlinein++); | ||
307 | total += *(tlinein++); | ||
308 | total += *(tlinein++); | ||
309 | |||
310 | total += *(tlinein++); | ||
311 | total += *(tlinein++); | ||
312 | total += *(tlinein++); | ||
313 | total += *(tlinein++); | ||
314 | |||
315 | total += *(tlinein++); | ||
316 | total += *(tlinein++); | ||
317 | total += *(tlinein++); | ||
318 | total += *(tlinein++); | ||
319 | |||
320 | total += *(tlinein++); | ||
321 | total += *(tlinein++); | ||
322 | total += *(tlinein++); | ||
323 | total += *(tlinein++); | ||
324 | |||
325 | total += *(tlinein++); | ||
326 | total += *(tlinein++); | ||
327 | total += *(tlinein++); | ||
328 | total += *(tlinein++); | ||
329 | |||
330 | total += *(tlinein++); | ||
331 | total += *(tlinein++); | ||
332 | total += *(tlinein++); | ||
333 | total += *(tlinein); | ||
334 | |||
335 | *(lineout + line_size) = OO_SQRT2*total; | ||
336 | |||
337 | for (u = 1; u < LARGE_PATCH_SIZE; u++) | ||
338 | { | ||
339 | tlinein = linein + line_size; | ||
340 | tpcp = pcp + (u<<5); | ||
341 | |||
342 | total = *(tlinein++)*(*(tpcp++)); | ||
343 | total += *(tlinein++)*(*(tpcp++)); | ||
344 | total += *(tlinein++)*(*(tpcp++)); | ||
345 | total += *(tlinein++)*(*(tpcp++)); | ||
346 | |||
347 | total += *(tlinein++)*(*(tpcp++)); | ||
348 | total += *(tlinein++)*(*(tpcp++)); | ||
349 | total += *(tlinein++)*(*(tpcp++)); | ||
350 | total += *(tlinein++)*(*(tpcp++)); | ||
351 | |||
352 | total += *(tlinein++)*(*(tpcp++)); | ||
353 | total += *(tlinein++)*(*(tpcp++)); | ||
354 | total += *(tlinein++)*(*(tpcp++)); | ||
355 | total += *(tlinein++)*(*(tpcp++)); | ||
356 | |||
357 | total += *(tlinein++)*(*(tpcp++)); | ||
358 | total += *(tlinein++)*(*(tpcp++)); | ||
359 | total += *(tlinein++)*(*(tpcp++)); | ||
360 | total += *(tlinein++)*(*(tpcp++)); | ||
361 | |||
362 | total += *(tlinein++)*(*(tpcp++)); | ||
363 | total += *(tlinein++)*(*(tpcp++)); | ||
364 | total += *(tlinein++)*(*(tpcp++)); | ||
365 | total += *(tlinein++)*(*(tpcp++)); | ||
366 | |||
367 | total += *(tlinein++)*(*(tpcp++)); | ||
368 | total += *(tlinein++)*(*(tpcp++)); | ||
369 | total += *(tlinein++)*(*(tpcp++)); | ||
370 | total += *(tlinein++)*(*(tpcp++)); | ||
371 | |||
372 | total += *(tlinein++)*(*(tpcp++)); | ||
373 | total += *(tlinein++)*(*(tpcp++)); | ||
374 | total += *(tlinein++)*(*(tpcp++)); | ||
375 | total += *(tlinein++)*(*(tpcp++)); | ||
376 | |||
377 | total += *(tlinein++)*(*(tpcp++)); | ||
378 | total += *(tlinein++)*(*(tpcp++)); | ||
379 | total += *(tlinein++)*(*(tpcp++)); | ||
380 | total += *(tlinein)*(*tpcp); | ||
381 | |||
382 | *(lineout + line_size + u) = total; | ||
383 | } | ||
384 | } | ||
385 | |||
386 | inline void dct_column(F32 *linein, S32 *lineout, S32 column) | ||
387 | { | ||
388 | S32 u; | ||
389 | F32 total; | ||
390 | F32 oosob = 2.f/16.f; | ||
391 | F32 *pcp = gPatchCosines; | ||
392 | S32 *copy_matrix = gCopyMatrix; | ||
393 | F32 *qt = gPatchQuantizeTable; | ||
394 | |||
395 | #ifdef _PATCH_SIZE_16_AND_32_ONLY | ||
396 | F32 *tlinein, *tpcp; | ||
397 | S32 sizeu; | ||
398 | |||
399 | tlinein = linein + column; | ||
400 | |||
401 | total = *(tlinein); | ||
402 | total += *(tlinein += NORMAL_PATCH_SIZE); | ||
403 | total += *(tlinein += NORMAL_PATCH_SIZE); | ||
404 | total += *(tlinein += NORMAL_PATCH_SIZE); | ||
405 | |||
406 | total += *(tlinein += NORMAL_PATCH_SIZE); | ||
407 | total += *(tlinein += NORMAL_PATCH_SIZE); | ||
408 | total += *(tlinein += NORMAL_PATCH_SIZE); | ||
409 | total += *(tlinein += NORMAL_PATCH_SIZE); | ||
410 | |||
411 | total += *(tlinein += NORMAL_PATCH_SIZE); | ||
412 | total += *(tlinein += NORMAL_PATCH_SIZE); | ||
413 | total += *(tlinein += NORMAL_PATCH_SIZE); | ||
414 | total += *(tlinein += NORMAL_PATCH_SIZE); | ||
415 | |||
416 | total += *(tlinein += NORMAL_PATCH_SIZE); | ||
417 | total += *(tlinein += NORMAL_PATCH_SIZE); | ||
418 | total += *(tlinein += NORMAL_PATCH_SIZE); | ||
419 | total += *(tlinein += NORMAL_PATCH_SIZE); | ||
420 | |||
421 | *(lineout + *(copy_matrix + column)) = (S32)(OO_SQRT2*total*oosob*(*(qt + column))); | ||
422 | |||
423 | for (u = 1; u < NORMAL_PATCH_SIZE; u++) | ||
424 | { | ||
425 | tlinein = linein + column; | ||
426 | tpcp = pcp + (u<<4); | ||
427 | |||
428 | total = *(tlinein)*(*(tpcp++)); | ||
429 | total += *(tlinein += NORMAL_PATCH_SIZE)*(*(tpcp++)); | ||
430 | total += *(tlinein += NORMAL_PATCH_SIZE)*(*(tpcp++)); | ||
431 | total += *(tlinein += NORMAL_PATCH_SIZE)*(*(tpcp++)); | ||
432 | |||
433 | total += *(tlinein += NORMAL_PATCH_SIZE)*(*(tpcp++)); | ||
434 | total += *(tlinein += NORMAL_PATCH_SIZE)*(*(tpcp++)); | ||
435 | total += *(tlinein += NORMAL_PATCH_SIZE)*(*(tpcp++)); | ||
436 | total += *(tlinein += NORMAL_PATCH_SIZE)*(*(tpcp++)); | ||
437 | |||
438 | total += *(tlinein += NORMAL_PATCH_SIZE)*(*(tpcp++)); | ||
439 | total += *(tlinein += NORMAL_PATCH_SIZE)*(*(tpcp++)); | ||
440 | total += *(tlinein += NORMAL_PATCH_SIZE)*(*(tpcp++)); | ||
441 | total += *(tlinein += NORMAL_PATCH_SIZE)*(*(tpcp++)); | ||
442 | |||
443 | total += *(tlinein += NORMAL_PATCH_SIZE)*(*(tpcp++)); | ||
444 | total += *(tlinein += NORMAL_PATCH_SIZE)*(*(tpcp++)); | ||
445 | total += *(tlinein += NORMAL_PATCH_SIZE)*(*(tpcp++)); | ||
446 | total += *(tlinein += NORMAL_PATCH_SIZE)*(*(tpcp)); | ||
447 | |||
448 | sizeu = NORMAL_PATCH_SIZE*u + column; | ||
449 | |||
450 | *(lineout + *(copy_matrix + sizeu)) = (S32)(total*oosob*(*(qt+sizeu))); | ||
451 | } | ||
452 | #else | ||
453 | S32 size = gPatchCompressGlobalData.patch_size; | ||
454 | F32 oosob = 2.f/size; | ||
455 | S32 n; | ||
456 | total = 0.f; | ||
457 | for (n = 0; n < size; n++) | ||
458 | { | ||
459 | total += linein[size*n + column]; | ||
460 | } | ||
461 | lineout[copy_matrix[column]] = OO_SQRT2*total*oosob*qt[column]; | ||
462 | |||
463 | for (u = 1; u < size; u++) | ||
464 | { | ||
465 | total = 0.f; | ||
466 | for (n = 0; n < size; n++) | ||
467 | { | ||
468 | total += linein[size*n + column]*pcp[u*size+n]; | ||
469 | } | ||
470 | lineout[copy_matrix[size*u + column]] = total*oosob*qt[size*u + column]; | ||
471 | } | ||
472 | #endif | ||
473 | } | ||
474 | |||
475 | inline void dct_column_large(F32 *linein, S32 *lineout, S32 column) | ||
476 | { | ||
477 | S32 u; | ||
478 | F32 total; | ||
479 | F32 oosob = 2.f/32.f; | ||
480 | F32 *pcp = gPatchCosines; | ||
481 | S32 *copy_matrix = gCopyMatrix; | ||
482 | F32 *qt = gPatchQuantizeTable; | ||
483 | |||
484 | F32 *tlinein, *tpcp; | ||
485 | S32 sizeu; | ||
486 | |||
487 | tlinein = linein + column; | ||
488 | |||
489 | total = *(tlinein); | ||
490 | total += *(tlinein += LARGE_PATCH_SIZE); | ||
491 | total += *(tlinein += LARGE_PATCH_SIZE); | ||
492 | total += *(tlinein += LARGE_PATCH_SIZE); | ||
493 | |||
494 | total += *(tlinein += LARGE_PATCH_SIZE); | ||
495 | total += *(tlinein += LARGE_PATCH_SIZE); | ||
496 | total += *(tlinein += LARGE_PATCH_SIZE); | ||
497 | total += *(tlinein += LARGE_PATCH_SIZE); | ||
498 | |||
499 | total += *(tlinein += LARGE_PATCH_SIZE); | ||
500 | total += *(tlinein += LARGE_PATCH_SIZE); | ||
501 | total += *(tlinein += LARGE_PATCH_SIZE); | ||
502 | total += *(tlinein += LARGE_PATCH_SIZE); | ||
503 | |||
504 | total += *(tlinein += LARGE_PATCH_SIZE); | ||
505 | total += *(tlinein += LARGE_PATCH_SIZE); | ||
506 | total += *(tlinein += LARGE_PATCH_SIZE); | ||
507 | total += *(tlinein += LARGE_PATCH_SIZE); | ||
508 | |||
509 | total += *(tlinein += LARGE_PATCH_SIZE); | ||
510 | total += *(tlinein += LARGE_PATCH_SIZE); | ||
511 | total += *(tlinein += LARGE_PATCH_SIZE); | ||
512 | total += *(tlinein += LARGE_PATCH_SIZE); | ||
513 | |||
514 | total += *(tlinein += LARGE_PATCH_SIZE); | ||
515 | total += *(tlinein += LARGE_PATCH_SIZE); | ||
516 | total += *(tlinein += LARGE_PATCH_SIZE); | ||
517 | total += *(tlinein += LARGE_PATCH_SIZE); | ||
518 | |||
519 | total += *(tlinein += LARGE_PATCH_SIZE); | ||
520 | total += *(tlinein += LARGE_PATCH_SIZE); | ||
521 | total += *(tlinein += LARGE_PATCH_SIZE); | ||
522 | total += *(tlinein += LARGE_PATCH_SIZE); | ||
523 | |||
524 | total += *(tlinein += LARGE_PATCH_SIZE); | ||
525 | total += *(tlinein += LARGE_PATCH_SIZE); | ||
526 | total += *(tlinein += LARGE_PATCH_SIZE); | ||
527 | total += *(tlinein += LARGE_PATCH_SIZE); | ||
528 | |||
529 | *(lineout + *(copy_matrix + column)) = (S32)(OO_SQRT2*total*oosob*(*(qt + column))); | ||
530 | |||
531 | for (u = 1; u < LARGE_PATCH_SIZE; u++) | ||
532 | { | ||
533 | tlinein = linein + column; | ||
534 | tpcp = pcp + (u<<5); | ||
535 | |||
536 | total = *(tlinein)*(*(tpcp++)); | ||
537 | total += *(tlinein += LARGE_PATCH_SIZE)*(*(tpcp++)); | ||
538 | total += *(tlinein += LARGE_PATCH_SIZE)*(*(tpcp++)); | ||
539 | total += *(tlinein += LARGE_PATCH_SIZE)*(*(tpcp++)); | ||
540 | |||
541 | total += *(tlinein += LARGE_PATCH_SIZE)*(*(tpcp++)); | ||
542 | total += *(tlinein += LARGE_PATCH_SIZE)*(*(tpcp++)); | ||
543 | total += *(tlinein += LARGE_PATCH_SIZE)*(*(tpcp++)); | ||
544 | total += *(tlinein += LARGE_PATCH_SIZE)*(*(tpcp++)); | ||
545 | |||
546 | total += *(tlinein += LARGE_PATCH_SIZE)*(*(tpcp++)); | ||
547 | total += *(tlinein += LARGE_PATCH_SIZE)*(*(tpcp++)); | ||
548 | total += *(tlinein += LARGE_PATCH_SIZE)*(*(tpcp++)); | ||
549 | total += *(tlinein += LARGE_PATCH_SIZE)*(*(tpcp++)); | ||
550 | |||
551 | total += *(tlinein += LARGE_PATCH_SIZE)*(*(tpcp++)); | ||
552 | total += *(tlinein += LARGE_PATCH_SIZE)*(*(tpcp++)); | ||
553 | total += *(tlinein += LARGE_PATCH_SIZE)*(*(tpcp++)); | ||
554 | total += *(tlinein += LARGE_PATCH_SIZE)*(*(tpcp++)); | ||
555 | |||
556 | total += *(tlinein += LARGE_PATCH_SIZE)*(*(tpcp++)); | ||
557 | total += *(tlinein += LARGE_PATCH_SIZE)*(*(tpcp++)); | ||
558 | total += *(tlinein += LARGE_PATCH_SIZE)*(*(tpcp++)); | ||
559 | total += *(tlinein += LARGE_PATCH_SIZE)*(*(tpcp++)); | ||
560 | |||
561 | total += *(tlinein += LARGE_PATCH_SIZE)*(*(tpcp++)); | ||
562 | total += *(tlinein += LARGE_PATCH_SIZE)*(*(tpcp++)); | ||
563 | total += *(tlinein += LARGE_PATCH_SIZE)*(*(tpcp++)); | ||
564 | total += *(tlinein += LARGE_PATCH_SIZE)*(*(tpcp++)); | ||
565 | |||
566 | total += *(tlinein += LARGE_PATCH_SIZE)*(*(tpcp++)); | ||
567 | total += *(tlinein += LARGE_PATCH_SIZE)*(*(tpcp++)); | ||
568 | total += *(tlinein += LARGE_PATCH_SIZE)*(*(tpcp++)); | ||
569 | total += *(tlinein += LARGE_PATCH_SIZE)*(*(tpcp++)); | ||
570 | |||
571 | total += *(tlinein += LARGE_PATCH_SIZE)*(*(tpcp++)); | ||
572 | total += *(tlinein += LARGE_PATCH_SIZE)*(*(tpcp++)); | ||
573 | total += *(tlinein += LARGE_PATCH_SIZE)*(*(tpcp++)); | ||
574 | total += *(tlinein += LARGE_PATCH_SIZE)*(*(tpcp)); | ||
575 | |||
576 | sizeu = LARGE_PATCH_SIZE*u + column; | ||
577 | |||
578 | *(lineout + *(copy_matrix + sizeu)) = (S32)(total*oosob*(*(qt+sizeu))); | ||
579 | } | ||
580 | } | ||
581 | |||
582 | inline void dct_patch(F32 *block, S32 *cpatch) | ||
583 | { | ||
584 | F32 temp[NORMAL_PATCH_SIZE*NORMAL_PATCH_SIZE]; | ||
585 | |||
586 | #ifdef _PATCH_SIZE_16_AND_32_ONLY | ||
587 | dct_line(block, temp, 0); | ||
588 | dct_line(block, temp, 1); | ||
589 | dct_line(block, temp, 2); | ||
590 | dct_line(block, temp, 3); | ||
591 | |||
592 | dct_line(block, temp, 4); | ||
593 | dct_line(block, temp, 5); | ||
594 | dct_line(block, temp, 6); | ||
595 | dct_line(block, temp, 7); | ||
596 | |||
597 | dct_line(block, temp, 8); | ||
598 | dct_line(block, temp, 9); | ||
599 | dct_line(block, temp, 10); | ||
600 | dct_line(block, temp, 11); | ||
601 | |||
602 | dct_line(block, temp, 12); | ||
603 | dct_line(block, temp, 13); | ||
604 | dct_line(block, temp, 14); | ||
605 | dct_line(block, temp, 15); | ||
606 | |||
607 | dct_column(temp, cpatch, 0); | ||
608 | dct_column(temp, cpatch, 1); | ||
609 | dct_column(temp, cpatch, 2); | ||
610 | dct_column(temp, cpatch, 3); | ||
611 | |||
612 | dct_column(temp, cpatch, 4); | ||
613 | dct_column(temp, cpatch, 5); | ||
614 | dct_column(temp, cpatch, 6); | ||
615 | dct_column(temp, cpatch, 7); | ||
616 | |||
617 | dct_column(temp, cpatch, 8); | ||
618 | dct_column(temp, cpatch, 9); | ||
619 | dct_column(temp, cpatch, 10); | ||
620 | dct_column(temp, cpatch, 11); | ||
621 | |||
622 | dct_column(temp, cpatch, 12); | ||
623 | dct_column(temp, cpatch, 13); | ||
624 | dct_column(temp, cpatch, 14); | ||
625 | dct_column(temp, cpatch, 15); | ||
626 | #else | ||
627 | S32 i; | ||
628 | S32 size = gPatchCompressGlobalData.patch_size; | ||
629 | for (i = 0; i < size; i++) | ||
630 | { | ||
631 | dct_line(block, temp, i); | ||
632 | } | ||
633 | for (i = 0; i < size; i++) | ||
634 | { | ||
635 | dct_column(temp, cpatch, i); | ||
636 | } | ||
637 | #endif | ||
638 | } | ||
639 | |||
640 | inline void dct_patch_large(F32 *block, S32 *cpatch) | ||
641 | { | ||
642 | F32 temp[LARGE_PATCH_SIZE*LARGE_PATCH_SIZE]; | ||
643 | |||
644 | dct_line_large(block, temp, 0); | ||
645 | dct_line_large(block, temp, 1); | ||
646 | dct_line_large(block, temp, 2); | ||
647 | dct_line_large(block, temp, 3); | ||
648 | |||
649 | dct_line_large(block, temp, 4); | ||
650 | dct_line_large(block, temp, 5); | ||
651 | dct_line_large(block, temp, 6); | ||
652 | dct_line_large(block, temp, 7); | ||
653 | |||
654 | dct_line_large(block, temp, 8); | ||
655 | dct_line_large(block, temp, 9); | ||
656 | dct_line_large(block, temp, 10); | ||
657 | dct_line_large(block, temp, 11); | ||
658 | |||
659 | dct_line_large(block, temp, 12); | ||
660 | dct_line_large(block, temp, 13); | ||
661 | dct_line_large(block, temp, 14); | ||
662 | dct_line_large(block, temp, 15); | ||
663 | |||
664 | dct_line_large(block, temp, 16); | ||
665 | dct_line_large(block, temp, 17); | ||
666 | dct_line_large(block, temp, 18); | ||
667 | dct_line_large(block, temp, 19); | ||
668 | |||
669 | dct_line_large(block, temp, 20); | ||
670 | dct_line_large(block, temp, 21); | ||
671 | dct_line_large(block, temp, 22); | ||
672 | dct_line_large(block, temp, 23); | ||
673 | |||
674 | dct_line_large(block, temp, 24); | ||
675 | dct_line_large(block, temp, 25); | ||
676 | dct_line_large(block, temp, 26); | ||
677 | dct_line_large(block, temp, 27); | ||
678 | |||
679 | dct_line_large(block, temp, 28); | ||
680 | dct_line_large(block, temp, 29); | ||
681 | dct_line_large(block, temp, 30); | ||
682 | dct_line_large(block, temp, 31); | ||
683 | |||
684 | dct_column_large(temp, cpatch, 0); | ||
685 | dct_column_large(temp, cpatch, 1); | ||
686 | dct_column_large(temp, cpatch, 2); | ||
687 | dct_column_large(temp, cpatch, 3); | ||
688 | |||
689 | dct_column_large(temp, cpatch, 4); | ||
690 | dct_column_large(temp, cpatch, 5); | ||
691 | dct_column_large(temp, cpatch, 6); | ||
692 | dct_column_large(temp, cpatch, 7); | ||
693 | |||
694 | dct_column_large(temp, cpatch, 8); | ||
695 | dct_column_large(temp, cpatch, 9); | ||
696 | dct_column_large(temp, cpatch, 10); | ||
697 | dct_column_large(temp, cpatch, 11); | ||
698 | |||
699 | dct_column_large(temp, cpatch, 12); | ||
700 | dct_column_large(temp, cpatch, 13); | ||
701 | dct_column_large(temp, cpatch, 14); | ||
702 | dct_column_large(temp, cpatch, 15); | ||
703 | |||
704 | dct_column_large(temp, cpatch, 16); | ||
705 | dct_column_large(temp, cpatch, 17); | ||
706 | dct_column_large(temp, cpatch, 18); | ||
707 | dct_column_large(temp, cpatch, 19); | ||
708 | |||
709 | dct_column_large(temp, cpatch, 20); | ||
710 | dct_column_large(temp, cpatch, 21); | ||
711 | dct_column_large(temp, cpatch, 22); | ||
712 | dct_column_large(temp, cpatch, 23); | ||
713 | |||
714 | dct_column_large(temp, cpatch, 24); | ||
715 | dct_column_large(temp, cpatch, 25); | ||
716 | dct_column_large(temp, cpatch, 26); | ||
717 | dct_column_large(temp, cpatch, 27); | ||
718 | |||
719 | dct_column_large(temp, cpatch, 28); | ||
720 | dct_column_large(temp, cpatch, 29); | ||
721 | dct_column_large(temp, cpatch, 30); | ||
722 | dct_column_large(temp, cpatch, 31); | ||
723 | } | ||
724 | |||
725 | void compress_patch(F32 *patch, S32 *cpatch, LLPatchHeader *php, S32 prequant) | ||
726 | { | ||
727 | S32 i, j; | ||
728 | PCGD *pcp = &gPatchCompressGlobalData; | ||
729 | S32 stride = pcp->patch_stride; | ||
730 | S32 size = pcp->patch_size; | ||
731 | F32 block[LARGE_PATCH_SIZE*LARGE_PATCH_SIZE], *tblock; | ||
732 | F32 *tpatch; | ||
733 | |||
734 | S32 wordsize = prequant; | ||
735 | F32 oozrange = 1.f/php->range; | ||
736 | |||
737 | F32 dc = php->dc_offset; | ||
738 | |||
739 | S32 range = (1<<prequant); | ||
740 | F32 premult = oozrange*range; | ||
741 | // F32 sub = (F32)(1<<(prequant - 1)); | ||
742 | F32 sub = (F32)(1<<(prequant - 1)) + dc*premult; | ||
743 | |||
744 | php->quant_wbits = wordsize - 2; | ||
745 | php->quant_wbits |= (prequant - 2)<<4; | ||
746 | |||
747 | for (j = 0; j < size; j++) | ||
748 | { | ||
749 | tblock = block + j*size; | ||
750 | tpatch = patch + j*stride; | ||
751 | for (i = 0; i < size; i++) | ||
752 | { | ||
753 | // block[j*size + i] = (patch[j*stride + i] - dc)*premult - sub; | ||
754 | *(tblock++) = *(tpatch++)*premult - sub; | ||
755 | } | ||
756 | } | ||
757 | |||
758 | if (size == 16) | ||
759 | dct_patch(block, cpatch); | ||
760 | else | ||
761 | dct_patch_large(block, cpatch); | ||
762 | } | ||
763 | |||
764 | void get_patch_group_header(LLGroupHeader *gopp) | ||
765 | { | ||
766 | PCGD *pcp = &gPatchCompressGlobalData; | ||
767 | gopp->stride = pcp->patch_stride; | ||
768 | gopp->patch_size = pcp->patch_size; | ||
769 | gopp->layer_type = pcp->layer_type; | ||
770 | } | ||