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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? pic2448.c

?? PWM控制輸出電壓由于該程序所需完成的功能比較簡單
?? C
?? 第 1 頁 / 共 2 頁
字號(hào):
#include "pic1687x.h"     //包含頭文件 
#include "pic.h"

__IDLOC(15F0);
__CONFIG(HS&WDTDIS&LVPDIS&DUNPROT);  //高速晶振,禁止低電壓編程,看門狗禁止,禁止代碼保護(hù) 

//__CONFIG(HS&WDTEN&LVPDIS&DUNPROT);  高速晶振,禁止低電壓編程,看門狗允許,禁止代碼保護(hù) 

#define	uchar	unsigned char
#define	uint	unsigned int
#define ulong   unsigned long

#define bitset(var,bitno) 	((var)|=1<<(bitno))             //位置位
#define bitclr(var,bitno) 	((var)&=~(1<<(bitno)))          //位清零
#define bitchk(var,bitno) 	(var&(0x01<<(bitno)))           //位測試
#define	PORTBIT(adr, bit)	((unsigned)(&adr)*8+(bit))  	//取得位地址

#define bits_on(var,mask) 	((var)|=(mask))             	//置位對應(yīng)位
#define bits_off(var,mask) 	((var)&=~0^(mask))         	    //清零對應(yīng)位 
#define	bittst_on(data,bitno)	((data>>bitno)&0x01)  		
#define	hibyte(x)		(unsigned char)(x>>8)         	    //取高8位
#define	lobyte(x)		(unsigned char)(x & 0xFF)     	    //取低8位

#define	_NOP_	asm("NOP")

						// 以下是口定義

#define ADR_ID RA4				// 地址編碼

#define SHUT0 RB0				// 模塊關(guān)機(jī)控制
#define SHUT1 RB1
#define SHUT2 RB2
#define SHUT4 RB4
#define SHUT5 RB5

#define SHUT3 RC0

#define VSET  RC3				// 模塊狀態(tài)比較電壓控制
#define RLSW  RC4				// 輸出繼電器控制
#define EN485 RC5				// 485 收發(fā)轉(zhuǎn)換

#define GIN1  RD6				// 通用輸入
#define GIN2  RD7

#define SIO_RX_LEN 6
#define SIO_TX_LEN 10

#define RCT_CUR_RANG 400 /* 1023 -- 40.0 A */

uchar ticks=0,secs=0,norx_secs=0;// 50ms,秒,無通信計(jì)時(shí)定義

uchar img_RCSTA;				// 寄存器影像
uchar img_RCREG;

uchar sio_tx_num;				// 發(fā)送字節(jié)數(shù)
uchar sio_rx_num;				// 接收字節(jié)數(shù)
bank1 uchar sio_rx_buf[SIO_RX_LEN];		// 接收緩沖區(qū)
bank1 uchar sio_tx_buf[SIO_TX_LEN];

ulong  cpu3;

uchar id_addr=0;				//模塊組地址
uchar rct_addr=0;				//模塊地址

uint  ad_vol_set;				// 調(diào)壓輸出測量值

uint  pwm_vol_set;				// PWM調(diào)壓輸出(0-1023)
uint  pwm_cur_lmt;				// PWM限流輸出(0-1023)

uint  vol_set;					// 調(diào)壓輸出設(shè)置值(0-1023)
uint  cur_lmt;					// 限流輸出設(shè)置值(0-1023)
uchar rct_pow;					// 整流器關(guān)機(jī)
uchar rct_warn;					// 整流器告警
uchar rct_no=0xff;				// 整流器在位
bank1 uint  rct_cur[6];			// 整流器電流

bank1 uint ibuf[9];				// AD采樣數(shù)組





#define    CUR_MAX 4000
#define    DCV_MAX 6062

uint    cur_nc=1023;
uint    cur_pc=1023;

uint    DC_F=900;
uint    DC_J=900;

bit      change=0;




