<big id="a5mua"></big>

      <tt id="a5mua"><dfn id="a5mua"></dfn></tt>
      <wbr id="a5mua"><sup id="a5mua"></sup></wbr>

        
        

      1. 亚洲综合小综合中文字幕,国产久爱免费精品视频,精品国产品香蕉在线,国产午夜精品在人线播放,精品一二三四区在线观看,国产成人无码免费看视频软件 ,色欲久久人妻内射,午夜在线观看成人av
        zhaocongxue
        級別: 家園常客
        精華主題: 0
        發(fā)帖數(shù)量: 371 個
        工控威望: 500 點(diǎn)
        下載積分: 1226 分
        在線時(shí)間: 185(小時(shí))
        注冊時(shí)間: 2007-10-27
        最后登錄: 2025-09-27
        查看zhaocongxue的 主題 / 回貼
        樓主  發(fā)表于: 2012-08-18 09:43
        系統(tǒng)程序:
        #include <c8051f000.h>
        typedef unsigned char uchar;
        typedef unsigned int uint;
        typedef unsigned long ulong;
        sbit P1_0=P1^0;
        sbit P1_2=P1^2;
        sbit P0_6=P0^6;
        sbit P0_4=P0^4;
        sbit P0_7=P0^7;
        sbit P1_3=P1^3;
        sbit P1_4=P1^4;
        #define CON 28585756
        uint t[4]={0,0,0,0};
        uint i=0,a=0,t1=0,t2=0,e=0,tt=0;
        char d=1,n=1,jj=0,j=0,m=0;

        union tcfint16{
              uint myword0;
              struct{uchar hi;uchar low;}bytes0;
              }myint16;
        union tcfint116{
              uint myword1;
              struct{uchar hi;uchar low;}bytes1;
              }myint116;
        void pca1()                            //設(shè)置脈沖捕捉
        {    
        EIE1=0x00;                          //禁止脈沖捕捉中斷
        PCA0MD=0x00;                      //系統(tǒng)時(shí)鐘12分頻,禁止pca中斷
        PCA0CN=0x00;                       //CR=0
        PCA0CPM0=0x20;
        PCA0CPM1=0x20;                      //正沿捕捉
        }
        void DAC0(uint DAChl)
        {
        myint16.myword0=DAChl;
        DAC0L=myint16.bytes0.low;
        DAC0H=myint16.bytes0.hi;
        }
        void delay()
        {
        uint xxxx,xxx=999,xx,x;
        for(x=0;x<400;x++)
           for(xx=0;xx<x;xx++)
           {
             xxxx=xxx/1000;
            }
        }
        main()                              //主函數(shù)
        {
        uint t0;
        uint dk1=0,dk2=0;
        WDTCN=0xde;
        WDTCN=0xad;            //關(guān)看門狗
        XBR0=0x12;
        XBR2=0x40;               //交叉開關(guān)設(shè)置,外部中斷無引腳
        XBR1=0x00;
        OSCICN=0x95;             //內(nèi)部時(shí)鐘4MHz
        DAC1CN=0;               //DCA1無效
        PRT0CF=0xc0;
        PRT1CF=0x18;
        CKCON=0xe7;            //系統(tǒng)時(shí)鐘12分頻
        TMOD=0x11;
        TCON=0x00;               //外部中斷請求及標(biāo)志位0
        TH0=0x00;
        TL0=0x00;
        TH1=0x00;
        TL1=0x00;
        pca1();                   //pca初始化  
        REF0CN=0x03;
        DAC0CN=0x84;             //DCA0使能,左對齊
          P1_0=0;
          P1_2=1;
          P0_6=0;
          P0_7=0;
          P1_3=0;
          P1_4=0;
           EA=1;                          //中斷設(shè)置
           ET0=1;
           PT0=1;
           ET1=1;
           PT1=1;
           a=0x91A0;
           //a=0xF2A0;
             DAC0(a);
            delay();    
        //****************************測頻*****************************//
          while(1){
           for(i=1;i<4;i++){
            CCF0=0;                         //變頻上升沿標(biāo)志
           while(CCF0==0)
           {}
           TR1=1;
           CCF0=0;                          //變頻上升沿標(biāo)志
           while(CCF0==0)
           {}
           TR1=0;
        myint116.bytes1.low=TL1;
        myint116.bytes1.hi=TH1;
        TH1=0;
        TL1=0;
        if(myint116.myword1>6000&&myint116.myword1<30000)  //剔除粗大誤差值
        {m++;
        t[m]=myint116.myword1;
        }
        else
        i--;}
            for(i=1;i<=2;i++)                //中值濾波
             for(jj=1;jj<=3-i;jj++)
               if(t[jj]>t[jj+1])
                 {t[0]=t[jj];
                 t[jj]=t[jj+1];
                 t[jj+1]=t[0];
                 }  
            dk1=t[2];                        
            for(i=0;i<4;i++)
            t=0;
            n=1;                           //進(jìn)入鑒頻鑒相
        //***************************鑒頻*****************************//
        while(d==1){                        //測量變頻周期
           for(i=1;i<4;i++){
            CCF1=0;                       //變頻上升沿標(biāo)志
           while(CCF1==0)
           {}
           TR1=1;
           CCF1=0;                         //變頻上升沿標(biāo)志
           while(CCF1==0)
           {}
           TR1=0;
        myint116.bytes1.low=TL1;
        myint116.bytes1.hi=TH1;
        TH1=0;
        TL1=0;
        if(myint116.myword1>6000&&myint116.myword1<30000)
        {m++;
        t[m]=myint116.myword1;
        }
        else
        i--;                   }
            for(i=1;i<=2;i++)                  //中值濾波
             for(jj=1;jj<=3-i;jj++)
               if(t[jj]>t[jj+1])
                 {t[0]=t[jj];
                 t[jj]=t[jj+1];
                 t[jj+1]=t[0];
                 }  
            dk2=t[2];
            for(i=0;i<4;i++)
            t=0;
            if(dk2>dk1+2)                       //鑒頻
             {a=a+192;
              DAC0(a);}
             else
              d=0;
             }
            a=0xF2A0;
            DAC0(a);
        //****************************鑒相*****************************//     TR0=1;
            while(n==1)
            {
            CCF1=0;
            while(CCF1==0)
            {}
            TR1=1;
            CCF0=0;
            while(CCF0==0)
            {}
            TR1=0;
            myint116.bytes1.low=TL1;
            myint116.bytes1.hi=TH1;
              TH1=0;
              TL1=0;
              t1=myint116.myword1;//假設(shè)變頻超前測t1
              if(t1>=(dk1-700))
              t1=t1-(dk1-700);
              else
              t1=700+t1;             //補(bǔ)償
            CCF0=0;
            while(CCF0==0)
            {}
            TR1=1;
            CCF1=0;
            while(CCF1==0)
            {}
            TR1=0;
            myint116.bytes1.low=TL1;
            myint116.bytes1.hi=TH1;
              TH1=0;
              TL1=0;
              t2=myint116.myword1;      //假設(shè)工頻超前測t2
            f(t2>=700)
            t2=t2-700;
            else
            t2=dk1-(700-t2);           //補(bǔ)償
              if(t1<=t2)               //變頻超前工頻
              {if(t1<250)
               {a=CON/dk1*16-t1;
               DAC0(a);}
               else{
               a=CON/dk1*16-250;
               DAC0(a);}
               n=0;                   //轉(zhuǎn)入測頻
               }
              else                      //工頻超前變頻
              {if(t2<250)
               {a=CON/dk1*16+t2;
               DAC0(a);}
                else{
               a=CON/dk1*16+250;
               DAC0(a);}
               n=0;                    //轉(zhuǎn)入測頻
              }
            }
          }
        }
        void t0_ISR()interrupt 1     //中斷服務(wù)程序
        {TH0=0x00;
        TL0=0x00;
        TF0=0;
        j++;
        if(j==80)
        {j=0;
        P0_7=1;}
        }
        void t1_ISR()interrupt 3   //中斷服務(wù)程序
        {TH1=0x00;
        TL1=0x00;
        TF1=0;
        }


        附件: 變頻工頻鎖相程序.doc (40 K) 下載次數(shù):19
        陳大圍
        工控新人,還請多多指教
        級別: 論壇先鋒

        精華主題: 0
        發(fā)帖數(shù)量: 843 個
        工控威望: 1161 點(diǎn)
        下載積分: 8915 分
        在線時(shí)間: 1865(小時(shí))
        注冊時(shí)間: 2011-04-17
        最后登錄: 2025-10-24
        查看陳大圍的 主題 / 回貼
        1樓  發(fā)表于: 2012-08-19 10:13
        看懂c的控制要求,在依要求編PLC程序
        專心學(xué)工控技術(shù),請各位幫忙指教

        主站蜘蛛池模板: 国产成人一区二区三区免费视频| 国产美女69视频免费观看| 韩国无码AV片在线观看网站| 亚洲第一人伊伊人色综合| 欧美激情视频二区三区| 熟妇人妻中文a∨无码| 中文字幕日韩一区二区不卡| 欧美在线一区二区三区精品| 疯狂做受XXXX高潮国产| 成码无人AV片在线电影网站| 2020年最新国产精品正在播放 | 色综合久久久久综合体桃花网| 精品尤物TV福利院在线网站| 国产SUV精品一区二区四| 国产一区二区三区啪| 4hu44四虎www在线影院麻豆| 日韩中文字幕亚洲精品| 日韩成人午夜精品久久高潮| 成人免费无码视频在线网站 | 99久久国产综合精品女图图等你| 久久久久无码中| 日本亚洲成高清一区二区三区| 一色桃子中出欲求不满人妻| а∨天堂一区中文字幕| 日本福利视频免费久久久| 亚洲一区二区中文av| 国厂精品114福利电影免费| 亚洲欧洲日产国产最新| 国产视频一区二区三区四区视频| 亚洲精品麻豆一区二区| 婷婷五月深深久久精品| 精品中文人妻中文字幕| 久久精品伊人无码二区| 黄色三级亚洲男人的天堂| 蜜桃视频在线观看免费网址入口 | 国产av午夜精品福利| 久久18禁高潮出水呻吟娇| 亚洲V天堂V手机在线| 国产性夜夜春夜夜爽| 18禁动漫一区二区三区| 国产精品妇女一二三区|