ppix_manager.c 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174
  1. /*
  2. * $Id: ppix_manager.c 897 2011-08-28 21:43:57Z Kaori.Hagihara@gmail.com $
  3. *
  4. * Copyright (c) 2002-2011, Communications and Remote Sensing Laboratory, Universite catholique de Louvain (UCL), Belgium
  5. * Copyright (c) 2002-2011, Professor Benoit Macq
  6. * Copyright (c) 2003-2004, Yannick Verschueren
  7. * Copyright (c) 2010-2011, Kaori Hagihara
  8. * All rights reserved.
  9. *
  10. * Redistribution and use in source and binary forms, with or without
  11. * modification, are permitted provided that the following conditions
  12. * are met:
  13. * 1. Redistributions of source code must retain the above copyright
  14. * notice, this list of conditions and the following disclaimer.
  15. * 2. Redistributions in binary form must reproduce the above copyright
  16. * notice, this list of conditions and the following disclaimer in the
  17. * documentation and/or other materials provided with the distribution.
  18. *
  19. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS `AS IS'
  20. * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  21. * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  22. * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
  23. * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
  24. * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
  25. * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
  26. * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
  27. * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
  28. * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
  29. * POSSIBILITY OF SUCH DAMAGE.
  30. */
  31. /*! \file
  32. * \brief Modification of jpip.c from 2KAN indexer
  33. */
  34. #include <stdio.h>
  35. #include <stdlib.h>
  36. #include <math.h>
  37. #include "opj_includes.h"
  38. /*
  39. * Write faix box of ppix
  40. *
  41. * @param[in] coff offset of j2k codestream
  42. * @param[in] compno component number
  43. * @param[in] cstr_info codestream information
  44. * @param[in] EPHused true if if EPH option used
  45. * @param[in] j2klen length of j2k codestream
  46. * @param[in] cio file output handle
  47. * @return length of faix box
  48. */
  49. int write_ppixfaix( int coff, int compno, opj_codestream_info_t cstr_info, opj_bool EPHused, int j2klen, opj_cio_t *cio);
  50. int write_ppix( int coff, opj_codestream_info_t cstr_info, opj_bool EPHused, int j2klen, opj_cio_t *cio)
  51. {
  52. int len, lenp, compno, i;
  53. opj_jp2_box_t *box;
  54. /* printf("cstr_info.packno %d\n", cstr_info.packno); //NMAX? */
  55. lenp = -1;
  56. box = (opj_jp2_box_t *)opj_calloc( cstr_info.numcomps, sizeof(opj_jp2_box_t));
  57. for (i=0;i<2;i++){
  58. if (i) cio_seek( cio, lenp);
  59. lenp = cio_tell( cio);
  60. cio_skip( cio, 4); /* L [at the end] */
  61. cio_write( cio, JPIP_PPIX, 4); /* PPIX */
  62. write_manf( i, cstr_info.numcomps, box, cio);
  63. for (compno=0; compno<cstr_info.numcomps; compno++){
  64. box[compno].length = write_ppixfaix( coff, compno, cstr_info, EPHused, j2klen, cio);
  65. box[compno].type = JPIP_FAIX;
  66. }
  67. len = cio_tell( cio)-lenp;
  68. cio_seek( cio, lenp);
  69. cio_write( cio, len, 4); /* L */
  70. cio_seek( cio, lenp+len);
  71. }
  72. opj_free(box);
  73. return len;
  74. }
  75. int write_ppixfaix( int coff, int compno, opj_codestream_info_t cstr_info, opj_bool EPHused, int j2klen, opj_cio_t *cio)
  76. {
  77. int len, lenp, tileno, version, i, nmax, size_of_coding; /* 4 or 8*/
  78. opj_tile_info_t *tile_Idx;
  79. opj_packet_info_t packet;
  80. int resno, precno, layno, num_packet;
  81. int numOfres, numOfprec, numOflayers;
  82. packet.end_pos = packet.end_ph_pos = packet.start_pos = -1;
  83. (void)EPHused; /* unused ? */
  84. if( j2klen > pow( 2, 32)){
  85. size_of_coding = 8;
  86. version = 1;
  87. }
  88. else{
  89. size_of_coding = 4;
  90. version = 0;
  91. }
  92. lenp = cio_tell( cio);
  93. cio_skip( cio, 4); /* L [at the end] */
  94. cio_write( cio, JPIP_FAIX, 4); /* FAIX */
  95. cio_write( cio, version, 1); /* Version 0 = 4 bytes */
  96. nmax = 0;
  97. for( i=0; i<=cstr_info.numdecompos[compno]; i++)
  98. nmax += cstr_info.tile[0].ph[i] * cstr_info.tile[0].pw[i] * cstr_info.numlayers;
  99. cio_write( cio, nmax, size_of_coding); /* NMAX */
  100. cio_write( cio, cstr_info.tw*cstr_info.th, size_of_coding); /* M */
  101. for( tileno=0; tileno<cstr_info.tw*cstr_info.th; tileno++){
  102. tile_Idx = &cstr_info.tile[ tileno];
  103. num_packet=0;
  104. numOfres = cstr_info.numdecompos[compno] + 1;
  105. for( resno=0; resno<numOfres ; resno++){
  106. numOfprec = tile_Idx->pw[resno]*tile_Idx->ph[resno];
  107. for( precno=0; precno<numOfprec; precno++){
  108. numOflayers = cstr_info.numlayers;
  109. for( layno=0; layno<numOflayers; layno++){
  110. switch ( cstr_info.prog){
  111. case LRCP:
  112. packet = tile_Idx->packet[ ((layno*numOfres+resno)*cstr_info.numcomps+compno)*numOfprec+precno];
  113. break;
  114. case RLCP:
  115. packet = tile_Idx->packet[ ((resno*numOflayers+layno)*cstr_info.numcomps+compno)*numOfprec+precno];
  116. break;
  117. case RPCL:
  118. packet = tile_Idx->packet[ ((resno*numOfprec+precno)*cstr_info.numcomps+compno)*numOflayers+layno];
  119. break;
  120. case PCRL:
  121. packet = tile_Idx->packet[ ((precno*cstr_info.numcomps+compno)*numOfres+resno)*numOflayers + layno];
  122. break;
  123. case CPRL:
  124. packet = tile_Idx->packet[ ((compno*numOfprec+precno)*numOfres+resno)*numOflayers + layno];
  125. break;
  126. default:
  127. fprintf( stderr, "failed to ppix indexing\n");
  128. }
  129. cio_write( cio, packet.start_pos-coff, size_of_coding); /* start position */
  130. cio_write( cio, packet.end_pos-packet.start_pos+1, size_of_coding); /* length */
  131. num_packet++;
  132. }
  133. }
  134. }
  135. while( num_packet < nmax){ /* PADDING */
  136. cio_write( cio, 0, size_of_coding); /* start position */
  137. cio_write( cio, 0, size_of_coding); /* length */
  138. num_packet++;
  139. }
  140. }
  141. len = cio_tell( cio)-lenp;
  142. cio_seek( cio, lenp);
  143. cio_write( cio, len, 4); /* L */
  144. cio_seek( cio, lenp+len);
  145. return len;
  146. }