#define RCT_CUR_RANG_15B 200	    // A/D 1023 -- 20A
#define RCT_CUR_RANG_20D 370 		// A/D 1023 -- 37A
#define RCT_CUR_RANG_25D 400 		// A/D 1023 -- 40A
#define RCT_CUR_RANG_30D 500 		// A/D 1023 -- 50A

#define DCV_MAX_24V	 	 3031	    // D/A 24V
#define DCV_MAX_48V      6062		// D/A 48V
#define DCV_MID			 3500		// 24V與48V的分界值:35V
#define CUR_MAX_15B	     2000		// D/A 15Aor10A
#define CUR_MAX_20D      3700		// D/A 30Aor40A
#define CUR_MAX_25D      4000		// D/A 25A
#define CUR_MAX_30D      5000		// D/A 30Aor40A


uchar cur_type    = 0;				// 模塊電流類型
uchar flag_cfg	  = 0;	            // 0:需要配置模塊類型  1:模塊類型配置完成




void delay(uchar t)				// 延時(shí)子程序
{
 uchar s;
 s = 0;
 while(t--)
   while(--s)
     {
      _NOP_;
      _NOP_;
      _NOP_;
      _NOP_;
      _NOP_;
      _NOP_;
      _NOP_;
      _NOP_;
      _NOP_;
      CLRWDT();
      }
 }


uchar bittest(uchar var,uchar bitno)	//位測試
{
	if((var>>bitno)&0x01==1)
		return 1;
 	else
 		return 0;
}


uchar bittest0(uchar var,uchar bitno)	//位測試
{
	if((var>>bitno)&0x01==1)
		return 1;
 	else
 		return 0;
}


void delay_100us(uchar times)			// 延時(shí)100us
{
 TMR0 = 1;
 T0IF = 0;
 while(times--)
  {
   while(!T0IF);
   T0IF = 0;
   }
}

void  wr_eeprom(uchar addr,uchar val)		// 內(nèi)部EEPROM寫入(地址,數(shù)值)
{
  EECON1=0;
  while(WR);
  EEADRH=0;
  EEADR=addr;
  EEDATA=val;
  EEPGD=0;
  WREN=1;
  di();
  EECON2=0X55;
  EECON2=0XAA;
  WR=1;
  while(WR);
  WREN=0;
  ei();
  }

uchar rd_eeprom(uchar addr)			// 內(nèi)部EEPROM讀出(地址),返回?cái)?shù)據(jù)
{
  uchar val;
  EECON1=0;

  EEADRH=0;
  EEADR=addr;
  EEPGD=0;
  RD=1;
  asm("NOP");
  val=EEDATA;

  return val;
  }


uint start_ad(uchar chn)			// 啟動(dòng)指定通道的AD轉(zhuǎn)換,換回AD數(shù)值
{
  uint adres;

  ADCON1 = 0x81;	/* Result Right_justified, 7 A/D channels, Vref = RA3 - VSS */

  chn &= 7;
  chn <<= 3;
  chn |= 0b10000001;	/* set Fosc/32 clock, AD channel,AD operating on */
  ADCON0 = chn;
  delay_100us(1);
  ADGO = 1;		/* Start AD */

  while(ADGO);
  asm("NOP");
  asm("NOP");
  adres=ADRESH*256+ADRESL;

  return adres;
  }

uint start_channel(uchar ad_chn)		// 對指定通道進(jìn)行AD轉(zhuǎn)換,換回AD數(shù)值(內(nèi)含數(shù)值濾波)
{
 uchar t;
 uint  sum;
 uint  ad_max,ad_min;

 for(t=0;t<9;t++)				// 采樣9次(大約20ms)
 {
  ibuf[t] = start_ad(ad_chn);
  delay_100us(20);
  }

 ad_max = ad_min = ibuf[0];		// 求出9次采樣最大值,最小值
 for(t=1;t<9;t++)
 {
  if(ibuf[t] < ad_min)
    ad_min = ibuf[t];
  else if(ibuf[t] > ad_max)
    ad_max = ibuf[t];
  }

 for(t=0,sum=0;t<9;t++)			// 求排除最大值,最小值之外的7個(gè)數(shù)的平均值
    sum += ibuf[t];

 sum -= ad_max;
 sum -= ad_min;

 sum /= 7;

 return sum;
 }

