找回密碼
 立即注冊(cè)

QQ登錄

只需一步,快速開(kāi)始

搜索
查看: 2622|回復(fù): 0
打印 上一主題 下一主題
收起左側(cè)

PID算法控制電機(jī)轉(zhuǎn)速

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
部分程序圖

#include<reg52.h>
#include"lcd1602.h"

sfr T2MOD = 0x0c9;
#define uchar unsigned char
#define uint unsigned int

sbit Q0 = P2^4;
sbit Q1 = P2^5;
sbit Q2 = P2^6;
sbit Q3 = P2^7;

sbit PWM                 = P1^7;
sbit UP                         = P1^0;
sbit DOWM                 = P1^1;
sbit GORB                = P2^3; //換相
sbit ADDSPEED         = P1^2;
sbit SUBSPEED        = P1^3;

uint tuint = 65535;
uint tpwm = 1;        //pwm周期為10000us tpwm變量表示pwm高電平時(shí)間,也相當(dāng)于占空比 (仿真時(shí),頻率高時(shí),電機(jī)反應(yīng)慢。在實(shí)物上要加大頻率)
uchar t1_flag = 0;

uint pulse = 0;
uint t0_flag = 0;
uchar t2_flag = 0;
bit t2_over = 0;
bit Just_Get = 1;


#define         ZZ                 { Q0 = 0;Q1 = 0;Q2 = 1;Q3 = 1;}        //正轉(zhuǎn)
#define         FZ                 { Q0 = 1;Q1 = 1;Q2 = 0;Q3 = 0;}        //反轉(zhuǎn)
#define         STOP        { Q0 = 1;Q1 = 0;Q2 = 1;Q3 = 0;}        //停止
//禁止出現(xiàn) Q0 = 0;Q1 = 1;Q2 = 0;Q3 = 1; 不然會(huì)燒掉mos管

//************************ PID *************************************
float now = 0,bef = 0,bbef = 0;         //本次采樣值,上次采樣值,上上次采樣值
float err_now,err_bef,err_bbef;                //當(dāng)前偏差,上次偏差,上上次偏差
float error_add = 0;                                //所有偏差之和
float set = 25;                                                //設(shè)定值

float kp = 25;
float ki = 25;
float kd = 0;

//*****************************************************************

void delayms(uint ms)//延時(shí)?個(gè) ms
{
    uchar a,b,c;
        while(ms--)
        {
          for(c=1;c>0;c--)
        for(b=142;b>0;b--)
            for(a=2;a>0;a--);
        }
}

void timer_init()
{
        EA = 1;
        ET0 = 1;
        ET1 = 1;
        ET2 = 1;
        
        TMOD = 0x15; //定時(shí)器0 計(jì)數(shù)模式 定時(shí)器1模式1
        T2MOD = 0x01;
        
        TH0 = TL0 = 255;
        TH2 = 0x3C;
        TL2 = 0xB0;                //50MS
        
}
void timer1() interrupt 3
{
        if(t1_flag == 0)
        {
                t1_flag = 1;
                PWM = 1;
                TH1 = (tuint - tpwm + 1)/256;
                TL1 = (tuint - tpwm + 1)%256;
               
        }
        else
        {
                t1_flag = 0;
                PWM = 0;
                TH1 = (tuint - 10000 + tpwm + 1)/256;
                TL1 = (tuint - 10000 + tpwm + 1)%256;
        }
}


分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩

相關(guān)帖子

回復(fù)

使用道具 舉報(bào)

本版積分規(guī)則

手機(jī)版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表