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

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

?? example_280xadcsoc.c

?? 基于TMS320F2812的數字電源的c源程序2
?? C
?? 第 1 頁 / 共 3 頁
字號:
   MAX_PWM=(Uint32)710000/U_SUM_PJ;
   if(MAX_PWM>2495)
   MAX_PWM=2495;
   MAX_PWM_adj=(((Uint32)MAX_PWM*MOTOR_ADJ)/9000)+100; 
   if(MAX_PWM_adj>2495)
   MAX_PWM_adj=2495;
   //--------------------------------------------
   TEMP_PWM=(MOTOR_ADJ>>7)+((MOTOR_ADJ>>8)*(MOTOR_ADJ>>8))+((MOTOR_ADJ>>9)*(MOTOR_ADJ>>9));

   if(TEMP_PWM>600)
   pwm_temp=600;
   else
   pwm_temp=TEMP_PWM;
   //-------
    //protect();
    run_start();
   //--計算輸入直流電壓--
   cal_dc_in_vol();
   //--過欠壓保護--
   if(PROTECT_FLAG_reg.bit.FAULT_flag==0)
   {
    if((U_SUM>430)||(U_SUM<200))
    {
    PROTECT_FLAG_reg.bit.FAULT_flag=1;
    GpioDataRegs.GPACLEAR.bit.GPIO25=1;
    }
    }
   else
   {
    if((U_SUM<430)&&(U_SUM>200))
    {
    PROTECT_FLAG_reg.bit.FAULT_flag=0;
    GpioDataRegs.GPASET.bit.GPIO25=1;  
    }  
    }
   //-----------------------------------------
   	if(MOTOR_ADJ<12)
   	{
    PROTECT_FLAG_reg.bit.stop_run_flag=1;
    PROTECT_FLAG_reg.bit.soft_run_flag=0;
    Soft_vol=50;    
    }
    else
    {
     if(PROTECT_FLAG_reg.bit.stop_run_flag==1)
     {
      PROTECT_FLAG_reg.bit.stop_run_flag=0;
      PROTECT_FLAG_reg.bit.soft_run_flag=1;
      Soft_vol=50;
      }
    }
    if(MOTOR_ADJ<35)
    MT_325=75;
    else
    MT_325=89;
   ///////////////////////////////////////////
    }
}


