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

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

?? bldcmotor.c

?? 附件程序是我用DSP2812開發的無刷直流電機控制程序
?? C
字號:
/////////////////////////// 無刷直流電動機 24V seakeke@163.com 和我聯系//////////////////////////////////////////

#include "DSP281x_Device.h"     // DSP281x Headerfile Include File
#include "DSPMotor_Head.h"

#include "IQmathLib.h"
#include "BLDCMotor.h"
#include "parameter.h"

#include <math.h>
///// 函數聲明 ////////////////////////////////////////////////////////////
interrupt void MainISR(void);

///// 全局變量聲明
float32 SpeedRef = 0.20;           // Speed reference (pu)
float32 T = 0.001/ISR_FREQUENCY;   // Samping period (sec), see parameter.h

Uint32 VirtualTimer = 0;
Uint16 ILoopFlag = FALSE;
Uint16 SpeedLoopFlag = FALSE;
int16 DFuncDesired = 0x1A00;      // Desired duty cycle (Q15)=0.2

_iq CurrentSet = _IQ(0.3);

Uint16 IsrTicker = 0;
Uint16 BackTicker = 0;

int16 DlogCh1 = 0;
int16 DlogCh2 = 0;
int16 DlogCh3 = 0;
int16 DlogCh4 = 0;

// Instance PID regulator to regulate the DC-bus current and speed
PIDREG3 pid1_idc = PIDREG3_DEFAULTS;
PIDREG3 pid1_spd = PIDREG3_DEFAULTS;

// Instance a PWM driver instance
PWMGEN pwm1 = PWMGEN_DEFAULTS;

// Create an instance of the ADC driver
ADCVALS adc1 = ADCVALS_DEFAULTS;

// Instance a Hall effect driver
HALL3 hall1 = HALL3_DEFAULTS;

// Instance a ramp controller to smoothly ramp the frequency
RMPCNTL rc1 = RMPCNTL_DEFAULTS;

// Instance a RAMP2 Module
RMP2 rmp2 = RMP2_DEFAULTS;

// Instance a MOD6 Module
MOD6CNT mod1 = MOD6CNT_DEFAULTS;

// Instance a SPEED_PR Module
SPEED_MEAS_CAP speed1 = SPEED_MEAS_CAP_DEFAULTS;

// Create an instance of DATALOG Module
DLOG_4CH dlog = DLOG_4CH_DEFAULTS; 

////////////////////////// 主程序 //////////////////////////////////////////////

