亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? pid.c

?? 基于DSPLF2407A的PID算法
?? C
字號:
#include "2407c.h"                    
#include "PID.h"
#include "lcd.h"
ioport unsigned int port8000;
ioport unsigned int port8003;	
ioport unsigned int port8004;	
ioport unsigned int port8006;	
ioport unsigned int port8005;


// 大液晶控制板控制字  ----------------------------------------------------------
#define CTRSTATUS port8000 //port8000
#define CTRLED port8004 // port8004
#define MCTRKEY port8005  // port8005
#define CTRCLKEY port8006 // port8006
#define CTRSTATUS port8000 //port8000
#define CTRGR port8000 //port8000
#define CTRMOTORBSPEED port8003

void LCDPutString(unsigned int *pData,int x,int y,unsigned int nCharNumber,unsigned color);
void PIDControl(int rk,int yk);
void Delay(unsigned int nTime);		// 延時子程序
void PrintParameters();
void interrupt gptime1(void);     
void gp_init(void);   

int i=0,nnn;
unsigned int nCount,nCount_1=1,nCount1,nCount2,nCount3,nCount4,nJSSpeed,nJSSpeed_1=1,uWork;
unsigned int uLBD;
float a=0.6f,b=0.2f,c=0.1f,duk;
int ek,ek1,ek2,tz;
int nInput;
int nSSS,pwm,pwm1;
int md,wc;
unsigned int nScreenBuffer[30*128],pidnCount3,piduN;
int m_nSpeed,m_bPCSet;
unsigned int ccc;
int uN;
main()
{   
    unsigned int uWork1;
	int inputspeed;
	int breakflage;
	int speed[100],sp,lj;
	float ljh;
	int i,w1,w2,w3;
	
	*WSGR=0x09;
	*WDCR=0x6f;
	*WDKEY=0x5555;
	*WDKEY=0xaaaa;    
	*SCSR1=0x81fe;    //40m      
	
	asm(" setc INTM");
	for ( sp=0;sp<100;sp++ )	speed[sp]=0;
	for ( sp=0;sp<(30*128);sp++ )	nScreenBuffer[sp]=0;
	sp=nSSS=nCount=nCount1=nCount2=nCount3=nCount4=nJSSpeed=0; nInput=tz=wc=0;
	ek=ek1=ek2=0;
	uN=30; md=70; pwm1=60;
	m_nSpeed=70; m_bPCSet=0;
    inputspeed=0;
    uWork1=0;
    breakflage=0;
	
    CTRGR=0x80;
	CTRGR=0;
	CTRGR=0x80;
   	
    
	uWork=(*MCRC);
	uWork&=0x0ffc0;	/* PWM11/IOPE5,PWM12/IOPE6 for normal I/O ports */
	(*MCRC)=uWork;
	gp_init();   
	*IMR=0x3;
	*IFR=0xffff;    
	nCount=0;
	uWork=(*WSGR);
	uWork&=0x0fe39;
	(*WSGR)=uWork;
	
	// 設置顯示參數(shù)和內(nèi)容
	LCDSetDelay(1);		// 設置延時等待參數(shù)
	LCDSetScreenBuffer(nScreenBuffer);	// 顯示緩沖區(qū)
	LCDTurnOn();			// 打開顯示
	LCDCLS();				// 清除顯示內(nèi)存   
	LCDPutCString(str1,0,127,8,0);
	LCDPutCString(str2,0,111,2,1);
	LCDPutCString(str3,68,111,2,1);
	LCDPutCString(str6,0,95,2,1);
	LCDPutCString(str5,68,95,2,1);
	LCDPutCString(str7,0,79,3,1);
	LCDPutCString(str4,68,79,2,1);
	ShowParameters();		// 參數(shù)顯示
    CTRGR=01;   
	asm(" clrc INTM");         
	Delay(128);


	for(;;)
	{

	//讀鍵盤值
	 uWork1=MCTRKEY;
	 uWork1 &=0xff;
	 CTRCLKEY=0;
	 if(uWork1==4)
	 {		Delay(500);
		    uWork1=MCTRKEY;
	        uWork1 &=0xff;
	        CTRCLKEY=0; 
	        
		    md+=10;
		    ShowParameters();	// 顯示各參數(shù)值到LCD
	 }
	 if(uWork1==8)
	 {		Delay(500);
		    uWork1=MCTRKEY;
	        uWork1 &=0xff;
	        CTRCLKEY=0; 
	        
		    md-=10;
		    ShowParameters();	// 顯示各參數(shù)值到LCD
	 }
	 if(uWork1==1)
	 {		
		    Delay(500);
		    uWork1=MCTRKEY;
	        uWork1 &=0xff;
	        CTRCLKEY=0;
		    md+=1;
		    ShowParameters();	// 顯示各參數(shù)值到LCD
	 } 
	 if(uWork1==2)
	 {		
		    Delay(500);
		    uWork1=MCTRKEY;
	        uWork1 &=0xff;
	        CTRCLKEY=0;
		    md-=1;
		    ShowParameters();	// 顯示各參數(shù)值到LCD
	 }   
	  Delay(5);//延時,
		if (nJSSpeed_1==0)	// 讀取速度標志
		{ 
		    nJSSpeed_1=1; 
			nJSSpeed=0;
			//ccc=CTRMOTORBSPEED;	// 從端口讀取速度計數(shù)
			ccc=port8003;
			ccc=ccc&0xff;
			nSSS=ccc; 
			if ( nSSS>=0 && nSSS<400 )	// 合法性檢測
			{
				speed[sp]=nSSS; 		// 讀取66個計數(shù)值
				sp++; sp%=16;
			}
			if ( sp==0 )	// 是否已經(jīng)讀了66個速度?
			{				// 以下求速度平均值
				lj=0; ljh=0;
				for ( i=0;i<16;i++ )
				{
					if ( speed[i]>=0 && speed[i]<400 )
					{
						ljh+=speed[i];
						lj++;
					}
				}
				wc=( lj==0 )?(0):(ljh/lj);
				if ( wc>300 )
				{	
					wc=0;
				}
				//nCount3++; nCount3%=3;
				//if ( nCount3==2 )		
				//{
					PIDControl(md,wc);	// 調(diào)用PID算法控制程序進行控制
					uN=(100-pwm1)/2;			// 利用占空比調(diào)整控制
					ShowParameters();	// 顯示各參數(shù)值到LCD
			//	}
				//PrintParameters();
				nJSSpeed_1=1;
			}
		}
    }
}               
#define Hz200 50
#define Hz1 10000
void interrupt gptime1(void)
{  int fuzhi=0;
   uWork=(*PIVR);
   switch(uWork)
   {  
   		case 0x27:
   		{
			(*EVAIFRA)=0x80;
			//key();
			uWork=(*PEDATDIR);
			uWork|=0x6000;//設置pwm11和pwm12為io輸出模式
	        if(nCount1<=uN) 
	        {uWork=(*PEDATDIR);
	        uWork&=0x60DF;
	        (*PEDATDIR)=uWork;}
	        if(nCount1>uN) 
	        {uWork=(*PEDATDIR);
	        uWork|=0x6020;
	        (*PEDATDIR)=uWork;}
	         nCount1++; nCount1%=Hz200;
            if ( nCount2==0 )
            {
	        	
	        	if(nnn==0) {uWork=(*PEDATDIR);
			uWork|=0x6000;uWork&=0x60BF;(*PEDATDIR)=uWork;}
	        	if(nnn==1) {uWork=(*PEDATDIR);
			uWork|=0x6000;uWork|=0x6040;(*PEDATDIR)=uWork;}
	        	nnn=1-nnn;
            }
  			nCount2++; nCount2%=Hz1;
	        nJSSpeed++; nJSSpeed%=12000/8;	// 讀取速度標志
	        if(nJSSpeed==0) 
	        {nJSSpeed_1=0;}
	        /* nCount++; nCount%=51200;
	        if(nCount==0) 
	        {nCount_1=0;}*/
   		   	break;
   		}
   }
}                       

