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

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

?? pic2448.c

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

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

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

#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))             	//置位對應位
#define bits_off(var,mask) 	((var)&=~0^(mask))         	    //清零對應位 
#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				// 模塊關機控制
#define SHUT1 RB1
#define SHUT2 RB2
#define SHUT4 RB4
#define SHUT5 RB5

#define SHUT3 RC0

#define VSET  RC3				// 模塊狀態比較電壓控制
#define RLSW  RC4				// 輸出繼電器控制
#define EN485 RC5				// 485 收發轉換

#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,秒,無通信計時定義

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

uchar sio_tx_num;				// 發送字節數
uchar sio_rx_num;				// 接收字節數
bank1 uchar sio_rx_buf[SIO_RX_LEN];		// 接收緩沖區
bank1 uchar sio_tx_buf[SIO_TX_LEN];

ulong  cpu3;

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

uint  ad_vol_set;				// 調壓輸出測量值

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

uint  vol_set;					// 調壓輸出設置值(0-1023)
uint  cur_lmt;					// 限流輸出設置值(0-1023)
uchar rct_pow;					// 整流器關機
uchar rct_warn;					// 整流器告警
uchar rct_no=0xff;				// 整流器在位
bank1 uint  rct_cur[6];			// 整流器電流

bank1 uint ibuf[9];				// AD采樣數組





#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)				// 延時子程序
{
 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)			// 延時100us
{
 TMR0 = 1;
 T0IF = 0;
 while(times--)
  {
   while(!T0IF);
   T0IF = 0;
   }
}

void  wr_eeprom(uchar addr,uchar val)		// 內部EEPROM寫入(地址,數值)
{
  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)			// 內部EEPROM讀出(地址),返回數據
{
  uchar val;
  EECON1=0;

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

  return val;
  }


uint start_ad(uchar chn)			// 啟動指定通道的AD轉換,換回AD數值
{
  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)		// 對指定通道進行AD轉換,換回AD數值(內含數值濾波)
{
 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個數的平均值
    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轉換結果=0
 			break;
		}
	}









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

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

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

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

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

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

  下面函數計算與調整輸出電壓

 目的:消除7805供電電壓,16F877與運放等電路產生的輸出誤差

 此函數很重要:因為控制電壓信號與模塊輸出電壓有12倍增益關系,
               不同??匕逯g0.1V的輸出壓差將造成不均流現象。

 函數對設定值的設定調整范圍:正負50(實際試驗正負10)

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

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

