51proteus仿真:生成方波、正弦波、锯齿波和三角波

发布者:EnchantedDreams最新更新时间:2017-01-10 来源: eefocus关键字:方波  正弦波  锯齿波  三角波 手机看文章 扫描二维码
随时随地手机看文章

这个proteus仿真是一个网友做的,该仿真可以生成方波、正弦波、锯齿波和三角波,并且还可以用按键调整波形。

不过,对初学者来讲,可能有点复杂。对于本科生来说,这个仿真几乎可以作为毕业论文了吧。当然,需要用实际元器件来调试,制作pcb,焊接。

我做的生成锯齿波生成正弦波的仿真,可以作为学习这个仿真的阶梯。

这个仿真主要是用到溢出中断,和外部键盘中断。熟悉中断,和定时器的编程后,实现这个仿真其实也很简单。

 

仿真图:

正弦波三角波锯齿波方波

 

C程序如下:

有三个C文件:

主函数文件如下:

#include
//unsigned char TIME0_H=0xec,TIME0_L=0x78;      //定时器0的初值设置;全局变量
#include
#include<0832.h>
void main()
{
   TMOD=0X01;
   TH0=0xff;
   TL0=0xd9;
   IT0=1;    //设置中断触发方式,下降沿
   EA=1;
   EX0=1;
   ET0=1;
   IP=0X01;  //键盘中断级别高
   TR0=1;
   while(1)
    {
   // square();
   ;
 }

 

}

 

 

0832.h文件如下:

 

#ifndef __0832_h__
#define __0832_h__
//#define INPUT XBYTE[0xbfff]  //即cs 与xfer 轮流低电平。
//#define DACR  XBYTE[0x7fff]  //单通道输出,单缓冲就行了。
unsigned char i,sqar_num=128; //最大值100,默认值50
unsigned char cho=0;         //0:正弦波。1:方波。2:三角波。3:锯齿波。
unsigned char num=0;
unsigned char TIME0_H=0xff,TIME0_L=0xd9;      //定时器0的初值设置;全局变量.对应正弦波,锯齿波50HZ
sbit chg=   P1^0;          //三角波100Hz.
sbit freq_u=P1^1;
sbit freq_d=P1^2;
sbit duty_u=P1^3;
sbit duty_d=P1^4;
sbit cs    =P3^7;
bit flag=0;
unsigned int FREQ=50;//初始化频率,50HZ