void start_measure()
{
 static uchar rct_cur_channel;
 ulong ad_result;

 rct_cur_channel++;				// 開始:測量一路模塊電流(一次只測一次)
 rct_cur_channel %= 6;

 if(rct_cur_channel<3)
   ad_result = start_channel(rct_cur_channel);
 else
   ad_result = start_channel(rct_cur_channel+1);

	 
	 switch (cur_type)
	{
		case 15:																// 15Bor10D
		{
			ad_result *= RCT_CUR_RANG_15B;
 			ad_result>>= 10;
 			if (ad_result > RCT_CUR_RANG_15B)			// 防止超界
	  		ad_result = 0;
 			break;
 		}
		case 20:																// 20D
		{
			ad_result *= RCT_CUR_RANG_20D;
 			ad_result>>= 10;
 			if (ad_result > RCT_CUR_RANG_20D)			// 防止超界
	  		ad_result = 0;
 			break;
 		}
 		case 25:																// 25D
 		{
 			ad_result *= RCT_CUR_RANG_25D;
 			ad_result>>= 10;
 			if (ad_result > RCT_CUR_RANG_25D)			// 防止超界
	  		ad_result = 0;
 			break;
 		}
		case 30:																// 30Dor40D
		{
			ad_result *= RCT_CUR_RANG_30D;
 			ad_result>>= 10;
 			if (ad_result > RCT_CUR_RANG_30D)			// 防止超界
	  		ad_result = 0;
 			break;
 		}
 		default:																// 若未配置模塊類型
		{
		  ad_result = 0;												// 則AD轉(zhuǎn)換結(jié)果=0
 			break;
		}
	}









 //l *= RCT_CUR_RANG;
 //l /= 1024;

 di();
 rct_cur[rct_cur_channel] = (uint)ad_result;
 ei();						// 結(jié)束:測量一路模塊電流

 ad_result = start_channel(7);		// 測量電壓控制輸出值
 di();
 ad_vol_set = (uint)ad_result;
 ei();
 }

uint uiabs_sub(uint i, uint j)	// 無符號(hào)整數(shù)絕對值減法
{
 if(i>j)
   return i-j;
 else
   return j-i;
 }

uchar ucabs_sub(uchar i, uchar j)// 無符號(hào)字節(jié)絕對值減法
{
 if(i>j)
   return i-j;
 else
   return j-i;
 }

 /**************************************************************
  重要提示:

  下面函數(shù)計(jì)算與調(diào)整輸出電壓

 目的:消除7805供電電壓,16F877與運(yùn)放等電路產(chǎn)生的輸出誤差

 此函數(shù)很重要:因?yàn)榭刂齐妷盒盘?hào)與模塊輸出電壓有12倍增益關(guān)系,
               不同模控板之間0.1V的輸出壓差將造成不均流現(xiàn)象。

 函數(shù)對設(shè)定值的設(shè)定調(diào)整范圍:正負(fù)50(實(shí)際試驗(yàn)正負(fù)10)

 ***************************************************************/

 #define DIF_ZERO    128
 #define MAX_DIF_ERR 25
 #define MAX_ITG_ERR 51

