You cannot select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
	
	
		
			109 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			C
		
	
			
		
		
	
	
			109 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			C
		
	
| /*
 | |
|  *  Copyright (c) 2011 The WebRTC project authors. All Rights Reserved.
 | |
|  *
 | |
|  *  Use of this source code is governed by a BSD-style license
 | |
|  *  that can be found in the LICENSE file in the root of the source
 | |
|  *  tree. An additional intellectual property rights grant can be found
 | |
|  *  in the file PATENTS.  All contributing project authors may
 | |
|  *  be found in the AUTHORS file in the root of the source tree.
 | |
|  */
 | |
| 
 | |
| 
 | |
| /*
 | |
|  * This file contains the implementation of functions
 | |
|  * WebRtcSpl_MemSetW16()
 | |
|  * WebRtcSpl_MemSetW32()
 | |
|  * WebRtcSpl_MemCpyReversedOrder()
 | |
|  * WebRtcSpl_CopyFromEndW16()
 | |
|  * WebRtcSpl_ZerosArrayW16()
 | |
|  * WebRtcSpl_ZerosArrayW32()
 | |
|  * WebRtcSpl_OnesArrayW16()
 | |
|  * WebRtcSpl_OnesArrayW32()
 | |
|  *
 | |
|  * The description header can be found in signal_processing_library.h
 | |
|  *
 | |
|  */
 | |
| 
 | |
| #include <string.h>
 | |
| #include "webrtc/common_audio/signal_processing/include/signal_processing_library.h"
 | |
| 
 | |
| 
 | |
| void WebRtcSpl_MemSetW16(int16_t *ptr, int16_t set_value, int length)
 | |
| {
 | |
|     int j;
 | |
|     int16_t *arrptr = ptr;
 | |
| 
 | |
|     for (j = length; j > 0; j--)
 | |
|     {
 | |
|         *arrptr++ = set_value;
 | |
|     }
 | |
| }
 | |
| 
 | |
| void WebRtcSpl_MemSetW32(int32_t *ptr, int32_t set_value, int length)
 | |
| {
 | |
|     int j;
 | |
|     int32_t *arrptr = ptr;
 | |
| 
 | |
|     for (j = length; j > 0; j--)
 | |
|     {
 | |
|         *arrptr++ = set_value;
 | |
|     }
 | |
| }
 | |
| 
 | |
| void WebRtcSpl_MemCpyReversedOrder(int16_t* dest, int16_t* source, int length)
 | |
| {
 | |
|     int j;
 | |
|     int16_t* destPtr = dest;
 | |
|     int16_t* sourcePtr = source;
 | |
| 
 | |
|     for (j = 0; j < length; j++)
 | |
|     {
 | |
|         *destPtr-- = *sourcePtr++;
 | |
|     }
 | |
| }
 | |
| 
 | |
| int16_t WebRtcSpl_CopyFromEndW16(const int16_t *vector_in,
 | |
|                                  int16_t length,
 | |
|                                  int16_t samples,
 | |
|                                  int16_t *vector_out)
 | |
| {
 | |
|     // Copy the last <samples> of the input vector to vector_out
 | |
|     WEBRTC_SPL_MEMCPY_W16(vector_out, &vector_in[length - samples], samples);
 | |
| 
 | |
|     return samples;
 | |
| }
 | |
| 
 | |
| int16_t WebRtcSpl_ZerosArrayW16(int16_t *vector, int16_t length)
 | |
| {
 | |
|     WebRtcSpl_MemSetW16(vector, 0, length);
 | |
|     return length;
 | |
| }
 | |
| 
 | |
| int16_t WebRtcSpl_ZerosArrayW32(int32_t *vector, int16_t length)
 | |
| {
 | |
|     WebRtcSpl_MemSetW32(vector, 0, length);
 | |
|     return length;
 | |
| }
 | |
| 
 | |
| int16_t WebRtcSpl_OnesArrayW16(int16_t *vector, int16_t length)
 | |
| {
 | |
|     int16_t i;
 | |
|     int16_t *tmpvec = vector;
 | |
|     for (i = 0; i < length; i++)
 | |
|     {
 | |
|         *tmpvec++ = 1;
 | |
|     }
 | |
|     return length;
 | |
| }
 | |
| 
 | |
| int16_t WebRtcSpl_OnesArrayW32(int32_t *vector, int16_t length)
 | |
| {
 | |
|     int16_t i;
 | |
|     int32_t *tmpvec = vector;
 | |
|     for (i = 0; i < length; i++)
 | |
|     {
 | |
|         *tmpvec++ = 1;
 | |
|     }
 | |
|     return length;
 | |
| }
 |