//调节部分——频率
void freq_ud(void)
{
   unsigned int temp;
   if(freq_d==0)
 {  FREQ--;  }
   else if(freq_u==0) 
  { FREQ++;  }
  
   if(cho==1|cho==3) //锯齿波256次中断一周期,特殊处理下。否则他的频率是100(+\-)n*2Hz.
  {
   temp=0xffff-3906/FREQ;  //方波,三角波默认为100hz,切换后频率也为50HZ 65336-10^6/(256*FREQ)
   TIME0_H=temp/256;
      TIME0_L=temp%256;
  }
   else if(cho==0|cho==3){  //正弦波 三角波默认周期50hz  65536-10^6//(512*FREQ)
   temp=0xffff-1953/FREQ;
   TIME0_H=temp/256;
   TIME0_L=temp%256;
   }
}
//调节部分——方波的占空比
void duty_ud(void)  //方波也采用512次中断构成一个周期。
{
   if(duty_d==0&sqar_num>0)
    sqar_num--;
   else if(duty_u==0&sqar_num<255) 
   sqar_num++;


}
//波形发生函数
void sint(void)
{
     if(!flag)
     {
        cs=0;
  P2=sin_num[num++];
  cs=1;
  if(num==0){num=255;flag=1;}
     }
    else if(flag) 
    {
    cs=0;
    P2=sin_num[num--];
    cs=1;
    if(num==255){num=0;flag=0;}
  
  }
}
void square(void)
{
    if(i++ else{cs=0;P2=0X00;cs=1;}
}
void triangle(void)
{
  cs=0;P2=num++;cs=1;
}
void stw(void)
{
   if(~flag)
     {
        cs=0;P2=num++;cs=1;
  if(num==0){num=255;flag=1;}
     }
   else if(flag)
     {
    cs=0;P2=num--;cs=1;
    if(num==255){num=1;flag=0;}
  
  }
}
//按键中断处理程序。
void it0() interrupt 0
{
   if(chg==0) { if(++cho==4) {cho=0;num=0;} }  //num=0;所有数据从新开始,保证波形的完整性
   else if(freq_u==0|freq_d==0)
     {freq_ud();}
   else if (cho==1&(duty_d==0|duty_u==0))
     {duty_ud();}
   else ;
}
//定时器中断处理程序。
void intt0() interrupt 1
{

 //TH0=0x00;TL0=0x00;sinx();

  switch(cho)
  {

   case 0:{TH0=TIME0_H;TL0=TIME0_L;sint()    ;break;}  //正弦波//每半周期256取样。
 case 1:{TH0=TIME0_H;TL0=TIME0_L;square();  break;} //方波   //为了提高方波的最高频率,只有牺牲占空比的最小可调值。分100份 每次1%。
 case 2:{TH0=TIME0_H;TL0=TIME0_L;triangle();break;} //三角波
   case 3:{TH0=TIME0_H;TL0=TIME0_L;stw();     break;} //锯齿波
 default: ;
  
  }

}

#endif

 

 

sinx.h如下:

 

//正弦表;每半个周期256个取值,最大限度保证波形不失真。
//各个值通过MATLAB算出,并四设五如取整。具体程序如下

#ifndef __sinx_h__
#define __sinx_h__
unsigned char code sin_num[]={     
      0,0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 2, 2, 2,
   2, 3, 3, 4, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9,
      10, 10, 11, 12, 12, 13, 14, 15, 15, 16, 17, 18, 18, 19, 20, 21,
   22, 23, 24, 25, 25, 26, 27, 28, 29, 30, 31, 32, 34, 35, 36, 37,
      38, 39, 40, 41, 42, 44, 45, 46, 47, 49, 50, 51, 52, 54, 55, 56,
      57, 59, 60, 61, 63, 64, 66, 67, 68, 70, 71, 73, 74, 75, 77, 78,
    80, 81, 83, 84, 86, 87, 89, 90, 92, 93, 95, 96, 98, 99, 101,102,
   104, 106, 107, 109, 110, 112,    113, 115, 116, 118, 120, 121, 123, 124, 126, 128,
   129, 131,    132, 134, 135,    137,    139, 140, 142, 143, 145, 146, 148,    149, 151, 153,
   154, 156, 157, 159, 160, 162, 163, 165,    166, 168, 169, 171, 172, 174, 175, 177,
   178, 180, 181,    182, 184, 185, 187, 188, 189, 191, 192, 194, 195, 196, 198, 199,
   200, 201, 203, 204, 205, 206, 208, 209, 210, 211, 213, 214, 215, 216, 217, 218, 
   219, 220, 221, 223, 224, 225, 226, 227, 228, 229, 230, 230, 231, 232, 233, 234, 
   235, 236, 237, 237, 238, 239, 240, 240, 241, 242, 243, 243, 244, 245, 245, 246, 
   246, 247, 247, 248, 248, 249, 249, 250, 250, 251, 251,    251, 252, 252, 253, 253, 
   253, 253, 254, 254, 254, 254, 254, 255, 255, 255, 255,    255, 255, 255, 255, 255


      };
#endif
//MATLAB程序:
//x=linspace(-pi/2,pi/2,255);%如果过采用1位采用,很多值是重的。虽然实际中并不会。
//y=(sin(x)+1)/2.0*255;
//%uint32(y)%强制类型转换。
//%fprintf('%.f\n',uint32(y));%控制输出类型
//round(y)%四舍五入函数


关键字:方波  正弦波  锯齿波  三角波 引用地址:51proteus仿真:生成方波、正弦波、锯齿波和三角波

上一篇:51proteus仿真:7段数码管显示小数
下一篇:51proteus仿真:生成正弦波

推荐阅读最新更新时间:2024-03-16 15:30

ML2036产生程控增益正弦波的应用电路
4 应用电路 ML2036简单易用,可以很方便的产生程控正弦波信号,图4所示是ML2036产生程控增益正弦波的硬件原理设计,图中的U3(AD5262)是程控数字电位器,具有256个节点,正负双电源供电,可以处理正负双向交流信号,过零正弦波峰峰值(±2.5V)分辨率可以达到VREF/256=10mW,再经过运放把峰峰值放大为20V。单片机AT89C2051用普通I/0口即可模拟ML2036和数字电位器AD5262的数字接口,从而对输出正弦波进行频率和幅度的控制。再把单片机串口收发信号经232电平转换后接到PC机串口,就构成幅度和频率都可以连续程控的过零正弦波信号发生器。
[模拟电子]
ML2036产生程控增益<font color='red'>正弦波</font>的应用电路
c51: 用定时器T0 ,P0输出1s 方波,中断
/* T0工作方式2,自动重载8位定时器。 设 频率:f, 定时器初值 val ,定时时间 T。 关系式 T=(2^8-val)*12/f */ //任务:f=12MHZ ,T0工作方式2,定时250us,中断2000次,P0口翻转,使P0口输出1s 的方波。 #include reg52.h #define uint unsigned int //定义全局变量 uint counter; init_T0() { TMOD=0x02; //定时器工作方式 TL0=0x06; //时间常数 TH0=0x06; IE=0x82; //开中断 TR0=1; //T
[单片机]
PWM方波产生51程序
PWMH DATA 30H ;高电平脉冲的个数 PWM DATA 31H ;PWM周期 COUNTER DATA 32H pwmhmin DATA 33H ORG 0000H AJMP MAIN ;ORG 0003H ;AJMP INT_X0 ;ORG 0013H ;AJMP INT_X1 ORG 000BH AJMP INT_T0 ORG 0100H MAIN: MOV SP,#60H ;给堆栈指针赋初值 mov ie,#87h MOV PWMH,#02H ; MOV COUNTER,#01H MOV PWM,#14H MOV TMOD,#02H ;定时器0在模式2
[单片机]
51proteus仿真:生成方波正弦波锯齿波三角
这个proteus仿真是一个网友做的,该仿真可以生成方波、正弦波、锯齿波和三角波,并且还可以用按键调整波形。 不过,对初学者来讲,可能有点复杂。对于本科生来说,这个仿真几乎可以作为毕业论文了吧。当然,需要用实际元器件来调试,制作pcb,焊接。 我做的 生成锯齿波 和 生成正弦波 的仿真,可以作为学习这个仿真的阶梯。 这个仿真主要是用到溢出中断,和外部键盘中断。熟悉中断,和定时器的编程后,实现这个仿真其实也很简单。 仿真图: C程序如下: 有三个C文件: 主函数文件如下: #include reg51.h //unsigned char TIME0_H=0xec,TIME0_L=0x78; //定时器0的初值设置;全局
[单片机]
51proteus仿真:生成<font color='red'>方波</font>、<font color='red'>正弦波</font>、<font color='red'>锯齿波</font>和<font color='red'>三角</font><font color='red'>波</font>
正弦波输出逆变电源的设计
引言 低压小功率 逆变电源 已经被广泛应用于工业和民用领域。特别是新能源的开发利用,例如太阳能电池的普遍使用,需要一个逆变系统将太阳能电池输出的直流电压变换为220V、50Hz交流电压,以便于使用。本文给出了一种用单片机控制的 正弦波 输出逆变电源的设计,它以12V直流电源作为输入,输出220V、50Hz、0~150W的正弦波交流电,以满足大部分常规小电器的供电需求。该电源采用推挽升压和全桥逆变两级变换,前后级之间完全隔离。在控制电路上,前级推挽升压电路采用SG3525芯片控制,采样变压器绕组电压做闭环反馈;逆变部分采用单片机数字化SPWM控制方式,采样直流母线电压做电压前馈控制,同时采样电流做反馈控制;在保护上,具有输
[电源管理]
对示波器测量正弦波幅值和相位仿真实验
在博文 使用数字示波器DS6104测量交流信号的幅值和相位 中对于使用示波器测量正弦交流信号的幅值和相位进行了分析和实验研究。但是对测量出的幅值和相位结果中的误差随着示波器的时基( time base )不同而改变的原因,究竟是在博文第二部分分析中理论上存在的误差引起的,还是由于示波器本身在同步、AD位数精度、数据处理窗口方面引起的呢? 关于这个问题可以通过计算机仿真实验,对采集过程使用仿真来验证。 01数据生成和计算方法 在实验中,根据DS6104示波器的参数,对于采集到的数据做一下假设: 数据点个数N = 1400 N = 1400N=1400,时基T s T_sT s 对应100个数据采样点。信号的频率f
[测试测量]
对示波器测量<font color='red'>正弦波</font>幅值和相位仿真实验
单片机之晶振篇
1.什么是晶振? 晶振,一般我们指的是石英晶体振荡器,是一种高精度和高稳定度的振荡器。 通过一定的外接电路来,可以生成频率和峰值稳定的正弦波。 2.晶振对单片机的作用? 在单片机的最小系统一般有时钟电路,晶振是时钟电路的组成部分。 时钟电路产生脉冲信号。 单片机在运行的时候,需要一个脉冲信号,作为自己执行指令的触发信号,可以简单的想象为:单片机收到一个脉冲,就执行一次或多次指令,这也就是所谓的心跳。 3.硬件上,晶振电路的实现? 如上图是51单片机晶振的典型应用电路,一般晶振旁边会带两个30pf或者20pf的电容,这个电容叫做负载电容。 为什么要加电容?这涉及到晶振的应用原理。首先说一下结论,这两个电容是负载电容,不
[单片机]
单片机之晶振篇
精密幅度稳定的低失真正弦波振荡器的设计
很多应用都需要频率和/或幅度稳定的正弦波做为定标或测量的参考。对于LVDT信号调理、ADC测试、谐波失真测试等应用也要求低谐波失真。很多正弦波产生技术不可能简单地实现精密正弦波参考所要求的低谐波失真和幅度稳定度。本文所示的正弦波产生技术能实现小于0.003%失真和0.1幅度稳定度。   图1示出1个简单的振荡器电路,它是由1个Wein桥振荡器核心和1个幅度稳定回路组成的。Linear公司的LT1632高速低失真放大器和正反馈RC网络产生振荡。由LTC1968RMS-DC振荡器、LTC2054缓冲器和LTC1632误差放大器构成的负反馈回路控制正弦波的幅度和幅度稳定度。 图1 精密幅度稳定的低失真正弦波振荡器电路   振荡
[电源管理]
精密幅度稳定的低失真<font color='red'>正弦波</font>振荡器的设计
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved