| 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 | * All rights reserved. |
| 16 | * |
| 17 | * Redistribution and use in source and binary forms, with or without |
| 18 | * modification, are permitted provided that the following conditions |
| 19 | * are met: |
| 20 | * 1. Redistributions of source code must retain the above copyright |
| 21 | * notice, this list of conditions and the following disclaimer. |
| 22 | * 2. Redistributions in binary form must reproduce the above copyright |
| 23 | * notice, this list of conditions and the following disclaimer in the |
| 24 | * documentation and/or other materials provided with the distribution. |
| 25 | * |
| 26 | * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS `AS IS' |
| 27 | * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE |
| 28 | * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE |
| 29 | * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE |
| 30 | * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR |
| 31 | * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF |
| 32 | * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS |
| 33 | * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN |
| 34 | * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) |
| 35 | * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE |
| 36 | * POSSIBILITY OF SUCH DAMAGE. |
| 37 | */ |
| 38 | |
| 39 | #ifndef OPJ_MQC_H |
| 40 | #define OPJ_MQC_H |
| 41 | |
| 42 | #include "opj_common.h" |
| 43 | |
| 44 | /** |
| 45 | @file mqc.h |
| 46 | @brief Implementation of an MQ-Coder (MQC) |
| 47 | |
| 48 | The functions in MQC.C have for goal to realize the MQ-coder operations. The functions |
| 49 | in MQC.C are used by some function in T1.C. |
| 50 | */ |
| 51 | |
| 52 | /** @defgroup MQC MQC - Implementation of an MQ-Coder */ |
| 53 | /*@{*/ |
| 54 | |
| 55 | /** |
| 56 | This struct defines the state of a context. |
| 57 | */ |
| 58 | typedef struct opj_mqc_state { |
| 59 | /** the probability of the Least Probable Symbol (0.75->0x8000, 1.5->0xffff) */ |
| 60 | OPJ_UINT32 qeval; |
| 61 | /** the Most Probable Symbol (0 or 1) */ |
| 62 | OPJ_UINT32 mps; |
| 63 | /** next state if the next encoded symbol is the MPS */ |
| 64 | const struct opj_mqc_state *nmps; |
| 65 | /** next state if the next encoded symbol is the LPS */ |
| 66 | const struct opj_mqc_state *nlps; |
| 67 | } opj_mqc_state_t; |
| 68 | |
| 69 | #define MQC_NUMCTXS 19 |
| 70 | |
| 71 | /** |
| 72 | MQ coder |
| 73 | */ |
| 74 | typedef struct opj_mqc { |
| 75 | /** temporary buffer where bits are coded or decoded */ |
| 76 | OPJ_UINT32 c; |
| 77 | /** only used by MQ decoder */ |
| 78 | OPJ_UINT32 a; |
| 79 | /** number of bits already read or free to write */ |
| 80 | OPJ_UINT32 ct; |
| 81 | /* only used by decoder, to count the number of times a terminating 0xFF >0x8F marker is read */ |
| 82 | OPJ_UINT32 end_of_byte_stream_counter; |
| 83 | /** pointer to the current position in the buffer */ |
| 84 | OPJ_BYTE *bp; |
| 85 | /** pointer to the start of the buffer */ |
| 86 | OPJ_BYTE *start; |
| 87 | /** pointer to the end of the buffer */ |
| 88 | OPJ_BYTE *end; |
| 89 | /** Array of contexts */ |
| 90 | const opj_mqc_state_t *ctxs[MQC_NUMCTXS]; |
| 91 | /** Active context */ |
| 92 | const opj_mqc_state_t **curctx; |
| 93 | /* lut_ctxno_zc shifted by (1 << 9) * bandno */ |
| 94 | const OPJ_BYTE* lut_ctxno_zc_orient; |
| 95 | /** Original value of the 2 bytes at end[0] and end[1] */ |
| 96 | OPJ_BYTE backup[OPJ_COMMON_CBLK_DATA_EXTRA]; |
| 97 | } opj_mqc_t; |
| 98 | |
| 99 | #include "mqc_inl.h" |
| 100 | |
| 101 | /** @name Exported functions */ |
| 102 | /*@{*/ |
| 103 | /* ----------------------------------------------------------------------- */ |
| 104 | |
| 105 | /** |
| 106 | Return the number of bytes written/read since initialisation |
| 107 | @param mqc MQC handle |
| 108 | @return Returns the number of bytes already encoded |
| 109 | */ |
| 110 | OPJ_UINT32 opj_mqc_numbytes(opj_mqc_t *mqc); |
| 111 | /** |
| 112 | Reset the states of all the context of the coder/decoder |
| 113 | (each context is set to a state where 0 and 1 are more or less equiprobable) |
| 114 | @param mqc MQC handle |
| 115 | */ |
| 116 | void opj_mqc_resetstates(opj_mqc_t *mqc); |
| 117 | /** |
| 118 | Set the state of a particular context |
| 119 | @param mqc MQC handle |
| 120 | @param ctxno Number that identifies the context |
| 121 | @param msb The MSB of the new state of the context |
| 122 | @param prob Number that identifies the probability of the symbols for the new state of the context |
| 123 | */ |
| 124 | void opj_mqc_setstate(opj_mqc_t *mqc, OPJ_UINT32 ctxno, OPJ_UINT32 msb, |
| 125 | OPJ_INT32 prob); |
| 126 | /** |
| 127 | Initialize the encoder |
| 128 | @param mqc MQC handle |
| 129 | @param bp Pointer to the start of the buffer where the bytes will be written |
| 130 | */ |
| 131 | void opj_mqc_init_enc(opj_mqc_t *mqc, OPJ_BYTE *bp); |
| 132 | /** |
| 133 | Set the current context used for coding/decoding |
| 134 | @param mqc MQC handle |
| 135 | @param ctxno Number that identifies the context |
| 136 | */ |
| 137 | #define opj_mqc_setcurctx(mqc, ctxno) (mqc)->curctx = &(mqc)->ctxs[(OPJ_UINT32)(ctxno)] |
| 138 | /** |
| 139 | Encode a symbol using the MQ-coder |
| 140 | @param mqc MQC handle |
| 141 | @param d The symbol to be encoded (0 or 1) |
| 142 | */ |
| 143 | void opj_mqc_encode(opj_mqc_t *mqc, OPJ_UINT32 d); |
| 144 | /** |
| 145 | Flush the encoder, so that all remaining data is written |
| 146 | @param mqc MQC handle |
| 147 | */ |
| 148 | void opj_mqc_flush(opj_mqc_t *mqc); |
| 149 | /** |
| 150 | BYPASS mode switch, initialization operation. |
| 151 | JPEG 2000 p 505. |
| 152 | @param mqc MQC handle |
| 153 | */ |
| 154 | void opj_mqc_bypass_init_enc(opj_mqc_t *mqc); |
| 155 | |
| 156 | /** Return number of extra bytes to add to opj_mqc_numbytes() for the² |
| 157 | size of a non-terminating BYPASS pass |
| 158 | @param mqc MQC handle |
| 159 | @param erterm 1 if ERTERM is enabled, 0 otherwise |
| 160 | */ |
| 161 | OPJ_UINT32 (opj_mqc_t *mqc, OPJ_BOOL erterm); |
| 162 | |
| 163 | /** |
| 164 | BYPASS mode switch, coding operation. |
| 165 | JPEG 2000 p 505. |
| 166 | @param mqc MQC handle |
| 167 | @param d The symbol to be encoded (0 or 1) |
| 168 | */ |
| 169 | void opj_mqc_bypass_enc(opj_mqc_t *mqc, OPJ_UINT32 d); |
| 170 | /** |
| 171 | BYPASS mode switch, flush operation |
| 172 | @param mqc MQC handle |
| 173 | @param erterm 1 if ERTERM is enabled, 0 otherwise |
| 174 | */ |
| 175 | void opj_mqc_bypass_flush_enc(opj_mqc_t *mqc, OPJ_BOOL erterm); |
| 176 | /** |
| 177 | RESET mode switch |
| 178 | @param mqc MQC handle |
| 179 | */ |
| 180 | void opj_mqc_reset_enc(opj_mqc_t *mqc); |
| 181 | |
| 182 | #ifdef notdef |
| 183 | /** |
| 184 | RESTART mode switch (TERMALL) |
| 185 | @param mqc MQC handle |
| 186 | @return Returns 1 (always) |
| 187 | */ |
| 188 | OPJ_UINT32 opj_mqc_restart_enc(opj_mqc_t *mqc); |
| 189 | #endif |
| 190 | |
| 191 | /** |
| 192 | RESTART mode switch (TERMALL) reinitialisation |
| 193 | @param mqc MQC handle |
| 194 | */ |
| 195 | void opj_mqc_restart_init_enc(opj_mqc_t *mqc); |
| 196 | /** |
| 197 | ERTERM mode switch (PTERM) |
| 198 | @param mqc MQC handle |
| 199 | */ |
| 200 | void opj_mqc_erterm_enc(opj_mqc_t *mqc); |
| 201 | /** |
| 202 | SEGMARK mode switch (SEGSYM) |
| 203 | @param mqc MQC handle |
| 204 | */ |
| 205 | void opj_mqc_segmark_enc(opj_mqc_t *mqc); |
| 206 | |
| 207 | /** |
| 208 | Initialize the decoder for MQ decoding. |
| 209 | |
| 210 | opj_mqc_finish_dec() must be absolutely called after finishing the decoding |
| 211 | passes, so as to restore the bytes temporarily overwritten. |
| 212 | |
| 213 | @param mqc MQC handle |
| 214 | @param bp Pointer to the start of the buffer from which the bytes will be read |
| 215 | Note that OPJ_COMMON_CBLK_DATA_EXTRA bytes at the end of the buffer |
| 216 | will be temporarily overwritten with an artificial 0xFF 0xFF marker. |
| 217 | (they will be backuped in the mqc structure to be restored later) |
| 218 | So bp must be at least len + OPJ_COMMON_CBLK_DATA_EXTRA large, and |
| 219 | writable. |
| 220 | @param len Length of the input buffer |
| 221 | @param extra_writable_bytes Indicate how many bytes after len are writable. |
| 222 | This is to indicate your consent that bp must be |
| 223 | large enough. |
| 224 | */ |
| 225 | void opj_mqc_init_dec(opj_mqc_t *mqc, OPJ_BYTE *bp, OPJ_UINT32 len, |
| 226 | OPJ_UINT32 ); |
| 227 | |
| 228 | /** |
| 229 | Initialize the decoder for RAW decoding. |
| 230 | |
| 231 | opj_mqc_finish_dec() must be absolutely called after finishing the decoding |
| 232 | passes, so as to restore the bytes temporarily overwritten. |
| 233 | |
| 234 | @param mqc MQC handle |
| 235 | @param bp Pointer to the start of the buffer from which the bytes will be read |
| 236 | Note that OPJ_COMMON_CBLK_DATA_EXTRA bytes at the end of the buffer |
| 237 | will be temporarily overwritten with an artificial 0xFF 0xFF marker. |
| 238 | (they will be backuped in the mqc structure to be restored later) |
| 239 | So bp must be at least len + OPJ_COMMON_CBLK_DATA_EXTRA large, and |
| 240 | writable. |
| 241 | @param len Length of the input buffer |
| 242 | @param extra_writable_bytes Indicate how many bytes after len are writable. |
| 243 | This is to indicate your consent that bp must be |
| 244 | large enough. |
| 245 | */ |
| 246 | void opj_mqc_raw_init_dec(opj_mqc_t *mqc, OPJ_BYTE *bp, OPJ_UINT32 len, |
| 247 | OPJ_UINT32 ); |
| 248 | |
| 249 | |
| 250 | /** |
| 251 | Terminate RAW/MQC decoding |
| 252 | |
| 253 | This restores the bytes temporarily overwritten by opj_mqc_init_dec()/ |
| 254 | opj_mqc_raw_init_dec() |
| 255 | |
| 256 | @param mqc MQC handle |
| 257 | */ |
| 258 | void opq_mqc_finish_dec(opj_mqc_t *mqc); |
| 259 | |
| 260 | /** |
| 261 | Decode a symbol |
| 262 | @param mqc MQC handle |
| 263 | @return Returns the decoded symbol (0 or 1) |
| 264 | */ |
| 265 | /*static INLINE OPJ_UINT32 opj_mqc_decode(opj_mqc_t * const mqc);*/ |
| 266 | /* ----------------------------------------------------------------------- */ |
| 267 | /*@}*/ |
| 268 | |
| 269 | /*@}*/ |
| 270 | |
| 271 | #endif /* OPJ_MQC_H */ |
| 272 | |