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

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

?? 50ba9a335c64001d17b19fccf218e59b

?? 這是我畢業(yè)設(shè)計(jì)做的一個(gè)SVPWM同步永磁交流電機(jī)的控制系統(tǒng)
??
字號(hào):
/*This file has been prepared for Doxygen automatic documentation generation.*/

#include "header/includes.h"
#include "altera_avalon_uart.h"

alt_u8 led = 0x2;
alt_u8 dir = 0;

void led_flash(void)
{
    if (led & 0x81) 
    {
      dir = (dir ^ 0x1);
    }

    if (dir)
    {
      led = led >> 1;
    }
    else
    {
      led = led << 1;
    }
    IOWR_ALTERA_AVALON_PIO_DATA(LED_BASE, led);
}
/********************************************************************
                         PID計(jì)算相關(guān)參數(shù)定義
*********************************************************************/
#define PID_PERIOD 8000
//#define PID_PERIOD 8000
#define HOERF 0
#define HOERM 1
#define HOERL 2

volatile long counter=0;   //編碼器的計(jì)數(shù)器
uchar go_en=0;    //使能走
//int clk_cnt=0;   //輸出脈沖計(jì)數(shù)器
volatile long locate = 0; //位置信息,調(diào)節(jié)用
volatile long Initposition = 0;  //初始化后的位置

volatile int  vd = -30,vq = 30;
volatile int Speed=0;    //速度參數(shù)
struct PID_DATA piddata;

alt_16 timeren;
alt_16 timercnt;
alt_16 timeren10;


/********************************************************************
                            電機(jī)控制和定時(shí)中斷函數(shù)
*********************************************************************/
long get_addr(void)
{
    int addr,circle;
    addr = IORD_ALTERA_AVALON_PIO_DATA(ABADDR_BASE);
    circle = IORD_ALTERA_AVALON_PIO_DATA(CIRCLES_BASE);
    counter = (circle - 0x800)*1500L + addr;
    return counter;
}

void Mspeed(int spd) //調(diào)速
{
    //為了不超調(diào),將vd和vq的值都限制在-600~600之間。
    //spd = -spd;
    if(spd >= 0)
    {
        if(spd > 600)
            spd = 600;
        vd = -spd*3/2;
        vq = spd;
    }
    else
    {
        if(spd < -600)
            spd = -600;
        vd = -spd*6/5;
        vq = spd;
    }

    IOWR_ALTERA_AVALON_PIO_DATA(VD_BASE, vd);
    IOWR_ALTERA_AVALON_PIO_DATA(VQ_BASE, vq);
}

