找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 7492|回复: 7
收起左侧

51单片机正弦波发生器(1~100KHZ) 用DAC0832+定时器中断实现 带proteus仿真

  [复制链接]
ID:140725 发表于 2017-3-17 22:58 | 显示全部楼层 |阅读模式
下面给出一个设计实例,在实例中通过定时器中断和DAC0832结合的方式来产生1~100KHZ的正弦波,幅度为0-Vcc/2。
首先按照下面的公式建立一个正弦波样本表,样表中将一个正弦波周期分成128个点,每个点按7位量化(127对应最高幅度Vcc/2):
f(x) = 64 + 63 * sin(2πx/180) x∈[0…127]
程序中使用16位定时器0产生取样中断,及定时器0的中断时间即为正弦波的采样周期。(T=1/(f*64))。本例中将正弦波分成64个采样点输出,及每隔两个点要从采样样本中取出一个数DAC0832的输入。

0.png


单片机源程序:
  1. #define SIN_GLOBAL 1
  2. #include "sin.h"
  3. //正弦波128个采样点寄存数组
  4. code uchar Sin[128] = {
  5.                         64,67,70,73,76,79,82,85,88,91,94,96,99,102,104,106,
  6.                                                 109,111,113,115,117,118,120,121,123,124,125,126,126,
  7.                                                 127,127,127,127,127,127,127,126,126,125,124,123,121,
  8.                                                 120,118,117,115,113,111,109,106,104,102,99,96,94,91,
  9.                                                 88,85,82,79,76,73,70,67,64,60,57,54,51,48,45,42,39,
  10.                                                 36,33,31,28,25,23,21,18,16,14,12,10,9,7,6,4,3,2,1,
  11.                                                 1,0,0,0,0,0,0,0,1,1,2,3,4,6,7,9,10,12,14,16,18,21,23,
  12.                                                 25,28,31,33,36,39,42,45,48,51,54,57,60
  13.                       };
  14. /**********************************************************
  15. *函数名称:Timer0_init(double timer0Delay)
  16. *函数功能:定时器0初始化
  17. *函数入口:timer0Delay,定时器定时时间,单位为毫秒
  18. *函数出口:无
  19. **********************************************************/
  20. void Timer0_init(double timer0Delay)
  21. {
  22.    double time;
  23.    double timeTemp;
  24.    timer0TH0=0x00;
  25.    timer0TL0=0x00;
  26.    timeTemp=0x00;
  27.    time=(double)(((double)12)/((F_CPU)/1000000));
  28.    if(((double)255)*time>timer0Delay)
  29.     {
  30.        timer0TH0=0x00;
  31.            timer0TL0=(uchar)(256ul-timer0Delay/time);
  32.     }
  33.    else
  34.     {
  35.           while(timeTemp>timer0Delay)
  36.           {
  37.            timeTemp+=time;
  38.            timer0TH0++;  
  39.           }
  40.           timer0TH0--;                                 
  41.           timeTemp=timeTemp-((double)timer0TH0)*time;
  42.           timer0TL0=(uchar)(256ul-timeTemp/time);
  43.     }
  44.    TMOD|=0x01;                               //GATE=0,TR=1运行;C/T=1,counter,0,timer;01十六进制
  45.    TH0=timer0TH0;
  46.    TL0=timer0TL0;
  47.    TR0=1;                                         //timer0 控制位,为1时启动timer0
  48.    ET0=1;                                    //timer0 中断使能
  49. }
  50. /**********************************************************
  51. *函数名称:dac0832_init(void)       
  52. *函数功能:D/A转换芯片dac0832初始化
  53. *函数入口:无
  54. *函数出口:无
  55. **********************************************************/
  56. void dac0832_init(void)                            
  57. {
  58.   sinCodeCount=0;
  59.   DAC0832=Sin[0];
  60. }
  61. /**********************************************************
  62. *函数名称:writeDAC0832(uchar dacDate)       
  63. *函数功能:向D/A转换芯片dac0832数据口写数据
  64. *函数入口:dacDate
  65. *函数出口:无
  66. **********************************************************/
  67. void writeDAC0832(uchar dacDate)            
  68. {
  69.   DAC0832=dacDate;
  70. }
复制代码
0.png
下载:
正弦波发生器.rar (20.14 KB, 下载次数: 181)
回复

使用道具 举报

ID:217225 发表于 2017-7-4 22:28 | 显示全部楼层
程序有问题  求指导
回复

使用道具 举报

ID:396689 发表于 2018-10-24 21:53 来自手机 | 显示全部楼层
程序报错啊
回复

使用道具 举报

ID:407843 发表于 2018-10-26 21:24 | 显示全部楼层
测式AD好东西
回复

使用道具 举报

ID:592753 发表于 2019-8-8 13:33 | 显示全部楼层
没有main函数
回复

使用道具 举报

ID:281113 发表于 2019-10-20 09:09 | 显示全部楼层
看一看
回复

使用道具 举报

ID:774573 发表于 2024-1-18 15:54 | 显示全部楼层
这个问题解决了吗
回复

使用道具 举报

ID:1126601 发表于 2024-7-25 08:52 | 显示全部楼层
正弦波的频率怎么调的?
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表