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

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

?? pid.c

?? 基于DSPLF2407A的PID算法
?? C
字號:
#include "2407c.h"                    
#include "PID.h"
#include "scancode.h"
#include "ctr.h"
ioport unsigned int port8000;	
ioport unsigned int port8001;	
ioport unsigned int port8002;	
ioport unsigned int port8007;
ioport unsigned int port8003;	

void Delay(unsigned int nTime);
void interrupt time(void);
char ConvertScanToChar(unsigned char cScanCode);
void interrupt gptime1(void);     
void gp_init(void);      
void PIDControl(int rk,int yk);
void ShowParameters();
//void key(void);
ioport unsigned int port8001;	
unsigned int uWork,nCount,uN,uN1,nCount1=0,nDir;
int i=0,nnn;
unsigned int nCount,nCount1,nCount2,nCount3,nCount_1=1,nJSSpeed,nJSSpeed1=1,uWork,uN;
unsigned int uLBD;
float a=0.6f,b=0.2f,c=0.1f,duk;
int ek,ek1,ek2,tz;
int nInput;
int nSSS,pwm;
int md,wc,speed[100];
unsigned int nScreenBuffer[1024];
unsigned int _nClearKey,_ledx[8],_ledbuf[8],_ledkey[11][8];
char cKey,cOldKey;
unsigned int nScanCode;
unsigned int uWork1,uWork_1=0,nSpeed;
unsigned int uPort8000;
int sp,sp1=1,lj;
float ljh;
char strInput[4];
int i,w1,w2,w3;
main()
{   
    
	
	asm(" setc INTM");
	uLBD=nnn=0;
	nCount=nCount1=nCount2=nCount3=nJSSpeed=0;
	for ( sp=0;sp<100;sp++ )	speed[sp]=0;
	sp=nSSS=nCount=nCount1=nCount2=nJSSpeed=0; cKey=0; nInput=tz=wc=0;
	ek=ek1=ek2=0;
	for ( uWork=0;uWork<4;uWork++ )	strInput[uWork]=0;
	uN=40; md=30; pwm=60;
	
	port8000=0;
	port8000=0x80;
	port8000=0;
	port8007=0;			// 關閉東西方向的交通燈
	port8007=0x40;	// 關閉南北方向的交通燈
	uWork1=port8002;	// 清除鍵盤緩沖區

    CTRInit();
	
    *WSGR=0x09;
	*WDCR=0x6f;
	*WDKEY=0x5555;
	*WDKEY=0xaaaa;    
	*SCSR1=0x81fe;    //40m      
	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;
	
	// 設置顯示參數和內容
	LCDSetDelay(1);		// 設置延時等待參數
	LCDSetScreenBuffer(nScreenBuffer);	// 顯示緩沖區
	LCDTurnOn();			// 打開顯示
	LCDCLS();				// 清除顯示內存   
	LCDPutCString(str1,0,63,8,0);
	LCDPutCString(str2,0,47,2,1);
	LCDPutCString(str3,68,47,2,1);
	LCDPutCString(str6,0,31,2,1);
	LCDPutCString(str5,68,31,2,1);
	LCDPutCString(str7,0,15,3,1);
	LCDPutCString(str4,68,15,2,1);
	ShowParameters();		// 參數顯示
	asm(" clrc INTM");         
	Delay(128);
	port8000=0x81;
	//port8007=0x0c4;//使能直流電機
	for(;;)
	{

		/*if ( nCount_1==0 )	// 讀取鍵盤標志
		{ 
		  nCount_1=1;
		  key();
		}*/
		if ( nJSSpeed1==0 )	// 讀取速度標志
		{  asm(" setc INTM");
			nJSSpeed1=1;
			nSSS=port8003;	// 從端口讀取速度計數
			nSSS&=0x0ff;
			if ( nSSS>=0 && nSSS<100 )	// 合法性檢測
			{
				speed[sp]=nSSS; 		// 讀取66個計數值
				sp++; sp%=16;
				if(sp==0) sp1=0;
			}
			if ( sp1==0 )	// 是否已經讀了66個速度?
			{				// 以下求速度平均值
			    sp1=1;
				lj=0; ljh=0;
				for ( i=0;i<16;i++ )
				{
					if ( speed[i]>=0 && speed[i]<150 )
					{
						ljh+=speed[i];
						lj++;
					}
				}
				wc=( lj==0 )?(0):(ljh/lj);
				if ( wc>150 )
				{	
					wc=0;
				}
				nCount3++; nCount3%=3;
				if ( nCount3==2 )		
				{
					PIDControl(md,wc);	// 調用PID算法控制程序進行控制
					uN=(100-pwm)/2;			// 利用占空比調整控制
					ShowParameters();	// 顯示各參數值到LCD
				}
			}
		}
			asm(" clrc INTM");  
	}
	port8000=0;
	port8000=0x80;
	port8000=0;
	exit(0);
}               
#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) nJSSpeed1=0;
			//nCount++; nCount%=51200/10;	
			//if(nCount==0) nCount_1=0;	
   		   	break;
   		}
   }
}                       