void timer_0_IRQ(void *context, alt_u32 id)
{
    //alt_putstr("Hello from Nios II!\n");
    
    static long e[2];
    long deta;
    char limit_tmp;
    //IOWR_ALTERA_AVALON_PIO_DATA(LED_BASE, 1);
    IOWR_ALTERA_AVALON_TIMER_STATUS( TIMER_0_BASE,0 );
    timeren = 1;
    timercnt++;

    //get_addr();
    deta = get_addr() - locate;
    /*
    //if(temp >= -1 && temp <= 1) pid_Reset_Integrator(&piddata);
    //if(temp == 0) pid_Reset_Integrator(&piddata);
    //disp(temp,8);
    e[1] = deta - e[0];
    e[0] = deta;
    fuzzy_step(e);
    pid_factor(crisp_scale[0],crisp_scale[1], crisp_scale[2], &piddata);
    */
    //Speed = pid_Controller(locate,counter,&piddata);
    //pid_factor(100, 50, 10, &piddata);
    
    //deta = get_addr() - locate;

    Speed = pid_Controller(locate,counter,&piddata);
    
    if(deta >= -1 && deta <= 1)
    //if(deta == 0)
    {
        //if(deta == 0)
            pid_Reset_Integrator(&piddata); 
        Speed = 0;
    }
    //else
    {
        
    }
    
    limit_tmp = IORD_ALTERA_AVALON_PIO_DATA(LIMIT_BASE);
    if(limit_tmp & (1<<HOERL))  //最后的霍爾元件報(bào)警,速度只能為負(fù)
    {
        if(Speed > 0)
        {
            Mspeed(0);
            Speed = 0;
        }
        else
            Mspeed(Speed);
    }
    else if(limit_tmp & ((1<<HOERM)|(1<<HOERF)))
    {
        if(Speed < 0)
        {
            Mspeed(0);
            Speed = 0;
        }
        else
            Mspeed(Speed);
    }
    else
        Mspeed(Speed);
    
    if(timercnt == 100000000/PID_PERIOD)
    {
        timercnt = 0;
        timeren10 = 1;
    }
    //IOWR_ALTERA_AVALON_PIO_DATA(LED_BASE, 0);
}
/********************************************************************
                               步進(jìn)電機(jī)控制函數(shù)
*********************************************************************/
alt_16 Stlocation;
void Stepper(void)
{
    char i;

    alt_16 st_limit, st_position;
    st_limit = IORD_ALTERA_AVALON_PIO_DATA(STLIMIT_BASE);
    if(st_limit)
    {
        st_position = IORD_ALTERA_AVALON_PIO_DATA(STPOSITION_BASE);
        if(st_limit & 0x01)  //底下開關(guān)關(guān)閉,限制往下走
        {
            if(Stlocation > st_position)
            {
                IOWR_ALTERA_AVALON_PIO_DATA(STSTOP_BASE, 1);
                IOWR_ALTERA_AVALON_PIO_DATA(STLOCATE_BASE, Stlocation);
                IOWR_ALTERA_AVALON_PIO_DATA(STLE_BASE, 0);
                for(i=0;i<4;i++)
                {
                    IOWR_ALTERA_AVALON_PIO_DATA(STLE_BASE, 0);
                    IOWR_ALTERA_AVALON_PIO_DATA(STLE_BASE, 0);
                    IOWR_ALTERA_AVALON_PIO_DATA(STLE_BASE, 1);
                    IOWR_ALTERA_AVALON_PIO_DATA(STLE_BASE, 1);
                }
            }
        }
        else if(st_limit & 0x02)//頂部開關(guān)關(guān)閉,限制往上走
        {
            if(Stlocation < st_position)
            {
                IOWR_ALTERA_AVALON_PIO_DATA(STSTOP_BASE, 1);
                IOWR_ALTERA_AVALON_PIO_DATA(STLOCATE_BASE, Stlocation);
                IOWR_ALTERA_AVALON_PIO_DATA(STLE_BASE, 0);
                for(i=0;i<4;i++)
                {
                    IOWR_ALTERA_AVALON_PIO_DATA(STLE_BASE, 0);
                    IOWR_ALTERA_AVALON_PIO_DATA(STLE_BASE, 0);
                    IOWR_ALTERA_AVALON_PIO_DATA(STLE_BASE, 1);
                    IOWR_ALTERA_AVALON_PIO_DATA(STLE_BASE, 1);
                }
            }
        }
    }
    else
    {
        IOWR_ALTERA_AVALON_PIO_DATA(STSTOP_BASE, 1);
        IOWR_ALTERA_AVALON_PIO_DATA(STLOCATE_BASE, Stlocation);
        IOWR_ALTERA_AVALON_PIO_DATA(STLE_BASE, 0);
        for(i=0;i<4;i++)
        {
            IOWR_ALTERA_AVALON_PIO_DATA(STLE_BASE, 0);
            IOWR_ALTERA_AVALON_PIO_DATA(STLE_BASE, 0);
            IOWR_ALTERA_AVALON_PIO_DATA(STLE_BASE, 1);
            IOWR_ALTERA_AVALON_PIO_DATA(STLE_BASE, 1);
        }
    }
}

void Stepper_init(void)
{
    char i;
    IOWR_ALTERA_AVALON_PIO_DATA(STRST_BASE, 0);
    for(i=0;i<100;i++);
    IOWR_ALTERA_AVALON_PIO_DATA(STRST_BASE, 1);
    IOWR_ALTERA_AVALON_PIO_DATA(STSTOP_BASE, 1);
}
/********************************************************************
                             主機(jī)串口處理函數(shù)
*********************************************************************/
alt_16 tmp=0,rcvcnt=0,chk0 = 0;
alt_16 state0 = 0;
alt_16 xaa,x55;  //識(shí)別0x55和0xaa用
alt_16 update;
char rcv[10];
alt_16 rcvlength;
alt_16 Sttodo;  //步進(jìn)電機(jī)位置更新未執(zhí)行為1

void do_receive(void)
{
    alt_16 i;
    alt_32 rcvtmp;
    rcvtmp = 0;
    for(i=0;i<4;i++)
    {
        rcvtmp <<= 8;
        rcvtmp |= rcv[i];
    }
    locate = rcvtmp + Initposition;  //伺服電機(jī)位置更新
    rcvtmp = 0;
    
    for(i=0;i<2;i++)
    {
        rcvtmp <<= 8;
        rcvtmp |= rcv[i+4];
    }
    Stlocation = rcvtmp;  //步進(jìn)電機(jī)位置更新
    Stepper();
}

void usart0_do(void)
{
    if(rx_counter0)
    {
        tmp = get_char0();
        if(state0 == 0)
        {
            if(tmp == 0x55) //接收到數(shù)據(jù)包起始標(biāo)志位
            {
                state0 = 1;
                rcvcnt = 0;  //準(zhǔn)備接收數(shù)據(jù)
                rcvlength = 0;
                xaa = 0;
                x55 = 0;
                chk0 = 0;
            }
        }
        else if(state0 == 1)
        {
            rcvlength = tmp;  //以第一個(gè)數(shù)據(jù)為有效數(shù)據(jù)長度,有校驗(yàn)
            chk0 += tmp;
            state0 = 2;
        }
        else if(state0 == 2) //接收數(shù)據(jù)狀態(tài)
        {
            if(tmp != 0xaa)
            {
                if(xaa == 0xaa)  //說明前一個(gè)數(shù)是0xaa
                {
                    rcv[rcvcnt] = x55;
                    rcvcnt++; //接收計(jì)數(shù)器
                    xaa = 0;
                }
                rcv[rcvcnt] = tmp;
                chk0 += tmp; //校驗(yàn)
                rcvcnt++; //接收計(jì)數(shù)器
                xaa = 0;
                if(rcvcnt >= rcvlength)
                    state0 = 4;
                if(tmp == 0x55)  //出錯(cuò)
                    state0 = 0;
            }
            else
            {
                if(xaa == 0xaa)  //說明接收到連續(xù)兩個(gè)0xaa,否則aa為0
                {
                    x55 = 0xaa;
                    chk0 += 0xaa;  //校驗(yàn)
                }
                else  //第一次接到0xaa
                {
                    x55 = 0x55;
                    chk0 += 0xaa;  //校驗(yàn)
                    xaa = 0xaa;
                }
            }
        }
        else if(state0 == 3) //暫時(shí)沒有校驗(yàn)
        {
            if(chk0 == tmp)
                state0 = 4;
            else
                state0 = 0;
        }
        else if(state0 == 4)
        {
            if(tmp == 0x55)
            {
                state0 = 0;   //結(jié)束,回到起始狀態(tài)
                update = 1;   //完成一次接收,準(zhǔn)備數(shù)據(jù)更新
                chk0 = 0;
                put_char0(0x55);
            }
        }
        else
        {
            state0 = 0;
        }
    }
    //數(shù)據(jù)更新
    if(update)
    {
        update = 0;
        do_receive();
    }
}
/********************************************************************
                               初始化
*********************************************************************/
void timer_init(void)  //100Hz
{
    alt_irq_register(TIMER_0_IRQ,0,timer_0_IRQ);
    //初始化周期寄存器
    IOWR_ALTERA_AVALON_TIMER_PERIODL(TIMER_0_BASE,PID_PERIOD&0x0000FFFF);
    IOWR_ALTERA_AVALON_TIMER_PERIODH(TIMER_0_BASE,(PID_PERIOD>>16)&0x0000FFFF);
    //打開中斷、循環(huán)計(jì)數(shù)、定時(shí)開始
    IOWR_ALTERA_AVALON_TIMER_CONTROL(TIMER_0_BASE,(ALTERA_AVALON_TIMER_CONTROL_ITO_MSK|ALTERA_AVALON_TIMER_CONTROL_START_MSK|ALTERA_AVALON_TIMER_CONTROL_CONT_MSK));
}



/********************************************************************
                           顯示讀取的sin值
*********************************************************************/
void disp_long(long temp)
{
    alt_16 bit[7];
    alt_16 i = 0;
    for(;i<6;i++)
    {
        bit[5-i] = temp%10;
        temp /= 10;
    }
    for(i=0;i<6;i++)
    {
        put_char0(bit[i]+'0');
    }
}
void disp(void)
{
    put_str0("\nlocate = ");
    disp_long(locate);
    put_str0("; counter = ");
    disp_long(counter);
    put_str0("; speed = ");
    disp_long(Speed);
    put_str0("; Initposition = ");
    disp_long(Initposition);
}

/********************************************************************
                               主函數(shù)
*********************************************************************/
char Init_PMSM_succeed = 0;
char Init_Stepper_succeed = 0;
void Init(void)
{
    pid_Init(100, 100, 50, &piddata);
    timer_init();
    uart0_init();
    Stepper_init();
    locate = 0;

    Stlocation = -0x8000;
    Stepper();
}

