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

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

?? vsi_control.c

?? 許繼的2812開發全套驅動程序,很全很實用的.rar
?? C
?? 第 1 頁 / 共 3 頁
字號:
	temp=CHA7>>4;	
	
	CtrVars.Vs_sum_20ms=CtrVars.Vs_sum_20ms+temp;	
	CtrVars.Vs=temp-CtrVars.Vs_offset;	
	temp_32=CtrVars.Vs;
	temp_32=temp_32*CtrVars.sinwt;	// calculate the peak value of output voltage	
	temp=temp_32>>13;
	CtrVars.Vs_sinwt_sum=CtrVars.Vs_sinwt_sum+temp;
	

//Ic

	CHA6 = AdcRegs.ADCRESULT1;
	temp=CHA6>>4;
	
	CtrVars.Ic_sum_20ms=CtrVars.Ic_sum_20ms+temp;	
	CtrVars.Ic=temp-CtrVars.Ic_offset;	
	temp_32=CtrVars.Ic;
	temp_32=temp_32*cosN;//CtrVars.coswt;	// calculate the peak value of output voltage	
	temp=temp_32>>13;
	CtrVars.Ic_coswt_sum=CtrVars.Ic_coswt_sum+temp;	

//Il

	CHA5 = AdcRegs.ADCRESULT2;
	temp=CHA5>>4;
	
	CtrVars.Il=temp-CtrVars.Il_offset;
	CtrVars.Il_sum_20ms=CtrVars.Il_sum_20ms+CtrVars.Il;				
	temp_32=CtrVars.Il;
	temp_32=temp_32*CtrVars.sinwt;	// calculate the peak value of output current
	temp=temp_32>>13;
	CtrVars.Il_sinwt_sum=CtrVars.Il_sinwt_sum+temp;
	
//Udc		

	CHA4 = AdcRegs.ADCRESULT3;
	temp=CHA4>>4;	
		
	CtrVars.Udc=temp-CtrVars.Udc_offset;
	temp_32=CtrVars.Udc;
	temp_32=CtrVars.Udc_prescale*temp_32;
	CtrVars.Udc=temp_32>>10;
		
	CtrVars.Udc_sum=CtrVars.Udc_sum+CtrVars.Udc;	

