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

蟲蟲首頁| 資源下載| 資源專輯| 精品軟件
登錄| 注冊

防碰撞算法

多標簽防碰撞算法主要分為三類:①基于Aloha的算法,又稱為隨機性算法;②基于樹的算法,又稱為確定性算法;③混合算法,將基于Aloha的算法和基于樹的算法相結合而產生的一種算法。
  • RFID智能停車場管理系統的研究與設計

    隨著經濟的迅猛發展和人民生活水平的提高,我國私人汽車保有量日益攀升,這一現象給城市交通基礎設施建設提出了新的挑戰。傳統停車場管理方式存在著識別效率低、易出錯、數據傳輸率低、識別距離近、必須停車減速等問題。因此,本文針對上述問題提出了基于RFID高頻有源電子標簽的遠距離車輛識別停車場管理系統,研究了智能停車場管理系統的特點,對軟件系統進行了需求分析與設計實現。系統由車輛基本信息管理,系統運營維護管理、車輛出入車場管理3個功能模塊組成。高頻標簽帶來了更遠的識別距離和更快的識別速度,實現了高速、不停車的車輛識別,但是識別范圍的擴大也給系統帶來了多標簽碰撞問題。針對多車輛信息碰撞的問題,本文對RFID系統的防碰撞算法進行了深入研究,在現有的二進制防碰撞算法基礎上提出了一種改進方法,該算法解決了典型算法在安全性上存在的隱患,在識讀效率上優越于典型算法,在高吞吐率、高負載的情景下性能尤V為關油:隨著停車場的日益大型化,停車場內的路徑選擇也影響著系統的效率。因此,本文設計一種停車場最短路徑停車引導模型,為停車提供最短行駛路線。結合圖論形成停車位的賦權有向圖,然后利用A*算法搜索最短停車路徑,通過數據庫和信息顯示設備引導停車,大大加快了停車速度,提高了停車場的停車位利用率。最后,在總結全文工作的基礎上對進一步研究提出了建議和展望。

    標簽: rfid 智能停車場

    上傳時間: 2022-06-26

    上傳用戶:slq1234567890

  • 基于招撲地圖的AGV智能路徑規劃技術研究(碩士論文)

    本文首先介紹了 AGV的整體控制系統結構,隨后指出了設計AGV系統時的關鍵技術。本系統中環境電子地圖采用拓撲地圖方法構建。簡單介紹了電子地圖在數據庫中的存儲方式以及在計算機中的存儲方法,在介紹完這些之后,又對文章中采用的數據庫訪問方法進行了簡單講解。除此之外,本文提出了 一種新的路徑規劃方法,這種方法采用改進的Dijkstra路徑搜索算法作為全局路徑搜索算法,采用啟發式搜索算法A*算法作為局部路徑搜索算法。在多AGV路徑規劃方面,為了實現小車防碰撞,本文介紹了多種防止沖突的方法,包括交通規則法,單向路徑法,時間窗方法等。為了驗證所提出算法的有效性,在文章的最后,針對小車運行的多種情形,進行了仿真試驗和實際運行實驗,結果表明了所設計算法的實用性,應用該算法搜索到的路徑不僅長度最短,轉彎最少,而且有效的防止了沖突,所有路徑均為最優路徑。

    標簽: 基于招撲地圖的AGV智能路徑規劃技術研究 智能算法

    上傳時間: 2016-04-01

    上傳用戶:五塊錢的油條

  • 基于RF通信的分體式金融POS機設計.rar

    本文介紹了一種新型金融終端(POS),其座機與手持機之間采用射頻通信方式,并在射頻通信中采用跳頻和防碰撞設計,使得座機和手持機之間的通信速率高、穩定可靠。本設計中的金融終端還具有非接觸式IC卡數據采集功能,這在設備功能上是一個巨大的創新。手持機可移動操作,方便了客戶操作,在很大程度上可以幫助商家提高服務質量,非常適用于餐廳、酒店以及娛樂場所等。 本設計中的金融終端包括手持機和座機,手持機的主要功能是采集金融信息,采集的對象可以是磁條卡,接觸式IC卡或非接觸IC卡,采集到卡的賬號和密碼等信息后以射頻的方式發送至座機,同時接收座機發送來的數據;座機收到手持機發送的金融信息后,再通過有線方式(電話網或以太網)發送給銀行主機,交易數據處理后,銀行主機將數據以有線的方式發回給座機,座機再通過無線方式發送給手持機,并打印交易憑證。文中詳細介紹了手持機和座機各功能模塊的硬件設計和功能實現方式,包括各主要芯片選型依據、所選芯片的特性、設計原理以及各相關模塊在POS中的功能。 POS的軟件設計包括硬件驅動程序(底層程序)設計和應用程序(上層應用程序)設計,底層程序跟所使用的硬件相關,是CPU控制各外圍器件實現各模塊硬件功能的程序,通常驅動程序會封裝起來,有入口參數,供上層應用調用;上層應用程序足根據產品要實現的服務功能而編寫的相關程序,上層應用程序通常需要調用底層程序。文中驅動程序主要介紹了鍵盤驅動,顯示驅動,并重點介紹了射頻通信驅動程序的設計,包括CPU如何控制射頻收發芯片、為抗干擾而采取的跳頻設計和設備問的防碰撞設計;應用程序中主要介紹了磁條卡和IC卡的處理程序。 由于本設計中的金融終端座機與手持機之間的通信速率較高,通信穩定可靠,同時還新增了非接觸卡的數據采集功能,使該設備有較大的使用范圍,從而有廣闊的市場前景。

    標簽: POS RF通信 分體式

    上傳時間: 2013-06-27

    上傳用戶:1234567890qqq

  • 基于ARM的自動導引車設計

    AGV(Automated Guided Vehicle)即自動導引車,是具備一定自主能力的運輸設備,在自動化物流系統和工廠自動化系統中具有重要的應用價值。 AGV是一種高度自動化產品,它所涉及的技術包括針對特定用途的車體結構、貨物移送機構、路徑導引技術、貨位檢測技術、防碰撞技術、驅動技術和控制技術。更深入的研究還包括多車協調與優化調度技術、智能控制技術等。 本文首先對AGV的發展及關鍵技術進行了總結與歸納,并分析了現有技術的特點與不足,在此基礎上設計了一個模擬貨物分揀的小型AGV系統。車體采用二輪驅動和前后萬向輪支承的結構,可以實現靈活的轉向和快速移動。導引方式采用光電傳感器路徑導引,以計數方式實現貨位識別檢測。ARM是一種高性能的嵌入式微處理器,AGV控制系統采用了基于ARM7核的微控制器LPC2210,其豐富的片上資源可以很方便地實現AGV的所有檢測、信息處理及控制功能。利用LPC2210的串行通信功能,再配合無線通信模塊建立與PC機的通信聯系,通過PC機實現對AGV小車的控制與調度。 制作完成后的AGV樣機在實驗室模擬環境下進行了性能測試,其性能指標均滿足設計要求。

    標簽: ARM 自動

    上傳時間: 2013-04-24

    上傳用戶:cjl42111

  • 遠程RFID技術探討

    RFID(Radio Frequency Identification)技術是利用射頻通信實現的一種非接觸式自動識別技術。擁有廣闊的發展前景和巨大的市場潛力。本文介紹了RFID技術的原理、特點,深入分析了信號傳輸時所采取的反方向散射的調制方式,影響傳輸距離的因素,最后介紹了在遠程RFID自動識別系統中的讀寫沖突和防沖突算法,更好的解決了遠程RFID系統存在的沖突問題。

    標簽: RFID 遠程 技術探討

    上傳時間: 2013-10-11

    上傳用戶:fdfadfs

  • 一個j2me手機游戲程序

    一個j2me手機游戲程序,有卡馬克地圖算法和動畫,以及碰撞算法的實現

    標簽: j2me 手機游戲 程序

    上傳時間: 2014-01-21

    上傳用戶:417313137

  • 文檔從數學的角度

    文檔從數學的角度,描述了物體、場景的碰撞檢測和響應原理,并給出部分程序。是學習研究碰撞算法難得的好書.(英文文檔)

    標簽: 文檔 角度

    上傳時間: 2013-12-19

    上傳用戶:lunshaomo

  • 12345

    /****************temic*********t5557***********************************/    #include   <at892051.h>     #include   <string.h>    #include   <intrins.h>     #include   <stdio.h>     #define    uchar    unsigned char     #define    uint     unsigned int     #define    ulong    unsigned long     //STC12C2051AD的SFR定義     sfr  WDT_CONTR = 0xe1;//stc2051的看門狗??????     /**********全局常量************/    //寫卡的命令     #define    write_command0       0//寫密碼     #define    write_command1       1//寫配置字     #define    write_command2       2//密碼寫數據     #define    write_command3       3//喚醒     #define    write_command4       4//停止命令     #define    TRUE       1     #define    FALSE      0     #define    OK         0     #define    ERROR      255     //讀卡的時間參數us     #define ts_min          250//270*11.0592/12=249//取近似的整數     #define ts_max          304//330*11.0592/12=304     #define t1_min          73//90*11.0592/12=83:-10調整     #define t1_max          156//180*11.0592/12=166     #define t2_min          184//210*11.0592/12=194     #define t2_max          267//300*11.0592/12=276     //***********不采用中斷處理:采用查詢的方法讀卡時關所有中斷****************/     sbit p_U2270B_Standby = P3^5;//p_U2270B_Standby PIN=13     sbit p_U2270B_CFE = P3^3;//p_U2270B_CFE     PIN=6     sbit p_U2270B_OutPut = P3^7;//p_U2270B_OutPut  PIN=2     sbit wtd_sck = P1^7;//SPI總線     sbit wtd_si = P1^3;    sbit wtd_so = P1^2;    sbit iic_data = P1^2;//lcd IIC     sbit iic_clk = P1^7;    sbit led_light = P1^6;//測試綠燈     sbit led_light1 = P1^5;//測試紅燈     sbit led_light_ok  = P1^1;//讀卡成功標志     sbit fengmingqi = P1^5;    /***********全局變量************************************/       uchar data Nkey_a[4] = {0xA0, 0xA1, 0xA2, 0xA3};//初始密碼             //uchar idata card_snr[4];   //配置字     uchar data bankdata[28] = {1,2,3,4,5,6,7,1,2,3,4,5,6,7,1,2,3,4,5,6,7,1,2,3,4,5,6,7};     //存儲卡上用戶數據(1-7)7*4=28     uchar data cominceptbuff[6] = {1,2,3,4,5,6};//串口接收數組ram     uchar command; //第一個命令     uchar command1;//     //uint  temp;     uchar j,i;    uchar myaddr = 8;    //uchar ywqz_count,time_count;             //ywqz jishu:     uchar bdata DATA;    sbit BIT0 = DATA^0;    sbit BIT1 = DATA^1;    sbit BIT2 = DATA^2;    sbit BIT3 = DATA^3;    sbit BIT4 = DATA^4;    sbit BIT5 = DATA^5;    sbit BIT6 = DATA^6;    sbit BIT7 = DATA^7;    uchar bdata DATA1;    sbit BIT10 = DATA1^0;    sbit BIT11 = DATA1^1;    sbit BIT12 = DATA1^2;    sbit BIT13 = DATA1^3;    sbit BIT14 = DATA1^4;    sbit BIT15 = DATA1^5;    sbit BIT16 = DATA1^6;    sbit BIT17 = DATA1^7;    bit i_CurrentLevel;//i_CurrentLevel  BIT 00H(Saves current level of OutPut pin of U2270B)     bit timer1_end;    bit read_ok = 0;    //緩存定時值,因用同一個定時器     union HLint { uint W;    struct   {    uchar H;uchar L;   }   B; };//union HLint idata a     union HLint data a;    //緩存定時值,因用同一個定時器     union HLint0 { uint W;    struct {   uchar H;   uchar L; } B; };//union HLint idata a     union HLint0 data b;    /**********************函數原型*****************/    //讀寫操作     void f_readcard(void);//全部讀出1~7 AOR喚醒     void f_writecard(uchar x);//根據命令寫不同的內容和操作     void f_clearpassword(void);//清除密碼     void f_changepassword(void);//修改密碼     //功能子函數     void write_password(uchar data *data p);//寫初始密碼或數據     void write_block(uchar x,uchar data *data p);//不能用通用指針     void write_bit(bit x);//寫位     /*子函數區*****************************************************/    void delay_2(uint x)    //延時,時間x*10us@12mhz,最小20us@12mhz     {    x--; x--;    while(x)    {      _nop_();      _nop_();      x--;    }    _nop_();//WDT_CONTR=0X3C;不能頻繁的復位     _nop_();    }    /////////////////////////////////////////////////////////////////////     void initial(void)    {    SCON = 0x50; //串口方式1,允許接收     //SCON  =0x50;     //01010000B:10位異步收發,波特率可變,SM2=0不用接收到有效停止位才RI=1,     //REN=1允許接收     TMOD = 0x21; //定時器1 定時方式2(8位),定時器0 定時方式1(16位)     TCON = 0x40; //設定時器1 允許開始計時(IT1=1)     TH1 = 0xfD;  //FB 18.432MHz 9600 波特率     TL1 = 0xfD;  //fd 11.0592 9600     IE = 0X90;     //EA=ES=1     TR1 = 1;     //啟動定時器     WDT_CONTR = 0x3c;//使能看門狗     p_U2270B_Standby = 0;//單電源     PCON = 0x00;    IP = 0x10;//uart you xian XXXPS PT1 PX1 PT0 PX0     led_light1 = 1;    led_light = 0;    p_U2270B_OutPut = 1;    }    /************************************************/    void f_readcard()//讀卡     {    EA = 0;//全關,防止影響跳變的定時器計時     WDT_CONTR = 0X3C;//喂狗     p_U2270B_CFE = 1;//      delay_2(232);  //>2.5ms            /*   //   aor    用喚醒功能來防碰撞   p_U2270B_CFE = 0; delay_2(18);//start gap>150us   write_bit(1);//10=操作碼讀0頁   write_bit(0);       write_password(&bankdata[24]);//密碼block7   p_U2270B_CFE =1 ;//    delay_2(516);//編程及確認時間5.6ms   */    WDT_CONTR = 0X3C;//喂狗     led_light = 0;    b.W = 0;    while(!(read_ok == 1))    {             //while(p_U2270B_OutPut);//等一個穩定的低電平?超時判斷?              while(!p_U2270B_OutPut);//等待上升沿的到來同步信號檢測1       TR0 = 1;      //deng xia jiang       while(p_U2270B_OutPut);//等待下降沿       TR0 = 0;   a.B.H = TH0;   a.B.L = TL0;   TH0 = TL0 = 0;   TR0 = 1;//定時器晚啟動10個周期       //同步頭       if((324 < a.W) && (a.W < 353)) ;//檢測同步信號1                  else     {     TR0 = 0;     TH0 = TL0 = 0;     goto read_error;    }      //等待上升沿        while(!p_U2270B_OutPut);   TR0 = 0;   a.B.H = TH0;   a.B.L = TL0;   TH0 = TL0 = 0;   TR0 = 1;//b.N1<<=8;            if(a.B.L < 195);//0.5p       else     {     TR0 = 0;     TH0 = TL0 = 0;     goto read_error;    }      //讀0~7塊的數據       for(j = 0;j < 28;j++)      {       //uchar i;                  for(i = 0;i < 16;i++)//8個位        {        //等待下降沿的到來         while(p_U2270B_OutPut);                TR0 = 0;     a.B.H = TH0;     a.B.L = TL0;     TH0 = TL0 = 0;     TR0 = 1;              if(t2_max < a.W/*)&&(a.W < t2_max)*/)//1P          {         b.W >>= 2;//先左移再賦值          b.B.L += 0xc0;                             i++;        }        else if(t1_min < a.B.L/*)&&(a.B.L < t1_max)*/)//0.5p         {         b.W >>= 1;         b.B.L += 0x80;                           }        else      {      TR0 = 0;      TH0 = TL0 = 0;      goto read_error;     }        i++;        while(!p_U2270B_OutPut);//上升                   TR0 = 0;     a.B.H = TH0;     a.B.L = TL0;     TH0 = TL0 = 0;     TR0 = 1;                      if(t2_min < a.W/*)&&(a.W < t2_max)*/)//1P          {         b.W >>= 2;         i++;        }        else if(t1_min < a.B.L/*a.W)&&(a.B.L < t1_max)*/)//0.5P         //else if(!(a.W==0))         {         b.W >>= 1;         //temp+=0x00;          //led_light1=0;led_light=1;delay_2(40000);         }        else      {      TR0 = 0;      TH0 = TL0 = 0;      goto read_error;     }        i++;       }       //取出奇位        DATA = b.B.L;       BIT13 = BIT7;    BIT12 = BIT5;    BIT11 = BIT3;    BIT10 = BIT1;       DATA = b.B.H;       BIT17 = BIT7;    BIT16 = BIT5;    BIT15 = BIT3;    BIT14 = BIT1;       bankdata[j] = DATA1;      }              read_ok = 1;//讀卡完成了     read_error:    _nop_();    }       }    /***************************************************/    void f_writecard(uchar x)//寫卡     {    p_U2270B_CFE = 1;    delay_2(232);  //>2.5ms            //psw=0 standard write     if (x == write_command0)//寫密碼:初始化密碼     {      uchar i;      uchar data *data p;      p = cominceptbuff;      p_U2270B_CFE = 0;   delay_2(31);//start gap>330us       write_bit(1);//寫操作碼1:10       write_bit(0);//寫操作碼0       write_bit(0);//寫鎖定位0       for(i = 0;i < 35;i++)      {       write_bit(1);//寫數據位1       }      p_U2270B_CFE = 1;      led_light1 = 0;   led_light = 1;   delay_2(40000);//測試使用       //write_block(cominceptbuff[4],p);       p_U2270B_CFE = 1;      bankdata[20] = cominceptbuff[0];//密碼存入       bankdata[21] = cominceptbuff[1];      bankdata[22] = cominceptbuff[2];      bankdata[23] = cominceptbuff[3];    }    else if (x == write_command1)//配置卡參數:初始化     {      uchar data *data p;      p = cominceptbuff;      write_bit(1);//寫操作碼1:10       write_bit(0);//寫操作碼0       write_bit(0);//寫鎖定位0               write_block(cominceptbuff[4],p);      p_U2270B_CFE=  1;    }    //psw=1  pssword mode     else if(x == write_command2)  //密碼寫數據    {      uchar data*data p;      p = &bankdata[24];      write_bit(1);//寫操作碼1:10       write_bit(0);//寫操作碼0       write_password(p);//發口令       write_bit(0);//寫鎖定位0       p = cominceptbuff;      write_block(cominceptbuff[4],p);//寫數據            }    else if(x == write_command3)//aor    //喚醒 {      //cominceptbuff[1]操作碼10 X xxxxxB       uchar data *data p;      p = cominceptbuff;      write_bit(1);//10       write_bit(0);             write_password(p);//密碼       p_U2270B_CFE = 1;//此時數據不停的循環傳出     }    else //停止操作碼     {      write_bit(1);//11       write_bit(1);             p_U2270B_CFE = 1;         }    p_U2270B_CFE = 1;    delay_2(560);//5.6ms     }    /************************************/    void f_clearpassword()//清除密碼     {    uchar data *data p;    uchar i,x;          p = &bankdata[24];//原密碼     p_U2270B_CFE = 0; delay_2(18);//start gap>150us     //操作碼10:10xxxxxxB     write_bit(1);    write_bit(0);              for(x = 0;x < 4;x++)//發原密碼     {             DATA = *(p++);      for(i = 0;i < 8;i++)      {       write_bit(BIT0);       DATA >>= 1;      }    }    write_bit(0);//鎖定位0:0     p = &cominceptbuff[0];    write_block(0x00,p);//寫新配置參數:pwd=0             //密碼無效:即清除密碼     DATA = 0x00;//停止操作碼00000000B     for(i = 0;i < 2;i++)    {    write_bit(BIT7);    DATA <<= 1;    }    p_U2270B_CFE = 1;       delay_2(560);//5.6ms     }    /*********************************/    void f_changepassword()//修改密碼            {       uchar data *data p;    uchar i,x,addr;    addr = 0x07;//block7     p = &Nkey_a[0];//原密碼     DATA = 0x80;//操作碼10:10xxxxxxB     for(i = 0;i < 2;i++)    {      write_bit(BIT7);      DATA <<= 1;    }    for(x = 0;x < 4;x++)//發原密碼     {             DATA = *(p++);      for(i = 0;i < 8;i++)      {       write_bit(BIT7);       DATA >>= 1;      }    }    write_bit(0);//鎖定位0:0     p = &cominceptbuff[0];    write_block(0x07,p);//寫新密碼     p_U2270B_CFE = 1;    bankdata[24] = cominceptbuff[0];//密碼存入     bankdata[25] = cominceptbuff[1];    bankdata[26] = cominceptbuff[2];    bankdata[27] = cominceptbuff[3];    DATA = 0x00;//停止操作碼00000000B     for(i = 0;i < 2;i++)    {      write_bit(BIT7);      DATA <<= 1;    }    p_U2270B_CFE = 1;       delay_2(560);//5.6ms     }    /***************************子函數***********************************/    void write_bit(bit x)//寫一位     {    if(x)    {      p_U2270B_CFE = 1;   delay_2(32);//448*11.0592/120=42延時448us       p_U2270B_CFE = 0;   delay_2(28);//280*11.0592/120=26寫1     }    else    {      p_U2270B_CFE = 1;   delay_2(92);//192*11.0592/120=18       p_U2270B_CFE = 0;   delay_2(28);//280*11.0592/120=26寫0     }    }    /*******************寫一個block*******************/    void write_block(uchar addr,uchar data *data p)    {    uchar i,j;        for(i = 0;i < 4;i++)//block0數據     {             DATA = *(p++);      for(j = 0;j < 8;j++)      {       write_bit(BIT0);       DATA >>= 1;      }    }    DATA = addr <<= 5;//0地址     for(i = 0;i < 3;i++)    {      write_bit(BIT7);      DATA <<= 1;    }                   }    /*************************************************/    void write_password(uchar data *data p)    {    uchar i,j;        for(i = 0;i < 4;i++)//     {             DATA = *(p++);      for(j = 0;j < 8;j++)      {       write_bit(BIT0);       DATA >>= 1;      }    }        }   /*************************************************/   void main()    {    initial();    TI = RI = 0;    ES = 1;    EA = 1;  delay_2(28);   //f_readcard();     while(1) {   f_readcard();      //讀卡   f_writecard(command1);  //寫卡    f_clearpassword();   //清除密碼     f_changepassword();    //修改密碼 } }

    標簽: 12345

    上傳時間: 2017-10-20

    上傳用戶:my_lcs

  • MCU電壓檢測方法

    MCU電壓檢測方法。講解并分析了常用的十種電壓檢測防抖算法。方便初學者學習使用。

    標簽: MCU 電壓 檢測方法

    上傳時間: 2021-10-06

    上傳用戶:rockwu_sz

  • 基于自動巡航無人駕駛船的水產養殖在線監控技術

    研制了一種由自動巡航無人駕駛船、環境生態監控裝置和遠程服務平臺3部分組成的水產養殖在線監控設備,在提高養殖監控效率和降低監控成本的同時,實現養殖過程的實時在線監測和精準調控。綜合應用自動化航向航速控制、自動導航定位和防碰撞技術,實現無人駕駛船的自動巡航功能。利用無人船運載自制的多功能環境生態監控裝置,實現水質指標(溫度、溶解氧、p H值和氧化還原能力)以及魚、蝦生態信息的實時定點獲取,并能根據用戶需求調整檢測指標。無人船在大幅減少環境生態監控裝置數量的同時,有效提高了裝置的檢測精度。將統計分析、信息融合、組態控制、嵌入式等技術相結合,用于對數據進行處理與分析,實現養殖現場環境調控設備的精準控制。試驗表明,該監控設備能滿足規模化水產養殖需求,對推廣應用精準農業技術與裝置、進行水產養殖過程監測與精準調控有積極的促進作用。

    標簽: 自動巡航無人駕駛

    上傳時間: 2022-06-16

    上傳用戶:

主站蜘蛛池模板: 锦屏县| 滦南县| 社会| 景泰县| 报价| 滁州市| 卢氏县| 都江堰市| 安塞县| 河间市| 双城市| 灌云县| 五原县| 庐江县| 亚东县| 叙永县| 曲阜市| 广河县| 邵东县| 孟村| 凌海市| 柳河县| 武汉市| 吴旗县| 宜宾县| 湘潭县| 泸溪县| 即墨市| 武川县| 吉木乃县| 贵南县| 枝江市| 伊吾县| 腾冲县| 郯城县| 荥阳市| 东安县| 安西县| 南乐县| 连江县| 阜宁县|