1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50
|
//##########################################################################
//# #
//# CLOUDCOMPARE #
//# #
//# This program is free software; you can redistribute it and/or modify #
//# it under the terms of the GNU General Public License as published by #
//# the Free Software Foundation; version 2 or later of the License. #
//# #
//# This program is distributed in the hope that it will be useful, #
//# but WITHOUT ANY WARRANTY; without even the implied warranty of #
//# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the #
//# GNU General Public License for more details. #
//# #
//# COPYRIGHT: EDF R&D / TELECOM ParisTech (ENST-TSI) #
//# #
//##########################################################################
#ifndef CC_NORMAL_COMPRESSOR_HEADER
#define CC_NORMAL_COMPRESSOR_HEADER
//Local
#include "ccBasicTypes.h"
//! Normal compressor
class QCC_DB_LIB_API ccNormalCompressor
{
public:
//! Compressed normals quantization level (number of directions: 2^(2*N+3))
/** \warning Never pass a 'constant initializer' by reference
**/
static const unsigned char QUANTIZE_LEVEL = 9; //2097152 normals * 12 bytes = 24 Mb of memory
//! Last valid normal code
static const unsigned MAX_VALID_NORM_CODE = (1 << (QUANTIZE_LEVEL * 2 + 3)) - 1;
//! Null normal code
static const unsigned NULL_NORM_CODE = MAX_VALID_NORM_CODE + 1;
//! Compression algorithm
static unsigned Compress(const PointCoordinateType N[3]);
//! Decompression algorithm
static void Decompress(unsigned index, PointCoordinateType N[3], unsigned char level = QUANTIZE_LEVEL);
//! Inverts a (compressed) normal
static void InvertNormal(CompressedNormType &code);
};
#endif //CC_NORMAL_COMPRESSOR_HEADER
|