• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            隨筆-380  評論-37  文章-0  trackbacks-0
            轉:http://qinysong.iteye.com/blog/678941


            在此把這個算法稱作B* 尋路算法(Branch Star 分支尋路算法,且與A*對應),本算法適用于游戲中怪物的自動尋路,其效率遠遠超過A*算法,經過測試,效率是普通A*算法的幾十上百倍。

            通過引入該算法,一定程度上解決了游戲服務器端無法進行常規尋路的效率問題,除非服務器端有獨立的AI處理線程,否則在服務器端無法允許可能消耗大量時間的尋路搜索,即使是業界普遍公認的最佳的A*,所以普遍的折中做法是服務器端只做近距離的尋路,或通過導航站點縮短A*的范圍。

            算法原理
            本算法啟發于自然界中真實動物的尋路過程,并加以改善以解決各種阻擋問題。
            前置定義:
            1、探索節點:
            為了敘述方便,我們定義在尋路過程中向前探索的節點(地圖格子)稱為探索節點,起始探索節點即為原點。(探索節點可以對應為A*中的開放節點)

            2、自由的探索節點:
            探索節點朝著目標前進,如果前方不是阻擋,探索節點可以繼續向前進入下一個地圖格子,這種探索節點我們稱為自由探索節點;

            3、繞爬的探索節點:
            探索節點朝著目標前進,如果前方是阻擋,探索節點將試圖繞過阻擋,繞行中的探索節點我們成為繞爬的探索節點;
            算法過程
            1、起始,探索節點為自由節點,從原點出發,向目標前進;
            2、自由節點前進過程中判斷前面是否為障礙,
                 a、不是障礙,向目標前進一步,仍為自由節點;
                 b、是障礙,以前方障礙為界,分出左右兩個分支,分別試圖繞過障礙,這兩個分支節點即成為兩個繞爬的探索節點;
            3、繞爬的探索節點繞過障礙后,又成為自由節點,回到2);
            4、探索節點前進后,判斷當前地圖格子是否為目標格子,如果是則尋路成功,根據尋路過程構造完整路徑;
            5、尋路過程中,如果探索節點沒有了,則尋路結束,表明沒有目標格子不可達;


            演示如下: 
                
               



            B*與A*算法的性能比較

            尋路次數比較(5秒鐘尋路次數) 


             
            B*與A*性能比較實例
            1、 無障礙情況
            此種情況,根據以上測試數據,B*算法效率是普通A*的44倍(左為A*,右為B*)

                 
             

            2、線形障礙
            此種情況,根據以上測試數據,B*算法效率是普通A*的28倍(左為A*,右為B*)

               

              
            3、環形障礙
            此種情況,根據以上測試數據,B*算法效率是普通A*的132倍(左為A*,右為B*)

                  


            4、封閉障礙(目標不可達)
            此種情況,根據以上測試數據,B*算法效率是普通A*的581倍(左為A*,右為B*)
                

            衍生算法
            通過以上封閉障礙,可以看出,這個方法在判斷地圖上的兩個點是否可達上,也是非常高效的,在不可達情況下,時間復雜度與封閉障礙的周長相當,而不是整個地圖的面積。
            posted on 2011-04-07 00:07 小王 閱讀(4876) 評論(0)  編輯 收藏 引用 所屬分類: 游戲服務器端開發
            久久久久高潮综合影院| 国产成人无码精品久久久久免费| 久久久久99精品成人片三人毛片 | 久久AV高清无码| 97久久精品人人做人人爽| 合区精品久久久中文字幕一区| 久久精品国产亚洲AV电影| 精品国产青草久久久久福利| 亚洲AV日韩AV天堂久久| 国产精品xxxx国产喷水亚洲国产精品无码久久一区 | 久久午夜福利无码1000合集| AV色综合久久天堂AV色综合在 | 亚洲欧美国产日韩综合久久| 91视频国产91久久久| 无码八A片人妻少妇久久| 亚洲国产精品婷婷久久| 色婷婷久久综合中文久久蜜桃av| 欧美久久亚洲精品| 国内精品久久久久久久coent | 久久人人爽人人澡人人高潮AV | 日产精品99久久久久久| 狠狠色丁香久久婷婷综合_中 | 综合网日日天干夜夜久久 | 久久婷婷五月综合97色直播| 97久久天天综合色天天综合色hd| 国色天香久久久久久久小说| 亚洲精品无码久久久久AV麻豆| 久久艹国产| 久久久久亚洲av成人无码电影| 久久免费观看视频| 亚洲国产成人久久精品99| 亚洲а∨天堂久久精品9966| 久久久噜噜噜久久中文字幕色伊伊| 国产成人AV综合久久| 久久精品国产99国产精品| 色综合久久天天综线观看| 亚洲伊人久久综合中文成人网| 国产精品99久久久精品无码| 国内精品久久国产| 日韩乱码人妻无码中文字幕久久 | 精品无码久久久久久国产|