- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
程序设计试验样本-Read
《计算机接口技术》课程综合性实验报告
开课实验室:接口实验室 2008年 6 月 7日
实验题目 数字录音机 一、实验目的
1.了解数字录音原理
2.掌握A/D、D/A的使用。
3.掌握对语音数据处理的方法,如滤波、压缩等算法。
二、设备与环境
1.TPC-2003A
2.微机及麦克。
3.Vc++编译器。
三、实验内容
1.硬件接线图
将传感器接J2,把代表语音的电信号送给ADC0809通道2(IN2);D/A转换器的输出
端通过K8跳线接喇叭。
2.程序流程图
滤波子程序
3.源程序
#includestdio.h
#includeconio.h
#include ApiEx.h
#pragma comment(lib,ApiEx.lib)
#define N??11
void lu(); /*录音函数*/
void fang(); /*放音函数*/
void de_lay(); /*延时函数*/
int i;
BYTE *ii,a;
void main()
{printf(--------------------EXP22_13_LYJ---------------------\n);
printf(1. MIC === J2\n);
printf(2. I/O (298-29F) === 0809 (CS)\n);
printf(3. (JUMP 2 TO 3) of JP2\n);
printf(4. SPEAKER === J1\n);
printf(5. I/O (290-297) === 0832 (CS)\n);
printf(6. 8253 (CLK0) === (1MHz) or (2MHz)\n);
printf(7. TPC (+5V) === 8253 (GATE0)\n);
printf(8. 8253 (OUT0) === 8255 (PA0)\n);
printf(9. I/O (280-287) === 8253 (CS)\n);
printf(10. I/O (288-28F) === 8255 (CS)\n);
printf(Press any key to begin!\n\n);
getch();
if(!Startup()) /*打开设备*/
{printf(ERROR: Open Device Error!\n);
return;}
ii = (BYTE *)malloc(60000); /*分配空间用于存放录音数据*/
if(!ii)
{printf(No memory!\7);
exit(0);}
PortWriteByte(0x28b,0x9b); /*设8255A口为输入方式*/
PortWriteByte(0x283,0x10); /*初始化8253通道0为方式0*/
printf(Press any key to record!\n); /*录音提示*/
getch();
printf(Playing record!\n);
lu(); /*按任意键后开始录音*/
printf(Press any key to playing!ESC is exit!\n); /*放音提示*/
while(getch() != 0x1b)
{fang(); /*按任意键后开始放音*/
printf(Playing end!\n); }
Cleanup(); /*关闭设备*/}
void lu()
{BYTE data;
for(i=0;i60000;i++) /*启动A/D,采集60000个数据放在ii中*/
{PortWriteByte(0x29a,0);
de_lay();
PortReadByte(0x29a,data);
*(ii+i) = data;}}
void fang()
{BYTE data;
for(i=0;i60000;i++) /*将ii中的60000个从D/A输出*/
{data = *(ii+i);
a=filter();PortWriteByte(0x290,a);
de_lay();}}
void de_lay()
{BYTE data;
PortWriteByte(0x280,200); /*送计数器初值200*/
do{PortReadByte(0x288,data);}while(!data0x01);
/*查询8255的PA0是否为高电平,若是则表明定时时间到*/
}
Byte filter(
文档评论(0)