* Combined Workspace for Encoder and Decoder * Addressed review comments and some minor edits --------- Co-authored-by: Divya B M <100655@ittiam.com>
80 lines
2.8 KiB
C
80 lines
2.8 KiB
C
/******************************************************************************
|
|
* *
|
|
* Copyright (C) 2023 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
|
|
*/
|
|
|
|
#include <math.h>
|
|
#include "ixheaac_type_def.h"
|
|
#include "ixheaace_mps_common_fix.h"
|
|
#include "ixheaace_mps_defines.h"
|
|
#include "ixheaace_mps_common_define.h"
|
|
|
|
FLOAT32
|
|
ixheaace_mps_212_sum_up_cplx_pow_2_dim_2(ixheaace_cmplx_str inp[MAX_ANA_TIME_SLOT][MAX_QMF_BANDS],
|
|
const WORD32 start_dim_1, const WORD32 stop_dim_1,
|
|
const WORD32 start_dim_2, const WORD32 stop_dim_2) {
|
|
WORD32 idx_1, idx_2;
|
|
|
|
FLOAT32 sum;
|
|
sum = 0.0f;
|
|
for (idx_1 = start_dim_1; idx_1 < stop_dim_1; idx_1++) {
|
|
for (idx_2 = start_dim_2; idx_2 < stop_dim_2; idx_2++) {
|
|
sum += inp[idx_1][idx_2].re * inp[idx_1][idx_2].re;
|
|
sum += inp[idx_1][idx_2].im * inp[idx_1][idx_2].im;
|
|
}
|
|
}
|
|
return (sum / 2);
|
|
}
|
|
|
|
VOID ixheaace_mps_212_cplx_scalar_product(
|
|
ixheaace_cmplx_str *const out, ixheaace_cmplx_str inp_1[MAX_ANA_TIME_SLOT][MAX_QMF_BANDS],
|
|
ixheaace_cmplx_str inp_2[MAX_ANA_TIME_SLOT][MAX_QMF_BANDS], const WORD32 start_dim_1,
|
|
const WORD32 stop_dim_1, const WORD32 start_dim_2, const WORD32 stop_dim_2) {
|
|
WORD32 idx_1, idx_2;
|
|
FLOAT32 re_x, re_y, im_x, im_y, re, im;
|
|
re = 0.0f;
|
|
im = 0.0f;
|
|
|
|
for (idx_1 = start_dim_1; idx_1 < stop_dim_1; idx_1++) {
|
|
for (idx_2 = start_dim_2; idx_2 < stop_dim_2; idx_2++) {
|
|
re_x = inp_1[idx_1][idx_2].re;
|
|
im_x = inp_1[idx_1][idx_2].im;
|
|
re_y = inp_2[idx_1][idx_2].re;
|
|
im_y = inp_2[idx_1][idx_2].im;
|
|
re += (re_x * re_y) + (im_x * im_y);
|
|
im += (im_x * re_y) - (re_x * im_y);
|
|
}
|
|
}
|
|
|
|
out->re = re / 2;
|
|
out->im = im / 2;
|
|
}
|
|
|
|
FLOAT32 ixheaace_mps_212_sum_up_cplx_pow_2(const ixheaace_cmplx_str *const inp,
|
|
const WORD32 len) {
|
|
WORD32 idx;
|
|
FLOAT32 sum;
|
|
sum = 0.0f;
|
|
|
|
for (idx = 0; idx < len; idx++) {
|
|
sum += inp[idx].re * inp[idx].re;
|
|
sum += inp[idx].im * inp[idx].im;
|
|
}
|
|
|
|
return (sum / 2);
|
|
}
|