基于mspg的简易正弦波发生器设计.docx

上传人:marr****208 文档编号:133587834 上传时间:2020-05-28 格式:DOCX 页数:16 大小:3.27MB
返回 下载 相关 举报
基于mspg的简易正弦波发生器设计.docx_第1页
第1页 / 共16页
基于mspg的简易正弦波发生器设计.docx_第2页
第2页 / 共16页
基于mspg的简易正弦波发生器设计.docx_第3页
第3页 / 共16页
基于mspg的简易正弦波发生器设计.docx_第4页
第4页 / 共16页
基于mspg的简易正弦波发生器设计.docx_第5页
第5页 / 共16页
点击查看更多>>
资源描述

《基于mspg的简易正弦波发生器设计.docx》由会员分享,可在线阅读,更多相关《基于mspg的简易正弦波发生器设计.docx(16页珍藏版)》请在金锄头文库上搜索。

1、电子工程学院2015年大学生电子设计竞赛设计报告 学院:电子工程学院 姓名:马晨迪(2012210987)(硬件)宋明洁(2012210991)(软件)完成任务1基本要求(1)振荡频率:10KHz;(2)输出信号电压范围(峰-峰值):2V;(负载1K欧,500欧,50欧)(3)测量振荡信号参数:峰峰值、有效值、频率;测量精度要求:满足(2)的负载下测量误差5%。(以外接示波器测试为参考)2发挥部分指定发挥要求:(1) 振荡频率: 100KHz;(2) 测量精度提高:误差1%;(以外接示波器测试为参考)(3) 显示并绘制输入信号波形(绘制要求有坐标轴及刻度,单位)(4) VDD =3.3V;(5

2、) 提交设计论文3 设计思路(1) 硬件a) 原理利用产生自激振荡的条件去构成正反馈电路,以产生正弦波振荡。原理图如下:自激振荡的平衡条件: 1)振幅条件: 2)相位条件:A+B()=2n要产生自激震荡可以采用LC、RC或者石英晶体振荡电路。但是在产生较低频率的正弦波是时,若采用LC电路,所需电感很大,实际中往往很难找到,而石英晶体震荡频率虽然稳定,但是可调节范围较小。所以我们最终采用了RC文氏桥电路。b) 模型文氏桥电路的原始模型:改进后的模型:上图中,在回路串联两个反向并联的二极管,利用电流增大时,二极管动态电阻减小的特点,加入非线性环节,使输出电压稳定。用两个电位器R,调节震荡频率,使得

3、满足起振条件和满足所要求的震荡频率。c) 仿真过程d) 实际操作实际操作过程中我们发现,仿真出来的效果很好,但是严格按照仿真结果出来的效果却并不是很好,甚至无法出现波形。开始时还以为是电路链接有问题,插了好几次,不见效果,后来试着不断调节电位器R的值,突然出现了波形。这说明理论和实际还真是有不小的差距。在实现大于10kHz的功能时,电容值C本来用的参考资料里的223但是发先频率可调范围较小,而且电压最高为2.1V左右,刚刚能够满足要求,所以,改选了102,效果比较好不仅频率达到了要求,而且电压最大值可达到2.7V。再加入负载之后,我们能实现电压仍大于2V的负载值最小只能是68欧。未接负载前:接

4、1000欧负载接500欧负载接68欧e) 拓展功能实现在实现100kHz时,我们更换电容C为容值更小的101(1000pF),实现了频率要求,但是电压的要求难以实现,要实现仍是正弦波的要求,电压幅度最大只能是几百毫伏。在使用电压3.3V供电时,频率上可以满足大于10k的要求(33k),但是电压只能达到1.74V。如下图(2) 软件软件设计主要包括测量正弦波频率、测量正弦波幅度、lcd显示模块 测量正弦波频率模块测量正弦波频率采用测频法,使用两个定时器A、B,定时器A的使用采用正弦波作为外部输入时钟,每输入一个正弦波的上升沿,TRA的值加一,这样可以使用定时器A的值记录输入的正弦波的周期数。定时

5、器B的时钟采用SMCLK,用来计时,当计时到1s时触发中断,利用此时定时器A的值计算得到正弦波的频率。 测量正弦波幅度模块将正弦波输入A1引脚,利用单片机内集成的ADC进行AD转换,对一定时间内采集的到的幅度值进行比较,最大值作为正弦波的幅度输出。 Lcd显示模块由于msp430g2553单片机的IO管脚比较少,所以LCD12864采用串行通信模式,只用连接SID,CS,SCLK三个控制引脚,对LCD12864写入的每一个字节的数据或者命令采用三字节的数据格式写入,第一个字节为控制命令,第二个字节的高4位为数据的高4位,第三个字节的高4位为数据的低4位。因为LCD12864内部含有字库,所以只