//------------------------------------------------	
	temp_32=CtrVars.Vs_rms_ref;
	temp_32=pwm_half_per*temp_32;
	temp=CtrVars.Udc_aver*6;	
	pre_value=temp_32/temp;	// pre_value=Vs_peak*pwm_half_per/(4*Udc), ratio=1:2	
	if(abs(CtrVars.Vs)>1100){CtrVars.Il_sinwt_main=0;}
	temp=CtrVars.Il_sinwt_main/3;
	pre_value=pre_value+temp;
	
	if(CtrVars.start==1)
		{
			CtrVars.factor_tmp++;
			CtrVars.pre_factor=CtrVars.factor_tmp>>2;
			if(CtrVars.pre_factor>pre_value)
				{
					CtrVars.pre_factor=pre_value;
					CtrVars.factor_tmp=0;
					CtrVars.start=0;		// finish the process of start					
				}
			Vs_err=0;					
		}
	else if(CtrVars.run_stop==1)
		{				
		    temp_32=CtrVars.Vs_rms_ref;
		    temp_32=temp_32*CtrVars.sinwt;			
			Vs_ref=temp_32>>14;
			Vs_err=Vs_ref-CtrVars.Vs;
			
			pid_output=Vs_err;
			
// low-pass filter
// y(k+1)=y(k)+2*y(k-1)+y(k-2)
			temp=pid_output+CtrVars.pid_Vyks1;
			temp=temp+CtrVars.pid_Vyks1;
			temp=temp+CtrVars.pid_Vyks2;
			pid_output=temp>>2;
			if(pid_output>200)pid_output=200;
			if(pid_output<-200)pid_output=-200;
			CtrVars.pid_Vyks2=CtrVars.pid_Vyks1;
			CtrVars.pid_Vyks1=pid_output;

/** x(k)=e(k)+Q(z)*x(k-N) **/
// Q(z)=0.95
//x(k)=e(k)+0.95*x(k-N)						
			temp_32=CtrVars.rep[CtrVars.t2ufint_counter];
			temp_32=972*temp_32;
			temp=temp_32>>10;
			CtrVars.rep[CtrVars.t2ufint_counter]=Vs_err+temp;
												
			if(CtrVars.rep[CtrVars.t2ufint_counter]>1500)CtrVars.rep[CtrVars.t2ufint_counter]=1500;
			if(CtrVars.rep[CtrVars.t2ufint_counter]<-1500)CtrVars.rep[CtrVars.t2ufint_counter]=-1500;

//y(k+1)=km1*y(k)+km2*y(k-1)+[kn1*x(k+12+9+1-N)+kn2*x(k+12+9-N)
//								+2*kn1*x(k+12+1-N)+2*kn2*x(k+12-N)
//								+kn1*x(k+12-9+1-N)+kn2*x(k+12-9-N)]/4
			temp=CtrVars.t2ufint_counter+21;
			if(temp>=f_point)temp=temp-f_point;
			temp32=kn1;
			temp32=temp32*CtrVars.rep[temp];
			
			temp=CtrVars.t2ufint_counter+20;
			if(temp>=f_point)temp=temp-f_point;
			temp_32=kn2;
			temp_32=temp_32*CtrVars.rep[temp];
			temp32=temp32+temp_32;
			
			temp=CtrVars.t2ufint_counter+12;
			if(temp>=f_point)temp=temp-f_point;
			temp_32=kn1;
			temp_32=temp_32*CtrVars.rep[temp];
			temp32=temp32+temp_32;
			temp32=temp32+temp_32;
			
			temp=CtrVars.t2ufint_counter+11;
			if(temp>=f_point)temp=temp-f_point;
			temp_32=kn2;
			temp_32=temp_32*CtrVars.rep[temp];
			temp32=temp32+temp_32;
			temp32=temp32+temp_32;
			
			temp=CtrVars.t2ufint_counter+3;
			if(temp>=f_point)temp=temp-f_point;
			temp_32=kn1;
			temp_32=temp_32*CtrVars.rep[temp];
			temp32=temp32+temp_32;
			
			temp=CtrVars.t2ufint_counter+2;
			if(temp>=f_point)temp=temp-f_point;
			temp_32=kn2;
			temp_32=temp_32*CtrVars.rep[temp];
			temp32=temp32+temp_32;
			
			temp32=temp32>>2;

//********************************************************
			temp_32=km1;
			temp_32=temp_32*CtrVars.Vyk;
			temp32=temp32+temp_32;
			
			temp_32=km2;
			temp_32=temp_32*CtrVars.Vyks1;
			temp32=temp32+temp_32;
				
			temp=temp32>>11;						
			temp=5*temp;
			temp=temp>>3;
			
			CtrVars.Vyks1=CtrVars.Vyk;
			CtrVars.Vyk=temp;			
						
			Vs_err=temp;
				
// limit the peak-value of output voltage			
			
			temp32=CtrVars.Ic_coswt_main;
			temp32=temp32*cosN; //CtrVars.coswt;
			temp=temp32>>14;
			temp=temp-CtrVars.Ic;
			temp=3*temp;
			temp=temp>>3;
			if(temp>100)temp=100;
			if(temp<-100)temp=-100;
			Vs_err=Vs_err+temp;
	
			Vs_err=Vs_err+pid_output;
			
			CtrVars.pre_factor=pre_value;  // set feedforward variable			

		}
	else
		{
			Vs_err=0;			
		}

	temp_32=CtrVars.pre_factor;
	temp_32=temp_32*sinN;
	temp=temp_32>>14;			
	temp=temp+pwm_half_per/2;
	
	temp=temp+Vs_err;
	temp=temp-CtrVars.pianci;	
		
	if(temp>pwm_half_per)
		{
			temp=pwm_half_per;
		}
	if(temp<0)
		{
			temp=0;
		}

