You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

general_bitpacking.h 1.5 kB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. /**
  2. * Copyright 2020 Huawei Technologies Co., Ltd
  3. *
  4. * Licensed under the Apache License, Version 2.0 (the "License");
  5. * you may not use this file except in compliance with the License.
  6. * You may obtain a copy of the License at
  7. *
  8. * http://www.apache.org/licenses/LICENSE-2.0
  9. *
  10. * Unless required by applicable law or agreed to in writing, software
  11. * distributed under the License is distributed on an "AS IS" BASIS,
  12. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. * See the License for the specific language governing permissions and
  14. * limitations under the License.
  15. */
  16. #ifndef MINDSPORE_LITE_TOOLS_CONVERTER_QUANTIZER__GENERAL_BITPACKING_H
  17. #define MINDSPORE_LITE_TOOLS_CONVERTER_QUANTIZER__GENERAL_BITPACKING_H
  18. #include <stdint.h>
  19. #include <stack>
  20. #include <queue>
  21. #include <vector>
  22. #include <cassert>
  23. namespace mindspore {
  24. namespace lite {
  25. class BitPack {
  26. public:
  27. explicit BitPack(const uint8_t &bitbum = 8);
  28. ~BitPack() = default;
  29. void BitPacking(const std::vector<uint8_t> &originDataVec, std::vector<uint8_t> &packedDataVec);
  30. void UnPack(uint8_t bitnum, uint8_t &packedData, std::vector<uint8_t> &originData, std::queue<bool> &unpackBitData);
  31. private:
  32. void UnPackFromUint8ToOrigin(uint8_t &n, std::queue<bool> &unpackBitData);
  33. void PackFromOriginToUint8(std::stack<bool> &ans, std::vector<uint8_t> &packedDataVec);
  34. void DoBinary(uint8_t &n, std::stack<bool> &ans, std::vector<uint8_t> &packed_data_vec);
  35. uint8_t bitnum;
  36. };
  37. } // namespace lite
  38. } // namespace mindspore
  39. #endif