"L. Spiro Engine"
|
00001 /* 00002 * Copyright (c) 2002-2007, Communications and Remote Sensing Laboratory, Universite catholique de Louvain (UCL), Belgium 00003 * Copyright (c) 2002-2007, Professor Benoit Macq 00004 * Copyright (c) 2001-2003, David Janssens 00005 * Copyright (c) 2002-2003, Yannick Verschueren 00006 * Copyright (c) 2003-2007, Francois-Olivier Devaux and Antonin Descampe 00007 * Copyright (c) 2005, Herve Drolon, FreeImage Team 00008 * All rights reserved. 00009 * 00010 * Redistribution and use in source and binary forms, with or without 00011 * modification, are permitted provided that the following conditions 00012 * are met: 00013 * 1. Redistributions of source code must retain the above copyright 00014 * notice, this list of conditions and the following disclaimer. 00015 * 2. Redistributions in binary form must reproduce the above copyright 00016 * notice, this list of conditions and the following disclaimer in the 00017 * documentation and/or other materials provided with the distribution. 00018 * 00019 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS `AS IS' 00020 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 00021 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 00022 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE 00023 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 00024 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 00025 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 00026 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 00027 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 00028 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 00029 * POSSIBILITY OF SUCH DAMAGE. 00030 */ 00031 00032 00033 #ifndef __LSI_TGT_H__ 00034 #define __LSI_TGT_H__ 00035 00036 #include "../LSIImageLib.h" 00037 #include "LSIBio.h" 00038 00039 namespace lsi { 00040 00047 class CTgt { 00048 public : 00049 // == Types. 00053 typedef struct opj_tgt_node_t { 00054 opj_tgt_node_t * parent; 00055 LSINT32 value; 00056 LSINT32 low; 00057 LSINT32 known; 00058 } * LPopj_tgt_node_t, * const LPCopj_tgt_node_t; 00059 00063 typedef struct opj_tgt_tree_t { 00064 LSINT32 numleafsh; 00065 LSINT32 numleafsv; 00066 LSINT32 numnodes; 00067 opj_tgt_node_t * nodes; 00068 } * LPopj_tgt_tree_t, * const LPCopj_tgt_tree_t; 00069 00070 00071 // == Functions. 00079 static opj_tgt_tree_t * LSE_CALL tgt_create( LSINT32 _i32NumLeafSh, LSINT32 _i32NumLeafSv ); 00080 00086 static LSVOID LSE_CALL tgt_destroy( opj_tgt_tree_t * _pttTree ); 00087 00093 static LSVOID LSE_CALL tgt_reset( opj_tgt_tree_t * _pttTree ); 00094 00102 static LSVOID LSE_CALL tgt_setvalue( opj_tgt_tree_t * _pttTree, LSINT32 _i32LeafNo, LSINT32 _i32Value ); 00103 00112 static LSVOID LSE_CALL tgt_encode( CBio::opj_bio_t * _pbBio, opj_tgt_tree_t * _pttTree, LSINT32 _i32LeafNo, LSINT32 _i32Threshold ); 00113 00123 static LSINT32 LSE_CALL tgt_decode( CBio::opj_bio_t * _pbBio, opj_tgt_tree_t * _pttTree, LSINT32 _i32LeafNo, LSINT32 _i32Threshold ); 00124 00125 00126 protected : 00127 00128 00129 }; 00130 00131 } // namespace lsi 00132 00133 #endif // __LSI_TGT_H__