// refresh the full compare registers
	EvaRegs.CMPR1=temp;
	EvaRegs.CMPR2=pwm_half_per-temp;
	
//	if(CtrVars.run_stop==1){tmp[CtrVars.t2ufint_counter]=CtrVars.Ic;}
		
	CtrVars.t2ufint_counter++;
//--------------------------------------------------------------------------------	
	if((CtrVars.t2ufint_counter==f_point/2)||(CtrVars.t2ufint_counter==f_point))
		{
			temp=f_point/2;
			CtrVars.Udc_aver=CtrVars.Udc_sum/temp;
			if(CtrVars.Udc_aver<0){CtrVars.Udc_aver=10;}			
			CtrVars.Udc_sum=0;
		}
//-------------------------------------------------------------------------------		
		
	if(CtrVars.t2ufint_counter>=f_point)
		{
			CtrVars.t2ufint_counter=0;
			CtrVars.sum_counter=0;				
	
			CtrVars.Vs_offset=CtrVars.Vs_sum_20ms/f_point;
			if(CtrVars.run_stop==0)
				{
					CtrVars.reset_lock=1;
					CtrVars.Ic_offset=CtrVars.Ic_sum_20ms/f_point;
					temp=CtrVars.Il_sum_20ms/f_point;
					CtrVars.Il_offset=temp+CtrVars.Il_offset;
				}
			
			if(abs(CtrVars.pianci_rec)>300 && abs(CtrVars.Il_sum_20ms)>300)
				{
					if(CtrVars.Il_sum_20ms>3000)CtrVars.pianci=CtrVars.pianci+5;
					else if(CtrVars.Il_sum_20ms>2000)CtrVars.pianci=CtrVars.pianci+3;
					else if(CtrVars.Il_sum_20ms>400)CtrVars.pianci++;
					else if(CtrVars.Il_sum_20ms<-3000)CtrVars.pianci=CtrVars.pianci-5;
					else if(CtrVars.Il_sum_20ms<-2000)CtrVars.pianci=CtrVars.pianci-3;			
					else if(CtrVars.Il_sum_20ms<-400)CtrVars.pianci--;			
					else{;}
				}
			CtrVars.pianci_rec=CtrVars.Il_sum_20ms;
			
			if(CtrVars.pianci>30)CtrVars.pianci=30;
			if(CtrVars.pianci<-30)CtrVars.pianci=-30;

			CtrVars.Vs_sum_20ms=0;
			CtrVars.Ic_sum_20ms=0;
			CtrVars.Il_sum_20ms=0;
				
			CtrVars.Vs_sinwt_main=CtrVars.Vs_sinwt_sum/f_point;
			CtrVars.Vs_sinwt_sum=0;
			
			CtrVars.Ic_coswt_main=CtrVars.Ic_coswt_sum/f_point;
			if(CtrVars.Ic_coswt_main<0){CtrVars.Ic_coswt_main=0;}
			CtrVars.Ic_coswt_sum=0;
			
			CtrVars.Il_sinwt_main=CtrVars.Il_sinwt_sum/f_point;
			if(CtrVars.Il_sinwt_main<20){CtrVars.Il_sinwt_main=0;}
			CtrVars.Il_sinwt_sum=0;						

		}

//used to control the flash of run_led, 0:off 1:on
	CtrVars.run_led=CtrVars.run_led+1;
	if(CtrVars.run_led==pwm_frequency)        /* second twinkle*/
    	{     		
//			RunLed();
			CtrVars.run_led=0;
			CtrVars.thirtysecond--;
			if(CtrVars.fault==1)
				{
//					StatusLed(2); /* twinkle */					
				}
    	}
    
    // Acknowledge interrupt to recieve more interrupts from PIE group 3
	PieCtrlRegs.PIEACK.all |= PIEACK_GROUP3;
}


