From 9ee651d0948ab7c721152dc6fdf0bfde31d9c180 Mon Sep 17 00:00:00 2001 From: Xavier Arteaga Date: Thu, 23 Jan 2020 15:11:38 +0100 Subject: [PATCH] srsLTE: Added set vector zeros for float and cf --- lib/include/srslte/phy/utils/vector.h | 5 +++++ lib/src/phy/utils/vector.c | 18 ++++++++++++++---- 2 files changed, 19 insertions(+), 4 deletions(-) diff --git a/lib/include/srslte/phy/utils/vector.h b/lib/include/srslte/phy/utils/vector.h index fc61fd3d7..a22af0141 100644 --- a/lib/include/srslte/phy/utils/vector.h +++ b/lib/include/srslte/phy/utils/vector.h @@ -89,6 +89,11 @@ SRSLTE_API uint8_t* srslte_vec_u8_malloc(uint32_t nsamples); SRSLTE_API void* srslte_vec_realloc(void* ptr, uint32_t old_size, uint32_t new_size); +/* Zero memory */ +SRSLTE_API void srslte_vec_cf_zero(cf_t* ptr, uint32_t nsamples); + +SRSLTE_API void srslte_vec_f_zero(float* ptr, uint32_t nsamples); + /* print vectors */ SRSLTE_API void srslte_vec_fprint_c(FILE* stream, cf_t* x, const uint32_t len); SRSLTE_API void srslte_vec_fprint_f(FILE* stream, float* x, const uint32_t len); diff --git a/lib/src/phy/utils/vector.c b/lib/src/phy/utils/vector.c index fe5fbf79a..e5b4bb2c8 100644 --- a/lib/src/phy/utils/vector.c +++ b/lib/src/phy/utils/vector.c @@ -174,6 +174,16 @@ uint8_t* srslte_vec_u8_malloc(uint32_t nsamples) return (uint8_t*)srslte_vec_malloc((uint32_t)sizeof(uint8_t) * nsamples); } +void srslte_vec_cf_zero(cf_t* ptr, uint32_t nsamples) +{ + memset(ptr, 0, sizeof(cf_t) * nsamples); +} + +void srslte_vec_f_zero(float* ptr, uint32_t nsamples) +{ + memset(ptr, 0, sizeof(float) * nsamples); +} + void* srslte_vec_realloc(void* ptr, uint32_t old_size, uint32_t new_size) { #ifndef LV_HAVE_SSE @@ -530,7 +540,7 @@ void srslte_vec_quant_fus(const float* in, int32_t tmp = (int32_t)(offset + gain * in[i]); tmp = SRSLTE_MAX(tmp, 0); tmp = SRSLTE_MIN(tmp, (int32_t)clip); - out[i] = (uint16_t)tmp; + out[i] = (uint16_t)tmp; } } @@ -545,7 +555,7 @@ void srslte_vec_quant_fuc(const float* in, int32_t tmp = (int32_t)(offset + gain * in[i]); tmp = SRSLTE_MAX(tmp, 0); tmp = SRSLTE_MIN(tmp, (int32_t)clip); - out[i] = (uint8_t)tmp; + out[i] = (uint8_t)tmp; } } @@ -560,7 +570,7 @@ void srslte_vec_quant_suc(const int16_t* in, int32_t tmp = (int32_t)(offset + (float)in[i] * gain); tmp = SRSLTE_MAX(tmp, 0); tmp = SRSLTE_MIN(tmp, (int32_t)clip); - out[i] = (uint8_t)tmp; + out[i] = (uint8_t)tmp; } } @@ -575,7 +585,7 @@ void srslte_vec_quant_sus(const int16_t* in, int32_t tmp = (int32_t)(offset + gain * (float)in[i]); tmp = SRSLTE_MAX(tmp, 0); tmp = SRSLTE_MIN(tmp, (int32_t)clip); - out[i] = (uint16_t)tmp; + out[i] = (uint16_t)tmp; } }