void main(void)
{

// Initialize System Control registers, PLL, WatchDog, Clocks to default state:
        // This function is found in the DSP281x_SysCtrl.c file.
	InitSysCtrl();

// HISPCP prescale register settings, normally it will be set to default values
    EALLOW;   // This is needed to write to EALLOW protected registers
    SysCtrlRegs.HISPCP.all = 0x0000;     // SYSCLKOUT/1 
    EDIS;   // This is needed to disable write to EALLOW protected registers 

// Disable and clear all CPU interrupts:
	DINT;
	IER = 0x0000;
	IFR = 0x0000;

// Initialize Pie Control Registers To Default State:
        // This function is found in the DSP281x_PieCtrl.c file.
	InitPieCtrl();

// Initialize the PIE Vector Table To a Known State:
        // This function is found in DSP281x_PieVect.c.
	// This function populates the PIE vector table with pointers
        // to the shell ISR functions found in DSP281x_DefaultIsr.c.
	InitPieVectTable();	
	
// User specific functions, Reassign vectors (optional), Enable Interrupts:
	
// Initialize EVA Timer 1/2:
    // Setup Timer 1/2 Registers (EV A)
    EvaRegs.GPTCONA.all = 0;

    // Set the Period for the GP timer 2
    EvaRegs.T2PR = SYSTEM_FREQUENCY*1000000*T;  // Perscaler X1 (T2), ISR period = T x 1
    
    // Clear the counter/compare Regs for GP timer 2
    EvaRegs.T2CNT = 0x0000;
    EvaRegs.T2CMPR = 0x0000;     

// Enable Period interrupt bits for GP timer 2
    EvaRegs.EVAIMRB.bit.T2PINT = 1;
    EvaRegs.EVAIFRB.bit.T2PINT = 1;

    // Count up, x1, internal clk, disable compare, use own period
    EvaRegs.T2CON.all = 0x1040;

// Reassign ISRs. 
        // Reassign the PIE vector for T2PINT to point to a different 
        // ISR then the shell routine found in DSP281x_DefaultIsr.c.
        // This is done if the user does not want to use the shell ISR routine
        // but instead wants to use their own ISR.
	
	EALLOW;	// This is needed to write to EALLOW protected registers
	PieVectTable.T2PINT = &MainISR;
	EDIS;   // This is needed to disable write to EALLOW protected registers

// Enable PIE group 3 interrupt 1 for T2PINT
    PieCtrlRegs.PIEIER3.all = M_INT1;

// Enable CPU INT3 for T2PINT:
	IER |= M_INT3;

// Initialize PWM module
    pwm1.PeriodMax = (SYSTEM_FREQUENCY/PWM_FREQUENCY)*1000;  // Asymmetric PWM
    pwm1.DutyFunc = DFuncDesired;                            // DutyFunc = Q15  
    pwm1.init(&pwm1);
    
// Initialize DATALOG module        
    dlog.iptr1 = &DlogCh1;  
    dlog.iptr2 = &DlogCh2;
    dlog.iptr3 = &DlogCh3;
    dlog.iptr4 = &DlogCh4;
    dlog.trig_value = 0x01;
    dlog.size = 0x400;
    dlog.prescalar = 1;
    dlog.init(&dlog);

// Initialize ADC module
    adc1.ChSelect = 0x6543;   // for DMC1500 and eZdsp2812/eZdsp2808 boards
	adc1.init(&adc1);

// Initialize the SPEED_PR module (150 MHz, N = 1 event period/rev)
 	speed1.InputSelect = 0;
 	speed1.BaseRpm = 120*(BASE_FREQ/P);
 	speed1.SpeedScaler = (Uint32)(ISR_FREQUENCY/(1*BASE_FREQ*0.001));

// Initialize RMPCNTL module
    rc1.RampDelayMax = 20;
    rc1.RampLowLimit = _IQ(0);
    rc1.RampHighLimit = _IQ(1);

// Initialize Hall module   
    hall1.DebounceAmount = 5;
    hall1.Revolutions = -10;
    hall1.init(&hall1);

// Initialize RMP2 module
	rmp2.Out = (int32)DFuncDesired;
	rmp2.Ramp2Delay = 0x00000050;
    rmp2.Ramp2Max = 0x00007FFF;
    rmp2.Ramp2Min = 0x0000000F;

// Initialize the PID_REG3 module for dc-bus current
    pid1_idc.Kp = _IQ(1);                  
	pid1_idc.Ki = _IQ(T/0.003);			
	pid1_idc.Kd = _IQ(0/T);					
 	pid1_idc.Kc = _IQ(0.2);
    pid1_idc.OutMax = _IQ(0.99);
    pid1_idc.OutMin = _IQ(0); 

// Initialize the PID_REG3 module for speed
    pid1_spd.Kp = _IQ(1);
	pid1_spd.Ki = _IQ(T/0.1);
	pid1_spd.Kd = _IQ(0/T);
 	pid1_spd.Kc = _IQ(0.2);
    pid1_spd.OutMax = _IQ(0.99);
    pid1_spd.OutMin = _IQ(0); 

// Enable global Interrupts and higher priority real-time debug events:
	EINT;   // Enable Global interrupt INTM
	ERTM;	// Enable Global realtime interrupt DBGM

// IDLE loop. Just sit and loop forever:	
	for(;;) BackTicker++;

} 	