void gp_init(void)
{
   *EVAIMRA = 0x80;
   *EVAIFRA = 0xffff;
   *GPTCONA = 0x0100;
   //*T1PR    = 0xe80;//燒到flash中運行用此參數
   *T1PR    = 0x200; //ram中運行用此參數
   *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>10 )	duk=3;		// 幅度限制
	tz=(int)duk;
	pwm+=tz;					// 計算當前占空比
	if ( pwm<0 )	pwm=0;
	else if ( pwm>99 )	pwm=99;
}
// 顯示參數到LCD
void ShowParameters()
{
	int w1,w2,w3;
	
	w1=md%1000/100; w2=md%100/10; w3=md%10;
	LCDPutString(numbers+w1*8,36,47,1,1);
	LCDPutString(numbers+w2*8,44,47,1,1);
	LCDPutString(numbers+w3*8,52,47,1,1);
	w1=wc%1000/100; w2=wc%100/10; w3=wc%10;
	LCDPutString(numbers+w1*8,104,47,1,1);
	LCDPutString(numbers+w2*8,112,47,1,1);
	LCDPutString(numbers+w3*8,120,47,1,1);
	if ( ek>=0 )
	{
		LCDPutString(numbers+88,36,31,1,1);
		w3=((int)ek)%100;
	}
	else
	{
		LCDPutString(numbers+96,36,31,1,1);
		w3=((int)(-ek))%100;
	}
	w1=w3%100/10; w2=w3%10;
	LCDPutString(numbers+w1*8,44,31,1,1);
	LCDPutString(numbers+w2*8,52,31,1,1);
	if ( tz>=0 )
	{
		LCDPutString(numbers+88,104,31,1,1);
		w3=tz;
	}
	else
	{
		LCDPutString(numbers+96,104,31,1,1);
		w3=(-tz);
	}
	w1=w3%100/10; w2=w3%10;
	LCDPutString(numbers+w1*8,112,31,1,1);
	LCDPutString(numbers+w2*8,120,31,1,1);
	w1=pwm%100/10; w2=pwm%10;
	LCDPutString(numbers+w1*8,44,15,1,1);
	LCDPutString(numbers+w2*8,52,15,1,1);
	LCDPutString(numbers+80,60,15,1,1);
	w1=uWork_1%1000/100; w2=uWork_1%100/10; w3=uWork_1%10;
	LCDPutString(numbers+w1*8,104,15,1,1);
	LCDPutString(numbers+w2*8,112,15,1,1);
    LCDPutString(numbers+w3*8,120,15,1,1);
	LCDRefreshScreen();
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
免费人成精品欧美精品| 欧美精品一区二区三| 国产原创一区二区三区| 亚洲午夜久久久久久久久久久| 国产日韩欧美激情| 久久精品免视看| 久久新电视剧免费观看| 2020日本不卡一区二区视频| 精品国产一区二区三区久久影院| 欧美一区二区美女| 精品久久久久久久久久久院品网 | 在线观看www91| 色综合久久久久久久久久久| 91污在线观看| 欧美一二区视频| 欧美一区二区播放| 2024国产精品| 中文字幕一区二区三| ...xxx性欧美| 日韩精品五月天| 精品一区二区三区免费播放 | 国产伦精品一区二区三区免费| 国产精品系列在线播放| 成人网男人的天堂| 欧美视频一区二区在线观看| 91精品国产入口在线| 久久综合久久综合久久综合| 国产精品人成在线观看免费| 亚洲欧美怡红院| 日本欧美在线看| 成人免费黄色大片| 欧美中文字幕一二三区视频| 日韩欧美国产一区二区在线播放| 国产欧美一区二区三区网站| 亚洲激情综合网| 国精品**一区二区三区在线蜜桃| 成人性色生活片免费看爆迷你毛片| 91麻豆国产自产在线观看| 91精品国产综合久久香蕉的特点| 亚洲国产岛国毛片在线| 午夜欧美视频在线观看| 成人app软件下载大全免费| 欧美剧在线免费观看网站| 欧美国产亚洲另类动漫| 日本不卡高清视频| 色综合av在线| 中文字幕精品一区二区精品绿巨人| 日韩中文字幕1| 99久久精品免费| 久久婷婷综合激情| 天堂va蜜桃一区二区三区| 国产99精品在线观看| 日韩一区二区三区视频在线| 一区二区三区免费| 丁香桃色午夜亚洲一区二区三区| 7777女厕盗摄久久久| 亚洲欧美偷拍三级| 成人亚洲精品久久久久软件| 日韩欧美精品在线视频| 午夜视黄欧洲亚洲| 在线观看免费亚洲| 一区二区三区在线免费播放 | 亚洲va欧美va人人爽| 成人精品国产免费网站| 久久综合给合久久狠狠狠97色69| 亚洲777理论| 欧美亚洲高清一区| 一区二区三区免费观看| 色伊人久久综合中文字幕| 国产精品人妖ts系列视频| 国产成人综合精品三级| 欧美mv日韩mv国产网站| 肉肉av福利一精品导航| 欧美精品黑人性xxxx| 五月天婷婷综合| 欧美午夜不卡视频| 亚洲乱码日产精品bd| 91官网在线免费观看| 亚洲人成网站影音先锋播放| 不卡的av中国片| 亚洲欧美aⅴ...| 日韩精品一区二区三区蜜臀| 蜜桃在线一区二区三区| 日韩一区二区三区在线观看| 免费在线观看精品| 久久免费美女视频| 国产成人在线观看| 1区2区3区精品视频| 一本到三区不卡视频| 亚洲一二三区视频在线观看| 欧美电影一区二区三区| 免费精品视频在线| 国产欧美精品一区二区色综合| 成人自拍视频在线| 一区二区三区高清| 制服丝袜中文字幕一区| 国产剧情一区在线| 亚洲丝袜精品丝袜在线| 欧美日韩久久一区二区| 蜜桃久久精品一区二区| 国产欧美一区二区三区在线看蜜臀 | 国产精品不卡在线观看| 欧洲色大大久久| 看电影不卡的网站| 中文字幕一区二区三区在线观看| 91麻豆免费看片| 美腿丝袜亚洲三区| 国产精品无码永久免费888| 一本一道波多野结衣一区二区| 亚洲图片欧美综合| 国产午夜精品久久久久久免费视| aa级大片欧美| 日韩成人午夜电影| 一色桃子久久精品亚洲| 日韩欧美中文字幕公布| 色婷婷久久久久swag精品| 精品一区二区三区久久久| 依依成人综合视频| 精品国产网站在线观看| 欧美亚洲动漫精品| 国产高清不卡一区二区| 日韩成人免费看| 日韩美女精品在线| 久久久另类综合| 欧美精品在线一区二区| 日本高清免费不卡视频| 国产精品一区二区在线播放| 午夜精品久久久久影视| 亚洲桃色在线一区| 国产精品美女一区二区三区| 日韩精品一区二区三区中文精品| 在线观看成人小视频| 不卡电影一区二区三区| 国产精品一区一区三区| 麻豆国产精品官网| 偷拍与自拍一区| 亚洲一区二区综合| 一区二区三区日韩在线观看| 国产精品久久久久桃色tv| 久久亚洲综合色| 欧美成人r级一区二区三区| 欧美男生操女生| 欧美天天综合网| 欧美三级乱人伦电影| 在线免费观看不卡av| 色激情天天射综合网| 91亚洲精品一区二区乱码| 成人18精品视频| 成人av综合一区| 不卡av免费在线观看| 99九九99九九九视频精品| 成人午夜av影视| 91在线码无精品| 色综合天天视频在线观看| 色拍拍在线精品视频8848| 色中色一区二区| 在线欧美小视频| 欧美性猛交xxxx乱大交退制版| 色美美综合视频| 在线视频一区二区免费| 欧美日韩高清一区二区| 欧美日韩免费视频| 日韩亚洲欧美高清| 日韩欧美国产一区在线观看| 久久久亚洲综合| 国产精品久久久久aaaa| 亚洲黄色免费网站| 午夜私人影院久久久久| 麻豆成人av在线| 国产乱码精品1区2区3区| 91女人视频在线观看| 欧美日韩国产一级| 日韩精品一区国产麻豆| 欧美激情一区二区三区不卡| 中文字幕字幕中文在线中不卡视频| 亚洲综合色噜噜狠狠| 日本欧美一区二区三区| 国产精品一品二品| 91亚洲国产成人精品一区二区三| 欧美日本不卡视频| 久久亚洲影视婷婷| 亚洲三级在线看| 视频一区二区欧美| 国产精品一二三四区| 色综合久久久久久久久久久| 日韩免费观看高清完整版在线观看| 久久女同性恋中文字幕| 日韩理论片一区二区| 偷拍日韩校园综合在线| 成人免费高清在线| 制服丝袜成人动漫| 最好看的中文字幕久久| 蜜臀va亚洲va欧美va天堂 | 日韩电影在线观看一区| 国产成人午夜片在线观看高清观看| 色哟哟亚洲精品| 国产午夜亚洲精品不卡| 偷窥少妇高潮呻吟av久久免费| 成人综合在线网站| 2014亚洲片线观看视频免费|