• <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>

            Heath's Blog

            There is no end, it is just the beginning! - A Game Developer's Notes

            Hierarchical Path-Finding

                 《Near Optimal Hierarchical Path-Finding》中提出了一種層次A*算法,正好能夠用于解決項目大地圖尋路的問題。大致思路是:1)預處理。將地圖劃分為nxn大小的區塊,找出每個區塊與周圍四個區塊在邊界上的互通點,在區塊中使用局部A*對找出的點做連通性測試并將其保存下來;2)尋路時,使用預處理得到的數據(邊界上的可通點與區塊內部的互通點),先在區塊層級上做一次A*,根據結果再在每個區塊中使用局部A*找到區塊與區塊之間的路徑,最終得到完整路徑。

            一、A* Path-Finding

                 A*算法就不多講了,可參考:

                 A*算法的優化可從搜索節點儲存和OpenList排序兩方面入手。

            二、預處理

                 每個相鄰區塊(C1和C2)都有一條由公共邊,該邊兩側小格組成L1和L2,則連通點集E滿足下列條件:

            • E ? L1 ∪ L2
            • ?t ∈ L1 ∪ L2 : t ∈ E ? symm(t) ∈ E ,其中symm(t)為對稱關系
            • E不含不可行走格子
                 對在E中且同邊的連續格子取其中點,如下圖所示:

            Image(6)

                對上面得到的位于同一區塊的點集合使用local A*做連通性測試,下圖用直線連接來表示兩點互通:

            Image(7)

            三、尋路

                 使用區塊連通信息,進行區塊級A*,得到區塊之間的連接點,如果在預處理時保存了區塊內互通點的路徑,就不必再進行區塊內的local A*了。

                 實驗結果表明,在未采用區塊內預存路徑的情況下,中長距離尋路使用層次A*后的平均效率是普通A*的5倍以上,距離越長效率對比越明顯。

            image

                 A* 93ms

            image

            HPA* 15ms

                 從上圖中可以看出,HPA*得到的路徑并不是最優的,它是在最優和效率上的折中,適合作為長距離尋路的一種優化方案。

            四、優化點

            • 可擴展為多層而不僅限于一層
            • 預存區塊內連通點路徑
            • 區塊邊界可通面積較大時,產生不自然路徑,如下圖所示:

            image

                      一個改進的方法是對過長的邊界再做劃分:

            Image(5)

            posted on 2011-11-12 12:50 Heath 閱讀(4265) 評論(0)  編輯 收藏 引用 所屬分類: Game Development

            久久综合噜噜激激的五月天| 国产亚洲精久久久久久无码| 亚洲精品tv久久久久| 亚洲人成无码网站久久99热国产| 丁香色欲久久久久久综合网| 免费观看成人久久网免费观看| 91精品国产91久久| 区亚洲欧美一级久久精品亚洲精品成人网久久久久 | 欧美一级久久久久久久大片| 无码伊人66久久大杳蕉网站谷歌 | 99久久精品免费看国产免费| 亚洲国产成人久久精品99 | 伊人久久大香线蕉综合影院首页| 久久精品国产亚洲综合色| 精产国品久久一二三产区区别| 久久精品成人国产午夜| 热re99久久6国产精品免费| 色婷婷综合久久久久中文字幕| 久久99国产精品二区不卡| 久久综合国产乱子伦精品免费| 久久综合五月丁香久久激情| 91精品国产91久久久久久蜜臀 | 香蕉久久av一区二区三区| 欧洲国产伦久久久久久久| 国产999精品久久久久久| 精品久久久久久国产91| 99久久777色| 久久er热视频在这里精品| 国产情侣久久久久aⅴ免费| 久久青青草原亚洲av无码app| 无码人妻久久久一区二区三区| 亚洲精品国产第一综合99久久| 久久久久亚洲精品天堂久久久久久 | 2022年国产精品久久久久| 性欧美丰满熟妇XXXX性久久久 | 久久夜色精品国产亚洲av| 精品久久久无码中文字幕| 国内精品久久久久久久亚洲| 伊人久久精品线影院| 日韩电影久久久被窝网| 99久久免费国产精品特黄|