"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 #ifndef __LSI_MCT_H__ 00033 #define __LSI_MCT_H__ 00034 00035 #include "../LSIImageLib.h" 00036 00037 namespace lsi { 00038 00045 class CMct { 00046 public : 00047 // == Functions. 00056 static LSVOID LSE_CALL mct_encode( LSINT32 * _pi32C0, LSINT32 * _pi32C1, LSINT32 * _pi32C2, LSINT32 _i32N ); 00057 00066 static LSVOID LSE_CALL mct_decode( LSINT32 * _pi32C0, LSINT32 * _pi32C1, LSINT32 * _pi32C2, LSINT32 _i32N ); 00067 00074 static LSDOUBLE LSE_CALL mct_getnorm( LSINT32 _i32CompNo ); 00075 00084 static LSVOID LSE_CALL mct_encode_real( LSINT32 * _pi32C0, LSINT32 * _pi32C1, LSINT32 * _pi32C2, LSINT32 _i32N ); 00085 00094 static LSVOID LSE_CALL mct_decode_real( LSFLOAT * _pfC0, LSFLOAT * _pfC1, LSFLOAT * _pfC2, LSINT32 _i32N ); 00095 00102 static LSDOUBLE LSE_CALL mct_getnorm_real( LSINT32 _i32CompNo ); 00103 00104 00105 protected : 00106 // == Members. 00110 static const LSDOUBLE m_dNorms[3]; 00111 00115 static const LSDOUBLE m_dNormsReal[3]; 00116 }; 00117 00118 } // namespace lsi 00119 00120 #endif // __LSI_MCT_H__