ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

使用matlab生成正弦波、三角波、方波

2022-08-26 16:00:15  阅读:183  来源: 互联网

标签:十六进制 方波 正弦波 生成 zeros matlab 127 100 数据


生成余弦波数据(该示例中展示了如何输出十六进制数据到文件中)

N = 100 ;
y = zeros(N , 1) ;%生成100行*1列的矩阵
y_integer = zeros(N , 1) ;%生成100行*1列的矩阵
y_hex = zeros(N , 1) ;%生成100行*1列的矩阵,十六进制
for i = 1:1:N %循环1~100,累加1
    x = i ;
    %y(i,1) = ceil( 127*sin(x*2*pi/N) ) ;%ceil为四舍五入函数,输出范围为-127~127的正弦波数据
    y(i,1) = ceil( 127*cos(x*2*pi/N) )  ;%ceil为四舍五入函数,输出范围为-127~127的余弦波数据
end   
plot(y);%画图预览
 
fid = fopen('cos_100point.coe','wt');    %创建一个名为cos_100point.coe的文件
%- COE 文件前置格式
fprintf( fid, 'MEMORY_INITIALIZATION_RADIX = 16;\n');                     
fprintf( fid, 'MEMORY_INITIALIZATION_VECTOR =\n');
%- 写数据
 
for i = 1:1:N
    if (y(i,1)<0)
       y_integer(i,1)=y(i,1)+256;%负数用补码表示
    else
       y_integer(i,1)=y(i,1);%正数的补码为原码
    end    
    y_hex= dec2hex(y_integer);%因为dec2hex只能转换正数,因此先将y取补码
 
    if(i == N)
        %最后一个点时,标点为分号,其余时候为逗号
        fprintf(fid,'%c%c;',y_hex(i,1),y_hex(i,2));  %输出16进制数据
%       fprintf(fid,'%d,\n',y(i,1));  %输出10进制数据
    else
        fprintf(fid,'%c%c,\n',y_hex(i,1),y_hex(i,2));  %输出16进制数据
%       fprintf(fid,'%d,\n',y(i,1));  %输出10进制数据
    end
end
fclose(fid);%关闭文件

  

上述matlab代需要重点关注的是:

1、按照需求,模拟生成正弦波数据,利用率sin函数和cos函数。

2、将负数通过转换,变为正数,操作方式为加上256(2的N次方,N为数据位宽)

3、使用DEC2HEX将补码数据转换为十六进制字符

4、使用fprintf函数,利用两个%c,将十六进制字符写入文件中。实现了十六进制数据的转换。

依据正弦波的matlab代码编写方法,照葫芦画瓢,可以得到三角波数据和方波数据。
三、生成三角波数据

%% triangle wave data write in coe file
N = 100 ;
y = zeros(N , 1) ;%生成100行1列的矩阵
for i = 1:1:N 
    if(i <= 50) %从0递增到49
        y(i,1) = i-1 ;
    else      %从49递减到0
        y(i,1) = 100 - i;
    end
end   
plot(y);%绘图预览
fid = fopen('triangle_100point.coe','wt');    
%COE文件格式
fprintf( fid, 'MEMORY_INITIALIZATION_RADIX = 10;\n');                     
fprintf( fid, 'MEMORY_INITIALIZATION_VECTOR =\n');
%输出十进制数据,保存至文件
for i = 1:1:N
    if(i == N)
        fprintf(fid,'%d;',y(i,1)); %最后一个点时,标点为分号,其余时候为逗号
    else
        fprintf(fid,'%d,\n',y(i,1));  
    end 
end
fclose(fid);%关闭文件

  

生成方波数据

N = 100 ;%100个点的数据
y = zeros(N , 1) ;%生成100行1列的矩阵
for i = 1:1:N 
    if(i <= 50) %输出50个点的高电平,50个点的低电平
        y(i,1) = 255 ;
    else
        y(i,1) = 0 ;
    end
end   
plot(y);
 
fid = fopen('rectangle_100point.coe','wt');    %创建文件rectangle_100point.coe
%COE文件格式
fprintf( fid, 'MEMORY_INITIALIZATION_RADIX = 10;\n');                     
fprintf( fid, 'MEMORY_INITIALIZATION_VECTOR =\n');
%保存文件数据至COE文件中
for i = 1:1:N
    if(i == N)
        fprintf(fid,'%d;',y(i,1)); %最后一个点时,标点为分号,其余时候为逗号
    else
        fprintf(fid,'%d,\n',y(i,1));  
    end
end
fclose(fid);%关闭文件

  

 

标签:十六进制,方波,正弦波,生成,zeros,matlab,127,100,数据
来源: https://www.cnblogs.com/54programer/p/16627823.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有