/* =============================================================================== FILE: field_rgb14.hpp CONTENTS: PROGRAMMERS: martin.isenburg@rapidlasso.com - http://rapidlasso.com uday.karan@gmail.com - Hobu, Inc. COPYRIGHT: (c) 2007-2014, martin isenburg, rapidlasso - tools to catch reality (c) 2014, Uday Verma, Hobu, Inc. This is free software; you can redistribute and/or modify it under the terms of the GNU Lesser General Licence as published by the Free Software Foundation. See the COPYING file for more information. This software is distributed WITHOUT ANY WARRANTY and without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. CHANGE HISTORY: =============================================================================== */ namespace lazperf { namespace detail { class Rgb14Base { protected: struct ChannelCtx { int have_last_; las::rgb14 last_; models::arithmetic used_model_; std::array diff_model_; ChannelCtx() : have_last_{false}, used_model_(128), diff_model_{ models::arithmetic(256), models::arithmetic(256), models::arithmetic(256), models::arithmetic(256), models::arithmetic(256), models::arithmetic(256) } {} }; std::array chan_ctxs_; int last_channel_ = -1; }; class Rgb14Compressor : public Rgb14Base { public: Rgb14Compressor(OutCbStream& stream) : stream_(stream), rgb_enc_(false) {} void writeSizes(); void writeData(); const char *compress(const char *buf, int& sc); private: OutCbStream& stream_; encoders::arithmetic rgb_enc_; }; class Rgb14Decompressor : public Rgb14Base { public: Rgb14Decompressor(InCbStream& stream) : stream_(stream) {} void dumpSums(); void readSizes(); void readData(); char *decompress(char *buf, int& sc); private: InCbStream& stream_; uint32_t rgb_cnt_; decoders::arithmetic rgb_dec_; utils::Summer sumRgb; }; } // namespace detail } // namespace laszip