void  calcu_vol_set_pwm()   		// 計算與調整輸出電壓
{
 static uchar err_itg;				// 電壓控制信號

 uchar t;
 uint i;

 if(uiabs_sub(vol_set,ad_vol_set) > 2*MAX_DIF_ERR)// 計算設定于采樣的誤差是否大于50
   {
    err_itg = DIF_ZERO;				// 誤差積分清0
    if(ad_vol_set < vol_set) 			// PWM數值步進MAX_DIF_ERR調整
      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						       // 計算誤差積分
   {
    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;// 計算積分誤差調整值,增益1/25(經驗數值,
                                                // 此值過大,過小都引起系統輸出電壓震蕩,)

    if(t)					// 根據調正量修正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,按照最大正負50調整
   {
    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()   	// 計算限流輸出
{
 di();
 pwm_cur_lmt = cur_lmt;		    // 無修正,按照設定數值輸出(原因:限流精度要求不高,正負0.1足以)
 ei();
 }


void set_pwm_out()				// 設定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()				// 關機處理
{
 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()				// 獲得模塊狀態
 {
  uchar t;

  //di();

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



  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;  // 獲模塊在位信號

  VSET = 1;				// 設模塊狀態比較值3.3V
  TRISD =0b11111111;	/* PORT_D as input */
  _NOP_;
  _NOP_;
  _NOP_;
  _NOP_;

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




  _NOP_;
  _NOP_;
  //ei();

  }

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产一区二区精品久久| 不卡视频在线观看| 国产精品乱码一区二区三区软件| 91高清视频免费看| 国产精品一卡二卡在线观看| 亚洲国产精品久久一线不卡| 久久网站最新地址| 欧美日韩黄视频| 成人动漫在线一区| 黄色成人免费在线| 天天亚洲美女在线视频| 亚洲婷婷在线视频| 欧美国产一区在线| 精品国产一区二区三区不卡 | 国产亚洲欧美激情| 欧美日韩高清一区二区三区| 97久久超碰国产精品| 国产一区二区三区免费播放| 亚洲成av人片在线观看无码| 国产精品久久久久影院老司| 精品国产亚洲在线| 欧美一区二区三区四区五区| 日本道免费精品一区二区三区| 国产精品996| 国精产品一区一区三区mba视频 | 欧美三级三级三级爽爽爽| 成人小视频在线观看| 狠狠色伊人亚洲综合成人| 日韩激情视频网站| 亚洲va国产天堂va久久en| 一区二区三区中文在线| 一区二区中文字幕在线| 中文字幕av资源一区| 日本一区二区三区dvd视频在线| 欧美电影免费观看完整版| 欧美高清视频在线高清观看mv色露露十八 | 波多野结衣视频一区| 国产成人av影院| 国产精品88888| 国产不卡在线视频| 成人一级视频在线观看| 岛国精品在线观看| 成人激情免费电影网址| 波多野结衣视频一区| 97se亚洲国产综合在线| 色婷婷久久综合| 在线精品视频免费观看| 91黄色在线观看| 欧美三区在线观看| 欧美一区2区视频在线观看| 91麻豆精品国产91久久久久久久久 | 精品久久久久久无| 欧美电视剧在线看免费| 26uuu国产日韩综合| 久久欧美一区二区| 中文字幕av资源一区| 日韩美女精品在线| 亚洲午夜久久久久久久久电影网 | 日韩一二在线观看| 精品精品国产高清一毛片一天堂| 26uuu欧美| 国产欧美日韩在线视频| 国产精品久久久久影院老司| 一区二区三区美女视频| 日韩av中文字幕一区二区| 久久66热re国产| 国产成人免费视频网站 | 亚洲女女做受ⅹxx高潮| 亚洲不卡在线观看| 久久99日本精品| gogo大胆日本视频一区| 欧美三级资源在线| 久久久www免费人成精品| 日韩一区欧美小说| 日韩高清一区二区| 成人一区二区三区视频 | 国产精品情趣视频| 亚洲午夜精品久久久久久久久| 免费三级欧美电影| av不卡一区二区三区| 欧美日韩三级一区| 国产亚洲欧美日韩俺去了| 亚洲在线一区二区三区| 国内外成人在线| 色狠狠色噜噜噜综合网| 精品成人一区二区| 夜夜嗨av一区二区三区中文字幕| 麻豆精品一区二区| a级高清视频欧美日韩| 欧美剧情片在线观看| 日本一区二区三区久久久久久久久不 | 国产欧美日本一区视频| 一区二区三区精品在线观看| 久久国产精品色婷婷| 色欧美乱欧美15图片| 亚洲精品一区二区精华| 一区二区三区美女视频| 岛国一区二区三区| 日韩欧美高清一区| 亚洲福利电影网| 99久久久免费精品国产一区二区| 日韩欧美久久久| 亚洲国产综合91精品麻豆| 国产大陆a不卡| 91精品国产aⅴ一区二区| 亚洲精品视频在线观看网站| 国产原创一区二区| 欧美日韩一本到| 亚洲女人的天堂| 成人开心网精品视频| 日韩一级完整毛片| 亚洲国产精品久久久男人的天堂 | 日本最新不卡在线| 91精彩视频在线| ㊣最新国产の精品bt伙计久久| 蜜桃免费网站一区二区三区| 欧洲一区二区三区在线| 中文字幕在线视频一区| 国产成人免费在线观看不卡| 日韩免费高清电影| 天堂在线一区二区| 欧美天堂一区二区三区| 18欧美亚洲精品| 成人性生交大合| 国产日本欧美一区二区| 蓝色福利精品导航| 欧美福利视频导航| 亚洲地区一二三色| 欧美人狂配大交3d怪物一区| 一卡二卡欧美日韩| 色美美综合视频| 一区二区三区日韩在线观看| 91麻豆国产精品久久| 亚洲色图欧美在线| 色哟哟一区二区在线观看| 亚洲欧洲另类国产综合| 91亚洲精品久久久蜜桃| 专区另类欧美日韩| 91麻豆福利精品推荐| 亚洲精品va在线观看| 日本韩国一区二区| 亚洲动漫第一页| 欧美丰满嫩嫩电影| 久久爱另类一区二区小说| www久久久久| 成人永久看片免费视频天堂| 国产精品久久久久久久久久免费看| 国产成人av一区二区| 日本一区二区三区在线观看| 成人av免费在线| 亚洲综合色丁香婷婷六月图片| 欧美日韩国产欧美日美国产精品| 奇米精品一区二区三区在线观看一| 91精品福利在线一区二区三区| 蜜桃精品视频在线观看| 久久综合资源网| av中文字幕一区| 亚洲午夜电影在线| 日韩欧美的一区| 国产99精品国产| 亚洲综合免费观看高清完整版在线| 欧美肥妇free| 东方欧美亚洲色图在线| 亚洲精品综合在线| 欧美一区二区日韩一区二区| 久久精品久久综合| 国产精品国产三级国产aⅴ中文| 在线亚洲一区二区| 日韩电影在线免费看| 亚洲精品一区在线观看| 99久久精品免费观看| 亚洲国产日日夜夜| 国产性做久久久久久| 在线视频你懂得一区| 极品少妇xxxx精品少妇| 中文字幕在线播放不卡一区| 在线不卡欧美精品一区二区三区| 国模套图日韩精品一区二区| 亚洲欧洲日韩综合一区二区| 91精品婷婷国产综合久久竹菊| 国产不卡在线视频| 日韩福利电影在线| 日韩久久一区二区| 精品福利在线导航| 欧美在线免费观看亚洲| 国内成人精品2018免费看| 一区二区在线观看视频| xf在线a精品一区二区视频网站| 色老汉一区二区三区| 久久av老司机精品网站导航| 亚洲影视资源网| 国产丝袜美腿一区二区三区| 欧美日韩国产高清一区二区| 成人黄色综合网站| 久久国产尿小便嘘嘘| 亚洲午夜久久久久中文字幕久| 中文字幕不卡在线| 精品国产乱码久久久久久图片 | 日韩精品一二区| 国产精品国产三级国产专播品爱网|