interrupt void  adc_isr(void)
{
Uint16 i,temp,temp_i,TEMP2;
if(ConversionCount==3)
  Voltage1[ConversionCount] = AdcRegs.ADCRESULT0 >>5;
else
  Voltage1[ConversionCount] = AdcRegs.ADCRESULT0 >>4;
  //Voltage2[ConversionCount] = AdcRegs.ADCRESULT1 >>4;
  //Voltage3[ConversionCount] = AdcRegs.ADCRESULT2 >>6;
  //Voltage4[ConversionCount] = AdcRegs.ADCRESULT3 >>4;
  
  I_SUM128+=AdcRegs.ADCRESULT1 >>4;  
  U_SUM128+=AdcRegs.ADCRESULT2 >>4;
  MOTOR_SUM128+=AdcRegs.ADCRESULT3 >>4;
  //Voltage5[ConversionCount]=AdcRegs.ADCRESULT3 >>4;
  //----------------------------------------------------------
     if(PROTECT_FLAG_reg.bit.run_start_flag==1)
     {
      EPwm1Regs.AQCSFRC.bit.CSFA =0x01;
     }
     else
     {
  if(ConversionCount==MT_325) 
  {
   if(MOTOR_ADJ<250)
   EPwm1Regs.AQCSFRC.bit.CSFA =0x01;
   }
   if(ConversionCount==0) 
   {
   if(MOTOR_ADJ<12)
    EPwm1Regs.AQCSFRC.bit.CSFA =0x01;
   else
    EPwm1Regs.AQCSFRC.bit.CSFA =0x00;
   }
   }
  //----------------------------------------------------------
   //if(ConversionCount ==127) 
  // If 40 conversions have been logged, start over
  if(ConversionCount == 127) 
  {
   S60_S90_QF();
     ConversionCount = 0;
    // EPwm1Regs.AQCSFRC.bit.CSFA =0x01;
    PROTECT_FLAG_reg.bit.SAMP_flag=1;
    MOTOR_SUM+=MOTOR_SUM128>>8;//
    MOTOR_SUM128=0;
    MOTOR_COUNT++;
    //--
    if(MOTOR_COUNT==15)
    {
    MOTOR_COUNT=0;
    if(MOTOR_SUM<8000)
    MOTOR_ADJ_s60s90=MOTOR_SUM>>4;
    else
    MOTOR_ADJ_s60s90=MOTOR_SUM/5;
	//---
	ADJ_count++;
	if(ADJ_count>127)
	ADJ_count=0;
	Voltage5[ADJ_count]=MOTOR_ADJ_s60s90;
    //--
    MOTOR_SUM=0;
    }
    //--
    U_SUM=U_SUM128/819;
    U_SUM128=0; 
    MAX_COUNT++;
    U_SUM_SUM+=U_SUM;
    if(MAX_COUNT>15)
    {
    U_SUM_PJ=U_SUM_SUM>>4;
    MAX_COUNT=0;
    U_SUM_SUM=0;
    }
    NOLOAD_CURRENT=(((Uint32)17*(Uint32)M_U)/5830)+5;//27*5830=157410
    if(NOLOAD_CURRENT>17)
    NOLOAD_CURRENT=17;
    temp_i=(I_SUM128/699);//I_SUM
    if(temp_i<NOLOAD_CURRENT)
    I_SUM=0;
    else
    I_SUM=temp_i-NOLOAD_CURRENT;
    I_SUM128=0;    
  }

  else
      ConversionCount++;
   if(ConversionCount==1)
   {
    temp=0;
       for(i=0;i<4;i++)
         {
          temp+=Voltage1[124+i];
           } 
       if(PROTECT_FLAG_reg.bit.A1_flag==1)//MC2
       {          
       TEMP2=temp>>2;
       if(TEMP2>11)
       Uint16Emf1=TEMP2-8;
       else
       Uint16Emf1=TEMP2; 
       }
       else//mc3
       {
       TEMP2=temp>>2;
       if(TEMP2>11)
       Uint16Emf1=TEMP2-10;
       else
       Uint16Emf1=TEMP2;
       } 
         //------------------------------
       if(MOTOR_ADJ<30)
       motor_ctrl_1();
       else if(MOTOR_ADJ<226)
       motor_ctrl_2();
      // else if(MOTOR_ADJ<700)
      // motor_ctrl_3(); 
      // else if(MOTOR_ADJ<1300)
      // motor_ctrl_4();             
       else
       motor_ctrl_9();
       
         //------------------------------
   }

   //----------------------------------------------------
   
   //----------------------------------------------------
  // if(ConversionCount == 40) 
  //      EPwm1Regs.AQCSFRC.bit.CSFA =0x00;
  // Reinitialize for next ADC sequence
  AdcRegs.ADCTRL2.bit.RST_SEQ1 = 1;         // Reset SEQ1
  AdcRegs.ADCST.bit.INT_SEQ1_CLR = 1;       // Clear INT SEQ1 bit
  PieCtrlRegs.PIEACK.all = PIEACK_GROUP1;   // Acknowledge interrupt to PIE
  
  return;
}
//---------------------------------------------------------------------------------

