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

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

?? pid.c

?? DSP芯片實現PID控制的源碼
?? C
字號:
#include "DSP281x_Device.h"     // DSP281x Headerfile Include File
#include "DSP281x_Examples.h"   // DSP281x Examples Include File
#include "ctr.h"
#include "PID.h"
#include "scancode.h"

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

#define LEDS *(int *)0xc0000
#define port8000 (*((unsigned int *)0x108000))
#define port8001 (*((unsigned int *)0x108001))
#define port8002 (*((unsigned int *)0x108002))
#define port8003 (*((unsigned int *)0x108003))
#define port8004 (*((unsigned int *)0x108004))
#define port8007 (*((unsigned int *)0x108007))

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);
char ConvertScanToChar(unsigned char cScanCode);

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,nCount1,nCount2,nCount3,nJSSpeed,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;
unsigned int nScreenBuffer[1024];

void main(void)
{   
	
	unsigned int uPort8000;
	unsigned int nScanCode;
	unsigned char cKey;
	int speed[100],sp,lj;
	float ljh;
	char strInput[4];
	int i,w1,w2,w3;

	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=100; md=70; pwm=0;
// Step 1. Initialize System Control:
// PLL, WatchDog, enable Peripheral Clocks
// This example function is found in the DSP281x_SysCtrl.c file.
   InitSysCtrl();

// 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  = 3709*2;
	// 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;	         


   StartCpuTimer0();

// 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();
   *(int *)0x108000=0;		// 初始化ICETEK-CTR
   *(int *)0x108000=0x80;
   *(int *)0x108000=0;
   *(int *)0x108007=0;			// 關閉東西方向的交通燈
   *(int *)0x108007=0x40;	// 關閉南北方向的交通燈
  uPort8000=*(int *)0x108002;
	// 設置顯示參數和內容
	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();		// 參數顯示

   *(int *)0x108007=0x0c4;
   
     while ( 1 )
	{
		if ( nCount==0 )	// 讀取鍵盤標志
		{
			nScanCode=port8001;	// 讀掃描碼
			nScanCode&=0x0ff;	// 低8位
			if ( nScanCode!=0 )
			{
				uWork=port8002;		// 清除鍵盤緩沖區
				if ( nScanCode==SCANCODE_Num )	break;	// NUM鍵退出
				else
				{
					if ( nScanCode==SCANCODE_Enter )	// 按回車鍵輸入速度
					{
						uWork=strInput[0]*10+strInput[1];	// 計算調整速度
						md=uWork;
						for ( uWork=0;uWork<2;uWork++ )	strInput[uWork]=0;
						nInput=0;
						LCDPutString(numbers,104,15,1,1);
						LCDPutString(numbers,112,15,1,1);
						LCDPutString(numbers,120,15,1,1);
						LCDRefreshScreen();
					}
					else
					{
						cKey=ConvertScanToChar(nScanCode);	
						if ( cKey>='0' && cKey<='9' )		// 輸入速度值
						{
							strInput[nInput]=cKey-'0';
							nInput++; if ( nInput>=2 )	nInput=0;
							uWork=strInput[0]*10+strInput[1];	// 計算調整速度
							w1=uWork%1000/100; w2=uWork%100/10; w3=uWork%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();
						}
					}
				}
			}
		}
		if ( nJSSpeed==0 )	// 讀取速度標志
		{
			nJSSpeed=0;
			nSSS=port8003;	// 從端口讀取速度計數
			nSSS&=0x0ff;
			if ( nSSS>=0 && nSSS<100 )	// 合法性檢測
			{
				speed[sp]=nSSS; 		// 讀取66個計數值
				sp++; sp%=66;
			}
			if ( sp==0 )	// 是否已經讀了66個速度?
			{				// 以下求速度平均值
				lj=0; ljh=0;
				for ( i=50;i<66;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;			// 利用占空比調整控制
					ShowParameters();	// 顯示各參數值到LCD
				}
			}
		}
	}

} 

