- 1、本文档共17页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数字信号发生器和数字电子琴
摘要 Matlab是一个具有数值分析、矩阵计算、科学数据可视化以及非线性动态系统的建模和仿真等易于使用的视窗环境在很大程度上摆脱了传统非交互式程序设计语言(如C、Fortran)的编辑模式1概述
MATLAB是矩阵实验室(Matrix Laboratory)的简称,是美国MathWorks公司出品的商业数学软件。可以进行矩阵运算、绘制函数和数据、实现算法、创建用户界面、连接其他编程语言的程序等,主要应用于工程计算、控制设计、信号处理与通讯、图像处理、信号检测、金融建模设计与分析等领域。图形用户界面(Graphical User Interface,简称GUI,又称图形用户接口)是指采用图形方式显示的计算机操作用户界面。与早期计算机使用的命令行界面相比,图形界面对于用户来说在视觉上更易于接受。Matlab自带了强大的GUl工具[1]。在本文中,将利用Matlab的GUI工具,设计出数字信号发生器和数字电子琴。
信号发生器又称信号源或振荡器,是一种能提供各种频率、波形和输出电平电信号,常用作测试的信号源或激励源的设备在生产实践和科技领域中有着广泛的应用。按信号波形可分为正弦信号、函数(波形)信号、脉冲信号和随机信号发生器等四大类。各种波形曲线均可以用三角函数方程式来表示。能够产生多种波形,如三角波、锯齿波、矩形波(含方波)、正弦波的电路被称为函数信号发生器。
2技术路线
虚拟数字信号发生器设计的流程图如图2.1:
图2.1 数字信号发生器流程图
在此基础上,将产生的数字信号写入声卡,即可播放出相应音阶的声音,实现电子琴的功能。
3实现方法
3.1数字信号发生器
3.1.1搭建GUI界面
图形用户界面(Graphical User Interface,简称 GUI,又称图形用户接口)是指采用图形方式显示的计算机操作用户界面。与早期计算机使用的命令行界面相比,图形界面对于用户来说在视觉上更易于接受。凭借其强大的计算能力,系统集成能力以及图形处理能力,其图形用户接口(GUI)也日趋成熟。atlab GUI的控件丰富,调用方便,可视化效果美观。GUI可以使得参数的输入和结果的输出可视化更高,操作更加方便。
图3.1 数字信号发生器界面
3.1.2编写M文件
搭建好界面后保存,系统将自动生成M文件与Fig文件,并且M文件内部已经按照GUI界面中组件的类别,自动生成了相应的模块调用函数。根据需要,我们对生成的各个函数进行补充,完成函数功能的实现及各个函数的调用关系。本次实验主要对控件的回调函数(callback)下写入相应的程序。
下面这段程序(部分程序)实现了函数根据用户的输入生成不同的正弦波、余弦波、三角波、方波等,最终将波形显示在坐标轴1上。其中,sliderA ,editA输入幅值,当用户在输入一个新的幅值时,A为对应幅值变量,发生相应改变,并判断选择的是何种波型,然后对相应的波型的幅值进行修改,最终通过绘图函数的调用将新波形显示在图上。同理,当我们逐渐改变频率和相位时,波形也会对应发生变化,在此不再赘述。
幅值滚动条的回调函数如下:
function sliderA_Callback(hObject, eventdata, handles)
a=get(hObject,'value');
set(handles.editA,'string',a);
幅值可变文本的回调函数如下:
function editA_Callback(hObject, eventdata, handles)
val=get(hObject,'string');
a=str2num(val);
if ~isempty(a)&&(val>=0&val<=20)
set(handles.sliderA,'value',a)
end
下拉菜单回调函数如下:
function popupmenu1_Callback(hObject, eventdata, handles)
A=str2num(get(handles.editA,'string'));
f=str2num(get(handles.editF,'string'));
d=str2num(get(handles.editD,'string'));
fs=5000;
T=0.05;
dt=1.0/fs;
N=T/dt;
t=linspace(0,T,N);
s=get(hObject,'value');
switch s
case 1
y=A*sin(2*pi*f*t+d);
axes(handles.axes1);
文档评论(0)