FIRMR
对源矢量执行多速率FIR滤波,多速率是与单速率相对的。
计算taps向量(长度为tapsLen)和src向量(长度为numIters * downFactor)、dlySrc向量(长度为(tapsLen + upFactor - 1) / upFactor)的相关线性点积运算,目标向量存储到dst向量中,延迟线目标向量存储在dlyDst中。
计算公式从FIRSR的计算公式发展而来,如下:
;
;
;
。
其中,
- src是延迟线向量和源向量的组合。
- tapsN是FIR滤波器系数组成的特定序列的二维数组。
- upFactor:滤波信号内部上行采样所依据的因子。即在输入信号的每个样本之间插入upFactor - 1个零。
- upPhase:非零样本在upFactor- 上采样输入信号的长度块内的偏移相位。
- downFactor:FIR响应内部向下采样的因子。即从上采样滤波器响应的每downFactor -上采样滤波器响应的长度输出块中丢弃downFactor-1个输出样本。
- downPhase:非丢弃样本位于上采样滤波器响应块内的偏移相位。
- 如果dlySrc为空,该函数使用全零值的延迟线。
- 如果dlyDst为空,该函数不会将任何数据复制到目标延迟线。
FIRMR函数调用流程如下:
- 调用Init初始化FIRPolicy结构体,
- 调用主函数,
- 最后调用Release释放FIRPolicy函数所包含内存(16s、16sc使用32f、32fc初始化及释放)。
函数接口声明如下:
- 初始化操作:
HmppResult HMPPS_FIRMRInit_32f(const float *taps, int32_t tapsLen, int32_t upFactor, int32_t upPhase, int32_t downFactor, int32_t downPhase, HmppsFIRPolicy_32f **policy);
HmppResult HMPPS_FIRMRInit_64f(const double *taps, int32_t tapsLen, int32_t upFactor, int32_t upPhase, int32_t downFactor, int32_t downPhase, HmppsFIRPolicy_64f **policy);
HmppResult HMPPS_FIRMRInit_32fc(const Hmpp32fc *taps, int32_t tapsLen, int32_t upFactor, int32_t upPhase, int32_t downFactor, int32_t downPhase, HmppsFIRPolicy_32fc **policy);
HmppResult HMPPS_FIRMRInit_64fc(const Hmpp64fc *taps, int32_t tapsLen, int32_t upFactor, int32_t upPhase, int32_t downFactor, int32_t downPhase, HmppsFIRPolicy_64fc **policy);
HmppResult HMPPS_FIRMRInit32f_32fc(const float *taps, int32_t tapsLen, int32_t upFactor, int32_t upPhase, int32_t downFactor, int32_t downPhase, HmppsFIRPolicy_32f **policy);
- 主函数操作:
HmppResult HMPPS_FIRMR_16s(const int16_t *src, int16_t *dst, int32_t numIters, HmppsFIRPolicy_32f *policy, const int16_t *dlySrc, int16_t *dlyDst);
HmppResult HMPPS_FIRMR_32f(const float *src, float *dst, int32_t numIters, HmppsFIRPolicy_32f *policy, const float *dlySrc, float *dlyDst);
HmppResult HMPPS_FIRMR_64f(const double *src, double *dst, int32_t numIters, HmppsFIRPolicy_64f *policy, const double *dlySrc, double *dlyDst);
HmppResult HMPPS_FIRMR_16sc(const Hmpp16sc *src, Hmpp16sc *dst, int32_t numIters, HmppsFIRPolicy_32fc *policy, const Hmpp16sc *dlySrc, Hmpp16sc *dlyDst);
HmppResult HMPPS_FIRMR_32fc(const Hmpp32fc *src, Hmpp32fc *dst, int32_t numIters, HmppsFIRPolicy_32fc *policy, const Hmpp32fc *dlySrc, Hmpp32fc *dlyDst);
HmppResult HMPPS_FIRMR_64fc(const Hmpp64fc *src, Hmpp64fc *dst, int32_t numIters, HmppsFIRPolicy_64fc *policy, const Hmpp64fc *dlySrc, Hmpp64fc *dlyDst);
HmppResult HMPPS_FIRMR32f_32fc(const Hmpp32fc *src, Hmpp32fc *dst, int32_t numIters, HmppsFIRPolicy_32f *policy, const Hmpp32fc *dlySrc, Hmpp32fc *dlyDst);
- 释放内存操作:
HmppResult HMPPS_FIRMRRelease_32f(HmppsFIRPolicy_32f *policy);
HmppResult HMPPS_FIRMRRelease_64f(HmppsFIRPolicy_64f *policy);
HmppResult HMPPS_FIRMRRelease_32fc(HmppsFIRPolicy_32fc *policy);
HmppResult HMPPS_FIRMRRelease_64fc(HmppsFIRPolicy_64fc *policy);
HmppResult HMPPS_FIRMRRelease32f_32fc(HmppsFIRPolicy_32f *policy);
参数
参数名 |
描述 |
取值范围 |
输入/输出 |
---|---|---|---|
taps |
指向滤波器系数的指针。 |
非空 |
输入 |
tapsLen |
FIR滤波器系数的长度。 |
(0, INT_MAX] |
输入 |
upFactor |
多速率上采样因子。 |
(0, INT_MAX] |
输入 |
upPhase |
上采样信号的相位。 |
[0, upFactor] |
输入 |
downFacor |
多速率下采样因子。 |
(0, INT_MAX] |
输入 |
downPhase |
下采样信号的相位。 |
[0, downFacor] |
输入 |
src |
指向源向量的指针。 |
非空 |
输入 |
numIters |
与函数过滤的样本数量相关联的迭代次数。源向量的元素(numIters* downFactor)被过滤,结果(numIter * upFactor)的样本被存储在目标数组中。 |
(0, INT_MAX] |
输入 |
dst |
指向目的向量的指针。 |
非空 |
输出 |
dlySrc |
指向包含源延迟线值向量的指针。 |
向量可以为NULL,如果为非NULL,则数组长度定义为( tapsLen+ upFactor - 1) / upFactor |
输入 |
dlyDst |
指向包含目标延迟线值向量的指针。 |
向量可以为NULL,如果为非NULL,则数组长度定义为( tapsLen+ upFactor - 1) / upFactor |
输出 |
policy (init函数中) |
指向内存存储FIRPolicy的指针的指针。 |
非空 |
输出 |
policy (主函数中和release函数中) |
指向FIRPolicy结构体的指针。 |
非空 |
输入 |
返回值
- 成功:返回HMPP_STS_NO_ERR。
- 失败:返回错误码。
错误码
错误码 |
描述 |
---|---|
HMPP_STS_NO_ERR |
表示没有错误。 |
HMPP_STS_NULL_PTR_ERR |
当任何指定的指针为空时指示错误。 |
HMPP_STS_SIZE_ERR |
当tapsLen或numIters小于或等于0时指示错误。 |
HMPP_STS_OVERFLOW_ERR |
指示计算溢出时错误。 |
HMPP_STS_FIRMR_FACTOR_ERR |
采样因子小于或等于0时错误。 |
HMPP_STS_FIRMR_PHASE_ERR |
相位小于0或采用因子小于相位时错误。 |
HMPP_STS_MALLOC_FAILED |
Init函数中进行算法模型所需内存申请失败。 |
注意
- 调用该接口计算之前,必须调用Init接口初始化FIRPolicy规范结构。
- FIRPolicy结构体初始化需在Init函数中进行申请的,用户无法自己进行该结构体申请定义。
- FIRPolicy结构体初始化成功后,如果执行主函数失败,必须使用Release函数释放结构体。
- src不能和dst是同一数组,否则可能导致结果错误。
示例
#define TPAS_SIZE_S 8 #define UP_FACTOR_SIZE_S 5 #define UP_PHASE_SIZE_S 4 #define DOWN_FACTOR_SIZE_S 3 #define DOWN_PHASE_SIZE_S 2 #define NUM_ITERS_SIZE_S 2 void FIRMRExample(void) { int32_t tapsLen = TPAS_SIZE_S; int32_t upFactor = UP_FACTOR_SIZE_S; int32_t upPhase = UP_PHASE_SIZE_S; int32_t downFacor = DOWN_FACTOR_SIZE_S; int32_t downPhase = DOWN_PHASE_SIZE_S; int32_t numIters = NUM_ITERS_SIZE_S; float taps[TPAS_SIZE_S] = { -0.023, -3.1463, 35.5304, -0.0622, 0.2213, 0.0127, 0.0183, 59.8159 }; float src[NUM_ITERS_SIZE_S * DOWN_FACTOR_SIZE_S] = { 0.3065, -1.8737, -58.7455, 155.8426, -0.0294, 4.3917 }; float dlySrc[(TPAS_SIZE_S + UP_FACTOR_SIZE_S - 1) / UP_FACTOR_SIZE_S] = { 0.2107, -40.6842}; float dst[NUM_ITERS_SIZE_S * UP_FACTOR_SIZE_S] = { 0.0f }; float dlyDst[TPAS_SIZE_S - 1] = { 0.0f }; HmppsFIRPolicy_32f *policy = NULL; HmppResult result; result = HMPPS_FIRMRInit_32f(taps, tapsLen, upFactor, upPhase, downFacor, downPhase, &policy); printf("HMPPS_FIRMRInit_32f result = %d\n", result); if (result != HMPP_STS_NO_ERR) { return; } result = HMPPS_FIRMR_32f(src, dst, numIters, policy, dlySrc, dlyDst); printf("HMPPS_FIRMR_32f result = %d\n", result); HMPPS_FIRMRRelease_32f(policy); policy = NULL; if (result != HMPP_STS_NO_ERR) { return; } int32_t i; int32_t dstLen = numIters * upFactor; int32_t dlyLen = (tapsLen + upFactor - 1) / upFactor; printf("dstLen = %d\ndst =", dstLen); for(i = 0; i < dstLen; ++i){ printf(" %f", dst[i]); } printf("\ndlyDstLen = %d\ndst2 =", dlyLen); for(i = 0; i < dlyLen; ++i){ printf(" %f", dlyDst[i]); } printf("\n"); }
运行结果:
HMPPS_FIRMRInit_32f result = 0 HMPPS_FIRMR_32f result = 0 dstLen = 10 dst = 2.530557 -1.708862 0.067828 -48.239738 1.327350 3.653970 -491.402649 34.487968 9320.820312 -0.101382 dlyDstLen = 2 dst2 = -0.029400 4.391700