quant.c 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. /********************************************************************
  2. * *
  3. * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE. *
  4. * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS *
  5. * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
  6. * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING. *
  7. * *
  8. * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009 *
  9. * by the Xiph.Org Foundation and contributors http://www.xiph.org/ *
  10. * *
  11. ********************************************************************
  12. function:
  13. last mod: $Id: quant.c 16503 2009-08-22 18:14:02Z giles $
  14. ********************************************************************/
  15. #include <stdlib.h>
  16. #include <string.h>
  17. #include <ogg/ogg.h>
  18. #include "quant.h"
  19. #include "decint.h"
  20. static const unsigned OC_DC_QUANT_MIN[2]={4<<2,8<<2};
  21. static const unsigned OC_AC_QUANT_MIN[2]={2<<2,4<<2};
  22. /*Initializes the dequantization tables from a set of quantizer info.
  23. Currently the dequantizer (and elsewhere enquantizer) tables are expected to
  24. be initialized as pointing to the storage reserved for them in the
  25. oc_theora_state (resp. oc_enc_ctx) structure.
  26. If some tables are duplicates of others, the pointers will be adjusted to
  27. point to a single copy of the tables, but the storage for them will not be
  28. freed.
  29. If you're concerned about the memory footprint, the obvious thing to do is
  30. to move the storage out of its fixed place in the structures and allocate
  31. it on demand.
  32. However, a much, much better option is to only store the quantization
  33. matrices being used for the current frame, and to recalculate these as the
  34. qi values change between frames (this is what VP3 did).*/
  35. void oc_dequant_tables_init(ogg_uint16_t *_dequant[64][3][2],
  36. int _pp_dc_scale[64],const th_quant_info *_qinfo){
  37. /*Coding mode: intra or inter.*/
  38. int qti;
  39. /*Y', C_b, C_r*/
  40. int pli;
  41. for(qti=0;qti<2;qti++)for(pli=0;pli<3;pli++){
  42. /*Quality index.*/
  43. int qi;
  44. /*Range iterator.*/
  45. int qri;
  46. for(qi=0,qri=0;qri<=_qinfo->qi_ranges[qti][pli].nranges;qri++){
  47. th_quant_base base;
  48. ogg_uint32_t q;
  49. int qi_start;
  50. int qi_end;
  51. memcpy(base,_qinfo->qi_ranges[qti][pli].base_matrices[qri],
  52. sizeof(base));
  53. qi_start=qi;
  54. if(qri==_qinfo->qi_ranges[qti][pli].nranges)qi_end=qi+1;
  55. else qi_end=qi+_qinfo->qi_ranges[qti][pli].sizes[qri];
  56. /*Iterate over quality indicies in this range.*/
  57. for(;;){
  58. ogg_uint32_t qfac;
  59. int zzi;
  60. int ci;
  61. /*In the original VP3.2 code, the rounding offset and the size of the
  62. dead zone around 0 were controlled by a "sharpness" parameter.
  63. The size of our dead zone is now controlled by the per-coefficient
  64. quality thresholds returned by our HVS module.
  65. We round down from a more accurate value when the quality of the
  66. reconstruction does not fall below our threshold and it saves bits.
  67. Hence, all of that VP3.2 code is gone from here, and the remaining
  68. floating point code has been implemented as equivalent integer code
  69. with exact precision.*/
  70. qfac=(ogg_uint32_t)_qinfo->dc_scale[qi]*base[0];
  71. /*For postprocessing, not dequantization.*/
  72. if(_pp_dc_scale!=NULL)_pp_dc_scale[qi]=(int)(qfac/160);
  73. /*Scale DC the coefficient from the proper table.*/
  74. q=(qfac/100)<<2;
  75. q=OC_CLAMPI(OC_DC_QUANT_MIN[qti],q,OC_QUANT_MAX);
  76. _dequant[qi][pli][qti][0]=(ogg_uint16_t)q;
  77. /*Now scale AC coefficients from the proper table.*/
  78. for(zzi=1;zzi<64;zzi++){
  79. q=((ogg_uint32_t)_qinfo->ac_scale[qi]*base[OC_FZIG_ZAG[zzi]]/100)<<2;
  80. q=OC_CLAMPI(OC_AC_QUANT_MIN[qti],q,OC_QUANT_MAX);
  81. _dequant[qi][pli][qti][zzi]=(ogg_uint16_t)q;
  82. }
  83. /*If this is a duplicate of a previous matrix, use that instead.
  84. This simple check helps us improve cache coherency later.*/
  85. {
  86. int dupe;
  87. int qtj;
  88. int plj;
  89. dupe=0;
  90. for(qtj=0;qtj<=qti;qtj++){
  91. for(plj=0;plj<(qtj<qti?3:pli);plj++){
  92. if(!memcmp(_dequant[qi][pli][qti],_dequant[qi][plj][qtj],
  93. sizeof(oc_quant_table))){
  94. dupe=1;
  95. break;
  96. }
  97. }
  98. if(dupe)break;
  99. }
  100. if(dupe)_dequant[qi][pli][qti]=_dequant[qi][plj][qtj];
  101. }
  102. if(++qi>=qi_end)break;
  103. /*Interpolate the next base matrix.*/
  104. for(ci=0;ci<64;ci++){
  105. base[ci]=(unsigned char)(
  106. (2*((qi_end-qi)*_qinfo->qi_ranges[qti][pli].base_matrices[qri][ci]+
  107. (qi-qi_start)*_qinfo->qi_ranges[qti][pli].base_matrices[qri+1][ci])
  108. +_qinfo->qi_ranges[qti][pli].sizes[qri])/
  109. (2*_qinfo->qi_ranges[qti][pli].sizes[qri]));
  110. }
  111. }
  112. }
  113. }
  114. }