Register forum user name Search FAQ

Gammon Forum

Notice: Any messages purporting to come from this site telling you that your password has expired, or that you need to "verify" your details, making threats, or asking for money, are spam. We do not email users with any such messages. If you have lost your password you can obtain a new one by using the password reset link.
 Entire forum ➜ SMAUG ➜ Lua ➜ Adding path finding command to SMAUG

Adding path finding command to SMAUG

It is now over 60 days since the last post. This thread is closed.     Refresh page


Pages: 1 2  

Posted by Nick Gammon   Australia  (23,052 posts)  Bio   Forum Administrator
Date Sat 07 Jul 2007 04:08 AM (UTC)
Message
Now that I have been adding Lua scripting to SMAUG Fuss, I have been experimenting with the path-finding algorithm described in this post:

http://www.gammon.com.au/forum/bbshowpost.php?id=7306

The objective of this was to help newbies find their way around, by listing common locations (eg. baker, repairs, academy), and tell them the way to walk to get there. I am sure I have seen something similar in one of the pay MUDs.

This code is entirely implemented in Lua, except for the 3 lines of code needed to add the command handler into the commands list.

Here is an example of it in operation. First you can type "whereis" to find the known destinations:


whereis

This will show you how to get to commonly-used locations.
Type 'whereis [destination]' to get a suggested route (eg. 'whereis baker').

    Destination : Room name
-------------------------------------------------------
        Academy : Entrance to the Academy
      Alchemist : The Alchemist's
          Baker : The Darkhaven Bakery
   Battleground : Battle Grounds
        Butcher : The Butcher's Shop
Cathedral altar : The Cathedral Altar
       Clothing : Annir's Clothing
          Dairy : The Dairy Tent
      East gate : Inside the Eastern Gate
       Fountain : Darkhaven Academy
   Headmistress : Darkhaven Academy
         Healer : The Academy Healer
            Inn : The Darkhaven Inn
      Languages : Abbigayle's Language Lessons
          Magic : The Wizard's Tent
     North gate : Inside the Northern Gate
        Repairs : The Blacksmith's Tent
        Scrolls : The Scribe's Tent
         Skills : The Laboratory of Skills and Spells
     South gate : Inside the Southern Gate
         Square : Darkhaven Square
         Tailor : Annir's Clothing
         Tavern : The Tavern
        Weapons : Weaponry Shop
      West gate : Inside the Western Gate


The exact list is under your control, as you edit a table of vnums that you want to be made available. Now you can choose one:


whereis repairs

To get to The Blacksmith's Tent walk: 5s 2e (se) 2s e s


This generates the shortest path from the current room to the selected room, using the algorithm mentioned before.

Here is another example:


whereis academy

To get to Entrance to the Academy walk: 5s 2e (se) 3e s


The list of destinations is in the Lua source file, it looks like this:


available_dests = {
   butcher = 21057,
   academy = 21280,
   inn = 21069,
   baker = 21060 ,
   tavern = 21068,
   dairy = 21061,
   alchemist = 21054,
   weapons = 21062,
   square = 21000,
   magic = 21055,
   scrolls = 21051,
   repairs = 21058,
   clothing = 21066,
   headmistress = 10300,
   languages = 10306,
   skills = 10303,
   healer = 10319,
   battleground = 10368,
   fountain = 10300,
   tailor = 21066,
   ["south gate"] = 21074,
   ["north gate"] = 21100,
   ["west gate"] = 21088,
   ["east gate"] = 21113,
   ["cathedral altar"] = 21194,
   
   }


You can customize it to show as many or as few rooms as you want. The room descriptions are looked up, and the list sorted into alphabetic order.

- Nick Gammon

www.gammon.com.au, www.mushclient.com
Top

Posted by David Haley   USA  (3,881 posts)  Bio
Date Reply #1 on Sat 07 Jul 2007 07:30 AM (UTC)
Message
Cool stuff! One quick question; why are some of the directions parenthesized?

David Haley aka Ksilyan
Head Programmer,
Legends of the Darkstone

http://david.the-haleys.org
Top

Posted by Nick Gammon   Australia  (23,052 posts)  Bio   Forum Administrator
Date Reply #2 on Sat 07 Jul 2007 07:58 AM (UTC)
Message
With speedwalking in MUSHclient the spaces are optional, so you can write this:


