1*fb1b10abSAndroid Build Coastguard Worker /* 2*fb1b10abSAndroid Build Coastguard Worker * Copyright (c) 2016 The WebM project authors. All Rights Reserved. 3*fb1b10abSAndroid Build Coastguard Worker * 4*fb1b10abSAndroid Build Coastguard Worker * Use of this source code is governed by a BSD-style license 5*fb1b10abSAndroid Build Coastguard Worker * that can be found in the LICENSE file in the root of the source 6*fb1b10abSAndroid Build Coastguard Worker * tree. An additional intellectual property rights grant can be found 7*fb1b10abSAndroid Build Coastguard Worker * in the file PATENTS. All contributing project authors may 8*fb1b10abSAndroid Build Coastguard Worker * be found in the AUTHORS file in the root of the source tree. 9*fb1b10abSAndroid Build Coastguard Worker */ 10*fb1b10abSAndroid Build Coastguard Worker 11*fb1b10abSAndroid Build Coastguard Worker #include "./vpx_dsp_rtcd.h" 12*fb1b10abSAndroid Build Coastguard Worker vpx_sum_squares_2d_i16_c(const int16_t * src,int stride,int size)13*fb1b10abSAndroid Build Coastguard Workeruint64_t vpx_sum_squares_2d_i16_c(const int16_t *src, int stride, int size) { 14*fb1b10abSAndroid Build Coastguard Worker int r, c; 15*fb1b10abSAndroid Build Coastguard Worker uint64_t ss = 0; 16*fb1b10abSAndroid Build Coastguard Worker 17*fb1b10abSAndroid Build Coastguard Worker for (r = 0; r < size; r++) { 18*fb1b10abSAndroid Build Coastguard Worker for (c = 0; c < size; c++) { 19*fb1b10abSAndroid Build Coastguard Worker const int16_t v = src[c]; 20*fb1b10abSAndroid Build Coastguard Worker ss += v * v; 21*fb1b10abSAndroid Build Coastguard Worker } 22*fb1b10abSAndroid Build Coastguard Worker src += stride; 23*fb1b10abSAndroid Build Coastguard Worker } 24*fb1b10abSAndroid Build Coastguard Worker 25*fb1b10abSAndroid Build Coastguard Worker return ss; 26*fb1b10abSAndroid Build Coastguard Worker } 27