interrupt void epwm1_isr(void)
{
   // Update the CMPA and CMPB values
   //update_compare(&epwm1_info);
  // EPwm1Regs.CMPA.half.CMPA++;
  // EPwm1Regs.CMPB++;
   // Clear INT flag for this timer
  /*if(PwmCount<38) 
  {
   EPwm1Regs.AQCSFRC.bit.CSFA =0x01;
   }
   else
   EPwm1Regs.AQCSFRC.bit.CSFA =0x00; */
   if(PROTECT_FLAG_reg.bit.soft_run_flag==1)
   {
    if(Soft_vol<50)
    {
    Soft_vol++;
    EPwm1Regs.CMPA.half.CMPA=60+Soft_vol;
    }
    else
    {
    PROTECT_FLAG_reg.bit.soft_run_flag=0;
    Soft_vol=0;
    }
   }
   else
   {
   EPwm1Regs.CMPA.half.CMPA = EPWM1_CMPA;    // Set compare A value EPWM1_CMPA123,//
   }
   EPwm1Regs.CMPA.half.CMPAHR = (DutyFine << 8)+0x180;     // Left shift by 8 to write into MSB bits
   EPwm1Regs.ETCLR.bit.INT = 1;
   
   // Acknowledge this interrupt to receive more interrupts from group 3
   PieCtrlRegs.PIEACK.all = PIEACK_GROUP3;
}


interrupt void epwm2_isr(void)
{

   // Update the CMPA and CMPB values
   //update_compare(&epwm2_info);
  // EPwm2Regs.CMPA.half.CMPA++;
  // EPwm2Regs.CMPB++;
   // Clear INT flag for this timer
   EPwm2Regs.ETCLR.bit.INT = 1;
     //  ConversionCount = 0; 

     //       LoopCount++;
     //if(LoopCount>15)
     //       LoopCount=0;
            
   // Acknowledge this interrupt to receive more interrupts from group 3
   PieCtrlRegs.PIEACK.all = PIEACK_GROUP3;
}

/*interrupt void epwm3_isr(void)
{

   // Update the CMPA and CMPB values
   update_compare(&epwm3_info);
   // Clear INT flag for this timer
   EPwm3Regs.ETCLR.bit.INT = 1;
   // Acknowledge this interrupt to receive more interrupts from group 3
   PieCtrlRegs.PIEACK.all = PIEACK_GROUP3;
}*/

