xref: /aosp_15_r20/external/libaom/aom_dsp/blk_sse_sum.c (revision 77c1e3ccc04c968bd2bc212e87364f250e820521)
1*77c1e3ccSAndroid Build Coastguard Worker /*
2*77c1e3ccSAndroid Build Coastguard Worker  * Copyright (c) 2019, Alliance for Open Media. All rights reserved.
3*77c1e3ccSAndroid Build Coastguard Worker  *
4*77c1e3ccSAndroid Build Coastguard Worker  * This source code is subject to the terms of the BSD 2 Clause License and
5*77c1e3ccSAndroid Build Coastguard Worker  * the Alliance for Open Media Patent License 1.0. If the BSD 2 Clause License
6*77c1e3ccSAndroid Build Coastguard Worker  * was not distributed with this source code in the LICENSE file, you can
7*77c1e3ccSAndroid Build Coastguard Worker  * obtain it at www.aomedia.org/license/software. If the Alliance for Open
8*77c1e3ccSAndroid Build Coastguard Worker  * Media Patent License 1.0 was not distributed with this source code in the
9*77c1e3ccSAndroid Build Coastguard Worker  * PATENTS file, you can obtain it at www.aomedia.org/license/patent.
10*77c1e3ccSAndroid Build Coastguard Worker  */
11*77c1e3ccSAndroid Build Coastguard Worker 
12*77c1e3ccSAndroid Build Coastguard Worker #include "config/aom_dsp_rtcd.h"
13*77c1e3ccSAndroid Build Coastguard Worker 
aom_get_blk_sse_sum_c(const int16_t * data,int stride,int bw,int bh,int * x_sum,int64_t * x2_sum)14*77c1e3ccSAndroid Build Coastguard Worker void aom_get_blk_sse_sum_c(const int16_t *data, int stride, int bw, int bh,
15*77c1e3ccSAndroid Build Coastguard Worker                            int *x_sum, int64_t *x2_sum) {
16*77c1e3ccSAndroid Build Coastguard Worker   *x_sum = 0;
17*77c1e3ccSAndroid Build Coastguard Worker   *x2_sum = 0;
18*77c1e3ccSAndroid Build Coastguard Worker   for (int i = 0; i < bh; ++i) {
19*77c1e3ccSAndroid Build Coastguard Worker     for (int j = 0; j < bw; ++j) {
20*77c1e3ccSAndroid Build Coastguard Worker       const int val = data[j];
21*77c1e3ccSAndroid Build Coastguard Worker       *x_sum += val;
22*77c1e3ccSAndroid Build Coastguard Worker       *x2_sum += val * val;
23*77c1e3ccSAndroid Build Coastguard Worker     }
24*77c1e3ccSAndroid Build Coastguard Worker     data += stride;
25*77c1e3ccSAndroid Build Coastguard Worker   }
26*77c1e3ccSAndroid Build Coastguard Worker }
27