diff options
author | Hamsalekha S <hamsalekha.s@ittiam.com> | 2015-03-13 21:24:58 +0530 |
---|---|---|
committer | Hamsalekha S <hamsalekha.s@ittiam.com> | 2015-04-02 15:59:02 +0530 |
commit | 8d3d303c7942ced6a987a52db8977d768dc3605f (patch) | |
tree | cc806c96794356996b13ba9970941d0aed74a97e /encoder/irc_fixed_point_error_bits.c | |
parent | 3956d913d37327dcb340f836e604b04bd478b158 (diff) | |
download | android_external_libavc-8d3d303c7942ced6a987a52db8977d768dc3605f.tar.gz android_external_libavc-8d3d303c7942ced6a987a52db8977d768dc3605f.tar.bz2 android_external_libavc-8d3d303c7942ced6a987a52db8977d768dc3605f.zip |
Initial version
Change-Id: I7efe9a589cd24edf86e8d086b40c27cbbf8b4017
Diffstat (limited to 'encoder/irc_fixed_point_error_bits.c')
-rwxr-xr-x | encoder/irc_fixed_point_error_bits.c | 185 |
1 files changed, 185 insertions, 0 deletions
diff --git a/encoder/irc_fixed_point_error_bits.c b/encoder/irc_fixed_point_error_bits.c new file mode 100755 index 0000000..42dcfc5 --- /dev/null +++ b/encoder/irc_fixed_point_error_bits.c @@ -0,0 +1,185 @@ +/****************************************************************************** + * + * Copyright (C) 2015 The Android Open Source Project + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at: + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + ***************************************************************************** + * Originally developed and contributed by Ittiam Systems Pvt. Ltd, Bangalore +*/ + +/*****************************************************************************/ +/* File Includes */ +/*****************************************************************************/ + +/* System include files */ +#include <stdio.h> + +/* User include files */ +#include "irc_datatypes.h" +#include "irc_common.h" +#include "irc_cntrl_param.h" +#include "irc_mem_req_and_acq.h" +#include "irc_fixed_point_error_bits.h" + +typedef struct error_bits_t +{ + /* Max tgt frm rate so that dynamic change in frm rate can be handled */ + WORD32 i4_max_tgt_frm_rate; + + /* Cur frm rate */ + WORD32 i4_cur_tgt_frm_rate; + + /* tgt frame rate*/ + WORD32 i4_tgt_frm_rate; + + /* tgt frm rate increment */ + WORD32 i4_tgt_frm_rate_incr; + + /* flag to indicate 1 second is up */ + UWORD8 u1_compute_error_bits; + + /* Bitrate/frame rate value added over a period */ + WORD32 i4_accum_bitrate; + + /* bitrate */ + WORD32 i4_bitrate; + +} error_bits_t; + +WORD32 irc_error_bits_num_fill_use_free_memtab(error_bits_t **pps_error_bits, + itt_memtab_t *ps_memtab, + ITT_FUNC_TYPE_E e_func_type) +{ + WORD32 i4_mem_tab_idx = 0; + static error_bits_t s_error_bits_temp; + + /* + * Hack for all alloc, during which we don't have any state memory. + * Dereferencing can cause issues + */ + if(e_func_type == GET_NUM_MEMTAB || e_func_type == FILL_MEMTAB) + (*pps_error_bits) = &s_error_bits_temp; + + /* For src rate control state structure */ + if(e_func_type != GET_NUM_MEMTAB) + { + fill_memtab(&ps_memtab[i4_mem_tab_idx], sizeof(error_bits_t), + ALIGN_128_BYTE, PERSISTENT, DDR); + use_or_fill_base(&ps_memtab[0], (void**)pps_error_bits, e_func_type); + } + i4_mem_tab_idx++; + + return (i4_mem_tab_idx); +} + +/******************************************************************************* + * @brief Calculates the error bits due to fixed point divisions + ******************************************************************************/ +void irc_init_error_bits(error_bits_t *ps_error_bits, + WORD32 i4_max_tgt_frm_rate, + WORD32 i4_bitrate) +{ + /* Initializing the parameters*/ + ps_error_bits->i4_cur_tgt_frm_rate = 0; + ps_error_bits->i4_max_tgt_frm_rate = i4_max_tgt_frm_rate; + + /* Value by which i4_cur_tgt_frm_rate is incremented every VOP*/ + ps_error_bits->i4_tgt_frm_rate_incr = 1000; + + /*Compute error bits is set to 1 at the end of 1 second*/ + ps_error_bits->u1_compute_error_bits = 0; + ps_error_bits->i4_tgt_frm_rate = i4_max_tgt_frm_rate; + ps_error_bits->i4_accum_bitrate = 0; + ps_error_bits->i4_bitrate = i4_bitrate; +} + +/******************************************************************************* + * @brief Updates the error state + ******************************************************************************/ +void irc_update_error_bits(error_bits_t *ps_error_bits) +{ + WORD32 i4_bits_per_frame; + + X_PROD_Y_DIV_Z(ps_error_bits->i4_bitrate, 1000, + ps_error_bits->i4_tgt_frm_rate, i4_bits_per_frame); + + /* + * This value is incremented every at the end of every VOP by + * i4_tgt_frm_rate_incr + */ + ps_error_bits->i4_cur_tgt_frm_rate += ps_error_bits->i4_tgt_frm_rate_incr; + if(ps_error_bits->u1_compute_error_bits == 1) + { + ps_error_bits->i4_accum_bitrate = 0; + } + ps_error_bits->i4_accum_bitrate += i4_bits_per_frame; + + /* + * When current tgt frm rate is equal or greater than max tgt frame rate + * 1 second is up , compute the error bits + */ + if(ps_error_bits->i4_cur_tgt_frm_rate >= ps_error_bits->i4_max_tgt_frm_rate) + { + ps_error_bits->i4_cur_tgt_frm_rate -= + ps_error_bits->i4_max_tgt_frm_rate; + ps_error_bits->u1_compute_error_bits = 1; + } + else + { + ps_error_bits->u1_compute_error_bits = 0; + } +} + +/******************************************************************************* + * @brief Returns the error bits for the current frame if there are any + * + ******************************************************************************/ +WORD32 irc_get_error_bits(error_bits_t *ps_error_bits) +{ + WORD32 i4_error_bits = 0; + + /*If 1s is up calculate error for the last 1s worth of frames*/ + if(ps_error_bits->u1_compute_error_bits == 1) + { + /*Error = Actual bitrate - bits_per_frame * num of frames*/ + i4_error_bits = ps_error_bits->i4_bitrate + - ps_error_bits->i4_accum_bitrate; + } + + return (i4_error_bits); +} + +/* ***************************************************************************** + * + * @brief Change the frame rate parameter for the error bits state + * + ******************************************************************************/ +void irc_change_frm_rate_in_error_bits(error_bits_t *ps_error_bits, + WORD32 i4_tgt_frm_rate) +{ + /* Value by which i4_cur_tgt_frm_rate is incremented every VOP*/ + ps_error_bits->i4_tgt_frm_rate_incr = (ps_error_bits->i4_max_tgt_frm_rate + * 1000) / i4_tgt_frm_rate; + ps_error_bits->i4_tgt_frm_rate = i4_tgt_frm_rate; +} + +/******************************************************************************* + * @brief Change the bitrate value for error bits module + ******************************************************************************/ +void irc_change_bitrate_in_error_bits(error_bits_t *ps_error_bits, + WORD32 i4_bitrate) +{ + ps_error_bits->i4_bitrate = i4_bitrate; +} + |