int main(void)
{
    char i;
    alt_16 Itimer = 0;
    alt_16 stlimit0 = 0, stlimit1 = 0; 
    alt_putstr("Hello from Nios II!\n");
    Init();
    while(1)
    {
        //led_flash();
        if(Init_PMSM_succeed && Init_Stepper_succeed)
        {
            usart0_do();
        }
        if(IORD_ALTERA_AVALON_PIO_DATA(STBUSY_BASE))
            IOWR_ALTERA_AVALON_PIO_DATA(LED_BASE, 1);
        else
            IOWR_ALTERA_AVALON_PIO_DATA(LED_BASE, 0);
        //檢測到有開關(guān)信號(hào),停止步進(jìn)電機(jī)
        
        stlimit1 = stlimit0;
        stlimit0 = IORD_ALTERA_AVALON_PIO_DATA(STLIMIT_BASE);
        if(stlimit0 != 0 && stlimit1 == 0)  //上升沿
        {
            IOWR_ALTERA_AVALON_PIO_DATA(STSTOP_BASE, 0);
        }
        
        if( Init_PMSM_succeed == 0)
        {
            //if(!IORD_ALTERA_AVALON_PIO_DATA(LIMIT_BASE))
            if(Itimer >= 5)
            {
                Initposition = get_addr();
                locate = Initposition;
                Init_PMSM_succeed = 1;
            }
            else
            {
                locate -= 1000;
            }
        }
        
        
        if(Init_Stepper_succeed == 0)
        {
            if(stlimit0)
            {
                IOWR_ALTERA_AVALON_PIO_DATA(STRST_BASE, 0);
                for(i=0;i<100;i++);
                IOWR_ALTERA_AVALON_PIO_DATA(STRST_BASE, 1);
                for(i=0;i<100;i++);
                IOWR_ALTERA_AVALON_PIO_DATA(STRST_BASE, 0);
                for(i=0;i<100;i++);
                IOWR_ALTERA_AVALON_PIO_DATA(STRST_BASE, 1);
                for(i=0;i<100;i++);
                Init_Stepper_succeed = 1;
            }
        }
        if(timeren10)
        {
            timeren10 = 0;
            disp();
            Itimer++;
        }
    }
    
    return 0;
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩在线卡一卡二| 91九色最新地址| 激情六月婷婷综合| 日日夜夜精品视频天天综合网| 亚洲精品美国一| 亚洲日韩欧美一区二区在线| 国产精品视频观看| 国产精品久久久久一区二区三区 | 亚洲色图一区二区| 国产精品不卡一区二区三区| 中文在线资源观看网站视频免费不卡| 久久久久综合网| 久久一区二区三区国产精品| 久久免费视频一区| 国产人成一区二区三区影院| 国产日韩欧美精品在线| 中文成人综合网| 自拍av一区二区三区| 亚洲激情校园春色| 亚洲线精品一区二区三区| 成人久久久精品乱码一区二区三区| 国内精品免费**视频| 国产成人免费在线| 白白色亚洲国产精品| 91同城在线观看| 欧美三级电影在线观看| 91精品国产综合久久精品麻豆| 欧美日本一道本| 欧美大片在线观看一区二区| 久久久精品国产99久久精品芒果| 欧美国产综合一区二区| 亚洲人成网站色在线观看| 亚洲乱码国产乱码精品精98午夜 | 欧美电影在线免费观看| 欧美一区二区久久久| 2023国产精华国产精品| 国产精品污网站| 午夜久久福利影院| 国产综合色产在线精品| 97久久超碰精品国产| 51精品秘密在线观看| 久久欧美一区二区| 亚洲美女精品一区| 秋霞午夜鲁丝一区二区老狼| 国产精品一区二区在线播放| 91免费视频网址| 日韩午夜精品视频| 日韩毛片视频在线看| 免费高清在线视频一区·| www.日韩av| 91精品在线免费观看| 国产日韩欧美麻豆| 天天综合色天天综合色h| 国产成人综合在线| 欧美人体做爰大胆视频| 国产日韩欧美激情| 偷拍一区二区三区四区| 懂色中文一区二区在线播放| 精品视频在线免费观看| 国产欧美久久久精品影院| 天天射综合影视| 91丨porny丨国产入口| 欧美videossexotv100| 亚洲综合在线观看视频| 国产凹凸在线观看一区二区| 制服丝袜亚洲色图| 亚洲精品国产视频| 国产成人精品三级麻豆| 日韩一级二级三级精品视频| 亚洲欧美日韩在线不卡| 国产美女精品在线| 欧美一区日本一区韩国一区| 亚洲欧美日韩国产中文在线| 国产一级精品在线| 日韩丝袜美女视频| 亚洲成人黄色小说| 中文字幕成人在线观看| 日韩成人午夜精品| 日本高清免费不卡视频| 国产精品三级电影| 亚洲成a人片在线观看中文| 北条麻妃国产九九精品视频| 久久精品视频免费观看| 久久国产欧美日韩精品| 欧美妇女性影城| 亚洲精品美国一| 91农村精品一区二区在线| 中文字幕精品在线不卡| 国产一区二区三区精品视频| 日韩三级免费观看| 日韩av电影免费观看高清完整版| 欧美亚洲禁片免费| 一区二区三区在线看| 99国产精品久久久| 国产精品久久久久9999吃药| 国产一区999| 久久精品一区八戒影视| 国产乱码精品一区二区三区av| 日韩免费看的电影| 美国欧美日韩国产在线播放| 欧美一区二区三区白人| 日日夜夜免费精品视频| 欧美一区二区三区性视频| 日韩成人伦理电影在线观看| 555www色欧美视频| 日本视频在线一区| 日韩一区二区影院| 老司机精品视频线观看86| 欧美成人一区二区三区在线观看| 美脚の诱脚舐め脚责91 | 91麻豆精东视频| 亚洲免费在线观看视频| 色哟哟一区二区| 亚洲一区二区三区在线| 欧美色网一区二区| 日韩成人免费电影| 精品日韩一区二区三区| 国产一区二区伦理片| 国产亚洲精久久久久久| www.日韩大片| 亚洲一区二区四区蜜桃| 欧美夫妻性生活| 久久99精品国产| 中文字幕欧美日本乱码一线二线| 99精品欧美一区二区三区小说 | 国产一区二区精品在线观看| 久久精品视频免费| 成人精品免费看| 亚洲精品久久久久久国产精华液| 欧美视频精品在线| 精品一区二区在线看| 国产人伦精品一区二区| 色欧美88888久久久久久影院| 亚洲aaa精品| 精品sm在线观看| 97久久超碰国产精品| 亚洲自拍偷拍欧美| 日韩一级免费一区| 波多野结衣中文一区| 亚洲妇女屁股眼交7| 精品奇米国产一区二区三区| 国产成人av电影免费在线观看| 亚洲裸体xxx| 欧美一级高清片| 成人高清视频在线观看| 亚洲成人免费在线观看| 久久九九久精品国产免费直播| 91美女精品福利| 麻豆久久久久久| 136国产福利精品导航| 91精品国产综合久久久久| 成人一道本在线| 午夜视频在线观看一区二区三区| 久久久久国色av免费看影院| 91成人看片片| 国产一区二区女| 午夜激情一区二区三区| 国产欧美一区二区三区沐欲| 欧美日韩精品高清| 波多野结衣在线一区| 久久成人羞羞网站| 一区二区三区在线观看视频| 久久久天堂av| 欧美精选午夜久久久乱码6080| 成人国产精品免费观看动漫| 美腿丝袜亚洲三区| 亚洲影院理伦片| 中文字幕免费不卡在线| 日韩三级中文字幕| 欧美亚洲精品一区| 99这里只有久久精品视频| 国产在线视频一区二区三区| 午夜激情一区二区三区| 亚洲欧美成aⅴ人在线观看 | 蜜桃av一区二区| 一区二区三区四区蜜桃| 欧美激情一区二区三区全黄| 日韩精品一区二区三区在线播放| 在线观看国产日韩| 成人污污视频在线观看| 久久99精品国产麻豆婷婷| 午夜精品久久久久久久久久 | 亚洲免费观看在线观看| 久久久99久久| 日韩精品在线网站| 中文字幕精品在线不卡| 精品1区2区在线观看| 欧美浪妇xxxx高跟鞋交| 在线影院国内精品| a4yy欧美一区二区三区| 国产aⅴ综合色| 国产精品综合网| 经典三级一区二区| 免费在线看成人av| 天天爽夜夜爽夜夜爽精品视频| 亚洲精品国产无套在线观| 日韩理论片在线| 亚洲欧洲国产专区| 国产精品不卡一区二区三区| 欧美国产精品一区二区|