4s2ensw


There is an obvious ambiguity for the "sw" part. Is it southwest, or south, followed by west?

So, MUSHclient uses parentheses for the directions nw, sw, ne,se.

Thus, the generated speedwalks follow the same pattern. You could change the output routine to do it differently, I initially had it like this:


s, s, s, s, s, e, e, se, s, s, e, s


This is clearer, if a bit wordy (note the multiple occurences of "s"), so I changed it to be something that could be copied and pasted into MUSHclient's speedwalks.

- Nick Gammon

www.gammon.com.au, www.mushclient.com
Top

Posted by David Haley   USA  (3,881 posts)  Bio
Date Reply #3 on Sat 07 Jul 2007 08:10 AM (UTC)
Message
Oh, right, I forgot about that... good reason.

I'm almost done implementing a trie class in Lua -- a map whose keys must be strings, and where the lookup time is proportional to the length of the key, not the number of elements. I'm going to use it for the command table implementation in Lua; I need to do prefix lookup in addition to exact matching.

David Haley aka Ksilyan
Head Programmer,
Legends of the Darkstone

http://david.the-haleys.org
Top

Posted by Gohan_TheDragonball   USA  (183 posts)  Bio
Date Reply #4 on Sat 07 Jul 2007 09:07 AM (UTC)
Message
so you have to physically list every room and where its exits lead to in the table?
Top

Posted by Nick Gammon   Australia  (23,052 posts)  Bio   Forum Administrator
Date Reply #5 on Sat 07 Jul 2007 10:42 AM (UTC)
Message
No, it works it out.

As a once-only operation, you run a command that generates a list of rooms and exits, like this:


rooms = {}
rooms [21013] = {
   exits = {s=21014, n=21012, } }
rooms [21021] = {
   exits = {e=21020, w=21022, n=24800, } }
rooms [21029] = {
   exits = {s=21028, n=21030, } }
rooms [21037] = {
   exits = {e=21038, s=21126, w=21036, } }


This is automatically generated from your rooms information.

To find a path the algorithm works out the shortest route, see the thread I posted for the way it works.

- Nick Gammon

www.gammon.com.au, www.mushclient.com
Top

Posted by David Haley   USA  (3,881 posts)  Bio
Date Reply #6 on Sat 07 Jul 2007 03:28 PM (UTC)
Message
You could also get that information by binding rooms to Lua objects; if you started by binding the current room and all neighboring rooms (which is really all you need anyhow) the memory requirements would be fairly small, and you wouldn't have the issue of pointers becoming invalid because you do the search 'instantly' -- people can't destroy rooms as you search.

David Haley aka Ksilyan
Head Programmer,
Legends of the Darkstone

http://david.the-haleys.org
Top

Posted by Nick Gammon   Australia  (23,052 posts)  Bio   Forum Administrator
Date Reply #7 on Sat 07 Jul 2007 09:54 PM (UTC)
Message
Good idea, David.

I have reworked the algorithm so it no longer needs a separately-generated file of rooms and exits. After all, it has that information available to it.

This also makes it more flexible, you could have it offer a different set of destinations, depending on where you are.

For example, town A could have a list of local places, and town B could have a different list.

So now it is completely automatic - everything is done from the in-memory rooms list.

- Nick Gammon

www.gammon.com.au, www.mushclient.com
Top

Posted by Conner   USA  (381 posts)  Bio
Date Reply #8 on Sat 07 Jul 2007 10:33 PM (UTC)
Message
This sounds really nifty, Nick. I'm not sure I follow entirely though, between the five pages of the other thread and the posts in this one, I don't quite see how you've done this. Would it be asking too much to see your actual code for this? It really sounds like a command I'd love to give my players that would get a lot of use on my mud once it's known.

-=Conner=-
--
Come test your mettle in the Land of Legends at telnet://tcdbbs.zapto.org:4000
or, for a little family oriented medieval fun, come join us at The Castle's Dungeon BBS at telnet://tcdbbs.zapto.org
or, if you just want information about either, check our web page at http://tcdbbs.zapto.org
Top

