tgt.h 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  1. /*
  2. * The copyright in this software is being made available under the 2-clauses
  3. * BSD License, included below. This software may be subject to other third
  4. * party and contributor rights, including patent rights, and no such rights
  5. * are granted under this license.
  6. *
  7. * Copyright (c) 2002-2014, Universite catholique de Louvain (UCL), Belgium
  8. * Copyright (c) 2002-2014, Professor Benoit Macq
  9. * Copyright (c) 2001-2003, David Janssens
  10. * Copyright (c) 2002-2003, Yannick Verschueren
  11. * Copyright (c) 2003-2007, Francois-Olivier Devaux
  12. * Copyright (c) 2003-2014, Antonin Descampe
  13. * Copyright (c) 2005, Herve Drolon, FreeImage Team
  14. * Copyright (c) 2008, Jerome Fimes, Communications & Systemes <jerome.fimes@c-s.fr>
  15. * Copyright (c) 2011-2012, Centre National d'Etudes Spatiales (CNES), France
  16. * Copyright (c) 2012, CS Systemes d'Information, France
  17. * All rights reserved.
  18. *
  19. * Redistribution and use in source and binary forms, with or without
  20. * modification, are permitted provided that the following conditions
  21. * are met:
  22. * 1. Redistributions of source code must retain the above copyright
  23. * notice, this list of conditions and the following disclaimer.
  24. * 2. Redistributions in binary form must reproduce the above copyright
  25. * notice, this list of conditions and the following disclaimer in the
  26. * documentation and/or other materials provided with the distribution.
  27. *
  28. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS `AS IS'
  29. * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  30. * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  31. * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
  32. * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
  33. * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
  34. * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
  35. * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
  36. * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
  37. * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
  38. * POSSIBILITY OF SUCH DAMAGE.
  39. */
  40. #ifndef OPJ_TGT_H
  41. #define OPJ_TGT_H
  42. /**
  43. @file tgt.h
  44. @brief Implementation of a tag-tree coder (TGT)
  45. The functions in TGT.C have for goal to realize a tag-tree coder. The functions in TGT.C
  46. are used by some function in T2.C.
  47. */
  48. /** @defgroup TGT TGT - Implementation of a tag-tree coder */
  49. /*@{*/
  50. /**
  51. Tag node
  52. */
  53. typedef struct opj_tgt_node {
  54. struct opj_tgt_node *parent;
  55. OPJ_INT32 value;
  56. OPJ_INT32 low;
  57. OPJ_UINT32 known;
  58. } opj_tgt_node_t;
  59. /**
  60. Tag tree
  61. */
  62. typedef struct opj_tgt_tree {
  63. OPJ_UINT32 numleafsh;
  64. OPJ_UINT32 numleafsv;
  65. OPJ_UINT32 numnodes;
  66. opj_tgt_node_t *nodes;
  67. OPJ_UINT32 nodes_size; /* maximum size taken by nodes */
  68. } opj_tgt_tree_t;
  69. /** @name Exported functions */
  70. /*@{*/
  71. /* ----------------------------------------------------------------------- */
  72. /**
  73. Create a tag-tree
  74. @param numleafsh Width of the array of leafs of the tree
  75. @param numleafsv Height of the array of leafs of the tree
  76. @param p_manager the event manager
  77. @return Returns a new tag-tree if successful, returns NULL otherwise
  78. */
  79. opj_tgt_tree_t *opj_tgt_create(OPJ_UINT32 numleafsh, OPJ_UINT32 numleafsv,
  80. opj_event_mgr_t *p_manager);
  81. /**
  82. * Reinitialises a tag-tree from an exixting one.
  83. *
  84. * @param p_tree the tree to reinitialize.
  85. * @param p_num_leafs_h the width of the array of leafs of the tree
  86. * @param p_num_leafs_v the height of the array of leafs of the tree
  87. * @param p_manager the event manager
  88. * @return a new tag-tree if successful, NULL otherwise
  89. */
  90. opj_tgt_tree_t *opj_tgt_init(opj_tgt_tree_t * p_tree,
  91. OPJ_UINT32 p_num_leafs_h,
  92. OPJ_UINT32 p_num_leafs_v, opj_event_mgr_t *p_manager);
  93. /**
  94. Destroy a tag-tree, liberating memory
  95. @param tree Tag-tree to destroy
  96. */
  97. void opj_tgt_destroy(opj_tgt_tree_t *tree);
  98. /**
  99. Reset a tag-tree (set all leaves to 0)
  100. @param tree Tag-tree to reset
  101. */
  102. void opj_tgt_reset(opj_tgt_tree_t *tree);
  103. /**
  104. Set the value of a leaf of a tag-tree
  105. @param tree Tag-tree to modify
  106. @param leafno Number that identifies the leaf to modify
  107. @param value New value of the leaf
  108. */
  109. void opj_tgt_setvalue(opj_tgt_tree_t *tree,
  110. OPJ_UINT32 leafno,
  111. OPJ_INT32 value);
  112. /**
  113. Encode the value of a leaf of the tag-tree up to a given threshold
  114. @param bio Pointer to a BIO handle
  115. @param tree Tag-tree to modify
  116. @param leafno Number that identifies the leaf to encode
  117. @param threshold Threshold to use when encoding value of the leaf
  118. */
  119. void opj_tgt_encode(opj_bio_t *bio,
  120. opj_tgt_tree_t *tree,
  121. OPJ_UINT32 leafno,
  122. OPJ_INT32 threshold);
  123. /**
  124. Decode the value of a leaf of the tag-tree up to a given threshold
  125. @param bio Pointer to a BIO handle
  126. @param tree Tag-tree to decode
  127. @param leafno Number that identifies the leaf to decode
  128. @param threshold Threshold to use when decoding value of the leaf
  129. @return Returns 1 if the node's value < threshold, returns 0 otherwise
  130. */
  131. OPJ_UINT32 opj_tgt_decode(opj_bio_t *bio,
  132. opj_tgt_tree_t *tree,
  133. OPJ_UINT32 leafno,
  134. OPJ_INT32 threshold);
  135. /* ----------------------------------------------------------------------- */
  136. /*@}*/
  137. /*@}*/
  138. #endif /* OPJ_TGT_H */