/***trace the phase and frequency of the system voltage***/
interrupt void eva_capint1_isr(void)
{
    // Note: To be safe, use a mask value to write to the entire
	// EVAIFRC register.  Writing to one bit will cause a read-modify-write
	// operation that may have the result of writing 1's to clear 
	// bits other then those intended. 
    EvaRegs.EVAIFRC.all = BIT0;
    	
		
	// Acknowledge interrupt to recieve more interrupts from PIE group 3
	PieCtrlRegs.PIEACK.all |= PIEACK_GROUP3;
}

interrupt void eva_capint2_isr(void)
{
    // Note: To be safe, use a mask value to write to the entire
	// EVAIFRC register.  Writing to one bit will cause a read-modify-write
	// operation that may have the result of writing 1's to clear 
	// bits other then those intended. 
    EvaRegs.EVAIFRC.all = BIT1;
	
	
	
	// Acknowledge interrupt to recieve more interrupts from PIE group 3
	PieCtrlRegs.PIEACK.all |= PIEACK_GROUP3;
}

//** communication software module
interrupt void sciarxint_isr(void)
{
/*	switch(SciaVars.i)
	{
	case 0:SciaVars.xxx[SciaVars.i]=SciaRegs.SCIRXBUF.bit.RXDT;break;	
	case 1:SciaVars.xxx[SciaVars.i]=SciaRegs.SCIRXBUF.bit.RXDT;break;
	case 2:SciaVars.xxx[SciaVars.i]=SciaRegs.SCIRXBUF.bit.RXDT;break;
	case 3:SciaVars.xxx[SciaVars.i]=SciaRegs.SCIRXBUF.bit.RXDT;break;
	case 4:SciaVars.xxx[SciaVars.i]=SciaRegs.SCIRXBUF.bit.RXDT;break;
    }
    SciaVars.i++;
*/    
       
    //When a maskable interrupt is acknowledged, only the IFR bit is cleared
	//automatically. The flag bit in the corresponding peripheral control register
	//is not cleared. If an application requires that the control register flag
	//be cleared, the bit must be cleared by software.
	SciaRegs.SCIFFRX.bit.RXFFINTCLR = 1;
	// Acknowledge interrupt to recieve more interrupts from PIE group 9
	PieCtrlRegs.PIEACK.all |= PIEACK_GROUP9;
}

interrupt void scibrxint_isr(void)
{

	
    ScibVars.test = ScibRegs.SCIRXBUF.bit.RXDT;
    
    //When a maskable interrupt is acknowledged, only the IFR bit is cleared
	//automatically. The flag bit in the corresponding peripheral control register
	//is not cleared. If an application requires that the control register flag
	//be cleared, the bit must be cleared by software.
	ScibRegs.SCIFFRX.bit.RXFFINTCLR = 1;
	// Acknowledge interrupt to recieve more interrupts from PIE group 9
	PieCtrlRegs.PIEACK.all |= PIEACK_GROUP9;
}

//*** MMI software module
interrupt void xnmi_isr(void)
{
	int temp;
	temp=INCS3 & 0x3f; // short-circuit fault protection
	if(temp!=0x3f)
		{
			EvaRegs.COMCONA.bit.FCOMPOE = 0; // set full compare output in Hi-Z state	
			CtrVars.fault=1;				 // don't allow self-restart after detecting fault
			CtrVars.short_circuit=temp;
		}
	else
		{
			CtrVars.Il_fault=1;
		}
}


