如何用matlab画出交流正弦波信号

如何用matlab画出交流正弦波信号,第1张

fs=3200;%采样频率设定 为3200Hz
t=0:1/fs:032-1/fs;%时间定为16个周期
x=sin(100pit+pi/6);%x为正弦信号波形,频率为基频,初相为pi/6
plot(t,x)%绘制x的波形。

首先在0至2π内产生40个点(随你也可产生任意点数),注意噪声的点数与x的点数相同,在命令提示符下输入:
>>x=linspace(0,2,40);
>>
y=sin(xpi);
>>
z=y+02rand(1,40);
>>
plot(z)

首先在0至2π内产生40个点(随你也可产生任意点数),注意噪声的点数与x的点数相同,在命令提示符下输入:
>>x=linspace(0,2,40);
>> y=sin(xpi);
>> z=y+02rand(1,40);
>> plot(z)

您好!MATLAB中可以使用FFT对信号进行傅里叶变化,假设时域信号为a(n),则傅里叶变换的过程就是f(n)=fft(a(n)),您所说的基波,应该是载波的意思吧,比如我们发射一个小能量信号,需要一个高频的载波作为载体,一般来说载波都是高频信号,所以用matlab中的fdatool产生一个低通的滤波器,通带截止频率要小于基波频率,然后用频域的滤波器响应和傅里叶变换结果相乘,得到的结果再用ifft做傅里叶逆变换就可以了。

>> t1 = 0:pi/50:2pi;t2 = pi:pi/50:4pi;

y1 = sin(t1);y2 = sin(2t2);

plot(t1,y1,'-k');

hold on

plot(t2,y2,'--b');

title('正弦函数图形');

xlabel('t');ylabel('y');

gtext('y1=sin(t1)');gtext('y2=sin(2t2)');

这里介绍两种方式:(一)这个方法只在matlab中生成数据表,需要自己手动的往mif文件中添加数据1假设用到的DA芯片为14为,则2^14=163842一个完整的正弦波为0-2pi3正弦波ROM的深度为4096(地址总数)4由于FPGA中不识别负数,加入一个直流分量,加8192则用matlab产生正弦表的函数为:Y=ceil((16384/2-1)sin(0:pi2/4096:2pi)+8192)其中ceil函数描述如下:ceil(x) : 大于x 的最小整数>> ceil( [312 -312])ans =4 -3(二)可以直接生成mif文件直接生成mif文件depth = 4096;width =14;x=ceil(16384/2sin(0:pi2/4096:2pi)+8192)fid = fopen('d:\romdata1mif','w');fprintf(fid,'depth= %d ;\n',depth);fprintf(fid,'width= %d ;\n',width);fprintf(fid,'address_radix=uns;\n');fprintf(fid,'data_radix = uns;\n');fprintf(fid,'Content Begin \n');for(k=1:depth)fprintf(fid,'%d: %d ;\n',k-1,x(k));endfprintf(fid,'end;');用上面这段程序最大值会出现16384,在Quartus II中会认为是超出数据范围,所以需要手动的改写为16383----------把x=ceil(16384/2sin(0:pi2/4096:2pi)+8192) 改写为下面语句x=ceil((16384/2-1)sin(0:pi2/4096:2pi)+8192) 就不存在上述问题了数据量小的话,可以用第一种方法,要是数据量大的话,介意用第二种方法。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/13041580.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-29
下一篇 2023-05-29

发表评论

登录后才能评论

评论列表(0条)

保存