interrupt void MainISR(void)
{

// Verifying the ISR
     IsrTicker++;

// ------------------------------------------------------------------------------
//    Call the ADC04U_DRV read function.
// ------------------------------------------------------------------------------
	  adc1.read(&adc1);

// ------------------------------------------------------------------------------
//    Connect inputs of the RMP module and call the Ramp control
//    calculation function.
// ------------------------------------------------------------------------------
      rc1.TargetValue = _IQ(SpeedRef);
      rc1.calc(&rc1);

// ------------------------------------------------------------------------------
//    Connect inputs of the HALL module and call the Hall sensor
//    read function.
// ------------------------------------------------------------------------------
      hall1.HallMapPointer = (int16)mod1.Counter; 
      hall1.read(&hall1);

// ------------------------------------------------------------------------------
//    Connect inputs of the MOD6 module and call the Modulo 6 counter
//    calculation function.
// ------------------------------------------------------------------------------
      mod1.TrigInput =(int32)hall1.CmtnTrigHall;
      mod1.Counter = (int32)hall1.HallMapPointer; 
      mod1.calc(&mod1);

// ------------------------------------------------------------------------------
//    Connect inputs of the RMP2 module and call the Ramp control 2
//    calculation function.
// ------------------------------------------------------------------------------
      rmp2.DesiredInput = (int32)DFuncDesired;
      rmp2.calc(&rmp2);

// ------------------------------------------------------------------------------
//    Connect inputs of the PID_REG3 module and call the PID speed controller
//    calculation function.
// ------------------------------------------------------------------------------  
      pid1_spd.Ref = rc1.SetpointValue;
      pid1_spd.Fdb = speed1.Speed;
      pid1_spd.calc(&pid1_spd);

// ------------------------------------------------------------------------------
//    Set the speed closed loop flag once the speed is built up to a desired value. 
// ------------------------------------------------------------------------------
      if (rc1.EqualFlag == 0x7FFFFFFF)  {
         SpeedLoopFlag = TRUE; 
         rc1.RampDelayMax = 300;  
      }

// ------------------------------------------------------------------------------
//    Connect inputs of the PWM_DRV module and call the PWM signal generation
//    update function.
// ------------------------------------------------------------------------------
   // Switch from fixed duty-cycle or controlled Speed duty-cycle by SpeedLoopFlag variable
      if (SpeedLoopFlag == FALSE)
         pwm1.DutyFunc = (int16)rmp2.Out;           // fixed duty-cycle
      else 
         pwm1.DutyFunc = (int16)_IQtoIQ15(pid1_spd.Out);   // controlled Speed duty-cycle

      pwm1.CmtnPointer = (int16)mod1.Counter;
      pwm1.update(&pwm1);

// ------------------------------------------------------------------------------
//    Connect inputs of the SPEED_PR module and call the speed calculation 
//    function.
// ------------------------------------------------------------------------------  
      if ((mod1.Counter == 5)&(hall1.CmtnTrigHall == 0x7FFF)) {
         speed1.TimeStamp = VirtualTimer;
         speed1.calc(speed1);
      }

// ------------------------------------------------------------------------------
//    Connect inputs of the DATALOG module 
// ------------------------------------------------------------------------------
      DlogCh1 = (int16)mod1.Counter; 
      DlogCh2 = (int16)mod1.TrigInput;
      DlogCh3 = (int16)_IQtoIQ15(pid1_spd.Ref);
      DlogCh4 = (int16)_IQtoIQ15(pid1_spd.Fdb);

// ------------------------------------------------------------------------------
//    Increase virtual timer and force 15 bit wrap around
// ------------------------------------------------------------------------------
	VirtualTimer++;
	VirtualTimer &= 0x00007FFF;

// ------------------------------------------------------------------------------
//    Call the DATALOG update function.
// ------------------------------------------------------------------------------
    dlog.update(&dlog);

// Enable more interrupts from this timer
	EvaRegs.EVAIMRB.bit.T2PINT = 1;
	
// Note: To be safe, use a mask value to write to the entire
	// EVAIFRB 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.EVAIFRB.all = BIT0;
	
// Acknowledge interrupt to recieve more interrupts from PIE group 3
	PieCtrlRegs.PIEACK.all |= PIEACK_GROUP3;
}


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

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
在线免费观看成人短视频| a亚洲天堂av| 中文字幕一区在线观看视频| 欧美无乱码久久久免费午夜一区 | 91捆绑美女网站| 亚洲激情欧美激情| 国产喷白浆一区二区三区| 91麻豆精品国产91久久久使用方法| 亚洲男同1069视频| 欧美精品一区二区三区蜜桃 | 亚洲老妇xxxxxx| 欧美va在线播放| 在线一区二区三区做爰视频网站| 国产精品综合二区| 日本欧美久久久久免费播放网| 中文字幕一区二区三区不卡| 精品国产伦一区二区三区观看体验 | 久久综合丝袜日本网| 欧美色涩在线第一页| 成人免费毛片app| 激情五月播播久久久精品| 亚洲国产精品久久久久秋霞影院| 中文天堂在线一区| 国产亚洲一本大道中文在线| 精品少妇一区二区三区免费观看 | 精品国产乱码久久久久久闺蜜| 欧美日韩在线电影| 91网址在线看| 国产v综合v亚洲欧| 国产一区二区三区在线观看免费 | 91尤物视频在线观看| 国产一区二区日韩精品| 美女www一区二区| 日韩不卡一区二区| 日本不卡视频在线| 日本午夜精品视频在线观看| 偷拍一区二区三区| 天堂蜜桃一区二区三区| 一区二区高清视频在线观看| 亚洲欧洲日产国码二区| 中文字幕在线不卡一区二区三区| 国产精品女同互慰在线看| 日本一区二区三区视频视频| 久久精品一区四区| 亚洲精品在线免费观看视频| 精品精品欲导航| 亚洲精品一区二区三区影院| 精品国产乱码久久久久久老虎| 精品久久一区二区| 国产亚洲一区二区三区在线观看| 久久精品一区四区| 国产精品萝li| 亚洲黄色小说网站| 亚洲午夜久久久久久久久电影网| 亚洲国产日韩a在线播放| 婷婷久久综合九色综合绿巨人| 日韩成人精品视频| 激情欧美日韩一区二区| 国产精品18久久久久久久久| 国产成人在线免费观看| 成人sese在线| 欧美中文字幕一区| 日韩一区二区高清| 欧美激情一区二区三区不卡 | 一区二区理论电影在线观看| 亚洲精品视频自拍| 日韩精品亚洲一区二区三区免费| 久久综合综合久久综合| 高清不卡一区二区| 91国偷自产一区二区开放时间| 91精品国产91久久久久久最新毛片 | 久久激五月天综合精品| 国产成a人亚洲| 欧美午夜理伦三级在线观看| 日韩欧美亚洲另类制服综合在线| 中文字幕精品在线不卡| 亚洲综合一区二区三区| 黑人精品欧美一区二区蜜桃| 91在线免费看| 欧美一区二区黄| 国产精品看片你懂得| 视频一区中文字幕| 成人开心网精品视频| 欧美一区二区三区视频在线| 欧美经典三级视频一区二区三区| 综合激情成人伊人| 久久99最新地址| 色妞www精品视频| 欧美va在线播放| 亚洲自拍偷拍网站| 丁香啪啪综合成人亚洲小说| 欧美久久婷婷综合色| 国产精品每日更新| 美女网站色91| 欧美午夜电影一区| 国产精品福利在线播放| 男人的天堂亚洲一区| 色婷婷久久久综合中文字幕| 精品国产伦理网| 亚洲第一久久影院| 91日韩在线专区| 久久这里只精品最新地址| 亚洲影院理伦片| 99久久综合狠狠综合久久| 欧美成人video| 亚洲一区自拍偷拍| 99九九99九九九视频精品| 精品久久五月天| 日韩有码一区二区三区| 欧美综合一区二区三区| 国产精品三级视频| 狠狠色丁香婷婷综合| 欧美精品日韩一本| 亚洲综合一区二区| 色偷偷一区二区三区| 日本一区免费视频| 国产一区二区三区免费在线观看 | 欧美色图第一页| 最近日韩中文字幕| jlzzjlzz亚洲日本少妇| 欧美精品一区二区三区一线天视频| 亚洲午夜日本在线观看| 99久久久精品| 国产精品婷婷午夜在线观看| 黄色资源网久久资源365| 欧美一区二区三区不卡| 亚洲成av人片在线观看| 色婷婷久久久综合中文字幕| 国产精品成人午夜| 国产乱人伦偷精品视频免下载| 亚洲国产成人tv| 欧美一区二区啪啪| 国产午夜精品一区二区三区嫩草 | 99久久久无码国产精品| 国产精品三级在线观看| 大胆亚洲人体视频| 国产精品乱码一区二区三区软件| 国产乱人伦偷精品视频不卡| 久久久久久毛片| 国产在线不卡一区| 国产日韩精品久久久| 国产最新精品精品你懂的| 久久综合九色综合欧美就去吻 | 久久99精品久久久久久| 欧美一区二区二区| 毛片av一区二区| 久久男人中文字幕资源站| 韩国精品主播一区二区在线观看| 精品国产一区二区三区忘忧草| 激情综合亚洲精品| 国产精品美日韩| 日本韩国精品在线| 日日嗨av一区二区三区四区| 日韩一区二区免费视频| 国产精品资源站在线| 国产精品久久久久影院老司| 色婷婷综合久色| 五月天欧美精品| 精品国产sm最大网站免费看| 国产成人免费视频一区| 亚洲色欲色欲www在线观看| 欧洲一区在线电影| 免费观看在线色综合| 国产三级三级三级精品8ⅰ区| 成人晚上爱看视频| 亚洲午夜在线电影| 久久一区二区三区四区| av一区二区不卡| 日本不卡123| 国产精品久久久久一区二区三区共 | 亚洲激情第一区| 日韩欧美中文字幕精品| 成人性生交大合| 亚洲国产精品综合小说图片区| 日韩欧美一二区| 成人成人成人在线视频| 午夜在线电影亚洲一区| 精品处破学生在线二十三| av亚洲精华国产精华精| 日本午夜精品视频在线观看| 国产日韩欧美综合在线| 欧美三区免费完整视频在线观看| 久久精工是国产品牌吗| 亚洲蜜臀av乱码久久精品| 欧美电视剧在线看免费| 99re成人在线| 蜜桃av噜噜一区| 亚洲人吸女人奶水| 337p粉嫩大胆噜噜噜噜噜91av| 99riav久久精品riav| 久久国产乱子精品免费女| 亚洲综合网站在线观看| 久久久www成人免费无遮挡大片| 色婷婷久久久久swag精品| 国产尤物一区二区在线| 亚洲第一搞黄网站| 国产精品大尺度| 国产日韩影视精品| 日韩情涩欧美日韩视频| 欧美在线999|