// initialize variables
void initvariable(void)
{	
	int i;
	CtrVars.reset_lock=0;
	CtrVars.pwm_enable=0;
	CtrVars.Udc_offset=2261;
	CtrVars.Udc_prescale=980;//900; 	// amplify 2^10 times
	CtrVars.Udc_uplimit=1000;    // 450V
	CtrVars.Udc_lowlimit=350;
	CtrVars.Udc_sum=0;	
	CtrVars.Udc_aver=1000;
	
	CtrVars.Vs_offset=2254;
	CtrVars.Vs_prescale=1024;  	// amplify 2^10 times	
	
	for(i=0;i<f_point;i++)CtrVars.rep[i]=0;
	CtrVars.Vyk=0;	CtrVars.Vyks1=0;
		
	CtrVars.Vs_sinwt_sum=0;
	CtrVars.Vs_rms_ref=1030;  	// the reference output voltage is Vs_rms_ref*sinwt
	
	CtrVars.Vs_sum_20ms=0;
	
	CtrVars.Ic_offset=2244; 	// the sample value of analog signal
	CtrVars.Ic_prescale=450; 	// amplify 2^10 times
	CtrVars.Ic_sum_20ms=0;
	
	CtrVars.Il_offset=2239; 	// the sample value of analog signal
	CtrVars.Il_sum_20ms=0;
	CtrVars.Il_sinwt_sum=0;	
	CtrVars.pianci=0;
				
	CtrVars.pre_factor=0;
	CtrVars.factor_tmp=0;
		
	CtrVars.start=0;	
	CtrVars.fault=0;
	CtrVars.run_led=0;			//used to control run_lamp
	CtrVars.run_stop=0;
	
	CtrVars.t2ufint_counter=0;
	CtrVars.sum_counter=0; 		// used to calculate phase
		
	CtrVars.pid_Vyks1=0;	CtrVars.pid_Vyks2=0;

	sintab_pointer=(_iq30 *)0x3ff000;
	
	CtrVars.short_circuit=0;
	CtrVars.Vs_fault=0;
	CtrVars.Il_fault=0;
	CtrVars.Udc_high_fault=0;
	CtrVars.Udc_low_fault=0;

}

