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

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

?? aaa.c

?? 用51單片機編譯成的頻率計的源程序
?? C
?? 第 1 頁 / 共 3 頁
字號:

    // NOTE: USER CODE MUST WAIT AT LEAST 20 MS before calling ADC_Read (Using the ADC)
}



/******************************************************************************
*                       ADC_Init(channel)
*功能描述:ADC初始化,選擇模擬通道輸入,初始化時鐘,關閉ADC中斷
*參    數:channel - uchar 選擇ADC通道
*注    意:當ADC通道改變得時候,此子程序一定要被調用
*****************************************************************************/
void ADC_Init (unsigned char channel) 
{
    unsigned char temp;
    ACON = 0;                           

    temp = (0x01) << channel;           // 選擇通道
    P1SFS0 |= temp;         
    P1SFS1 |= temp;                     // 設置P1口相應位為ADC輸入

    ADCPS =(0x08 + 1);  // 使能ADC時鐘,設置時鐘頻率
    _nop_();
    ACON = 0x20;                        // 允許ADC轉換


    // NOTE: USER CODE MUST WAIT AT LEAST 20 MS before calling ADC_Read (Using the ADC)
}

/******************************************************************************
*                      uint  ADC_Read(channel)
*功能描述:讀A/D轉換后的數據
*參    數:channel,初始化程序中選擇的通道
*返 回 值:ADC轉換結果,12位
*注    意:該子程序調用前,ADC_Init()必須先被調用
*******************************************************************************/
unsigned int ADC_Read( unsigned char channel )
{
    unsigned int  temp_ADC_result;  
    ACON &= 0xE0;                        //清除輸入通路  ~(00101110B) = (11010001B)

    ACON |= (channel<<2);                 //選擇通路
    _nop_ ();
    _nop_ ();   

    ACON |= 0x02;                           //開始ADC轉換
    _nop_ ();                               //延時一個機器周期: ADST: 1->0

    while( (ACON & 0x01) != 1 );            //等待轉換結束

      // Note: For increased ADC accuracy, the while loop above should be
      //       replaced with code that puts the MCU into Idle mode via PCON
      //       and makes use of the ADC interrupt to exit the Idle mode.
      //       The user would need to enable the ADC int and define the ADC ISR.

    temp_ADC_result = (ADAT1<<8)+ADAT0;     //Calculate ADC conversion result

    return (temp_ADC_result);
}


/*******************************************************************************
*    int sin_angle(long angle )
*功能描述:角度換算函數,使角度值控制在180以內
*
********************************************************************************/

int sin_angle(long angle )
{
	int Mod_data;

	Mod_data = (int)angle/180;
	switch (Mod_data )
	{
	case 0:
		 M_angle = sin_table[angle];
	     break;
	case 1:
		 M_angle = -sin_table[angle - 180];
		 break;
    case 2:
	     M_angle = sin_table[angle - 360];
		 break;
	case 3:
		 M_angle = -sin_table[angle - 540];
 	     break;
	}

	return(M_angle);
}

/*******************************************************************************
*             void first(void )
*第一個采樣點計算函數,在K=0時計算
*******************************************************************************/
void first(void )		
{

	U_angle = K*180/N;			//U相在K=0時計算
	V_angle = U_angle + 120;
	W_angle = U_angle + 240;


	U_Toff = ((Half_Ts * (0xffff - M*(sin_angle(U_angle))))>>16);
	V_Toff = ((Half_Ts * (0xffff - M*(sin_angle(V_angle))))>>16);
	W_Toff = ((Half_Ts * (0xffff - M*(sin_angle(W_angle))))>>16);



	P_flag = 0;

}

/*------------------------------------------------------------------------------
timer0_isr()

This function is an interrupt service routine for TIMER 0.  It should never
be called by a C or assembly function.  It will be executed automatically
when TIMER 0 overflows.

This ISR stops timer0, adjusts the counter so that another interrupt occurs in
10ms, and then restarts the timer.
------------------------------------------------------------------------------*/

