近期用verilog去做FFT相关的项目,需要用到matlab进行仿真然后和verilog出来的结果来做对比,然后计算误差。近期使用matlab犯了一个错误,极大的拖慢了项目进展,给我人都整emo了,因为怎么做仿真结果都不对,还好整体的代码都是我来写的,慢慢往下找就找到了问题的来源,全网没有看到多少人把这个愚蠢的错误写出来,我来引入一下。
代码错误的表现:复数向量的虚部被取反,正数变成负数,负数变成正数。
首先讲一下我做了什么,以及这个错误出现的原因:
- 我习惯在变量区查看变量,然后大致对照一下输入输出对不对。
- 如果一个矩阵是很长的行矩阵,例如1*512,我就习惯把它转置过来看,例如图1中matlab变量区的最左边变量cmplx_wave_single,按照图2,右键点击空白处,然后点击“转置变量”,这样倒过来看会看得更多更全。我以为这个转置就是线性代数的转置,值是不变的,但是!!!!!并不是!!!!!
