I think I'm biting off more than I can chew...

Collapse
X
 
  • Time
  • Show
Clear All
new posts
  • Therem Harth
    Knight
    • Jan 2008
    • 856

    I think I'm biting off more than I can chew...

    In ToME 2, drastically increasing MONSTER_FLOW_DEPTH and turning on the flow_by_sound option will make monsters better at tracking the player. But not good enough. You still get situations like this:



    The problem is that the monsters will never move *away* from the a character to reach him around obstacles, so they get stuck behind walls or in niches. And I really have no idea how to remedy this.

    Help?
  • konijn_
    Hellband maintainer
    • Jul 2007
    • 345

    #2
    I could only imagine that there is a sanity check that makes sure the monster is moving in the right direction ( not down and not right )

    If there is such a sanity check, then you might be in a world of pain after removing it ;]

    T.
    * Are you ready for something else ? Hellband 0.8.8 is out! *

    Comment

    • Therem Harth
      Knight
      • Jan 2008
      • 856

      #3
      *invokes Wizard Mode and resurrects thread*

      Okay, I've noticed that in Vanilla (3.2.0 or later) "smart" monsters go to great lengths to follow the player around. For instance, in my current V game I saw Sauron navigate his way out of a checkerboard room to come after my character. Even Trolls will occasionally move away from @ so they can intercept him.

      How do current versions of V handle the dungeon flow stuff? This behavior is really great, and I want to bring it to T2.

      Comment

      • andrewdoull
        Unangband maintainer
        • Apr 2007
        • 816

        #4
        The Roflwtfzomgbbq Quylthulg summons L33t Paladins -more-
        In UnAngband, the level dives you.
        ASCII Dreams: http://roguelikedeveloper.blogspot.com
        Unangband: http://unangband.blogspot.com

        Comment

        • Narvius
          Knight
          • Dec 2007
          • 539

          #5
          This is... this is... beautiful.
          If you can convincingly pretend you're crazy, you probably are.

          Comment

          • EpicMan
            Swordsman
            • Dec 2009
            • 447

            #6
            Yeah, I'm using those for a roguelike I'm making (yarg-roguelike on Google Code). The best improvement other than efficiency so far is free fleeing behavior (just flow in the opposite direction as pursuit, no need for extra logic).

            Those are pretty amazing.

            Comment

            • AnonymousHero
              Veteran
              • Jun 2007
              • 1322

              #7
              Am I missing something or isn't this just A* search with custom cost functions?

              (EDIT: Not that figuring out those cost functions is all that easy, necessarily, but...)

              Comment

              • fph
                Knight
                • Apr 2009
                • 956

                #8
                I was thinking about that, too, but the implementation seems different - I haven't worked out the big-Os but intuitively this feels worse than A*.
                --
                Dive fast, die young, leave a high-CHA corpse.

                Comment

                • EpicMan
                  Swordsman
                  • Dec 2009
                  • 447

                  #9
                  So in one sense it's worse than A* because you map out the whole level rather than quitting as soon as you find the path.

                  But with Dijkstra Maps, you just need to pathfind once when the player moves,and all the monsters who need to move to the player (or run away from him) can use the same map - just check the 8 adjacent squares and take the lowest-cost one (chase the player) or highest-cost (fleeing)

                  It's a lot better when you have many monsters pathfinding to the player.

                  Comment

                  • ekolis
                    Knight
                    • Apr 2007
                    • 825

                    #10
                    Wouldn't tunneling and the like require recalculations of the map?
                    You read the scroll labeled NOBIMUS UPSCOTI...
                    You are surrounded by a stasis field!
                    The tengu tries to teleport, but fails!

                    Comment

                    • EpicMan
                      Swordsman
                      • Dec 2009
                      • 447

                      #11
                      Yes, you recalculate anytime the map changes - terrain alteration and player moves, etc. But you are only doing it once for all monsters (or all monster flows), rather than doing pathfinding for every monster.

                      Comment

                      • Therem Harth
                        Knight
                        • Jan 2008
                        • 856

                        #12
                        Wait a minute, that looks very much like what ToME does already. From the code comments:

                        Code:
                        /*
                         * Hack -- fill in the "cost" field of every grid that the player
                         * can "reach" with the number of steps needed to reach that grid.
                         * This also yields the "distance" of the player from every grid.
                         *
                         * In addition, mark the "when" of the grids that can reach
                         * the player with the incremented value of "flow_n".
                         *
                         * Hack -- use the "seen" array as a "circular queue".
                         *
                         * We do not need a priority queue because the cost from grid
                         * to grid is always "one" and we process them in order.
                         */
                        Or am I reading that wrong? Also, the code in Vanilla looks almost the same as in ToME 2...

                        Comment

                        • Therem Harth
                          Knight
                          • Jan 2008
                          • 856

                          #13
                          I think I've found another problem: when a monster has two equidistant paths to the player, it can't seem to decide which one to take, and gets stuck. Darn.

                          Edit: or perhaps that's the same issue?

                          Comment

                          Working...
                          😀
                          😂
                          🥰
                          😘
                          🤢
                          😎
                          😞
                          😡
                          👍
                          👎