void gp_init(void)
{
   *EVAIMRA = 0x80;
   *EVAIFRA = 0xffff;
   *GPTCONA = 0x0100;
   //*T1PR    = 0xe80;//燒到flash中運行用此參數(shù)
   *T1PR    = 0x200; //ram中運行用此參數(shù)
   *T1CNT   = 0;
   *T1CON   = 0x1040;
}



void Delay(unsigned int nDelay)
{
	int i,j,k;
	
	for ( i=0;i<nDelay;i++ )
		for ( j=0;j<16;j++ )
			k++;
}

// PID算法控制子程序-------------------------------------------------------------------------
void PIDControl(int rk,int yk)
{
	ek=rk-yk;
	duk=a*ek+b*ek1+c*ek2;		// 計算控制輸出
	ek2=ek1; ek1=ek;
	if ( duk>5 )	duk=4;		// 幅度限制
	if ( duk<-4 )	duk=-4;		// 幅度限制
	tz=(int)duk;
	pwm1+=tz;					// 計算當前占空比
	if ( pwm1<0 )	pwm1=0;
	else if ( pwm1>99 )	pwm1=99;
}
void LCDPutString(unsigned int *pData,int x,int y,unsigned int nCharNumber,unsigned color)
{
	int i,j,l;
	unsigned int k,mcolor;
	
	for ( l=0;l<nCharNumber;l++ )
		for ( i=0;i<8;i++ )
		{
			k=1;
			for ( j=0;j<16;j++,k<<=1 )
			{
				if ( color==2 )	mcolor=2;
				else
				{
					mcolor=( pData[l*8+i]&k )?(1):(0);
					if ( color==0 )	mcolor=1-mcolor;
				}
				LCDPutPixel(x+l*8+i,y-j,mcolor);
			}
		}
}