//===========================================================================
// No more.
//===========================================================================

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久精品国产精品亚洲红杏| 亚洲午夜久久久久中文字幕久| 久久99精品久久久久婷婷| 欧美日韩日日骚| 日韩av一区二区三区| 91精品国产福利在线观看| 久久99精品国产麻豆不卡| 久久免费精品国产久精品久久久久| 国产成人午夜视频| 综合激情网...| 5858s免费视频成人| 久久精品免费观看| 国产精品视频你懂的| 色久优优欧美色久优优| 日韩国产在线观看| 久久久久久99久久久精品网站| 成人短视频下载| 视频一区视频二区在线观看| 欧美tk—视频vk| 91一区在线观看| 日韩国产欧美视频| 国产日产欧产精品推荐色| 欧美性猛交xxxxxx富婆| 久久国产精品露脸对白| 国产精品拍天天在线| 欧美中文字幕一区二区三区 | 色94色欧美sute亚洲线路一久| 亚洲成人第一页| 久久久久久久久久久电影| 色噜噜狠狠成人网p站| 蜜芽一区二区三区| 一色桃子久久精品亚洲| 日韩视频免费观看高清在线视频| 国产高清无密码一区二区三区| 一区二区三区 在线观看视频| 日韩午夜电影av| 91精品91久久久中77777| 久久精品国产一区二区| 一区二区三区日韩在线观看| 欧美精品一区二区三区很污很色的 | 成人黄色软件下载| 久久精品国产精品亚洲红杏| 中文字幕av一区 二区| 欧美一区二区三区在线电影| 99这里只有精品| 韩国成人在线视频| 亚洲成人一区在线| 1024亚洲合集| 国产日韩欧美激情| 日韩欧美在线观看一区二区三区| 91伊人久久大香线蕉| 国产成人精品www牛牛影视| 日韩二区在线观看| 亚洲国产一区在线观看| 国产精品丝袜91| 久久久夜色精品亚洲| 日韩一区二区在线观看视频播放| 91黄色小视频| 99精品视频在线播放观看| 国产一区在线精品| 蜜桃一区二区三区在线| 亚洲成人一二三| 亚洲啪啪综合av一区二区三区| 国产农村妇女精品| 精品国产亚洲一区二区三区在线观看 | 欧美专区亚洲专区| 99久精品国产| 9i看片成人免费高清| 成人免费看片app下载| 国产九色sp调教91| 精油按摩中文字幕久久| 久久99国产精品成人| 蜜桃视频在线一区| 理论电影国产精品| 国产原创一区二区| 国产一区二区三区黄视频| 国内精品免费**视频| 国产精品一区二区你懂的| 国产丶欧美丶日本不卡视频| 国产一区91精品张津瑜| 国产精品996| 风间由美一区二区三区在线观看| 国产999精品久久久久久| 成人综合在线观看| 91香蕉视频mp4| 在线免费视频一区二区| 欧美三级三级三级| 欧美一区二区三区的| 精品久久久久久久一区二区蜜臀| 精品福利一区二区三区| 久久精品免费在线观看| 国产精品拍天天在线| 亚洲激情图片小说视频| 亚洲成人第一页| 麻豆精品国产传媒mv男同| 国产一区二区三区黄视频| 成人黄色综合网站| 欧美性色黄大片手机版| 777久久久精品| 久久免费精品国产久精品久久久久 | 粉嫩av一区二区三区在线播放 | 亚洲欧美日韩国产手机在线| 亚洲福利视频一区二区| 日韩av午夜在线观看| 粉嫩蜜臀av国产精品网站| 色噜噜狠狠成人网p站| 欧美一级理论片| 中文字幕免费不卡在线| 亚洲午夜在线电影| 国模少妇一区二区三区| 色综合久久综合网97色综合| 91麻豆精品国产自产在线 | 国产精品久久毛片| 亚洲国产一区视频| 国产一区二区0| 欧美亚洲图片小说| 精品黑人一区二区三区久久| 综合网在线视频| 美女www一区二区| 91日韩精品一区| 精品乱码亚洲一区二区不卡| 亚洲美女精品一区| 激情综合五月婷婷| 在线观看www91| 国产日韩av一区二区| 日产国产高清一区二区三区 | 亚洲欧美日韩电影| 激情综合网激情| 欧洲一区在线电影| 日本一区二区三区dvd视频在线| 亚洲一卡二卡三卡四卡五卡| 丁香桃色午夜亚洲一区二区三区 | 51精品国自产在线| 综合网在线视频| 国产精品18久久久久久vr| 91精品国产色综合久久不卡蜜臀| 国产精品天美传媒沈樵| 麻豆国产精品视频| 欧美亚洲免费在线一区| 国产精品狼人久久影院观看方式| 青草av.久久免费一区| 91美女视频网站| 国产欧美日韩在线| 韩国av一区二区三区四区| 欧美精品乱人伦久久久久久| 综合久久国产九一剧情麻豆| 国产精品资源在线| 日韩欧美在线网站| 天堂va蜜桃一区二区三区| 色激情天天射综合网| 亚洲欧美综合另类在线卡通| 国产成人av电影在线| 久久综合久久鬼色中文字| 老汉av免费一区二区三区| 91精品国产一区二区三区| 亚洲高清一区二区三区| 一本大道久久a久久精品综合| 国产精品日韩精品欧美在线| 国产精品1024| 欧美激情一区在线| 国产传媒一区在线| 国产婷婷色一区二区三区| 精品一区二区av| 精品国产乱码久久久久久浪潮| 青青草原综合久久大伊人精品| 欧美日韩黄色影视| 亚洲成av人影院在线观看网| 欧美性视频一区二区三区| 一片黄亚洲嫩模| 欧美日韩一二区| 天堂久久久久va久久久久| 欧美一区二区三区免费视频 | 蜜桃视频免费观看一区| 日韩一区二区三区四区| 紧缚奴在线一区二区三区| 精品久久人人做人人爽| 国产乱国产乱300精品| 中文一区在线播放 | 91精品福利在线| 亚洲成a天堂v人片| 日韩午夜av一区| 国产精品白丝av| 亚洲人成小说网站色在线 | 日本欧美一区二区三区| 欧美xxxxxxxx| 国产成人精品aa毛片| 亚洲另类在线一区| 538在线一区二区精品国产| 精品中文字幕一区二区| 国产日韩欧美电影| 色婷婷久久久亚洲一区二区三区| 亚洲3atv精品一区二区三区| 日韩一区二区电影| 高清日韩电视剧大全免费| 一二三区精品福利视频| 欧美一区二区视频观看视频| 国产suv一区二区三区88区| 一区二区三区色| 久久尤物电影视频在线观看| 99国产精品久久久|