两通道实信号使用一个FFT同时计算算法
前言
在工程的实际应用场景中,往往是需要最省资源量。而DSP资源和BRAM资源对FPGA来说弥足珍贵。
对于同时存在多个通道的实信号需要做FFT而言,常规做法是每个通道用一个FFT IP,FFT IP的输入为RE+0*j。即输入FFT IP的虚部直接置0。
那有没有可能把这个虚部浪费掉的资源用起来呢,答案是肯定的。
参考文档
http://www.doc88.com/p-0394736871727.html
https://wenku.baidu.com/view/e89895af9ec3d5bbfc0a7403.html
基础知识
什么叫复数共轭对?
如果一个复数为a+b*j,那么它的共轭就是a-b*j。两者称为复数共轭对。
FFT的输出规律是啥?
如下图所示,对于N点FFT的输出,第1个点为直流分量,从第2个点开始是关于2N/2这个点共轭对称的。比如第2个点跟第N个点是共轭对称的。

算法流程
有两路同时的实信号需要进行计算,则可以使用1个N点的FFT就可以实现N点双路实信号的并行计算。
(1) 设x1(n)和x2(n)为两个N点的实序列。
(2) 构造新序列:x(n) = x1(n) + x2(n)*j。
(3) 计算x(n)的FFT,得到X(K) = RE(K) + IM(K)*j。
(4) 利用对称性,就有: FFT(x1(n)) = [X(K) + X*(N-K)]/2
FFT(x2(n)) = -j*[X(K) - X*(N-K)]/2
从而实现了x1(n),x2(n)的FFT。
注意:X*(N-K)为X(N-K)的共轭。上述中的第4点直流信号是不予考虑的,对工程应用无意义,直流信号点直接置0即可。
Maltab算法验证
令Fs=6M,x1信号为600k,x2信号为1200k,FFT点数为8192。
matlab代码可如下所示:
%%powered by kingstacker
%%
clc; %clear
clear all;
close all;
Fs = 6e6;
L = ;
n = :L-;
x1 = load('600k_signal_8192.txt');
x2 = load('1200k_signal_8192.txt');
%%构造信号FFT
y = x1 + x2*j;
Y = fft(y,);
%%
X1() = ; %第一个点直流置0即可
X2() = ;
for i = : %从第二个点开始
X1(i) = /*(Y(i)+conj(Y(-i)));
X2(i) = -/*j*(Y(i)-conj(Y(-i)));
end
x = n*Fs/(L*1e3)-Fs/(*1e3); %x axis
plot(x,fftshift(db(abs(X1))));
hold on ;
plot(x,fftshift(db(abs(X2))));
title('同一个FFT算法结果');
figure ;
plot(x,fftshift(db(abs(fft(x1)))));
hold on;
plot(x,fftshift(db(abs(fft(x2)))));
title('x1,x2分别FFT计算结果');
figure;
X1_reshape = reshape(X1,[,]);
X2_reshape = reshape(X2,[,]);
erro1 = abs(X1_reshape - fft(x1));
erro2 = abs(X2_reshape - fft(x2));
plot(erro1(:));
hold on;
plot(erro2(:));
title('不同计算结果的相对误差');
计算结果如下图所示:



可以看到由同一个FFT的计算算法结果跟分别FFT计算的输出结果误差很小,结果一致。
下一步就是FPGA中的具体实现啦。
以上。
两通道实信号使用一个FFT同时计算算法的更多相关文章
- CUDA cufftPlanMany的用法_31通道32*8像素的FFT
#include <cufft.h> #include <iostream> #include <cuda_runtime.h> #include <help ...
- 离散傅里叶变换的衍生,负频率、fftshift、实信号、共轭对称
封面是福州的福道,从高处往下看福道上的人在转圈圈.从傅里叶变换后的频域角度来看,我们的生活也是一直在转圈圈,转圈圈也是好事,说明生活有规律,而我们应该思考的是,如何更有效率地转圈圈--哦别误会,我真不 ...
- 用两个Stack来实现一个Queue
import java.util.Stack; /** * 问题:用两个Stack来实现一个Queue; * 方法:栈的特点是先进后出:而队列的特点是先进先出: * 用两个栈正好能把顺序调过来: * ...
- ----------jqery和js如何判断checkbox是否选中 --------两个单选按钮如何选一个,且用jquery获取被选的值
jqery和js如何判断checkbox是否选中 jquery: <div id="divId" class="divTable"> <div ...
- 一个类有两个方法,其中一个是同步的,另一个是非同步的; 现在又两个线程A和B,请问:当线程A访问此类的同步方法时,线程B是否能访问此类的非同步方法?
一个类有两个方法,其中一个是同步的,另一个是非同步的:现在又两个线程A和B,请问:当线程A访问此类的同步方法时,线程B是否能访问此类的非同步方法? 答案:可以 验证 package com.my.te ...
- 两周“学会”bootstrap搭建一个移动站点
一直想着用bootstrap搭建网站,它的自适应.元素封装完善.现成的Glyphicons字体图标,省去很多的css.js.ui的工作,可以快速搭建一个客户需要的站点.ytkah自己有一些div+cs ...
- C/C++ 中##(两个井号)和#(一个井号)用法
##(两个井号)和#(一个井号)都是什么意思 连接符 ##(两个井号) 不知道什么符 #(一个井号) ## 连接符号由两个井号组成,其功能是在带参数的宏定义中将两个子串(token)联接起来,从而形成 ...
- Java中如何把两个数组合并为一个
在Java中,如何把两个String[]合并为一个? 看起来是一个很简单的问题.但是如何才能把代码写得高效简洁,却还是值得思考的.这里介绍四种方法,请参考选用. 一.apache-commons 这是 ...
- C++中##(两个井号)和#(一个井号)用法
C(和C++)中的宏(Macro)属于编译器预处理的范畴,属于编译期概念(而非运行期概念).下面对常遇到的宏的使用问题做了简单总结.关 于#和##在C语言的宏中,#的功能是将其后面的宏参数进行字符串化 ...
随机推荐
- python中的修饰符@的作用
1.一层修饰符 1)简单版,编译即实现 在一个函数上面添加修饰符 @另一个函数名 的作用是将这个修饰符下面的函数作为该修饰符函数的参数传入,作用可以有比如你想要在函数前面添加记录时间的代码,这样每个函 ...
- Android平台签名证书(.keystore)生成指南
来源:https://ask.dcloud.net.cn/article/35777 Android平台签名证书(.keystore)生成指南 分类:HTML5+ Android证书 Android平 ...
- Spring cloud微服务安全实战-3-3 API安全机制之流控
首先要保证你的服务是可用的,其中一个重要的手段就是流控.就是流量控制.比如我的系统每秒只能处理500个请求,那么多余的请求就拒绝掉.这样我的系统不会被压死 实际的开发中,所要面对的流控场景实际是非常复 ...
- Linux记录-史上最全的MySQL高性能优化实战总结(转载)
史上最全的MySQL高性能优化实战总结! 1.1 前言 MySQL对于很多Linux从业者而言,是一个非常棘手的问题,多数情况都是因为对数据库出现问题的情况和处理思路不清晰.在进行MySQL的优 ...
- Glide图片加载过程(简)
iceIC 关注 2018.10.25 20:53* 字数 906 阅读 529评论 0喜欢 1 调研版本为4.7.1为了更加简单的理解,会将函数代码简化,详细代码请自行照源码对比 Glide用法 G ...
- JFreechart从入门到放弃
JFreechart从入门到放弃 觉得有用的话,欢迎一起讨论相互学习~Follow Me 参考文献 http://www.jfree.org/jfreechart/ 引言 干嘛用的 使用java画图, ...
- ASP.NET(C#)图片加文字、图片水印,神啊,看看吧
ASP.NET(C#)图片加文字.图片水印 一.图片上加文字: //using System.Drawing; //using System.IO; //using System.Drawing.Im ...
- IE6利用iframe遮挡 弹层 select
ie6的老bug了,select老是会挡住 弹层里的内容. 解决办法:(box需要设置高度) <div class="box"> <!--[if IE 6]> ...
- jira常用配置
1.关闭注册入口 系统->一般配置->运行模式:私有 2.分享给用户组是,看不到部分用户组的时候,只需要把你的账号添加该分组即可. 3.为项目分配权限,问题-->问题属性——> ...
- netty 实现心跳检查--断开重连--通俗易懂
一.心跳介绍 网络中的接收和发送数据都是使用操作系统中的SOCKET进行实现.但是如果此套接字已经断开,那发送数据和接收数据的时候就一定会有问题. 1.心跳机制: 是服务端和客户端定时的发送一个心跳包 ...