// 顯示參數(shù)到LCD
void ShowParameters()
{
	int w1,w2,w3;
	
	w1=md%1000/100; w2=md%100/10; w3=md%10;
	LCDPutString(numbers+w1*8,36,111,1,1);
	LCDPutString(numbers+w2*8,44,111,1,1);
	LCDPutString(numbers+w3*8,52,111,1,1);
	w1=wc%1000/100; w2=wc%100/10; w3=wc%10;
	LCDPutString(numbers+w1*8,104,111,1,1);
	LCDPutString(numbers+w2*8,112,111,1,1);
	LCDPutString(numbers+w3*8,120,111,1,1);
	if ( ek>=0 )
	{
		LCDPutString(numbers+88,36,95,1,1);
		w3=((int)ek)%100;
	}
	else
	{
		LCDPutString(numbers+96,36,95,1,1);
		w3=((int)(-ek))%100;
	}
	w1=w3%100/10; w2=w3%10;
	LCDPutString(numbers+w1*8,44,95,1,1);
	LCDPutString(numbers+w2*8,52,95,1,1);
	if ( tz>=0 )
	{
		LCDPutString(numbers+88,104,95,1,1);
		w3=tz;
	}
	else
	{
		LCDPutString(numbers+96,104,95,1,1);
		w3=(-tz);
	}
	w1=w3%100/10; w2=w3%10;
	LCDPutString(numbers+w1*8,112,95,1,1);
	LCDPutString(numbers+w2*8,120,95,1,1);
	w1=pwm1%100/10; w2=pwm1%10;
	LCDPutString(numbers+w1*8,44,79,1,1);
	LCDPutString(numbers+w2*8,52,79,1,1);
	LCDPutString(numbers+80,60,79,1,1);
	LCDRefreshScreen();
}

int wwcc;
void PrintParameters()
{
	wwcc=wc-md;
	printf("測速[%3d] 設置[%3d] 誤差[%+4d] PID調(diào)整量[%+3d] 占空比[%3d%%]\n",
			wc,md,wwcc,tz,pwm1);
}

// No more.
//========================================