void  calcu_vol_set_pwm()   		// 計(jì)算與調(diào)整輸出電壓
{
 static uchar err_itg;				// 電壓控制信號(hào)

 uchar t;
 uint i;

 if(uiabs_sub(vol_set,ad_vol_set) > 2*MAX_DIF_ERR)// 計(jì)算設(shè)定于采樣的誤差是否大于50
   {
    err_itg = DIF_ZERO;				// 誤差積分清0
    if(ad_vol_set < vol_set) 			// PWM數(shù)值步進(jìn)MAX_DIF_ERR調(diào)整
      pwm_vol_set = (pwm_vol_set > 1023-MAX_DIF_ERR)?1023:pwm_vol_set+MAX_DIF_ERR;
    else
      pwm_vol_set = (pwm_vol_set < MAX_DIF_ERR)?0:pwm_vol_set-MAX_DIF_ERR;
    }
 else						       // 計(jì)算誤差積分
   {
    err_itg = (err_itg > DIF_ZERO+2*MAX_DIF_ERR)?DIF_ZERO+2*MAX_DIF_ERR:err_itg;
    err_itg = (err_itg < DIF_ZERO-2*MAX_DIF_ERR)?DIF_ZERO-2*MAX_DIF_ERR:err_itg;


    if(ad_vol_set < vol_set)
      err_itg -= (uchar)(vol_set - ad_vol_set);
    else
      err_itg += (uchar)(ad_vol_set - vol_set);

    t = ucabs_sub(DIF_ZERO,err_itg)/MAX_ITG_ERR;// 計(jì)算積分誤差調(diào)整值,增益1/25(經(jīng)驗(yàn)數(shù)值,
                                                // 此值過大,過小都引起系統(tǒng)輸出電壓震蕩,)

    if(t)					// 根據(jù)調(diào)正量修正PWM輸出
      {
       if(err_itg < DIF_ZERO)
         pwm_vol_set = (pwm_vol_set>1023-t)?1023:pwm_vol_set+t;
       else
         pwm_vol_set = (pwm_vol_set<t)?0:pwm_vol_set-t;
       }
    }

 if(uiabs_sub(vol_set,pwm_vol_set) > 2*MAX_DIF_ERR)// 修正范圍超出50,按照最大正負(fù)50調(diào)整
   {
    if(vol_set > pwm_vol_set)
      {
       if(vol_set < 2*MAX_DIF_ERR)
         i = 0;
       else
         i = vol_set - 2*MAX_DIF_ERR;
       }
    else
      {
       if(vol_set > 1023 - 2*MAX_DIF_ERR)
         i = 1023;
       else
         i = vol_set + 2*MAX_DIF_ERR;
       }
    di();
    pwm_vol_set = i;
    ei();
    }
 }

void  calcu_cur_lmt_pwm()   	// 計(jì)算限流輸出
{
 di();
 pwm_cur_lmt = cur_lmt;		    // 無修正,按照設(shè)定數(shù)值輸出(原因:限流精度要求不高,正負(fù)0.1足以)
 ei();
 }


void set_pwm_out()				// 設(shè)定PWM輸出
{
 CCP1X = (pwm_vol_set&0x02)?1:0;
 CCP1Y = (pwm_vol_set&0x01)?1:0;

 CCPR1L = pwm_vol_set/4;

 CCP2X = (pwm_cur_lmt&0x02)?1:0;
 CCP2Y = (pwm_cur_lmt&0x01)?1:0;

 CCPR2L = pwm_cur_lmt/4;
 }

void pow_process()				// 關(guān)機(jī)處理
{
 if(rct_pow&0x01)   	SHUT0 = 1;
 else			SHUT0 = 0;
 if(rct_pow&0x02)   	SHUT1 = 1;
 else			SHUT1 = 0;
 if(rct_pow&0x04)   	SHUT2 = 1;
 else			SHUT2 = 0;
 if(rct_pow&0x08)   	SHUT3 = 1;
 else			SHUT3 = 0;
 if(rct_pow&0x10)   	SHUT4 = 1;
 else			SHUT4 = 0;
 if(rct_pow&0x20)   	SHUT5 = 1;
 else			SHUT5 = 0;
 }

