matlab的czt变换,CZT变换(chirp z-transform)

本文介绍了如何使用C语言实现MATLAB中的 chirp z-transform (CZT) 变换,并提供了详细的代码示例。通过CZT变换,可以进行信号的频率细化,从而更准确地估计信号频率。文章给出了MATLAB与C实现的频率估计仿真对比。
摘要由CSDN通过智能技术生成

作者:桂。

时间:2018-05-20  12:04:24

前言

相比DFT,CZT是完成频谱细化的一种思路,本文主要记录CZT的C代码实现。

一、代码实现

原理主要参考MATLAB接口:

a58be697581a31b3d7ea0aeccabc5bc4.png

对应C代码实现:

Complex.c

2b65ef29a5872cc0e4771c25889edd04.gif

6a087676c59fa8b19d76e6bb55a32902.gif

/*=============================

Chirp-Z Transform

=============================*/#include#include#include#include"Complex.h"#include"FFT.h"

void CZT(comp* x, int N, comp A, comp W, comp *xCZT, intM);voidmain()

{inti;intN,M;doublePI;doubleA0,Theta0;doubleW0,Phi0;

comp*x;

comp*xCZT;

comp A,W;

PI= 3.1415926;

N= 5; //信号长度

M = 10; //chirp-z 变换输出长度

x = (comp *)calloc(N,sizeof(comp));

xCZT= (comp *)calloc(M,sizeof(comp));for (i = 0;i < N; i++)

{

x[i].re=(float)(i-3);

x[i].im= 0.0;

}

A0= 1.0; //起始抽样点z0的矢量半径长度

Theta0 = 0.0; //起始抽样点z0的相角

A.re = (float)(A0*cos(Theta0));

A.im= (float)(A0*sin(Theta0));

Phi0= 2.0*PI/M; //两相邻抽样点之间的角度差

W0 = 1.0; //螺线的伸展率

W.re = (float)(W0*cos(-Phi0));

W.im= (float)(W0*sin(-Phi0));

CZT(x,N,A,W,xCZT,M);

printf("The Original Signal:\n");for (i = 0; i

{

printf("%10.4f",x[i].re);

printf("%10.4f\n",x[i].im);

}

printf("The Chirp-Z Transfrom:\n");for (i = 0 ;i

{

printf("%10.4f",xCZT[i].re);

printf("%10.4f\n",xCZT[i].im);

}

}/*----------------函数说明----------------------

Name: CZT

Function: Chirp-Z Transform

Para: x[in][out]:待变换信号 N[in]:信号长度

A[in]: W[in]:

M[in]:Chirp-Z变换输出长度

------------------

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值