• <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*算法,正好能夠用于解決項(xiàng)目大地圖尋路的問題。大致思路是:1)預(yù)處理。將地圖劃分為nxn大小的區(qū)塊,找出每個區(qū)塊與周圍四個區(qū)塊在邊界上的互通點(diǎn),在區(qū)塊中使用局部A*對找出的點(diǎn)做連通性測試并將其保存下來;2)尋路時(shí),使用預(yù)處理得到的數(shù)據(jù)(邊界上的可通點(diǎn)與區(qū)塊內(nèi)部的互通點(diǎn)),先在區(qū)塊層級上做一次A*,根據(jù)結(jié)果再在每個區(qū)塊中使用局部A*找到區(qū)塊與區(qū)塊之間的路徑,最終得到完整路徑。

            一、A* Path-Finding

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

                 A*算法的優(yōu)化可從搜索節(jié)點(diǎn)儲存和OpenList排序兩方面入手。

            二、預(yù)處理

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

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

            Image(6)

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

            Image(7)

            三、尋路

                 使用區(qū)塊連通信息,進(jìn)行區(qū)塊級A*,得到區(qū)塊之間的連接點(diǎn),如果在預(yù)處理時(shí)保存了區(qū)塊內(nèi)互通點(diǎn)的路徑,就不必再進(jìn)行區(qū)塊內(nèi)的local A*了。

                 實(shí)驗(yàn)結(jié)果表明,在未采用區(qū)塊內(nèi)預(yù)存路徑的情況下,中長距離尋路使用層次A*后的平均效率是普通A*的5倍以上,距離越長效率對比越明顯。

            image

                 A* 93ms

            image

            HPA* 15ms

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

            四、優(yōu)化點(diǎn)

            • 可擴(kuò)展為多層而不僅限于一層
            • 預(yù)存區(qū)塊內(nèi)連通點(diǎn)路徑
            • 區(qū)塊邊界可通面積較大時(shí),產(chǎn)生不自然路徑,如下圖所示:

            image

                      一個改進(jìn)的方法是對過長的邊界再做劃分:

            Image(5)

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

            精品久久人人爽天天玩人人妻| 精品久久久久久亚洲| 亚洲&#228;v永久无码精品天堂久久| 国内精品伊人久久久久| 久久久精品久久久久久| 久久精品国产亚洲AV忘忧草18| 久久精品国产亚洲AV电影| 国产AⅤ精品一区二区三区久久| 亚洲乱码日产精品a级毛片久久| 一本一道久久综合狠狠老| 久久综合九色综合精品| 国产激情久久久久久熟女老人| 久久精品成人免费网站| 99久久精品免费看国产一区二区三区| 99久久国产热无码精品免费| 欧美精品一区二区久久| 久久国产精品99久久久久久老狼| 久久亚洲视频| 色综合久久精品中文字幕首页| 2021最新久久久视精品爱| 青青热久久综合网伊人| 国产亚洲精品美女久久久| 欧美亚洲国产精品久久高清| 久久精品国产欧美日韩| 一本久久久久久久| 国产精品久久久久9999高清| 精品国产乱码久久久久久人妻| 色偷偷88欧美精品久久久| 热re99久久精品国产99热| MM131亚洲国产美女久久| 国产亚洲精品久久久久秋霞 | 亚州日韩精品专区久久久| 亚洲国产二区三区久久| 99久久国语露脸精品国产| 少妇高潮惨叫久久久久久| 国产美女亚洲精品久久久综合| 久久综合偷偷噜噜噜色| 久久久久久久97| 亚洲中文字幕无码久久2017| 久久人人爽人人爽人人片AV不| 亚洲日韩中文无码久久|