//定時器0中斷服務程序
//定時器0用于產生采樣周期的定時中斷,采樣周期Ts	=1/2載波周期 = 278 時鐘周期
static void timer0_isr (void) interrupt TF0_VECTOR using 1
{
  TR0 = 0;						/* stop timer 0 */
  TL0 = (timer0_value & 0x00FF);
  TH0 = (timer0_value >> 8);
  TR0 = 1;						/* start timer 0 */
  

////////////////////////////////////////////
////將上一次定時器中斷計算的延時值送入TCM0,TCM1,TCM2的比較寄存器
//
//
////取當前PCA0的計數值
	PCA0 = PCACL0 + (PCACH0  << 8 );
//
////實際延時時間應加上PCA0的當前計數值
//
	U_Toff += PCA0;
	V_Toff += PCA0;
	W_Toff += PCA0;
	U_Ton += PCA0;
	V_Ton += PCA0;
	W_Ton += PCA0;
//
//
////偶數頂點采樣使用Toff,奇數底點采樣使用Ton
  	if ( P_flag==0)
	{
		CAPCOML0 = (U_Toff & 0x00FF);
		CAPCOMH0 = (U_Toff >> 8);
	 	
		CAPCOML1 = (V_Toff & 0x00FF);
		CAPCOMH1 = (V_Toff >> 8);

		CAPCOML2 = (W_Toff & 0x00FF);
		CAPCOMH2 = (W_Toff >> 8);
	}
	else 
	{
		CAPCOML0 = (U_Ton & 0x00FF);
		CAPCOMH0 = (U_Ton >> 8);
	 	
		CAPCOML1 = (V_Ton & 0x00FF);
		CAPCOMH1 = (V_Ton >> 8);

		CAPCOML2 = (W_Ton & 0x00FF);
		CAPCOMH2 = (W_Ton >> 8);	
	}											 //66

////////////////////////////////////////////

//下一個采樣點
	
	
 	P_flag = ~P_flag;		//奇偶點變換

	K++;					//下一個采樣點值

	Tm++;
	U_angle = K*180/N;
	V_angle = U_angle + 120;
	W_angle = U_angle + 240;




	if (P_flag == 0)
	{
//		U_Toff =k1* ((Half_Ts * (0xffff - M*(sin_angle(U_angle))))>>16);
//		V_Toff =k1* ((Half_Ts * (0xffff - M*(sin_angle(V_angle))))>>16);
//		W_Toff =k1* ((Half_Ts * (0xffff - M*(sin_angle(W_angle))))>>16);
		U_Toff =((Half_Ts * (0xffff - M*(sin_angle(U_angle))))>>16);
		V_Toff =((Half_Ts * (0xffff - M*(sin_angle(V_angle))))>>16);
		W_Toff =((Half_Ts * (0xffff - M*(sin_angle(W_angle))))>>16);
	}
	else
	{
		U_Ton =((Half_Ts * (0xffff + M*(sin_angle(U_angle))))>>16);
		V_Ton =((Half_Ts * (0xffff + M*(sin_angle(V_angle))))>>16);
		W_Ton =((Half_Ts * (0xffff + M*(sin_angle(W_angle))))>>16);

	
	}

//	if (P_flag == 0)
//	{
//		U_Toff = (417 * (0x400000 - M*(sin_angle(U_angle))))>>22;
//		V_Toff = (417 * (0x400000 - M*(sin_angle(V_angle))))>>22;
//		W_Toff = (417 * (0x400000 - M*(sin_angle(W_angle))))>>22;
//	}
//	else
//	{
//		U_Ton = (417 * (0x400000 + M*(sin_angle(U_angle))))>>22;
//		V_Ton = (417 * (0x400000 + M*(sin_angle(V_angle))))>>22;
//		W_Ton = (417 * (0x400000 + M*(sin_angle(W_angle))))>>22;
//	
//	
//	}
//	aa=0;

	
	if ( K==2*N )
	{ K=0;

//	  P_flag = 0;
	 }

	 
}
  
/****************************************************************************
*死區指令延時,應實測,要考慮中斷影響
* 10個temp 延時約6us
****************************************************************************/
void delay1()					  
{								  
	char temp;					 

	EA=0;					
	temp = 0;
	temp = 0;
	temp = 0;
	temp = 0;
	temp = 0;
	temp = 0;
	temp = 0;
	temp = 0;
	temp = 0;
	temp = 0;
	temp = 0;
	temp = 0;
	temp = 0;
	temp = 0;
	temp = 0;
	temp = 0;
	temp = 0;
	temp = 0;

	EA=1;

}
/***************************************************************************
*定時器0初始化
***************************************************************************/
void timer0_init (void)
{
 	EA = 0;					/* disable interrupts */

  	TR0 = 0;				/* stop timer 0 */
  	TMOD &= 0xF0;			/* clear timer 0 mode bits - bottom 4 bits */
  	TMOD |= 0x01;			/* put timer 0 into 16-bit no prescale */

    timer0_value = 0x10000-Ts;		//采樣周期=1/2載波周期	
  	TL0 = (timer0_value & 0x00FF);
  	TH0 = (timer0_value >> 8);

 // 	PT0 = 1;				/* set high priority interrupt for timer 0 */
 	PT0 = 0;
  	ET0 = 1;				/* enable timer 0 interrupt */
  	TR0 = 1;				/* start timer 0 */
  	EA = 1;					/* enable interrupts */
}



/***************************************************************************
*PCA中斷服務程序
***************************************************************************/
static void PCA_isr (void) interrupt PCA_VECTOR using 1 

