1*15dc779aSAndroid Build Coastguard Worker /******************************************************************************
2*15dc779aSAndroid Build Coastguard Worker * *
3*15dc779aSAndroid Build Coastguard Worker * Copyright (C) 2023 The Android Open Source Project
4*15dc779aSAndroid Build Coastguard Worker *
5*15dc779aSAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License");
6*15dc779aSAndroid Build Coastguard Worker * you may not use this file except in compliance with the License.
7*15dc779aSAndroid Build Coastguard Worker * You may obtain a copy of the License at:
8*15dc779aSAndroid Build Coastguard Worker *
9*15dc779aSAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0
10*15dc779aSAndroid Build Coastguard Worker *
11*15dc779aSAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software
12*15dc779aSAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS,
13*15dc779aSAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14*15dc779aSAndroid Build Coastguard Worker * See the License for the specific language governing permissions and
15*15dc779aSAndroid Build Coastguard Worker * limitations under the License.
16*15dc779aSAndroid Build Coastguard Worker *
17*15dc779aSAndroid Build Coastguard Worker *****************************************************************************
18*15dc779aSAndroid Build Coastguard Worker * Originally developed and contributed by Ittiam Systems Pvt. Ltd, Bangalore
19*15dc779aSAndroid Build Coastguard Worker */
20*15dc779aSAndroid Build Coastguard Worker
21*15dc779aSAndroid Build Coastguard Worker #include "ixheaac_type_def.h"
22*15dc779aSAndroid Build Coastguard Worker #include "ixheaace_sbr_misc.h"
23*15dc779aSAndroid Build Coastguard Worker
ixheaace_shellsort_int(WORD32 * ptr_in,WORD32 n)24*15dc779aSAndroid Build Coastguard Worker VOID ixheaace_shellsort_int(WORD32 *ptr_in, WORD32 n) {
25*15dc779aSAndroid Build Coastguard Worker WORD32 i, j, v;
26*15dc779aSAndroid Build Coastguard Worker WORD32 inc = 1;
27*15dc779aSAndroid Build Coastguard Worker
28*15dc779aSAndroid Build Coastguard Worker do {
29*15dc779aSAndroid Build Coastguard Worker inc = 3 * inc + 1;
30*15dc779aSAndroid Build Coastguard Worker } while (inc <= n);
31*15dc779aSAndroid Build Coastguard Worker
32*15dc779aSAndroid Build Coastguard Worker do {
33*15dc779aSAndroid Build Coastguard Worker inc = inc / 3;
34*15dc779aSAndroid Build Coastguard Worker
35*15dc779aSAndroid Build Coastguard Worker for (i = inc + 1; i <= n; i++) {
36*15dc779aSAndroid Build Coastguard Worker v = ptr_in[i - 1];
37*15dc779aSAndroid Build Coastguard Worker j = i;
38*15dc779aSAndroid Build Coastguard Worker
39*15dc779aSAndroid Build Coastguard Worker while (ptr_in[j - inc - 1] > v) {
40*15dc779aSAndroid Build Coastguard Worker ptr_in[j - 1] = ptr_in[j - inc - 1];
41*15dc779aSAndroid Build Coastguard Worker j -= inc;
42*15dc779aSAndroid Build Coastguard Worker
43*15dc779aSAndroid Build Coastguard Worker if (j <= inc) {
44*15dc779aSAndroid Build Coastguard Worker break;
45*15dc779aSAndroid Build Coastguard Worker }
46*15dc779aSAndroid Build Coastguard Worker }
47*15dc779aSAndroid Build Coastguard Worker
48*15dc779aSAndroid Build Coastguard Worker ptr_in[j - 1] = v;
49*15dc779aSAndroid Build Coastguard Worker }
50*15dc779aSAndroid Build Coastguard Worker } while (inc > 1);
51*15dc779aSAndroid Build Coastguard Worker }
52*15dc779aSAndroid Build Coastguard Worker
ixheaace_add_vec_left(WORD32 * ptr_dst,WORD32 * ptr_length_dst,WORD32 * ptr_src,WORD32 length_src)53*15dc779aSAndroid Build Coastguard Worker VOID ixheaace_add_vec_left(WORD32 *ptr_dst, WORD32 *ptr_length_dst, WORD32 *ptr_src,
54*15dc779aSAndroid Build Coastguard Worker WORD32 length_src) {
55*15dc779aSAndroid Build Coastguard Worker WORD32 i;
56*15dc779aSAndroid Build Coastguard Worker
57*15dc779aSAndroid Build Coastguard Worker for (i = length_src - 1; i >= 0; i--) {
58*15dc779aSAndroid Build Coastguard Worker ixheaace_add_left(ptr_dst, ptr_length_dst, ptr_src[i]);
59*15dc779aSAndroid Build Coastguard Worker }
60*15dc779aSAndroid Build Coastguard Worker }
61*15dc779aSAndroid Build Coastguard Worker
ixheaace_add_left(WORD32 * ptr_vector,WORD32 * ptr_length_vector,WORD32 value)62*15dc779aSAndroid Build Coastguard Worker VOID ixheaace_add_left(WORD32 *ptr_vector, WORD32 *ptr_length_vector, WORD32 value) {
63*15dc779aSAndroid Build Coastguard Worker WORD32 i;
64*15dc779aSAndroid Build Coastguard Worker
65*15dc779aSAndroid Build Coastguard Worker for (i = *ptr_length_vector; i > 0; i--) {
66*15dc779aSAndroid Build Coastguard Worker ptr_vector[i] = ptr_vector[i - 1];
67*15dc779aSAndroid Build Coastguard Worker }
68*15dc779aSAndroid Build Coastguard Worker
69*15dc779aSAndroid Build Coastguard Worker ptr_vector[0] = value;
70*15dc779aSAndroid Build Coastguard Worker
71*15dc779aSAndroid Build Coastguard Worker (*ptr_length_vector)++;
72*15dc779aSAndroid Build Coastguard Worker }
73*15dc779aSAndroid Build Coastguard Worker
ixheaace_add_right(WORD32 * ptr_vector,WORD32 * ptr_length_vector,WORD32 value)74*15dc779aSAndroid Build Coastguard Worker VOID ixheaace_add_right(WORD32 *ptr_vector, WORD32 *ptr_length_vector, WORD32 value) {
75*15dc779aSAndroid Build Coastguard Worker ptr_vector[*ptr_length_vector] = value;
76*15dc779aSAndroid Build Coastguard Worker
77*15dc779aSAndroid Build Coastguard Worker (*ptr_length_vector)++;
78*15dc779aSAndroid Build Coastguard Worker }
79