?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一本久久a久久免费精品不卡| 久久久精品免费网站| 精品国产制服丝袜高跟| 一区二区高清视频在线观看| 久久国产日韩欧美精品| 色噜噜狠狠色综合欧洲selulu| xfplay精品久久| 亚洲午夜私人影院| 不卡一卡二卡三乱码免费网站| 这里只有精品免费| 亚洲一区二区黄色| va亚洲va日韩不卡在线观看| 久久久不卡网国产精品二区| 麻豆精品新av中文字幕| 884aa四虎影成人精品一区| 综合欧美一区二区三区| 成人一区二区三区| 国产午夜精品美女毛片视频| 日韩国产欧美在线播放| 欧美无砖砖区免费| 一个色妞综合视频在线观看| proumb性欧美在线观看| 中文字幕乱码亚洲精品一区| 国产精品自产自拍| 久久夜色精品一区| 国产乱码一区二区三区| 精品美女一区二区三区| 久久精品国产精品亚洲精品| 日韩一区二区精品| 男人的天堂久久精品| 日韩一区二区视频在线观看| 日本v片在线高清不卡在线观看| 欧美日韩精品福利| 午夜精品一区二区三区电影天堂 | 亚洲国产成人va在线观看天堂| 不卡的看片网站| 国产欧美日韩综合| 成人av中文字幕| 亚洲欧美偷拍另类a∨色屁股| 99精品久久久久久| 一个色妞综合视频在线观看| 欧美欧美欧美欧美| 日韩成人免费电影| 精品国产一区二区亚洲人成毛片| 国产一区二区三区蝌蚪| 亚洲国产高清不卡| 在线免费观看视频一区| 日韩国产欧美一区二区三区| 精品国产一区a| 成人国产视频在线观看| 亚洲人成精品久久久久| 欧美日韩精品欧美日韩精品一综合| 五月综合激情网| 精品国产一区二区精华| av亚洲精华国产精华精| 五月婷婷激情综合| 26uuu久久天堂性欧美| 99在线热播精品免费| 午夜精品久久一牛影视| 欧美mv日韩mv| gogogo免费视频观看亚洲一| 亚洲综合一二区| 精品剧情在线观看| 99精品国产热久久91蜜凸| 午夜一区二区三区视频| 精品国产一区二区国模嫣然| 91在线视频播放地址| 热久久免费视频| 亚洲欧洲日韩女同| 欧美一区二区三区小说| 不卡一区在线观看| 青青草视频一区| 亚洲精品国久久99热| 欧美大片一区二区| 在线一区二区视频| 国产精品亚洲专一区二区三区| 亚洲黄网站在线观看| 精品久久久久久久一区二区蜜臀| 色综合久久88色综合天天| 狠狠色丁香久久婷婷综合丁香| 亚洲三级在线看| 精品处破学生在线二十三| 欧美天天综合网| 99热国产精品| 国内精品国产成人| 免费视频一区二区| 亚洲永久精品大片| 日韩理论片中文av| 国产三级久久久| 精品国产乱码久久久久久图片| 色狠狠av一区二区三区| 顶级嫩模精品视频在线看| 首页国产欧美日韩丝袜| 夜夜嗨av一区二区三区四季av| 日本一区二区视频在线| 精品免费国产一区二区三区四区| 欧美日韩亚洲综合一区二区三区| 99re免费视频精品全部| 成人性生交大片免费看中文网站| 美女脱光内衣内裤视频久久网站| 午夜视频在线观看一区二区| 亚洲欧美成aⅴ人在线观看| 国产日韩精品一区二区三区| 欧美成人a∨高清免费观看| 91精品欧美综合在线观看最新| 色94色欧美sute亚洲线路一久| 丁香婷婷综合激情五月色| 狠狠狠色丁香婷婷综合激情| 久久成人免费网站| 日本不卡的三区四区五区| 日韩精品一级中文字幕精品视频免费观看| 一区二区三区高清不卡| 亚洲欧美经典视频| 亚洲一区二三区| 亚洲国产欧美另类丝袜| 亚洲bdsm女犯bdsm网站| 亚洲成人在线观看视频| 亚洲国产成人tv| 秋霞影院一区二区| 日本中文一区二区三区| 免费欧美在线视频| 国产精品影视在线观看| 成人中文字幕在线| 成人激情免费电影网址| www.激情成人| 欧美性猛交xxxx黑人交| 欧美视频在线一区| 日韩欧美色电影| 欧美国产日韩a欧美在线观看| 国产精品久久久久久一区二区三区 | 欧美综合亚洲图片综合区| 欧美性猛交xxxx乱大交退制版 | 久久精品视频免费| 中文字幕一区二区三区乱码在线| 亚洲人成在线观看一区二区| 亚洲香蕉伊在人在线观| 奇米四色…亚洲| 成人免费视频免费观看| 91丨九色丨黑人外教| 欧美日韩中文另类| 久久综合久久99| 自拍偷拍亚洲欧美日韩| 日韩成人午夜精品| 成人av资源下载| 欧美日韩在线播| 久久久99精品久久| 亚洲综合清纯丝袜自拍| 美女网站在线免费欧美精品| av在线不卡网| 日韩三级中文字幕| 亚洲视频小说图片| 另类中文字幕网| 99久久综合国产精品| 91精品国产入口| 亚洲欧洲一区二区三区| 美女视频黄免费的久久| 91麻豆123| 2021国产精品久久精品| 一区二区欧美精品| 成人一区二区三区视频在线观看 | 日韩av电影免费观看高清完整版在线观看 | 日韩欧美电影一区| 亚洲黄色免费网站| 国产精品12区| 欧美狂野另类xxxxoooo| 国产精品国产三级国产普通话蜜臀| 天天综合网 天天综合色| 成人黄色电影在线 | 亚洲欧美日韩综合aⅴ视频| 热久久免费视频| 欧美色爱综合网| 中文字幕制服丝袜成人av| 免费观看久久久4p| 欧美日韩国产综合一区二区| 国产精品久久久一区麻豆最新章节| 美女视频黄 久久| 欧美军同video69gay| 亚洲乱码国产乱码精品精的特点| 国产精一区二区三区| 日韩视频永久免费| 亚洲国产成人va在线观看天堂| 99国产精品国产精品久久| 久久久亚洲综合| 久久狠狠亚洲综合| 欧美一二三在线| 日韩福利视频导航| 欧美日韩免费高清一区色橹橹| 亚洲精品视频一区二区| 91啪亚洲精品| 最新热久久免费视频| av毛片久久久久**hd| 亚洲国产高清在线观看视频| 国产精品456| 国产日韩精品久久久| 国产69精品久久777的优势| 精品欧美一区二区在线观看| 奇米精品一区二区三区四区| 欧美一级二级在线观看| 蜜桃久久精品一区二区| 精品国产一区二区在线观看|