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

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

?? pid.c

?? 用PID算法控制直流電機
?? C
字號:
#include "DSP281x_Device.h"     // DSP281x Headerfile Include File
#include "DSP281x_Examples.h"   // DSP281x Examples Include File
#include "ctr.h"
#include "PID.h"

// Prototype statements for functions found within this file.
interrupt void cpu_timer0_isr(void);

// 大液晶控制板控制字  ----------------------------------------------------------
#define CTRSTATUS (*(unsigned int *)0x108000) //port8000
#define CTRLED (*(unsigned int *)0x108004) // port8004
#define MCTRKEY (*(unsigned int *)0x108005)  // port8005
#define CTRCLKEY (*(unsigned int *)0x108006) // port8006
#define CTRSTATUS (*(unsigned int *)0x108000) //port8000
#define CTRGR (*(unsigned int *)0x108000) //port8000
#define CTRMOTORBSPEED (*(unsigned int *)0x108003) //port8003

void Gpio_select(void);
void Gpio_PortB(void);
void ShowParameters();
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();
Uint16 var1 = 0;
Uint16 var2 = 0;
Uint16 var3 = 0;
Uint16 test_count = 0;
Uint16 Test_flag = 0;
Uint16 Test_var  = 0;
Uint16 Test_status[32];

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 char ccc;
int uN;
void main(void)
{   
	unsigned int uWork1;
	int inputspeed;
	int breakflage;
	int speed[100],sp,lj;
	float ljh;
	int i,w1,w2,w3;
    InitSysCtrl();
    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=40; md=70; pwm1=60;
	m_nSpeed=70; m_bPCSet=0;
    inputspeed=0;
    uWork1=0;
    breakflage=0;
// Step 1. Initialize System Control:
// PLL, WatchDog, enable Peripheral Clocks
// This example function is found in the DSP281x_SysCtrl.c file.
   

// Step 2. Initalize GPIO: 
// This example function is found in the DSP281x_Gpio.c file and
// illustrates how to set the GPIO to it's default state.
// InitGpio();  // Skipped for this example  


// Step 3. Clear all interrupts and initialize PIE vector table:
// Disable CPU interrupts 
   DINT;

// Initialize the PIE control registers to their default state.
// The default state is all PIE interrupts disabled and flags
// are cleared.  
// This function is found in the DSP281x_PieCtrl.c file.
   InitPieCtrl();
   
// Disable CPU interrupts and clear all CPU interrupt flags:
   IER = 0x0000;
   IFR = 0x0000;

// Initialize the PIE vector table with pointers to the shell Interrupt 
// Service Routines (ISR).  
// This will populate the entire table, even if the interrupt
// is not used in this example.  This is useful for debug purposes.
// The shell ISR routines are found in DSP281x_DefaultIsr.c.
// This function is found in DSP281x_PieVect.c.
   InitPieVectTable(); 

// Interrupts that are used in this example are re-mapped to
// ISR functions found within this file.  
   EALLOW;  // This is needed to write to EALLOW protected registers
   PieVectTable.TINT0 = &cpu_timer0_isr;
   EDIS;    // This is needed to disable write to EALLOW protected registers

// Step 4. Initialize all the Device Peripherals:
// This function is found in DSP281x_InitPeripherals.c
// InitPeripherals(); // Not required for this example

   /////InitCpuTimers();   // For this example, only initialize the Cpu Timers
   	CpuTimer0.RegsAddr = &CpuTimer0Regs;
	// Initialize timer period to maximum:	
	CpuTimer0Regs.PRD.all  = 3600*2;
	//CpuTimer0Regs.PRD.all  = 3600*20;
	// Initialize pre-scale counter to divide by 1 (SYSCLKOUT):	
	CpuTimer0Regs.TPR.all  = 0;
	CpuTimer0Regs.TIM.all  = 0;
	CpuTimer0Regs.TPRH.all = 0;
	// Make sure timer is stopped:
	CpuTimer0Regs.TCR.bit.TSS = 1;
	CpuTimer0Regs.TCR.bit.SOFT = 1;
	CpuTimer0Regs.TCR.bit.FREE = 1;
	// Reload all counter register with period value:
	CpuTimer0Regs.TCR.bit.TRB = 1;
	CpuTimer0Regs.TCR.bit.TIE = 1;
	// Reset interrupt counters:
	CpuTimer0.InterruptCount = 0;	         


   

// Step 5. User specific code, enable interrupts:


// Enable CPU INT1 which is connected to CPU-Timer 0:
   IER |= M_INT1;

// Enable TINT0 in the PIE: Group 1 interrupt 7
   PieCtrlRegs.PIEIER1.bit.INTx7 = 1;

// Enable global Interrupts and higher priority real-time debug events:
   EINT;   // Enable Global interrupt INTM
   ERTM;   // Enable Global realtime interrupt DBGM
   Gpio_PortB();
   
    CTRGR=0x80;
	CTRGR=0;
	CTRGR=0x80;
	// 設置顯示參數(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;   
    StartCpuTimer0();
     while ( 1 )
	{
    //讀鍵盤值
	 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(25);//延時,
		if (nJSSpeed_1==0)	// 讀取速度標志
		{ 
		    nJSSpeed_1=1; 
			nJSSpeed=0;
			ccc=CTRMOTORBSPEED;	// 從端口讀取速度計數(shù)
			ccc=ccc&0xff;
			nSSS=ccc; 
			if ( nSSS>=0 && nSSS<400 )	// 合法性檢測
			{
				speed[sp]=nSSS; 		// 讀取66個計數(shù)值
				sp++; sp%=66;
			}
			if ( sp==0 )	// 是否已經(jīng)讀了66個速度?
			{				// 以下求速度平均值
				lj=0; ljh=0;
				for ( i=0;i<66;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;
			}
		}
    }
} 

// PID算法控制子程序-------------------------------------------------------------------------
void PIDControl(int rk,int yk)
{
	ek=rk-yk;
	duk=a*ek+b*ek1+c*ek2;		// 計算控制輸出
	ek2=ek1; ek1=ek;
	if ( duk>2 )	duk=1;		// 幅度限制
	if ( duk<-2 )	duk=-1;		// 幅度限制
	tz=(int)duk;
	pwm1+=tz;					// 計算當前占空比
	if ( pwm1<0 )	pwm1=0;
	else if ( pwm1>99 )	pwm1=99;
}

#define Hz200 50
#define Hz1 10000
interrupt void cpu_timer0_isr(void)
{
   PieCtrlRegs.PIEACK.all = PIEACK_GROUP1;
   CpuTimer0Regs.TCR.bit.TIF = 1;
   CpuTimer0Regs.TCR.bit.TRB = 1;
	nCount1++; nCount1%=Hz200;
	GpioDataRegs.GPBDAT.bit.GPIOB4=( nCount1>uN )?1:0;
   if ( nCount2==0 )
   {
		GpioDataRegs.GPBDAT.bit.GPIOB5=nnn;
		nnn=1-nnn;
   }
   nCount2++; nCount2%=Hz1;
	nJSSpeed++; nJSSpeed%=12000/20;	// 讀取速度標志
	if(nJSSpeed==0) 
	{nJSSpeed_1=0;}
	nCount++; nCount%=51200;
	if(nCount==0) 
	{nCount_1=0;}
}


void Gpio_select(void)
{
     EALLOW;
     
    GpioMuxRegs.GPAMUX.all=var1;   // Configure MUXs as digital I/Os or
    GpioMuxRegs.GPBMUX.all=var1;   // peripheral I/Os
    GpioMuxRegs.GPDMUX.all=var1;
    GpioMuxRegs.GPFMUX.all=var1;         
    GpioMuxRegs.GPEMUX.all=var1; 
    GpioMuxRegs.GPGMUX.all=var1;
                                        
    GpioMuxRegs.GPADIR.all=var2;   // GPIO PORTs  as output
    GpioMuxRegs.GPBDIR.all=var2;   // GPIO DIR select GPIOs as output 
    GpioMuxRegs.GPDDIR.all=var2;
    GpioMuxRegs.GPEDIR.all=var2;        
    GpioMuxRegs.GPFDIR.all=var2; 
    GpioMuxRegs.GPGDIR.all=var2;

    GpioMuxRegs.GPAQUAL.all=var3;  // Set GPIO input qualifier values
    GpioMuxRegs.GPBQUAL.all=var3;   
    GpioMuxRegs.GPDQUAL.all=var3;
    GpioMuxRegs.GPEQUAL.all=var3;
 
    EDIS;
     
}     

void Gpio_PortB(void)
{    

// GPIO Test #2: 
// Configure Upper 8 bits of Port as inputs and lower 8 bits as outputs    
// Loop back bits [7:0] to bits [15:8]
// Don't set any input qualifier
 
    var1= 0x0000;       // sets GPIO Muxs as I/Os
    var2= 0x00FF;       // sets GPIO 15-8 DIR as inputs, 7-0 DIR as outputs
    var3= 0x0000;       // Don't set any input qualifier
    
    Gpio_select();    
    
    test_count = 0;
    Test_status[Test_var] = 0x0002;
    Test_var++;
    
    Test_status[Test_var] = 0xD0BE;      // Set the default value of status 
                                         // to "PASSED"
    GpioDataRegs.GPBCLEAR.all = 0x00FF;  // Test Clear
    asm(" RPT #5 ||NOP");                             
    GpioDataRegs.GPBSET.bit.GPIOB5=1;
    GpioDataRegs.GPBSET.bit.GPIOB4=1;
 
}

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.
//========================================

void Delay(unsigned int nDelay)
{
	int ii,jj,kk=0;
	for ( ii=0;ii<nDelay;ii++ )
	{
		for ( jj=0;jj<64;jj++ )
		{
			//RefreshLEDArray();
			kk++;
		}
	}
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久成人18免费观看| 精品国产乱码久久久久久久 | 亚洲国产精品一区二区www | 欧美精品乱人伦久久久久久| 不卡的电影网站| youjizz久久| 99久久99久久精品免费看蜜桃 | 日韩三级在线观看| 7777精品伊人久久久大香线蕉完整版| 欧美亚日韩国产aⅴ精品中极品| 色伊人久久综合中文字幕| 91亚洲男人天堂| 在线观看av一区二区| 在线精品视频一区二区三四| av在线免费不卡| 欧美日韩国产成人在线免费| 久久人人超碰精品| 国产精品无人区| 亚洲成a人在线观看| 免费成人在线观看视频| 成人中文字幕合集| av在线播放不卡| 欧美狂野另类xxxxoooo| 日韩女优毛片在线| 国产精品久久久久久久久晋中| 亚洲综合视频在线| 久久精品国产一区二区| 欧美天天综合网| 国产午夜精品久久久久久久 | 色屁屁一区二区| 2023国产精品| 亚洲午夜电影在线观看| 成人免费高清视频在线观看| 91精品国产综合久久福利| 日韩毛片视频在线看| 精品一区二区三区的国产在线播放| 97超碰欧美中文字幕| 国产日产欧产精品推荐色| 日韩激情一区二区| 7777精品伊人久久久大香线蕉完整版 | 波多野洁衣一区| 一区二区三区在线高清| 中文成人av在线| 成人在线综合网站| 中文字幕在线一区二区三区| 成人精品国产一区二区4080| 欧美精品一区二区蜜臀亚洲| 老司机精品视频在线| 91精品国产高清一区二区三区蜜臀| 亚洲成a人片在线观看中文| 欧美人妖巨大在线| 久久99精品久久久久久| 国产午夜精品久久| 欧美日韩极品在线观看一区| 午夜精品一区二区三区免费视频| 欧美丰满一区二区免费视频| 看国产成人h片视频| 亚洲成a人在线观看| 色成年激情久久综合| 亚洲品质自拍视频| 欧美三日本三级三级在线播放| 亚洲三级理论片| 成人手机电影网| 一区二区三区免费| 精品久久久久香蕉网| 成人黄色777网| 亚洲国产成人av好男人在线观看| 精品国产一区二区三区四区四| 日本高清不卡一区| 色婷婷综合中文久久一本| 韩日av一区二区| 亚洲成a人片综合在线| 国产精品久久国产精麻豆99网站| 欧美色男人天堂| 99久久精品国产导航| 国产东北露脸精品视频| 日韩国产欧美在线观看| 亚洲小说欧美激情另类| 免费日本视频一区| 免费成人小视频| 国产高清精品在线| 国产成人精品一区二| 激情图区综合网| 日韩av电影天堂| 天涯成人国产亚洲精品一区av| 中文字幕一区二区三区在线不卡| 国产日韩欧美高清| 亚洲视频一区二区在线观看| 亚洲一区二区三区自拍| 一区二区三区在线观看欧美| 亚洲人精品一区| 亚洲成人激情社区| 国产一区二区三区四区在线观看| www.亚洲精品| 欧美日韩成人综合| 国产精品午夜免费| 老司机午夜精品| 91丨九色丨国产丨porny| 欧美性猛交xxxx黑人交| 日韩三区在线观看| 国产精品视频一区二区三区不卡 | 日本特黄久久久高潮| 91日韩精品一区| 国产三级精品三级| 国产精品影音先锋| 精品国内片67194| 热久久久久久久| 色爱区综合激月婷婷| 国产人成亚洲第一网站在线播放| 亚洲成人自拍网| 欧美最猛性xxxxx直播| 亚洲三级视频在线观看| 91久久线看在观草草青青| 中文字幕一区二区三中文字幕| 精品一区二区在线观看| 欧美日韩一区二区三区免费看 | 色综合天天性综合| 国产精品毛片高清在线完整版 | 欧美日韩精品电影| 亚洲国产aⅴ天堂久久| 51精品国自产在线| 蜜臀av性久久久久蜜臀av麻豆| 欧美电影在线免费观看| 一区二区三区欧美视频| 欧美亚洲国产一区在线观看网站 | 蜜臀精品一区二区三区在线观看| 3atv在线一区二区三区| 国产精品夜夜嗨| 亚洲一二三四区不卡| 欧美一级在线视频| 岛国一区二区三区| 亚洲人吸女人奶水| 91麻豆精品国产91久久久久久| 国产一区免费电影| 亚洲国产成人91porn| 欧美国产一区视频在线观看| 欧美三日本三级三级在线播放| 精品无人区卡一卡二卡三乱码免费卡 | 欧美色视频在线观看| 成人一区二区三区中文字幕| 亚洲国产精品久久艾草纯爱| 精品女同一区二区| 欧美一级免费大片| 91网上在线视频| 懂色av一区二区在线播放| 午夜久久久久久久久久一区二区| 亚洲欧洲日韩综合一区二区| 亚洲欧洲日韩综合一区二区| 精品少妇一区二区| 精品美女在线播放| 日韩一区二区在线看| 欧美视频一区在线| av电影在线不卡| 成人美女在线视频| 99热精品一区二区| 国产综合久久久久影院| 韩国女主播一区二区三区| 亚洲成人综合视频| 欧美96一区二区免费视频| 极品尤物av久久免费看| 国产露脸91国语对白| 高清shemale亚洲人妖| 国产精品一区在线| 丰满白嫩尤物一区二区| 国产 日韩 欧美大片| 成人av免费网站| 成人18视频日本| 日本丶国产丶欧美色综合| 成人一区二区三区视频在线观看| 国内精品嫩模私拍在线| 菠萝蜜视频在线观看一区| 欧美在线观看视频一区二区| 7777精品伊人久久久大香线蕉 | 99riav久久精品riav| 这里只有精品免费| 中文字幕的久久| 五月婷婷欧美视频| 国产成人综合在线| 日韩欧美一级二级| 综合自拍亚洲综合图不卡区| 亚洲欧美另类在线| 六月丁香婷婷色狠狠久久| 91小宝寻花一区二区三区| 久久久久亚洲蜜桃| 亚洲成人动漫在线免费观看| 国产一区美女在线| 欧美天天综合网| 17c精品麻豆一区二区免费| 国产尤物一区二区| 精品国免费一区二区三区| 天堂影院一区二区| 色乱码一区二区三区88| 国产精品乱人伦中文| 在线观看免费成人| 亚洲一区日韩精品中文字幕| 欧美日韩卡一卡二| 日本人妖一区二区| 日韩欧美在线网站| 美女在线观看视频一区二区| 欧美一区二区三区日韩|