找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 4021|回复: 3
打印 上一主题 下一主题
收起左侧

基于51单片机的DC/DC电路仿真+程序设计,综合设计

  [复制链接]
跳转到指定楼层
楼主
ID:99800 发表于 2019-1-23 20:38 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
做的综合设计,融合了单片机技术,模拟电子技术,电力电子技术,自动控制技术,设计了一个基于51单片机的PID控制的DC/DC电路,该设计主体电路是BUCK电路,用单片机进行控制开关管的导通关断,从而实现对DC/DC的控制要求。开关管所需的PWM由单片机进行运算后发出,最终实现了DC/DC的输出功能。

仿真原理图如下(proteus仿真工程文件可到本帖附件中下载)
主电路


仿真


BUCK电路


单片机源程序:

  1. #include<reg51.h>

  2. #define uchar unsigned char
  3. #define uint unsigned int

  4. sbit pwm=P2^7;
  5. sbit lcdrs=P2^2;
  6. sbit lcdrw=P2^1;
  7. sbit lcden=P2^0;
  8. sbit st=P1^2;
  9. sbit eoc=P1^1;
  10. sbit oe=P1^0;

  11. #include"timer1.c"
  12. #include"delay.c"
  13. #include"adin0.c"
  14. #include"write_com.c"
  15. #include"write_data.c"
  16. #include"init.c"
  17. #include"xianshi.c"

  18. void main()
  19. {
  20.         int ww=0;
  21.         uchar i0,j0,t,k;
  22.         uint sum=0,in0,a[50];
  23.         init();
  24.         while(1)
  25.         {
  26.                 for(k=0;k<50;k++)                        //记录AD转换50次
  27.                 {
  28.                         a[k]=2*adin0();
  29.                 }
  30.                 for(j0=0;j0<49;j0++)        //50个数据排序
  31.                 {
  32.                         for(i0=0;i0<49-j0;i0++)
  33.                         {
  34.                                 if(a[i0]>a[i0+1])
  35.                                 {
  36.                                         t=a[i0];
  37.                                         a[i0]=a[i0+1];
  38.                                         a[i0+1]=t;
  39.                                 }
  40.                         }
  41.                 }
  42.                 sum=0;
  43.                 for(k=10;k<40;k++)                //去除最大的10个与最小的10个
  44.                 {
  45.                         sum=sum+a[k];
  46.                 }
  47.                 in0=sum/30;                //求平均值
  48.                 xianshi(in0);
  49.                 in0=in0*2-5;
  50.                 if(in0<490||in0>510)
  51. //                if(in0!=500)
  52.                 {
  53.                         if(in0<500)        ww+=(500-in0);
  54.                         if(in0>500)        ww-=(in0-500);
  55.                         b=(b*10+500-in0+ww/10)/10;
  56.                 }
  57.         }
  58. }
  59. int a=0,b=50;
  60. void timer1() interrupt 3                                        //确定pwm占空比
  61. {
  62.         if(a<b)pwm=1;
  63.         else pwm=0;
  64.         a++;
  65.         if(a==100)a=0;
  66. }
  67. void delay(uchar z)                                                        //延时函数        
  68. {
  69.         uchar i,j;
  70.         for(i=z;i>0;i--)
  71.                 for(j=110;j>0;j--);
  72. }
  73. uchar adin0()
  74. {
  75.         uchar value;
  76.         oe=0;                                                        
  77.         st=0;                                //启动信号输入端,上升沿清除ADC0808寄存器,下降沿启动AD转换
  78.         delay(10);
  79.         st=1;
  80.         delay(10);
  81.         st=0;
  82.         while(!eoc);                //等待转换完成
  83.         delay(10);
  84.         oe=1;                                                //准许输出信号
  85.         delay(1);
  86.         value=P3;
  87.         oe=0;
  88.         value=value;
  89.         return value;
  90. }
  91. write_com(uchar com)                        
  92. {
  93.         lcdrs=0;                //命令寄存器写入
  94.         P0=com;
  95.         delay(5);
  96.         lcden=1;                //准许LCD输入
  97.         delay(5);
  98.         lcden=0;
  99. }
  100. write_data(uchar date)               
  101. {
  102.         lcdrs=1;                //数据寄存器写入
  103.         P0=date;
  104.         delay(5);
  105.         lcden=1;                //准许LCD输入
  106.         delay(5);
  107.         lcden=0;
  108. }
  109. void init()                                                //初始化子程序
  110. {
  111.         TMOD=0x20;                //定时器1设置为方式2
  112.         TH1=246;                        //定时器1初值
  113.         TL1=246;
  114.         TR1=1;
  115.         ET1=1;
  116.         EA=1;
  117.         oe=0;        
  118.         P1=0x07;
  119.         lcdrs=0;                                                               
  120.         lcdrw=0;
  121.         lcden=0;
  122.         pwm=1;
  123.         write_com(0x38);                //显示模式设置               
  124.         write_com(0x0c);                //显示开关及光标设置               
  125.         write_com(0x06);                //输入方式设置
  126.         write_com(0x80);                //DDRAM(数据显示存储器)地址设置
  127. }
  128. uchar temp0,temp1,temp2,temp3;
  129. void xianshi(uint num)                        //显示数值子程序               
  130. {
  131.           write_com(0x80);
  132.                 num=2*num-3;
  133.                 temp0=num/100;
  134.                 temp1=num%100/10;
  135.                 temp2=num%100%10;
  136.                 write_data('s');
  137.                 write_data('h');
  138.                 write_data('u');
  139.                 write_data('c');
  140.                 write_data('h');
  141.                 write_data('u');
  142.                 write_data(':');
  143.                 write_data(0x30+temp0);
  144.           write_data('.');
  145.                 write_data(0x30+temp1);
  146.                 write_data(0x30+temp2);
  147.                 write_data('v');
  148. }
复制代码


求大家指导 如何加入pid算法?
Keil代码与Proteus7.5仿真下载::
程序.rar (52.64 KB, 下载次数: 77)
DCDC.rar (99.09 KB, 下载次数: 83)


评分

参与人数 1黑币 +50 收起 理由
admin + 50 共享资料的黑币奖励!

查看全部评分

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏5 分享淘帖 顶 踩
回复

使用道具 举报

沙发
ID:698294 发表于 2020-2-29 01:52 | 只看该作者
感谢楼主
回复

使用道具 举报

板凳
ID:317237 发表于 2020-4-24 21:54 | 只看该作者
老铁,你这如何加入PID啊。。。
回复

使用道具 举报

地板
ID:837828 发表于 2021-4-30 10:58 | 只看该作者
老哥,你这里面没有用PID算法呀。
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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