{
	unsigned char PCA_status;


	PCA_status = PCASTA;			//讀PCA中斷狀態


	if ( PCA_status & 0x01)			//TCM0中斷,U相
	{

		if (P_flag==0)
		{
			P4_3 = 1;				//偶數采樣中斷到,關V4 延時 開V1
			delay1();
			P4_0 = 0;
		}
		else 
		{
			P4_0 = 1;				//奇數采樣中斷到,關V1 延時 開V4
			delay1();
			P4_3 = 0;
		}
	PCASTA &= 0xFE;

	}
	
	if ( PCA_status & 0x02)			//TCM1中斷,V相
	{

		if (P_flag==0)
		{
			P4_5 = 1;				//偶數采樣中斷到,關V6 延時 開V3
			delay1();
			P4_2 = 0;
		}
		else 
		{
			P4_2 = 1;				//奇數采樣中斷到,關V3 延時 開V6
			delay1();
			P4_5 = 0;
		}
	PCASTA &= 0xFD;
	}

	if ( PCA_status & 0x04)			//TCM2中斷,W相
	{

		if (P_flag==0)
		{
			P4_4 = 1;				//偶數采樣中斷到,關V5 延時 開V2
			delay1();
			P4_1 = 0;
		}
		else 
		{
			P4_1 = 1;				//奇數采樣中斷到,關V2 延時 開V5
			delay1();
			P4_4 = 0;
		}
	PCASTA &= 0xFB;
	}

	
//	PCASTA &= 0x00;					 //清PCA中斷狀態

}

//PCA0初始化
void PCA_init()
{

	unsigned int PCA0;
	//0.1 Configure pins as PCA function
//	P4SFS0=0xff;
//	P4SFS1=0;

	//0.2 initialize PCA0 counter
	PCACL0=PCACH0=0;
	PCACL1=PCACH1=0;

	//1.2 select PCA0CLK as PCA0 clock source
	//PCA0時鐘為fosc,timer0_isr中Toff,Ton計數值*12 再寫入比較寄存器
//	CCON2=0x10;				
	CCON2=0x12;	   //fosc/4

	//Stop PCA0 counter
	PCACON0=0x00;

	//3. Set TCM0 operationg mode,16bit soft timer , enable softimer interrupt
//	TCMMODE0=0x48;
	TCMMODE0=0xC8;
	TCMMODE1=0xC8;
		
	TCMMODE2=0xC8;		


	CAPCOML0 = (PCA0 & 0x00FF);
	CAPCOMH0 = (PCA0 >> 8);


	// 開PCA中斷
	IEA |= 0x20;
	IPA |= 0X20;	  // set high priority interrupt for PCA0 
	
	 //5. Start PCA0 counter
	 PCACON0|=0x40;

}


/******************************************************************************
*                       uint getVA(channel)
*功能描述:讀取輸出電壓,電流值
*參    數:channel,選擇讀取通道
*****************************************************/


