/////////////////////////////////////////////////////////////////////////////// // /// \file price_tablegen.c /// \brief Probability price table generator /// /// Compiling: gcc -std=c99 -o price_tablegen price_tablegen.c /// // Authors: Igor Pavlov // Lasse Collin // // This file has been put into the public domain. // You can do whatever you want with this file. // /////////////////////////////////////////////////////////////////////////////// #include <inttypes.h> #include <stdio.h> #include "range_common.h" #include "price.h" static uint32_t rc_prices[RC_PRICE_TABLE_SIZE]; static void init_price_table(void) { for (uint32_t i = (UINT32_C(1) << RC_MOVE_REDUCING_BITS) / 2; i < RC_BIT_MODEL_TOTAL; i += (UINT32_C(1) << RC_MOVE_REDUCING_BITS)) { const uint32_t cycles_bits = RC_BIT_PRICE_SHIFT_BITS; uint32_t w = i; uint32_t bit_count = 0; for (uint32_t j = 0; j < cycles_bits; ++j) { w *= w; bit_count <<= 1; while (w >= (UINT32_C(1) << 16)) { w >>= 1; ++bit_count; } } rc_prices[i >> RC_MOVE_REDUCING_BITS] = (RC_BIT_MODEL_TOTAL_BITS << cycles_bits) - 15 - bit_count; } return; } static void print_price_table(void) { printf("/* This file has been automatically generated by " "price_tablegen.c. */\n\n" "#include \"range_encoder.h\"\n\n" "const uint8_t lzma_rc_prices[" "RC_PRICE_TABLE_SIZE] = {"); const size_t array_size = sizeof(lzma_rc_prices) / sizeof(lzma_rc_prices[0]); for (size_t i = 0; i < array_size; ++i) { if (i % 8 == 0) printf("\n\t"); printf("%4" PRIu32, rc_prices[i]); if (i != array_size - 1) printf(","); } printf("\n};\n"); return; } int main(void) { init_price_table(); print_price_table(); return 0; } |