mp4_iquant.c
上传用户:tuheem
上传日期:2007-05-01
资源大小:21889k
文件大小:1k
源码类别:

多媒体编程

开发平台:

Visual C++

  1. #include "mp4_vars.h"
  2. #include "mp4_predict.h"
  3. #include "mp4_iquant.h"
  4. #define _iquant_h263(coeff, q_2scale, q_add) if ((coeff) != 0) {
  5. if ((coeff) > 0) {
  6. (coeff) = ((q_2scale) * (coeff)) + (q_add); }
  7. else if ((coeff) < 0) {
  8. (coeff) *= -1;
  9. (coeff) = ((q_2scale) * (coeff)) + (q_add);
  10. (coeff) *= -1; }
  11. }
  12. /**
  13.  *
  14. **/
  15. __inline void iquant (short * psblock, int intraFlag)
  16. {
  17. int i;
  18. int q_scale = mp4_state->hdr.quantizer;
  19. int q_2scale = q_scale << 1;
  20. int q_add = (q_scale & 1) ? q_scale : (q_scale - 1);
  21. for (i = intraFlag; i < 64; i++)
  22. {
  23. _iquant_h263(psblock[i], q_2scale, q_add);
  24. }
  25. }
  26. void iquant_typefirst (short * psblock)
  27. {
  28. int i;
  29. for (i = 1; i < 64; i++)
  30. {
  31. if (psblock[i] != 0) {
  32. psblock[i] = (psblock[i] * 2 * mp4_state->hdr.quantizer * 
  33. mp4_tables->intra_quant_matrix[mp4_tables->zig_zag_scan[i]]) >> 4;
  34. }
  35. }
  36. }