void getVA (uchar channel)
{ 

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美激情综合在线| 欧美一区二区三区免费观看视频| 国产亚洲福利社区一区| 国产精品自在在线| 国产亚洲福利社区一区| 91视频91自| 午夜久久久影院| 精品国产一区二区精华| 国产精品一二三在| 亚洲天堂福利av| 欧美日本在线观看| 激情文学综合丁香| 国产精品久久久久一区二区三区共 | 亚洲综合成人在线视频| 91精品国产综合久久久久| 国产一区二区三区黄视频| 国产无一区二区| 欧美在线视频不卡| 国产一区不卡精品| 亚洲欧美激情小说另类| 日韩精品一区二区三区视频在线观看 | 亚洲女同ⅹxx女同tv| 欧美又粗又大又爽| 精品亚洲国内自在自线福利| 国产精品久久午夜夜伦鲁鲁| 欧美日韩和欧美的一区二区| 国产在线一区二区综合免费视频| 中文字幕中文在线不卡住| 7777精品伊人久久久大香线蕉经典版下载| 久久99久久99| 一区二区视频免费在线观看| 精品日韩在线观看| 色婷婷国产精品久久包臀| 老司机精品视频一区二区三区| 亚洲天堂精品视频| 欧美精品一区二区三区在线| 欧美中文字幕一区二区三区| 韩国精品主播一区二区在线观看| 一区二区三区在线免费观看 | 日本高清不卡视频| 国产综合一区二区| 五月综合激情婷婷六月色窝| 中文字幕成人av| 精品国产91洋老外米糕| 欧美三级电影网| 91视频免费看| 成人h动漫精品一区二| 久久69国产一区二区蜜臀| 亚洲综合男人的天堂| 国产精品三级在线观看| 精品国产99国产精品| 欧美一区二区播放| 欧美色网站导航| 91热门视频在线观看| 成人免费毛片嘿嘿连载视频| 久久国产精品99精品国产| 亚洲午夜羞羞片| 亚洲男人的天堂一区二区| 国产精品福利影院| 欧美国产日韩亚洲一区| 久久这里都是精品| 日韩亚洲电影在线| 欧美精品xxxxbbbb| 9191久久久久久久久久久| 欧美性色黄大片手机版| 91麻豆福利精品推荐| 成人网在线播放| 国产91在线看| 成人综合在线网站| 成人av电影在线| 99vv1com这只有精品| www.综合网.com| gogogo免费视频观看亚洲一| 成人av资源站| 91性感美女视频| 一本到不卡精品视频在线观看 | 依依成人综合视频| 最新热久久免费视频| 综合精品久久久| 亚洲女厕所小便bbb| 亚洲一区二区三区影院| 亚洲国产综合在线| 日韩在线a电影| 欧美aa在线视频| 国产综合一区二区| 成人中文字幕在线| 一本到不卡精品视频在线观看| 91色在线porny| 欧美高清一级片在线| 日韩一区二区精品在线观看| 精品区一区二区| 国产精品每日更新| 一区二区欧美视频| 天堂一区二区在线| 国产一区二区三区日韩| 成人激情动漫在线观看| 91免费看片在线观看| 欧美日韩精品欧美日韩精品一 | 日韩欧美一区二区免费| 精品99999| 国产精品国产a| 视频在线观看一区二区三区| 美国毛片一区二区三区| 东方aⅴ免费观看久久av| 日本大香伊一区二区三区| 欧美日韩亚洲丝袜制服| 久久人人爽爽爽人久久久| 亚洲人妖av一区二区| 婷婷综合另类小说色区| 韩国女主播成人在线观看| 99vv1com这只有精品| 欧美一卡二卡在线观看| 日本一区二区电影| 日韩av电影免费观看高清完整版在线观看 | 制服丝袜亚洲播放| 中文字幕av不卡| 石原莉奈一区二区三区在线观看| 国产乱码一区二区三区| 欧洲生活片亚洲生活在线观看| 日韩精品一区二区三区在线| 亚洲欧美在线高清| 免费成人在线观看| 在线亚洲+欧美+日本专区| 精品久久99ma| 亚洲一区二三区| 成人精品视频网站| 欧美成人一区二区三区在线观看| 亚洲男人的天堂在线aⅴ视频| 久久综合综合久久综合| 在线看日韩精品电影| 久久久777精品电影网影网| 亚洲成av人片在线观看无码| 成人av在线资源网站| 精品久久人人做人人爱| 亚洲国产综合91精品麻豆| www.欧美日韩国产在线| 久久久亚洲高清| 日本欧美一区二区三区| 99re8在线精品视频免费播放| 精品av久久707| 日韩成人免费电影| 欧美日韩卡一卡二| 亚洲日韩欧美一区二区在线| 国产精品影视天天线| 日韩精品一区二区三区蜜臀| 亚洲超丰满肉感bbw| 在线亚洲一区观看| 亚洲人成在线播放网站岛国| 成人爱爱电影网址| 久久精品一区八戒影视| 韩国女主播成人在线观看| 欧美成人aa大片| 人人精品人人爱| 91精品国产乱码| 午夜成人在线视频| 欧美色精品在线视频| 亚洲制服丝袜一区| 91捆绑美女网站| 亚洲免费观看在线视频| 91在线观看地址| 亚洲免费毛片网站| 色94色欧美sute亚洲线路一ni| 亚洲国产岛国毛片在线| 成人性视频免费网站| 国产精品天干天干在观线| 国产成人在线观看免费网站| 国产午夜亚洲精品午夜鲁丝片| 精品综合免费视频观看| 337p日本欧洲亚洲大胆精品 | 三级不卡在线观看| 欧美一区二区三区视频免费| 日韩精品亚洲一区二区三区免费| 欧美人体做爰大胆视频| 三级不卡在线观看| 日韩丝袜美女视频| 精品一区二区在线观看| 久久蜜桃香蕉精品一区二区三区| 国产精品一区二区你懂的| 国产三级精品视频| 不卡一二三区首页| 亚洲综合小说图片| 日韩欧美综合一区| 国内精品免费在线观看| 国产精品白丝在线| 欧美亚洲国产bt| 日本特黄久久久高潮| 精品福利一二区| 99re视频精品| 午夜视频在线观看一区二区三区 | 在线免费观看成人短视频| 午夜精品影院在线观看| 精品国产一区二区三区久久影院 | 欧美一级视频精品观看| 国产精品一区不卡| 国产精品久久久一区麻豆最新章节| 99久久综合精品| 天堂成人免费av电影一区| wwwwxxxxx欧美| 91麻豆国产自产在线观看| 日日摸夜夜添夜夜添精品视频|