void get_warn_status()				// 獲得模塊狀態(tài)
 {
  uchar t;

  //di();

  VSET = 0;					// 設(shè)模塊狀態(tài)比較值1.67V
  TRISD =0b11111111;		/* PORT_D as input */
  _NOP_;
  _NOP_;
  _NOP_;
  _NOP_;
  delay(1);
  t = PORTD;					// 獲模塊在位信號(hào)



  if((t&1)==0)
    rct_cur[0] = 0;
  if((t&2)==0)
    rct_cur[1] = 0;
  if((t&4)==0)
    rct_cur[2] = 0;
  if((t&8)==0)
    rct_cur[3] = 0;
  if((t&16)==0)
    rct_cur[4] = 0;
  if((t&32)==0)
    rct_cur[5] = 0;

  rct_no=t&0x3F;  // 獲模塊在位信號(hào)

  VSET = 1;				// 設(shè)模塊狀態(tài)比較值3.3V
  TRISD =0b11111111;	/* PORT_D as input */
  _NOP_;
  _NOP_;
  _NOP_;
  _NOP_;

  delay(1);
  t = PORTD;
  rct_warn = t&0x3F;		// 獲模塊告警信號(hào)




  _NOP_;
  _NOP_;
  //ei();

  }

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品久久久久影院色老大| 蜜桃精品视频在线| 午夜精品久久一牛影视| 丰满少妇在线播放bd日韩电影| 欧美伊人久久大香线蕉综合69| 亚洲人成在线播放网站岛国| 久久精品999| 欧美美女一区二区三区| 亚洲色图在线播放| 国产成人午夜99999| 日韩三区在线观看| 亚洲午夜精品17c| 成人av在线网站| 精品国产麻豆免费人成网站| 图片区日韩欧美亚洲| 在线视频国内自拍亚洲视频| 国产精品成人午夜| 国产高清不卡一区二区| 亚洲精品一区二区精华| 蜜臀av国产精品久久久久 | 亚洲精品老司机| 国产一区二区按摩在线观看| 91精品国产一区二区三区香蕉| 亚洲午夜精品网| 欧美日韩亚洲综合一区| 亚洲制服丝袜av| 色婷婷综合久色| 亚洲欧美日韩中文字幕一区二区三区 | 亚洲欧美一区二区三区国产精品| 国产乱码精品一区二区三区五月婷| 欧美精品视频www在线观看| 亚洲午夜av在线| 欧美性猛片aaaaaaa做受| 一区二区三区中文在线观看| 色婷婷综合久久久久中文一区二区 | 91色porny蝌蚪| 亚洲精品视频观看| 欧美丝袜自拍制服另类| 日韩精品一二三| 91精品国产欧美一区二区成人| 成人av第一页| 国产精品久久久一本精品| 不卡的电影网站| 亚洲另类在线一区| 欧美视频一区二| 久久er99精品| 中文字幕在线视频一区| 91国偷自产一区二区开放时间| 亚洲精品成人天堂一二三| 在线观看中文字幕不卡| 日韩电影在线观看电影| 久久午夜老司机| 91视视频在线观看入口直接观看www | 日韩精品一区二| 国产一区在线观看麻豆| 国产精品久久久久久亚洲伦| 欧美中文一区二区三区| 日本视频一区二区| 国产欧美精品一区| 色婷婷综合五月| 久久激情综合网| 国产精品电影院| 精品视频一区 二区 三区| 久久99国产精品免费| 中文字幕一区二区三区不卡| 欧美日韩国产美| 成人爽a毛片一区二区免费| 亚洲最新视频在线播放| 精品对白一区国产伦| 91视频你懂的| 国产精品自拍av| 亚洲高清一区二区三区| 久久久一区二区| 欧美人妇做爰xxxⅹ性高电影 | 日韩精品亚洲一区二区三区免费| 国产欧美中文在线| 9191久久久久久久久久久| 大胆欧美人体老妇| 日韩国产成人精品| 国产高清在线观看免费不卡| 天天色综合天天| 中文字幕一区二区三区在线观看| 日韩一级高清毛片| 色婷婷综合五月| 国产一区二区精品久久| 日韩激情在线观看| 亚洲精品videosex极品| 久久久久久夜精品精品免费| 337p亚洲精品色噜噜狠狠| 色香色香欲天天天影视综合网| 国产成人午夜精品影院观看视频| 石原莉奈一区二区三区在线观看 | 99在线精品观看| 极品少妇一区二区| 日韩精品每日更新| 一个色在线综合| 国产精品色哟哟| 久久久久久综合| 精品欧美一区二区三区精品久久| 欧美日韩视频不卡| 在线免费观看日本欧美| 99精品久久99久久久久| 国产成人免费在线| 国产成人免费xxxxxxxx| 精品一区二区三区视频| 日韩国产一区二| 日本午夜精品视频在线观看| 天天综合色天天综合| 午夜精品爽啪视频| 99r国产精品| 99久久精品国产毛片| 成人avav影音| 91社区在线播放| 日本福利一区二区| 在线视频亚洲一区| 精品视频一区二区不卡| 欧美日韩国产免费| 日韩午夜精品视频| 91精品国产免费| 日韩欧美一级在线播放| 日韩午夜中文字幕| 久久人人97超碰com| 久久你懂得1024| 国产精品久久久久三级| 亚洲精品老司机| 五月婷婷久久丁香| 久久国内精品自在自线400部| 国产一区二区0| www.亚洲激情.com| 欧美三级韩国三级日本一级| 欧美高清视频在线高清观看mv色露露十八| 欧美日韩一区三区四区| 日韩视频一区在线观看| 久久久蜜臀国产一区二区| 国产精品丝袜黑色高跟| 亚洲夂夂婷婷色拍ww47| 美女在线视频一区| 成人久久18免费网站麻豆| 在线观看亚洲精品| 日韩欧美国产综合| 欧美高清在线视频| 亚洲自拍偷拍麻豆| 激情六月婷婷久久| 色婷婷av一区二区| 91精品国产一区二区| 中文字幕欧美国产| 夜夜精品视频一区二区| 激情五月播播久久久精品| 不卡av电影在线播放| 欧美视频一区在线观看| 欧美精品一区二区三区视频| 亚洲人成人一区二区在线观看| 男女男精品视频网| 成人av在线观| 欧美videos中文字幕| 中文字幕在线不卡国产视频| 日本va欧美va欧美va精品| 成人精品国产福利| 欧美一级爆毛片| 亚洲精品日日夜夜| 国产成人av福利| 精品视频免费在线| 国产精品久久久久久户外露出| 亚洲v精品v日韩v欧美v专区| 成人午夜激情片| 日韩你懂的电影在线观看| 一区二区三区中文在线观看| 丰满少妇久久久久久久| 欧美一级专区免费大片| 亚洲男人的天堂在线aⅴ视频| 免费人成精品欧美精品 | 日韩一区二区高清| 亚洲欧美国产高清| 国产乱人伦精品一区二区在线观看| 欧美在线观看你懂的| 欧美激情一区二区三区蜜桃视频| 亚洲一级在线观看| av成人动漫在线观看| 久久精品人人爽人人爽| 久久99精品久久久久久国产越南| 欧美日韩精品欧美日韩精品一| 日韩毛片视频在线看| 成人中文字幕在线| 国产亚洲精久久久久久| 久久成人麻豆午夜电影| 91精品国产综合久久小美女 | 中文字幕在线不卡一区| 国产激情精品久久久第一区二区| 精品国产一区二区三区av性色| 视频一区欧美精品| 51精品久久久久久久蜜臀| 亚洲一区av在线| 欧美酷刑日本凌虐凌虐| 亚洲一二三四区| 在线免费观看成人短视频| 亚洲精品第1页| 欧美性生活一区| 午夜视频在线观看一区| 欧美亚洲国产一区二区三区| 亚洲香肠在线观看|