// 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=10;		// 幅度限制
	tz=(int)duk;
	pwm+=tz;					// 計算當前占空比
	if ( pwm<0 )	pwm=0;
	else if ( pwm>99 )	pwm=99;
}

#define Hz200 100
#define Hz1 20000
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;	// 讀取速度標志
	nCount++; nCount%=51200;
}


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);
			}
		}
}

// 顯示參數到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);
	LCDRefreshScreen();
}

char ConvertScanToChar(unsigned char cScanCode)
{
	char cReturn;
	
	cReturn=0;
	// 根據掃描碼得到相應字符
	switch ( cScanCode )
	{
		case SCANCODE_0: cReturn='0'; break;
		case SCANCODE_1: cReturn='1'; break;
		case SCANCODE_2: cReturn='2'; break;
		case SCANCODE_3: cReturn='3'; break;
		case SCANCODE_4: cReturn='4'; break;
		case SCANCODE_5: cReturn='5'; break;
		case SCANCODE_6: cReturn='6'; break;
		case SCANCODE_7: cReturn='7'; break;
		case SCANCODE_8: cReturn='8'; break;
		case SCANCODE_9: cReturn='9'; break;
		case SCANCODE_Plus: cReturn='+'; break;
		case SCANCODE_Minus: cReturn='-'; break;
	}
	 
	return cReturn;
}
// No more.
//========================================

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
美女尤物国产一区| 91精品国产综合久久精品图片| 日本韩国精品在线| 91精品国产综合久久婷婷香蕉| www国产精品av| 亚洲另类一区二区| 麻豆精品视频在线观看免费 | 91首页免费视频| 欧美人与z0zoxxxx视频| 国产精品久久久久9999吃药| 免费在线观看成人| 欧美亚洲国产一区二区三区| 久久女同精品一区二区| 一区二区三区中文字幕在线观看| 免费在线看一区| 在线精品国精品国产尤物884a| 久久男人中文字幕资源站| 亚洲一区二区三区四区在线 | 一区二区三区四区视频精品免费| 精品一区二区三区视频| 91精品国产综合久久久久久久| 自拍偷在线精品自拍偷无码专区| 美脚の诱脚舐め脚责91 | 久久国产婷婷国产香蕉| 91久久免费观看| 亚洲日本韩国一区| 成人伦理片在线| 国产日产精品1区| 激情综合一区二区三区| 精品国产凹凸成av人导航| 麻豆国产精品一区二区三区| 欧美日韩免费观看一区二区三区 | 首页国产欧美日韩丝袜| 欧美精品丝袜久久久中文字幕| 亚洲精品ww久久久久久p站| 99精品在线免费| 亚洲美女在线国产| 欧美在线观看视频一区二区三区| 亚洲在线视频网站| 日韩三级视频在线观看| 久久精品国产久精国产| 精品成a人在线观看| 国产成人免费视频网站 | 欧美午夜电影在线播放| 亚洲成a人v欧美综合天堂| 91精品国产综合久久久久久| 久久99这里只有精品| 久久午夜羞羞影院免费观看| 99久久综合色| 日韩不卡手机在线v区| 久久美女高清视频| 成人精品免费看| 亚洲在线视频免费观看| 69精品人人人人| 国产精品主播直播| 亚洲女同ⅹxx女同tv| 欧美福利一区二区| 国产91丝袜在线播放| 亚洲午夜久久久| 国产无人区一区二区三区| 在线观看网站黄不卡| 国产福利不卡视频| 亚洲高清三级视频| 国产精品国产三级国产aⅴ入口 | 成人av资源下载| 久久电影网电视剧免费观看| 亚洲日本乱码在线观看| 日韩欧美一二三四区| 99re热这里只有精品视频| 日本不卡不码高清免费观看| 1区2区3区国产精品| 欧美成人欧美edvon| 欧美日韩国产乱码电影| 成人午夜激情视频| 韩国毛片一区二区三区| 日韩精品1区2区3区| 一区二区三区四区在线播放| 国产精品日日摸夜夜摸av| 精品日韩99亚洲| 欧美精品一二三| 4438x成人网最大色成网站| 欧美亚洲禁片免费| 欧洲av在线精品| 在线看国产一区二区| 色88888久久久久久影院野外| www.欧美亚洲| 不卡视频一二三四| 91亚洲精品久久久蜜桃网站| 成人h动漫精品一区二区| 国产精品99久久久久久宅男| 国产精品一区一区| 成人永久aaa| 99久久精品免费| 99久久精品费精品国产一区二区| 色综合咪咪久久| 欧美日韩视频在线第一区| 欧美丝袜自拍制服另类| 欧美日韩一区二区电影| 欧美一二三区在线| 久久精品这里都是精品| 国产精品久久久久一区| 亚洲一区二区三区视频在线播放 | 视频一区二区中文字幕| 蜜臀av一级做a爰片久久| 国内精品伊人久久久久av一坑 | 国产不卡一区视频| 色婷婷综合中文久久一本| 欧美三级电影精品| 26uuu久久综合| 亚洲精品一二三| 国产一区欧美一区| 91国偷自产一区二区使用方法| 欧美精品18+| 国产欧美日韩精品一区| 亚洲午夜免费视频| 国产99久久久精品| 欧美精品自拍偷拍| 国产精品嫩草影院av蜜臀| 亚洲大型综合色站| 成年人国产精品| 日韩欧美中文字幕一区| 亚洲欧洲性图库| 美女免费视频一区| 精品视频一区二区不卡| 国产无一区二区| 人人狠狠综合久久亚洲| 91国产成人在线| 日本一区二区三区高清不卡 | 蜜臀国产一区二区三区在线播放| 不卡电影免费在线播放一区| 日韩欧美卡一卡二| 石原莉奈在线亚洲二区| 91理论电影在线观看| 国产欧美va欧美不卡在线| 韩国精品一区二区| 日韩免费观看高清完整版在线观看| 亚洲免费伊人电影| 99久久777色| 亚洲同性同志一二三专区| 国产成人福利片| 日本一区二区三区在线不卡| 国产做a爰片久久毛片| 久久一区二区三区四区| 久久精品国产精品青草| 欧美精品一区二| 国产在线播放一区三区四| 精品免费国产二区三区| 国产一区二区三区久久悠悠色av| 欧美一级在线免费| 精品国产3级a| 国内成人精品2018免费看| 中文字幕一区在线观看| 日韩精品一区二区三区中文不卡 | 久久精品国产99| 久久综合中文字幕| 国产精品一区二区视频| 日本一区二区免费在线观看视频| 国产剧情一区二区三区| 国产精品美女久久久久久久久久久 | 国产成人精品三级麻豆| 一区二区三区不卡视频| 欧美成人一区二区| 色综合久久66| 久久91精品国产91久久小草 | 免费精品视频在线| 日本一区二区动态图| 日本高清免费不卡视频| 国产一区二区三区免费观看| 一区二区免费看| 欧美成人一区二区三区片免费| 91色porny蝌蚪| 国产精品一区2区| 日精品一区二区三区| 国产精品乱码久久久久久| 久久激情五月婷婷| 亚洲素人一区二区| 国产精品视频看| 国产精品成人免费| 中文字幕一区日韩精品欧美| 国产精品视频第一区| 久久久蜜桃精品| 亚洲精品一区二区精华| 日韩欧美亚洲一区二区| 日韩午夜激情av| 欧美福利电影网| 在线不卡中文字幕播放| 欧美日韩精品一区视频| 一本久道中文字幕精品亚洲嫩| 国产成人综合亚洲91猫咪| 久久99最新地址| 国产在线精品一区在线观看麻豆| 蜜臀精品久久久久久蜜臀| 日韩1区2区3区| 麻豆国产一区二区| 国产一区二区三区免费看| 成人毛片在线观看| 91久久线看在观草草青青| 欧美亚男人的天堂| 精品视频全国免费看| 欧美日韩国产综合视频在线观看|