void InitEPwm1Example()
{

   // Setup TBCLK
   //EPwm1Regs.TBCTL.bit.CTRMODE = TB_COUNT_UP; // Count up
   EPwm1Regs.TBPRD = EPWM1_TIMER_TBPRD; //2000      // Set timer period
   EPwm1Regs.TBCTL.bit.PHSEN = TB_DISABLE;    // Disable phase loading
   EPwm1Regs.TBPHS.half.TBPHS = 0x0000;       // Phase is 0
   EPwm1Regs.TBCTR = 0x0000;                  // Clear counter
   //XZLEPwm1Regs.TBCTL.bit.HSPCLKDIV = TB_DIV2;   // Clock ratio to SYSCLKOUT
   //XZLEPwm1Regs.TBCTL.bit.CLKDIV = TB_DIV2;
   EPwm1Regs.TBCTL.bit.HSPCLKDIV = 0;   // Clock ratio to SYSCLKOUT
   EPwm1Regs.TBCTL.bit.CLKDIV = 0;

   // Setup shadow register load on ZERO
   EPwm1Regs.CMPCTL.bit.SHDWAMODE = CC_SHADOW;
   EPwm1Regs.CMPCTL.bit.SHDWBMODE = CC_SHADOW;
   EPwm1Regs.CMPCTL.bit.LOADAMODE = CC_CTR_ZERO;
   EPwm1Regs.CMPCTL.bit.LOADBMODE = CC_CTR_ZERO;   
   
   // Set Compare values
   EPwm1Regs.CMPA.half.CMPA = EPWM1_MIN_CMPA;    // Set compare A value EPWM1_CMPA
   EPwm1Regs.CMPB = EPWM1_MIN_CMPB;              // Set Compare B value

   // Set actions
   EPwm1Regs.AQCTLA.bit.ZRO =AQ_SET;           // Set PWM1A on Zero
   EPwm1Regs.AQCTLA.bit.CAU = AQ_CLEAR;             // Clear PWM1A on event A, up count

   EPwm1Regs.AQCTLB.bit.ZRO = AQ_CLEAR;            // Set PWM1B on Zero
   EPwm1Regs.AQCTLB.bit.CBU = AQ_SET;          // Clear PWM1B on event B, up count
   
   // Interrupt where we will change the Compare Values
   EPwm1Regs.ETSEL.bit.INTSEL = ET_CTR_ZERO;     // Select INT on Zero event
   EPwm1Regs.ETSEL.bit.INTEN = 1;                // Enable INT
   EPwm1Regs.ETPS.bit.INTPRD = ET_3RD;           // Generate INT on 3rd event   

   // Information this example uses to keep track
   // of the direction the CMPA/CMPB values are 
   // moving, the min and max allowed values and
   // a pointer to the correct ePWM registers
   epwm1_info.EPwm_CMPA_Direction = EPWM_CMP_UP; // Start by increasing CMPA & CMPB 
   epwm1_info.EPwm_CMPB_Direction = EPWM_CMP_UP;
   epwm1_info.EPwmTimerIntCount = 0;             // Zero the interrupt counter
   epwm1_info.EPwmRegHandle = &EPwm1Regs;        // Set the pointer to the ePWM module
   epwm1_info.EPwmMaxCMPA = EPWM1_MAX_CMPA;      // Setup min/max CMPA/CMPB values
   epwm1_info.EPwmMinCMPA = EPWM1_MIN_CMPA;       
   epwm1_info.EPwmMaxCMPB = EPWM1_MAX_CMPB;    
   epwm1_info.EPwmMinCMPB = EPWM1_MIN_CMPB;     
   	EALLOW;		
	EPwm2Regs.HRCNFG.all = 0x0;	
	EPwm2Regs.HRCNFG.bit.EDGMODE = HR_FEP;                //MEP control on Rising edge
	EPwm2Regs.HRCNFG.bit.CTLMODE = HR_CMP;
	EPwm2Regs.HRCNFG.bit.HRLOAD  = HR_CTR_ZERO;
	
	EDIS;  

}
/*
*/
void InitEPwm2Example()
{

   // Setup TBCLK
  // EPwm2Regs.TBCTL.bit.CTRMODE = TB_COUNT_UP; // Count up
   EPwm2Regs.TBPRD = EPWM2_TIMER_TBPRD; //2000      // Set timer period
   EPwm2Regs.TBCTL.bit.PHSEN = TB_DISABLE;    // Disable phase loading
   EPwm2Regs.TBPHS.half.TBPHS = 0x0000;       // Phase is 0
   EPwm2Regs.TBCTR = 0x0000;                  // Clear counter
   //XZLEPwm2Regs.TBCTL.bit.HSPCLKDIV = TB_DIV2;   // Clock ratio to SYSCLKOUT
   //XZLEPwm2Regs.TBCTL.bit.CLKDIV = TB_DIV2;
   EPwm2Regs.TBCTL.bit.HSPCLKDIV = 4;   // Clock ratio to SYSCLKOUT
   EPwm2Regs.TBCTL.bit.CLKDIV = 4;

   // Setup shadow register load on ZERO
   EPwm2Regs.CMPCTL.bit.SHDWAMODE = CC_SHADOW;
   EPwm2Regs.CMPCTL.bit.SHDWBMODE = CC_SHADOW;
   EPwm2Regs.CMPCTL.bit.LOADAMODE = CC_CTR_ZERO;
   EPwm2Regs.CMPCTL.bit.LOADBMODE = CC_CTR_ZERO;   

   // Set Compare values
   EPwm2Regs.CMPA.half.CMPA = EPWM2_MIN_CMPA;    // Set compare A value
   EPwm2Regs.CMPB = EPWM2_MIN_CMPB;              // Set Compare B value

   // Set actions
   EPwm2Regs.AQCTLA.bit.ZRO = AQ_CLEAR;            // Set PWM1A on Zero
   EPwm2Regs.AQCTLA.bit.CAU = AQ_SET;          // Clear PWM1A on event A, up count

   EPwm2Regs.AQCTLB.bit.ZRO = AQ_CLEAR;            // Set PWM1B on Zero
   EPwm2Regs.AQCTLB.bit.CBU = AQ_SET;          // Clear PWM1B on event B, up count
   
   // Interrupt where we will change the Compare Values
   EPwm2Regs.ETSEL.bit.INTSEL = ET_CTR_ZERO;     // Select INT on Zero event
   EPwm2Regs.ETSEL.bit.INTEN = 1;                // Enable INT
   EPwm2Regs.ETPS.bit.INTPRD = ET_3RD;           // Generate INT on 3rd event   

   // Information this example uses to keep track
   // of the direction the CMPA/CMPB values are 
   // moving, the min and max allowed values and
   // a pointer to the correct ePWM registers
   epwm2_info.EPwm_CMPA_Direction = EPWM_CMP_UP; // Start by increasing CMPA & CMPB 
   epwm2_info.EPwm_CMPB_Direction = EPWM_CMP_UP;
   epwm2_info.EPwmTimerIntCount = 0;             // Zero the interrupt counter
   epwm2_info.EPwmRegHandle = &EPwm2Regs;        // Set the pointer to the ePWM module

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91精品婷婷国产综合久久性色| 6080午夜不卡| 日本大胆欧美人术艺术动态| 欧美国产视频在线| 精品视频在线视频| 国产成人免费av在线| 午夜av区久久| 亚洲欧美日韩综合aⅴ视频| 4hu四虎永久在线影院成人| 99久久精品国产麻豆演员表| 久久国内精品视频| 一区二区三区在线视频免费 | 成人禁用看黄a在线| 丝袜美腿一区二区三区| 亚洲免费在线看| 国产欧美一区二区在线观看| 欧美一二区视频| 欧美日韩一二三区| 色诱视频网站一区| 波多野结衣的一区二区三区| 国产精品自拍av| 免费观看一级欧美片| 婷婷丁香久久五月婷婷| 成人免费小视频| 国产精品久久久久久亚洲毛片 | 久久日韩粉嫩一区二区三区| 欧美蜜桃一区二区三区| 欧美亚洲综合色| 91在线精品一区二区三区| 国产麻豆成人精品| 国产在线精品一区二区三区不卡| 日韩精品福利网| 午夜精品福利在线| 天天色综合天天| 天堂资源在线中文精品| 午夜精品视频在线观看| 香蕉加勒比综合久久| 一区二区三区影院| 一区二区三区欧美久久| 亚洲激情自拍偷拍| 亚洲特黄一级片| 亚洲视频 欧洲视频| 亚洲视频一区二区免费在线观看| 国产精品福利在线播放| 国产精品免费观看视频| 国产精品久久看| 国产精品久久久久一区二区三区共 | 国产精品成人一区二区三区夜夜夜| 久久精品夜色噜噜亚洲a∨| 久久九九国产精品| 日本一区二区久久| 亚洲另类色综合网站| 一区二区三区四区av| 午夜电影网一区| 国产在线精品一区二区三区不卡| 国产麻豆成人传媒免费观看| 成人av片在线观看| 在线免费不卡电影| 91精品国产综合久久蜜臀| 精品女同一区二区| 中文字幕av一区二区三区免费看| 中文一区二区在线观看| 一区二区三区欧美视频| 日韩成人一区二区三区在线观看| 日本视频一区二区| 国产精品一区二区免费不卡 | 日韩区在线观看| 2020日本不卡一区二区视频| 国产喷白浆一区二区三区| 自拍偷拍亚洲欧美日韩| 亚洲成a人片在线观看中文| 奇米色一区二区三区四区| 国产剧情一区二区三区| 91激情在线视频| 日韩欧美一区二区不卡| 国产精品久久久久影院| 亚洲18色成人| 国产高清亚洲一区| 91久久免费观看| 精品国产亚洲在线| 一区二区三区四区在线播放| 久久丁香综合五月国产三级网站| 国产a级毛片一区| 欧美日韩和欧美的一区二区| 2024国产精品| 亚洲国产精品自拍| 国产福利一区二区三区视频| 欧美亚洲国产一区二区三区va| 欧美videos中文字幕| 成人免费在线播放视频| 久久国产精品一区二区| 91丨九色丨国产丨porny| 欧美成人欧美edvon| 一级特黄大欧美久久久| 国产成人欧美日韩在线电影| 欧美日韩一区国产| 国产精品免费aⅴ片在线观看| 天天免费综合色| 91麻豆国产在线观看| 久久婷婷综合激情| 午夜免费欧美电影| 99综合影院在线| 久久―日本道色综合久久| 天天操天天干天天综合网| 色哟哟日韩精品| 国产蜜臀97一区二区三区| 蜜臀av性久久久久蜜臀aⅴ流畅| 97精品视频在线观看自产线路二| 欧美成人一区二区| 日韩精品电影在线观看| 91美女在线观看| 国产精品短视频| 风间由美一区二区三区在线观看 | 国产精品美女久久久久久久久久久 | 久久99精品视频| 欧美日韩一区二区三区视频 | 免费久久99精品国产| 色综合亚洲欧洲| 中文字幕一区二区三区在线观看| 狠狠色丁香九九婷婷综合五月| 欧美日韩美女一区二区| 亚洲卡通欧美制服中文| 成人v精品蜜桃久久一区| 国产亚洲一本大道中文在线| 久久电影网电视剧免费观看| 日韩三级视频在线看| 日韩在线卡一卡二| 欧美日韩国产首页在线观看| 一区2区3区在线看| 91九色02白丝porn| 亚洲自拍偷拍av| 欧美视频在线不卡| 亚洲国产综合视频在线观看| 在线视频国产一区| 夜夜揉揉日日人人青青一国产精品| 91丨国产丨九色丨pron| 亚洲视频你懂的| 在线一区二区观看| 亚洲午夜久久久| 在线成人av影院| 青青青爽久久午夜综合久久午夜| 欧美一区二区三区视频在线| 蜜臀av在线播放一区二区三区| 欧美精品黑人性xxxx| 日韩av一区二区三区| 日韩精品专区在线影院重磅| 国产最新精品免费| 国产欧美精品一区二区三区四区| 国产成人一级电影| 国产精品高潮久久久久无| 91亚洲精品久久久蜜桃网站| 亚洲精品免费视频| 欧美日韩高清一区二区不卡 | 国内成人精品2018免费看| 国产日韩成人精品| 一本到不卡精品视频在线观看| 亚洲色图一区二区三区| 欧美三级中文字幕在线观看| 美女视频黄免费的久久 | 国产欧美日韩三区| 99久久国产综合精品色伊| 伊人婷婷欧美激情| 91.xcao| 国产一区二区三区四区在线观看| 国产欧美精品日韩区二区麻豆天美| 99精品视频在线观看| 亚洲国产美国国产综合一区二区| 欧美一区二区在线不卡| 狠狠色伊人亚洲综合成人| 国产精品乱码一区二三区小蝌蚪| 91老司机福利 在线| 日本视频免费一区| 国产精品欧美一区喷水| 欧美三级在线看| 国内精品久久久久影院薰衣草| 亚洲欧洲日产国产综合网| 欧美酷刑日本凌虐凌虐| 国产成人在线视频网址| 亚洲一区二区三区中文字幕在线| 欧美一区二区三区人| 丰满岳乱妇一区二区三区| 午夜精品福利视频网站| 中文字幕第一区| 6080yy午夜一二三区久久| 成人免费av资源| 秋霞成人午夜伦在线观看| 国产精品久久久久三级| 欧美大度的电影原声| 色诱视频网站一区| 国产伦精品一区二区三区免费| 亚洲与欧洲av电影| 26uuu色噜噜精品一区二区| 欧美在线一区二区三区| 国产福利一区二区| 日韩国产高清影视| 亚洲美女在线一区| 国产午夜精品一区二区| 欧美一区二区黄色| 在线观看视频欧美| 国产成人精品一区二|