intra_trace.c 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245
  1. #include <stdlib.h>
  2. #include <string.h>
  3. #include "od_defs.h"
  4. #include "od_filter.h"
  5. #include "image_tools.h"
  6. #include "stats_tools.h"
  7. #include "trans_tools.h"
  8. typedef struct intra_trace_ctx intra_trace_ctx;
  9. struct intra_trace_ctx{
  10. int x;
  11. int y;
  12. int d;
  13. int c;
  14. image_data img;
  15. od_coeff min[OD_INTRA_NMODES];
  16. od_coeff max[OD_INTRA_NMODES];
  17. };
  18. void intra_trace_ctx_reset(intra_trace_ctx *_this){
  19. _this->x=0;
  20. _this->y=0;
  21. _this->d=3;
  22. _this->c=0;
  23. }
  24. void intra_trace_ctx_init(intra_trace_ctx *_this){
  25. int i;
  26. intra_trace_ctx_reset(_this);
  27. image_data_init(&_this->img,NULL,1,1);
  28. for(i=0;i<OD_INTRA_NMODES;i++){
  29. _this->min[i]=INT_MAX;
  30. _this->max[i]=-INT_MAX;
  31. }
  32. }
  33. void intra_trace_ctx_clear(intra_trace_ctx *_this){
  34. image_data_clear(&_this->img);
  35. }
  36. int intra_trace_ctx_next(intra_trace_ctx *_this,int _loop){
  37. int m;
  38. /*printf("%i %i %i\n",_this->x,_this->y,_this->d);*/
  39. m=0;
  40. if(_this->d&2){
  41. if(_this->d&1){
  42. if(_this->y==B_SZ*3-1){
  43. _this->x+=_this->x&1?-1:1;
  44. _this->d=2;
  45. m=1;
  46. }
  47. }
  48. else{
  49. if(_this->y==(_this->x^1)){
  50. _this->x++;
  51. _this->d=1;
  52. m=1;
  53. }
  54. }
  55. }
  56. else{
  57. if(_this->d&1){
  58. if(_this->x==B_SZ*4-1){
  59. _this->y+=_this->y&1?-1:1;
  60. _this->d=0;
  61. m=1;
  62. }
  63. }
  64. else{
  65. if(_this->x==(_this->y&1?_this->y+1:_this->y-1)){
  66. _this->y++;
  67. _this->d=3;
  68. m=1;
  69. }
  70. }
  71. }
  72. if(!m){
  73. if(_this->d&2){
  74. _this->y+=_this->d&1?1:-1;
  75. }
  76. else{
  77. _this->x+=_this->d&1?1:-1;
  78. }
  79. }
  80. if(_loop&&_this->x==2*B_SZ&&_this->y==2*B_SZ){
  81. _this->x=2*B_SZ-1;
  82. _this->y=2*B_SZ-1;
  83. _this->d=3;
  84. }
  85. _this->c++;
  86. if(_loop){
  87. return(_this->x==0&&_this->y==0);
  88. }
  89. else{
  90. return(_this->x==B_SZ&&_this->y==B_SZ);
  91. }
  92. }
  93. #define SUPPORT_SZ 32
  94. #define SPACE_SZ 16
  95. #define BLOCK_SZ 128
  96. #define IMAGE_X (5*(SPACE_SZ+BLOCK_SZ)+SPACE_SZ)
  97. #define IMAGE_Y (3*(SPACE_SZ+BLOCK_SZ)+SPACE_SZ)
  98. static void draw_pulse(od_rgba16_image *_image,int _x,int _y){
  99. int x0;
  100. int y0;
  101. od_rgba16_pixel c;
  102. int n;
  103. int j;
  104. int i;
  105. x0=(IMAGE_X-4*SUPPORT_SZ)/2;
  106. y0=SPACE_SZ+(BLOCK_SZ-3*SUPPORT_SZ)/2;
  107. n=SUPPORT_SZ/B_SZ;
  108. c[3]=(unsigned short)0xFFFFU;
  109. /* Clear region. */
  110. c[0]=c[1]=c[2]=0;
  111. for(j=0;j<3*SUPPORT_SZ;j++){
  112. for(i=0;i<4*SUPPORT_SZ;i++){
  113. od_rgba16_image_draw_point(_image,x0+i,y0+j,c);
  114. }
  115. }
  116. /* Draw blocks. */
  117. x0+=SUPPORT_SZ/2;
  118. y0+=SUPPORT_SZ/2;
  119. c[0]=c[1]=c[2]=0x7F00;
  120. for(j=0;j<SUPPORT_SZ;j++){
  121. for(i=0;i<SUPPORT_SZ;i++){
  122. od_rgba16_image_draw_point(_image,x0+SUPPORT_SZ*0+i,y0+SUPPORT_SZ*0+j,c);
  123. od_rgba16_image_draw_point(_image,x0+SUPPORT_SZ*1+i,y0+SUPPORT_SZ*0+j,c);
  124. od_rgba16_image_draw_point(_image,x0+SUPPORT_SZ*2+i,y0+SUPPORT_SZ*0+j,c);
  125. od_rgba16_image_draw_point(_image,x0+SUPPORT_SZ*0+i,y0+SUPPORT_SZ*1+j,c);
  126. }
  127. }
  128. /* Draw pulse. */
  129. x0-=SUPPORT_SZ/2;
  130. y0-=SUPPORT_SZ/2;
  131. c[0]=c[1]=c[2]=0xFF00;
  132. for(j=0;j<n;j++){
  133. for(i=0;i<n;i++){
  134. od_rgba16_image_draw_point(_image,x0+n*_x+i,y0+n*_y+j,c);
  135. }
  136. }
  137. }
  138. static void draw_point(od_rgba16_image *_image,int _m,int _x,int _y,
  139. unsigned char _v){
  140. int x0;
  141. int y0;
  142. int n;
  143. od_rgba16_pixel c;
  144. int j;
  145. int i;
  146. x0=SPACE_SZ+(SPACE_SZ+BLOCK_SZ)*(_m%5);
  147. y0=(SPACE_SZ+BLOCK_SZ)*(_m/5+1);
  148. n=BLOCK_SZ/(2*B_SZ);
  149. c[3]=(unsigned short)0xFFFFU;
  150. c[0]=c[1]=c[2]=_v*0x101;
  151. for(j=0;j<n;j++){
  152. for(i=0;i<n;i++){
  153. od_rgba16_image_draw_point(_image,x0+n*_x+i,y0+n*_y+j,c);
  154. }
  155. }
  156. }
  157. static void intra_trace_ctx_step(intra_trace_ctx *_ctx,od_rgba16_image *_image,
  158. const int *_f){
  159. unsigned char data[4*B_SZ*4*B_SZ];
  160. int m;
  161. (void)_f;
  162. memset(data,0,4*B_SZ*4*B_SZ);
  163. data[4*B_SZ*_ctx->y+_ctx->x]=255;
  164. draw_pulse(_image,_ctx->x,_ctx->y);
  165. image_data_pre_block(&_ctx->img,&data[4*B_SZ*(3*B_SZ>>1)+(3*B_SZ>>1)],4*B_SZ,
  166. 0,0);
  167. image_data_fdct_block(&_ctx->img,0,0);
  168. for(m=0;m<OD_INTRA_NMODES;m++){
  169. int j;
  170. int i;
  171. _ctx->img.mode[0]=m;
  172. image_data_pred_block(&_ctx->img,0,0);
  173. image_data_idct_block(&_ctx->img,0,0);
  174. /* Set non-predicted blocks to zero before post-filtering. */
  175. for(j=0;j<3*B_SZ;j++){
  176. for(i=0;i<3*B_SZ;i++){
  177. if(j/B_SZ!=1||i/B_SZ!=1){
  178. _ctx->img.idct[3*B_SZ*j+i]=-128*INPUT_SCALE;
  179. }
  180. }
  181. }
  182. image_data_post_block(&_ctx->img,0,0);
  183. for(j=0;j<2*B_SZ;j++){
  184. for(i=0;i<2*B_SZ;i++){
  185. od_coeff v;
  186. v=(_ctx->img.post[2*B_SZ*j+i]+INPUT_SCALE*128+INPUT_SCALE/2)/INPUT_SCALE;
  187. if(_ctx->min[m]>v){
  188. _ctx->min[m]=v;
  189. }
  190. if(_ctx->max[m]<v){
  191. _ctx->max[m]=v;
  192. }
  193. draw_point(_image,m,i,j,OD_CLAMPI(0,v+128,255));
  194. }
  195. }
  196. }
  197. }
  198. int main(int _argc,char *_argv[]){
  199. intra_trace_ctx ctx;
  200. const int *f;
  201. od_rgba16_image image;
  202. (void)_argc;
  203. (void)_argv;
  204. ne_filter_params_init();
  205. od_scale_init(OD_SCALE);
  206. #if B_SZ==4
  207. f=NE_FILTER_PARAMS4;
  208. #elif B_SZ==8
  209. f=NE_FILTER_PARAMS8;
  210. #elif B_SZ==16
  211. f=NE_FILTER_PARAMS16;
  212. #else
  213. # error "Unsupported block size."
  214. #endif
  215. intra_trace_ctx_init(&ctx);
  216. od_rgba16_image_init(&image,IMAGE_X,IMAGE_Y);
  217. do {
  218. char name[16];
  219. intra_trace_ctx_step(&ctx,&image,f);
  220. sprintf(name,"trace%04i",ctx.c);
  221. image_write_png(&image,name);
  222. }
  223. while(!intra_trace_ctx_next(&ctx,1));
  224. {
  225. int i;
  226. for(i=0;i<OD_INTRA_NMODES;i++){
  227. printf("%4i %4i\n",ctx.min[i],ctx.max[i]);
  228. }
  229. }
  230. intra_trace_ctx_clear(&ctx);
  231. od_rgba16_image_clear(&image);
  232. return EXIT_SUCCESS;
  233. }