EN
注册
我要评分
文档获取效率
文档正确性
内容完整性
文档易理解
在线提单
论坛求助
鲲鹏小智

FFTShift

将零频点移到频谱的中间,对于一维信号,其实就是入参数组左半部和右半部对换。

函数接口声明如下:

浮点数的操作:

HmppResult HMPPS_FFTShift_32f(const float *src, float *dst, int32_t len);

HmppResult HMPPS_FFTShift_64f(const double *src, double *dst, int32_t len);

HmppResult HMPPS_FFTShift_32fc(const Hmpp32fc *src, Hmpp32fc *dst, int32_t len);

HmppResult HMPPS_FFTShift_64fc(const Hmpp64fc* src, Hmpp64fc* dst, int32_t len);

参数

参数名

描述

取值范围

输入/输出

src

指向源向量的指针。

非空

输入

dst

指向目的向量的指针。

非空

输出

len

向量长度。

(0,INT_MAX]

输入

返回值

  • 成功:返回HMPP_STS_NO_ERR
  • 失败:返回错误码。

错误码

错误码

描述

HMPP_STS_NULL_PTR_ERR

src、dst这几个入参中存在空指针。

HMPP_STS_SIZE_ERR

len小于或等于0。

示例

#define BUFFER_SIZE_T 10
void FFTShift_Example(void)
{
    float src[BUFFER_SIZE_T] = {1.64, 1.63, -1.09, 0.71, -3.20, -0.43, 0.41, -4.83, 5.36, -4.40};
    float dst[BUFFER_SIZE_T];
    int32_t i;

    HmppResult result = HMPPS_FFTShift_32f(src, dst, BUFFER_SIZE_T);
    printf("result = %d \ndst =", result);
    for (i = 0; i < BUFFER_SIZE_T; i++) {
        printf("%.2f    ", dst[i]);
    }

}

运行结果:

result = 0
dst = -0.43      0.41      -4.83      5.36       -4.40      1.64      1.63      -1.09      0.71      -3.20