1*d9f75844SAndroid Build Coastguard Worker /* 2*d9f75844SAndroid Build Coastguard Worker * Copyright (c) 2011 The WebRTC project authors. All Rights Reserved. 3*d9f75844SAndroid Build Coastguard Worker * 4*d9f75844SAndroid Build Coastguard Worker * Use of this source code is governed by a BSD-style license 5*d9f75844SAndroid Build Coastguard Worker * that can be found in the LICENSE file in the root of the source 6*d9f75844SAndroid Build Coastguard Worker * tree. An additional intellectual property rights grant can be found 7*d9f75844SAndroid Build Coastguard Worker * in the file PATENTS. All contributing project authors may 8*d9f75844SAndroid Build Coastguard Worker * be found in the AUTHORS file in the root of the source tree. 9*d9f75844SAndroid Build Coastguard Worker */ 10*d9f75844SAndroid Build Coastguard Worker 11*d9f75844SAndroid Build Coastguard Worker 12*d9f75844SAndroid Build Coastguard Worker /* 13*d9f75844SAndroid Build Coastguard Worker * This file contains the function WebRtcSpl_Energy(). 14*d9f75844SAndroid Build Coastguard Worker * The description header can be found in signal_processing_library.h 15*d9f75844SAndroid Build Coastguard Worker * 16*d9f75844SAndroid Build Coastguard Worker */ 17*d9f75844SAndroid Build Coastguard Worker 18*d9f75844SAndroid Build Coastguard Worker #include "common_audio/signal_processing/include/signal_processing_library.h" 19*d9f75844SAndroid Build Coastguard Worker WebRtcSpl_Energy(int16_t * vector,size_t vector_length,int * scale_factor)20*d9f75844SAndroid Build Coastguard Workerint32_t WebRtcSpl_Energy(int16_t* vector, 21*d9f75844SAndroid Build Coastguard Worker size_t vector_length, 22*d9f75844SAndroid Build Coastguard Worker int* scale_factor) 23*d9f75844SAndroid Build Coastguard Worker { 24*d9f75844SAndroid Build Coastguard Worker int32_t en = 0; 25*d9f75844SAndroid Build Coastguard Worker size_t i; 26*d9f75844SAndroid Build Coastguard Worker int scaling = 27*d9f75844SAndroid Build Coastguard Worker WebRtcSpl_GetScalingSquare(vector, vector_length, vector_length); 28*d9f75844SAndroid Build Coastguard Worker size_t looptimes = vector_length; 29*d9f75844SAndroid Build Coastguard Worker int16_t *vectorptr = vector; 30*d9f75844SAndroid Build Coastguard Worker 31*d9f75844SAndroid Build Coastguard Worker for (i = 0; i < looptimes; i++) 32*d9f75844SAndroid Build Coastguard Worker { 33*d9f75844SAndroid Build Coastguard Worker en += (*vectorptr * *vectorptr) >> scaling; 34*d9f75844SAndroid Build Coastguard Worker vectorptr++; 35*d9f75844SAndroid Build Coastguard Worker } 36*d9f75844SAndroid Build Coastguard Worker *scale_factor = scaling; 37*d9f75844SAndroid Build Coastguard Worker 38*d9f75844SAndroid Build Coastguard Worker return en; 39*d9f75844SAndroid Build Coastguard Worker } 40