6、需要写入显示符号的ASCII码或者汉字,LCD会利用字库映射为对应的符号并显示出来。程序源代码/* * measure.c * * Created on: 2015-4-6 * Author: Elan * P1.0输入正弦波作为外部时钟 * P1.1输入正弦波进行adc采样 */#include msp430g2553.h#define uint unsigned int#define uchar unsigned char#define ulint unsigned long intunsigned long data;/频率double TA_OverflowCnt=0;/溢出次数flo

7、at adc_sample=0;float adc_max=0;float effective_value=0;void init_TA();void init_adc();void cal_max();void delay(uint t);void delay1(void);void int_430(void);void sendbyte(uchar zdata);void write_com(uchar cmdcode);void write_data(uchar Dispdata);void lcdinit();void print_string( char *s);void displ

8、ay_fre(void);void display_range(void);void display_effective_value(void);void main()init_TA();init_adc();int_430();lcdinit();while(1)cal_max();display_fre();display_range();display_effective_value();delay1();void init_TA()P1SEL |= BIT0; /选取管脚第二功能P1DIR &= BIT0; /p1.0置为输入TA1CCR0=65535;/定时1sTACCR0=6553

9、5;TA1CTL |= TASSEL_2 + ID_3 + MC_1 + TAIE + TACLR;/P1.1 SMCLK作为时钟,8分频,增计数,中断使能,初始置0TA0CTL = TASSEL_0 + TACLR + TAIE + MC_2;/P1.0 外部输入时钟,中断使能,初始清零,连续计数TA0CCTL0 |= CCIE;/使能捕获TA1CCTL0 |= CCIE;_EINT(); /打开全局中断void init_adc()ADC10CTL1 |= CONSEQ_2;/单通道重复采样模式/ADC10CTL0 |= SREF_0+REFON+REF2_5V;/选择内部参考电源,打开基

10、准源,参考电压设置为VCC 3.3VADC10CTL0 |= SREF_0;ADC10CTL0 |= ADC10SHT_0+MSC;/过采样率设置为4个采样周期ADC10CTL1|= ADC10SSEL_3+ADC10DIV_1+SHS_0;/采样时钟为SMCLK,二分频ADC10CTL1 |=INCH_1;/选择采样通道A1ADC10CTL0 |= ADC10ON;/开启ADC10ADC10AE0 |= 0x02;/开启外部采样通道void cal_max()unsigned int i;for(i=0;i65635;i+)ADC10CTL0 |=ENC+ADC10SC; /开始转换whil

11、e(ADC10CTL0 &ADC10IFG)=0); /等待ADC10IFG标志变高(转换完成)adc_sample=(float)ADC10MEM) *4.2583) /1023-2; /读取采样结果if(adc_max adc_sample)adc_max=adc_sample;effective_value=adc_max/1.414;display_fre();display_range();display_effective_value();delay1();/*延时函数*/void delay(uint t) uint i,j; for(i=0;it;i+) for(j=0;j10

12、;j+);/1s延时的计数闸门void delay1(void) unsigned long i; for(i=0;i119000;i+) _NOP(); / 该函数用来产生一个 MSP430 系统时钟周期的延时 void int_430(void) P1SEL&=BIT6;/输出高电平,充当电源 P1SEL&=BIT7; P1DIR|= BIT6; P1DIR|= BIT7; P1OUT|=BIT6; P1OUT|=BIT7; WDTCTL=WDTPW+WDTHOLD; / 关闭看门狗 P1SEL&=BIT4; P1DIR|= BIT4; P1OUT&=BIT4; P1SEL&=BIT5; P1DIR|= BIT5; P1OUT&=BIT5;/*数据传送函数*/void sendbyte(uchar zdata) uchar code_seg7,serial_clk, serial_shift; code_seg7=zdata; serial_shift=0x80; for(serial_clk=0; serial_clk1; /准备发送下一位数据 /*写命令函数*/void write_com(uchar cmdcode) /串口控制格式(11111AB0) /A数据方向控制,A=H时读,A=L时写 /B数据类型选择,B=H时为显示

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 高等教育 > 其它相关文档

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号