Posted by Nick Gammon   Australia  (23,052 posts)  Bio   Forum Administrator
Date Reply #9 on Sat 07 Jul 2007 10:34 PM (UTC)
Message
I have now allowed for multiple places that offer directions (eg. multiple towns).

There is now a table for each "zone" that you want to offer directions around. By checking the player's room against a vnum range, the appropriate list of directions is offered.

For example, if you move to Redferne's residence and type "whereis" you now get a different list:



    Destination : Room name
-------------------------------------------------------
        Kitchen : The Kitchen of Naris
    Monster pen : The Monster Pen
        Outside : Outside Redferne's residence

Type 'whereis [place]' to get a suggested route (eg. 'whereis kitchen').


- Nick Gammon

www.gammon.com.au, www.mushclient.com
Top

Posted by Conner   USA  (381 posts)  Bio
Date Reply #10 on Sat 07 Jul 2007 11:44 PM (UTC)
Message
That really is cool.. sure wish I could figure out how to add it to my mud... ;)

-=Conner=-
--
Come test your mettle in the Land of Legends at telnet://tcdbbs.zapto.org:4000
or, for a little family oriented medieval fun, come join us at The Castle's Dungeon BBS at telnet://tcdbbs.zapto.org
or, if you just want information about either, check our web page at http://tcdbbs.zapto.org
Top

Posted by Nick Gammon   Australia  (23,052 posts)  Bio   Forum Administrator
Date Reply #11 on Sun 08 Jul 2007 12:54 AM (UTC)
Message
You are welcome to see it, however it relies upon the Lua hooks I mentioned in the earlier posting.

I am tidying up the Lua interface, and adding a much more general "task" system (ie. a quest system).

It is working fairly well, I am just adding some example tasks to demonstrate the whole thing. When that is done I will release the entire code, Lua and C part, and you can see how it is all done.

It should be very simple to add to an existing SMAUG-based MUD.

- Nick Gammon

www.gammon.com.au, www.mushclient.com
Top

Posted by Conner   USA  (381 posts)  Bio
Date Reply #12 on Sun 08 Jul 2007 01:26 AM (UTC)
Message
Ok, Nick, I'll be patient then. :)

-=Conner=-
--
Come test your mettle in the Land of Legends at telnet://tcdbbs.zapto.org:4000
or, for a little family oriented medieval fun, come join us at The Castle's Dungeon BBS at telnet://tcdbbs.zapto.org
or, if you just want information about either, check our web page at http://tcdbbs.zapto.org
Top

Posted by Valcados   (15 posts)  Bio
Date Reply #13 on Tue 24 Jul 2007 12:58 AM (UTC)
Message
Forgive the late reply, I just registered for this forum.

Why create this complex LUA pathfinding algorithm when a pathfinding algorithm already exists in track.c? It's fairly straightforward to modify the algorithm in track.c to let you know the whole path, vs. just the first step. After all, it already traces the whole path anyway, then just throws away all the info except the first step.
Top

Posted by Nick Gammon   Australia  (23,052 posts)  Bio   Forum Administrator
Date Reply #14 on Tue 24 Jul 2007 01:59 AM (UTC)
Message
I must admit I didn't notice the track skill. It looks like it could be modified to find the path to a room (it currently finds a mob, so presumably finding the room it is in is part of it).

The Lua code isn't particularly complex - I can't see offhand exactly what method the track.c code uses, although it looks similar.

There is certainly more than one way of doing things like that - however to make the code in track.c do exactly what the Lua code does, you would need a few changes - like making a list of destination rooms, showing the possible rooms you can go to, finding the full path, returning it in a nice readable way, and so on.

I was really just trying to show how reasonably complex things can be done in the Lua interface - I don't doubt you could also do them in straight C.

- Nick Gammon

www.gammon.com.au, www.mushclient.com
Top

The dates and times for posts above are shown in Universal Co-ordinated Time (UTC).

To show them in your local time you can join the forum, and then set the 'time correction' field in your profile to the number of hours difference between your location and UTC time.


56,646 views.

This is page 1, subject is 2 pages long: 1 2  [Next page]

It is now over 60 days since the last post. This thread is closed.     Refresh page

Go to topic:           Search the forum


[Go to top] top

Information and images on this site are licensed under the Creative Commons Attribution 3.0 Australia License unless stated otherwise.