How the AI Works in Pokemon Mystery Dungeon Rescue Team Red and Blue

Despite the words’ lack in the title, the two videos linked here, both made by Some Body, are all about roguelike behavior, and likely have implications for Chunsoft’s Mystery Dungeon engine generally, from which the Rescue Games derive.

In terms of depth, this post is rated 4 out of 5: highly detailed information for obsessed fans and game designers.

The first (28m):

And, the second (44m), it goes further into the weeds and is longer:

So, here’s a tl;dw overview of the first video. Despite the length, this is really only a brief summary! Some Body got their information by reverse engineering the games’ code, so it should be considered authoritative.

PMD has three times of actions, moving, attacking and using items. First they try to use an item–if there is no item to use, or the situation isn’t appropriate, or there’s a random component and they choose not to, they fall through to attacking. If there’s no one appropriate to attack, they fall through to moving or wandering. If they’re not pursuing a target and aren’t wandering, they wait in place.

Awake Pokemon try to reach a target: team members try to reach the leader (you)*, enemies try to reach a party member of yours. If they are following someone, they try to reach the target by default moving diagonally before moving orthogonally. This is good to know, and an effective strategy, since it’s harder to escape a cardinal-adjacent Pokemon than a diagonal-adjacent one. If a Pokemon has a target in sight but can’t move towards towards it, it doesn’t move.

(* Note: for teammates, this assumes the “Let’s Go Together” tactic is in effect. Generally, tactics settings are covered in the second video.)

No Pokemon can move towards a target they can’t see. Sight in Blue & Red Rescue Team is two spaces around them, or throughout a lit room they are in plus one space into corridors. Of course, invisible targets can’t be seen, even if they’re nearby. Note, a quirk of the Mystery Dungeon series generally: when standing in the first space of a corridor, you can only see slightly into the room, but everyone in the room can see you. While your default sight range in darkness is two spaces in the PMD1 games, instead of MD’s standard 1 space, you’re still a bit blind when moving into rooms. Notably, that two space distance around you is a square, so in corridors with bends in them you get a bit extra sight distance.

Now comes the interesting part (to people who are as obsessed with roguelikes as I am): what happens if a Pokemon loses sight of its target? In PMD1, it considers the last four locations the Pokemon was in, and tries to go to the one it was visible in most recently. Note in bent corridors, it becomes harder for a character to lose its target.

If the target is four turns outside of the follower’s sight, it has lost track of it, and the follower begins wandering randomly. This can happen if the Pokemon has never had a target (none has come into sight), or the target or follower teleports, the target moves over terrain the follower cannot cross, or the target moves away when the follower is occupied, or, due to the variety of events that can happen in the Mystery Dungeons, other ways.

Followers without targets wander randomly. When they spot a target, they cease moving randomly and pursue it. But if still wandering, in rooms, they pick a random exit, go to it and go down the corridor. In a corridor, they follow it until they reach a room (then entering it), or they reach an intersection. At an intersection, we see an interesting behavior: PMD1 occured before Chunsoft switched over to making wanderering monsters pick random directions at corridor intersections! In later Mystery Dungeon games, including later Pokemon Mystery Dungeons, wandering monsters go straight in intersections if they can. This is behavior that can be relied upon, but not in PMD1.

Outmatched Pokemon can decide to flee, essentially, moving away from their targets instead of towards. In rooms, they pick the exit furthermost from their pursuer, unless they moves them towards that pursuer; then they just try to get away as best they can, likely remaining in the room. A quirk of this: sometimes a fleeing monster breaks for an an exit that is more distant from the target, but not away from at attacker, giving it a free hit. The circumstances around this are complicated: the explanation begins at 7:16 in the first video.

For attacking, Pokemon have up to four moves, and a normal “attack.” This generic attack is not part of the main Pokemon game series. It was present in the first two PMD games, but after that became less effective. In the fourth and fifth PMD games, the normal attack only does five points of damage, and in the Switch remake of Rescue Team, it does no damage at all; it’s only a tool for passing time. But we’re still in the realm of PMD1, where “normal attacks” are not only useful but frequently used, because they don’t consume any PP.

Attacks are chosen based on a weighted average of all the usable moves. Each move has its own weight value; the normal attack weight’s varies according to the number of other moves available.

Ranged attacks are an interesting case. If a Pokemon has a ranged attack, and an enemy that can be attacked at a distance, it triggers the attack routine, where it picks a move from those available, but then only actually performs the move if the attack can reach its target. This can result in an attacker passing up opportunities to attack while an opponent approaches it. Out of fairness, room-range attack moves are only used by the AI when adjacent to an enemy.

Items have a bunch of minutiae associated with their use by the AI, but a lot of it is pretty ordinary. A few highlights: teammates can throw held negative status equipment at enemies, wild Pokemon start using items at Level 16, and there is only one Orb that wild Pokemon can use, and teammates can’t use it: the Rollcall Orb, for them, summons a number of other wild Pokemon into adjacency with them.

Caves of Qud Intro Videos

Caves of Qud, after over a decade of development, finally reached a 1.0 release and has, for now at least, become the toast of the more-enlightened gaming internet. Of course there will people who will look at its time-based graphics and look down on it, and go back to their games of Call of World of Fortnight Among Us Craft Duty League. But if you’re here, then there’s a good chance that you get what’s special about roguelikes. And not just roguelikes, but classic roguelikes: heavily randomized, turn- and tile-based, and challenging. Hence, Caves of Qud.

Honestly, the roguelike scene is so large now that no one person could reasonably be expected to keep track of all of it. But there is no need to; others hold aloft that particular torch. Here’s a couple of videos, then, on getting started in Caves of Qud.

Publisher Kitfox Games (who also publish the Steam release of Dwarf Fortress) sponsored a video with “Getting Started” right in its title. Here it is (18 minutes):

It contains information on the different modes, the best starting location for beginners (Joppa), basic controls, navigating around the starting town, how to get around the world map (reminiscent of Alphaman!), how to spend kill points, how to read things, how to examine Artifacts, how to experiment with things (even if it gets you killed sometimes), how to steal things, performing the water ritual, and some combat tips.

Another, slightly longer at 24 minutes, intro video is by Rogue Rat:

It covers ranged weapons, the town of Joppa, Truekin, what to do when you get lost, some different skills to learn, gaining levels from giving books to a specific NPC, using its Crawl-type Autoexplore feature and other topics. Rogue Rat did a longer, more basic, intro video (34m) last year that went over many of the same topics as the first video here.

Roguelike Celebration 2024

Starting this Saturday at noon US Eastern time (9 AM Pacific, 5 PM Greenwich, 7 PM CEST) is Roguelike Celebration 2024! I’m presenting half an hour on the Mystery Dungeon games this year, at 3:15 PM Pacific/6:15 Eastern/11:15 Greenwich/1:15 AM Sunday CEST. Whew, the roundness of the Earth makes it difficult to express times!

It’s being held entirely online again this year, and offers a fun social space to explore that’s kind of like a MUD! Roguelike Celebration’s schedule is here, and you can get tickets for $30 for the whole event here. They usually set aside some free tickets for people who can’t afford the fee, although you might have to check around to find them.

Roguelike Celebration is nominally about roguelikes and procedural generation, but I think it’s interesting from a wide variety of gaming perspectives, and every year I find several talks that are incredibly interesting. Past years have offered presentations from people who worked on games as diverse as Kingdom of Loathing and Blaseball. Here are the talks being offered this year:

Saturday

  • Harry Solomons: Trampling on Ghosts: Hauntology and Permadeath
  • Cezar Capacle: Enhancing Narrative Through Randomness and Complications
  • Max Bottega: Keeping Art Direction interesting in a procedurally generated world
  • Stanley W. Baxton: Bringing Real-World Occultism into Your Games Without Accidentally Being Racist
  • Jeff Emtman and Martin Austwick: Neutrinowatch – the podcast that plays itself
  • Nic: Braided Narratives: Or How I Learned to Stop Worrying and Love Linear Stories
  • Pandamander: “Out of Book,” The Psychology of Why Roguelikes Keep Us Playing
  • ?: Inverse Terrain Solver
  • Adrian: Probably Impossible – NecroDancer’s network code
  • John Harris: A Trip Through The Mystery Dungeons (psst: this is mine)
  • Marlowe Dobbe: A Swarm of Monsters is Hard To Build: Generating Visual Concepts for Enemies in Roguelikes
  • John Bond: Doors or no Doors: How Roguelike games take you places
  • Dan Norder: Chase, The BASIC Language Proto-Roguelike

Sunday

  • Yong Zhen Zhou: Who Controls the Controller? Thinking about physical player interactions outside a digital game
  • Tabea Iseli: Animal Crossing meets Roguelite Dungeon Crawler – The surprising genre mixture behind Grimoire Groves
  • Philomena Schwab: 100,000 wishlists in 3 months – Weird roguelikes are taking over the world
  • Kaysa Konopljak: Going legit with DotA: How to transform a thousand authors into four
  • Alexander Birke: Practical procedural world and story generation in Sea Of Rifts, a naval roguelike RPG
  • Robin Mendoza: The Use of Knowledge in the Labyrinth: The price mechanism as a storytelling device
  • Ollie: The Right Variety – Understanding and Visualising the Output Diversity of Your Generators
  • Eiríkr: Uxn – Permacomputing & Roguelikes
  • Brian Cronin: Black Box Sim for Roguelikes
  • Isaac Io Schankler: Orb Pondering Simulator LIVE!
  • ?: 7 Layer Dip, Multi-Layered Narratives For Roguelikes
  • Emily Halina: New Levels from a Single Example via Tree-based Reconstructive Partitioning (TRP)
  • Courtney: Cheating the System (By Design!) for Epic Combos
  • Joe: Magic in Game Design: (Mis)Directing the Player’s Attention
  • Tyler Coleman: Finding your 80/20 Rule with Proc-Gen
  • Nat: Procedurality and the Primes

A Japanese Youtuber Plays Rogue

I only have the barest understanding of Japanese, and the auto-translation on this video is pretty bad*, but I still found this Japanese Youtuber’s experience with the Steam release of Epyx Rogue to be interesting (27 minutes):

They keep using terms from Chunsoft’s Mystery Dungeon games, especially Torneko no Daibouken from the Super Famicom, but seem to have a good sense of how those items connect to and were inspired by Rogue.

Your armor weakens, oh my! “All the F words in the world were about to come out.”

They also die a lot. Because Rogue doesn’t want you to win. It was made for a community of players who would play it over and over, and were competing on shared scoreboards on university machines, and indefinite play makes for a poor measure of player skill. Standing and trading blows with every monster is a bad strategy in Rogue in the long run. Instead, it helps to run from strong enemies, to build up more hit points so as to defeat them, and sometimes in order to escape them to the next floor. Rogue’s monsters grow in strength as you descend fairly quickly, and the player is usually not far ahead of them in the power curve. Then around the time Trolls show up they’re roughly an even match, and they keep getting tougher. The point where the monsters become stronger than the player is different every game, and depends a lot on which items the player has found and has identified, but it always comes eventually. They eventually get pretty far, dying on their fifth attempt to a Griffin on Level 18.

*
“Water supply texture: Say goodbye to the smell of raw oysters.”
“The Dora doll’s twisty honey positive is getting warmer.”
“I miss the days when I used to go Hee Hee in Centauros.”
“Let’s quickly wash and throw away the rotten plastic bottles we drank from.”
Tell me more, auto translate bot!

Shiren 6: What Happens When You Finish The Final Dungeon

I’ve been playing a lot of Shiren the Wanderer: The Mystery Dungeon of Serpentcoil Island lately. Partly in preparation to add a chapter on it to my Mystery Dungeon book, partly because I like Mystery Dungeon games. I streamed my playthrough of finishing the main dungeon (on my first attempt!) here.

Here is the title screen (which is a spoiler for after finishing the main dungeon, although that is really only a short way into the game):

After you finish every other task in the game, including finishing the final 99 Floor “megadungeon” where most items are unidentified, the title screen changes to add a nice rainbow:

I forgot to get a picture with the title in place. I can’t go back and get it now because of what followed….

There is one more thing to do at that point though. That is to play through the megadungeon again, but finding 12 “Celestial Stones” that severely restrict your inventory by the end.

Well, I’m not sure if they really counted on anyone doing that? There doesn’t seem to be much reward for it. It doesn’t go remarked upon by anyone in the game. But it does change one thing: the title screen. Here it is:

I like the red “IN SPACE” stamp! Sadly, all the graphics in the actual game still show an island floating in the atmosphere, and not in orbit. I wonder if they plan on doing something with this in an update? That seems like a lot of extra work for the benefit of not a lot of people.

Looking through my screenshots, I found this illustration that can be unlocked for behind the main menu, showing Shiren stumbling upon a Monster House:

There’s a lot more to say about Shiren 6, after I gather up my thoughts about it….

@Play: Glorious Adventure in the Mystery Dungeon

@Play‘ is a frequently-appearing column which discusses the history, present, and future of the roguelike dungeon exploring genre.

It’s the shortest @Play column ever!

What is happening here? This is the newest Mystery Dungeon game, Shiren the Wander: The Mystery Dungeon of Serpentcoil Island. It’s actually a great deal of fun, a sharply-designed entry in the long-running classic roguelike series.

This isn’t “roguelike” like half the games on Steam. This is a true roguelike, even if it doesn’t have ASCII graphics: a turn-based RPG with substantial randomized elements, that demands that you live (or not) by your tactics, strategy and wits. I don’t begrudge others appropriation of the term, but it does mean I have to now use the qualifier classic when I want to discuss the old style. Really, it’s better to call games not in the original style roguelite.

The dungeon depicted is Heart of Serpentcoil Island, the traditional end megadungeon that most Mystery Dungeon games have. After finishing the “main” dungeon, and playing a lot of extra bonus dungeons that each show off a specific element of the game’s engine, there’s the megadungeon: a 99-level gauntlet of terror where you enter at level 1. None of the items you’ve collected throughout the rest of the game will help you here. You must start from scratch with just a riceball. You don’t even have a weapon or a shield to begin with: everything you have, you must find along the way.

The game doesn’t pull many punches in this dungeon, as you can see. At experience level 1, every space in a room (other than the entrances: that’s a secret tip for you!) could contain a game-ending trap. The only consolation is that they’re really quite rare! I was exceptionally unlucky in this run.

Additionally, the uses of many of the items, the scrolls, grasses, pots, bracelets and incense found in the dungeon, are unknown: their effects must be discovered, through means both blatant and subtle, for yourself. Some of them will be essential to your survival, let alone success; others, like the Ill-fated Seed, you really want to avoid using.

It’s a ludicrous test of knowledge and skill, and a fitting capstone to the game. If the experience shown in the video seems like it might put you off, at least it shows conclusively that the game isn’t taking it easy on you. If you win, and it can be won, it’s a great accomplishment. I’m still working on this one myself; I’ll let you know how it goes.

Roguelike Celebration Talks Start Tomorrow!

Ah, it crept up on me, so let me remind everyone that Roguelike Celebration begins today, although until tomorrow it just means they’re opening their social space for awhile. Nicole Carpenter at Polygon wrote a short piece about this year’s conference.

There is an admittance fee, but if you can’t afford it you can also get a free pass! Please consider paying them if you are able though, they do a lot of work every year in putting it together.

Here is the official schedule (linked), below is it presented just as a list of talks, with ✨sparkle emojis✨ around the things that personally enthuse me. ✨Just because!✨

Times given are US Pacific/Eastern. If you think the short times between starts are indicative of short talks, most of them aren’t that short, they have two tracks going on beside each other:

SATURDAY

9:30 AM/12:30 PM: Arron A. Reed, Klingons, Hobbits, and the Oregon Trail: Procedural Generation in ✨the First Decade of Text Games

10:00 AM/ 1 PM: Nic Tringali, ✨Abstract Space Exploration✨ in The Banished Vault

10:30 AM/ 1:30 PM: Linas Gabrielaitis, Fictions of Infinity in ✨Geological Finitudes

10:45 AM/1:45 PM: Ludipe, Exploring ✨Pacifist✨ Roguelikes

11:30 AM/2:30 PM: Florence Smith Nicholls, Another Stupid Date: ✨Love Island as a Roguelike

11:45 AM/2:45 PM Kes, Hunting the Asphynx: Roguelikes, ✨Provenance✨, and You

Noon/3 PM: Mike Cook, Generating Procedures: ✨Rule and System Generation✨ for Roguelikes

1:30 PM/4:30 PM: Scott Burger, The ✨Data Science✨ of Roguelikes

2 PM/5 PM: Nat Alison, In Defense of ✨Hand-Crafted Sudoku

3 PM/6 PM: Eric Billingsley, Scoped-down design: ✨Making a Tiny Roguelike

3:30 PM/6:30 PM: Elliot Trinidad, Touching Grass & Taking Names: Tuning the ✨Blaseball✨ Name Generator

4:30 PM/7:30 PM: Paul Hembree, Audible Geometry: Coordinate Systems as a Resource for ✨Music Generation

5 PM/8 PM: Jurie Horneman, Why ✨Dynamic Content Selection✨ Is Hard

SUNDAY

9:30 AM/12:30 PM: Mark Johnson, ✨Generating Riddles✨ for a Generated World

10 AM/1 PM: Jesse Collet & Keni, Fireside Chat About the Development of ✨NetHack

10:30 AM/1:30 PM: ✨Leigh Alexander✨, ✨McMansions of Hell✨: Roguelikes and Reality TV

1 PM/4 PM: Ray, Remixing the Layer Cake: Facilitating ✨Fan Reinterpretation✨ Through ✨Caves of Qud✨’s Modular Data Files

1:15 PM/4:15 PM: Crashtroid, Preventing Ear Fatigue with ✨Roguelike Music

1:30 PM/4:30 PM: Everest Pipkin, The Fortunate Isles: Fragment Worlds, Walled Gardens, and ✨the Games That Are Played There

2 PM/5 PM: ✨Jeff Olson✨, ✨Alphaman✨: Developing and Releasing a Post-Apocalyptic Roguelike Game in the ✨DOS Days✨ When Computers Were Slow, Memory Was Scarce, and No One Had Ever Heard of Object-Oriented Code

3 PM/6 PM: Dustin Freeman, ✨Live Action Roguelike

3:30 PM/6:30 PM: Jonathan Lessard, A ✨Simulation✨ with a View

3:45 PM/6:45 PM: Tom Francis, Generating ✨Boring Levels✨ for Fresh Experiences in Heat Signature

4 PM/7 PM: Patrick Kemp, Design Tooling at ✨Spry Fox

5 PM/8 PM: Stav Hinenzon, A Messy Approach to ✨Dynamic Narrative✨ in Sunshine Shuffle

5:15 PM/8:15 PM: Josh Galecki, ✨Procedurally Generating Puzzles

5:30 PM/8:30 PM: Jasper Cole, ✨Backpack Hero✨ – Player Upgrades and Progression

6 PM/9 PM: Brianna McHorse & Chris Foster, Fusing AI with Game Design: Let the ✨Chaos✨ In

The Worst Possible Day to Play Nethack

As we’re reminded by abadidea on Mastodon, that day is today, October 13, 2023.

Nethack uses the system time-of-day clock to affect the game in modest ways. It figures out the phase of the moon, and if it’s a full moon the player’s “base luck,” the number at which it starts and tends to trend towards, is +1. Luck affects the game in many minor ways, most notably affecting the to-hit chances of striking monsters. Full moons also affect werecreatures and the chances to tame dogs, but those effects are highly situational.

Playing on a new moon has one effect, but it’s a big one. If you’re fighting a cockatrice and you hear its hissing, and are not carrying a lizard corpse, then you always begin turning to stone, instead of there only being a one-in-ten chance. This is what is called a “delayed instadeath”: you don’t die immediately, but if you don’t take immediate action it’ll happen in the next few turns. That’s the next few turns from the game’s perspective: various events may conspire to prevent you from getting that action at all. (The Nethack Wiki’s page on petrification is instructive.)

If you do get the turn, one of the things you can do is eat a lizard corpse, or that of another acidic monster. (Eating dead monsters raw is something you just end up doing often in Nethack.) If those aren’t at hand, what usually works is prayer, provided that you haven’t prayed too recently, your patron god is not angry with you and you’re not in Gehennom. Ordinarily, if you haven’t been playing badly, your god isn’t mad at you. If you’re in Gehennom you’re in the late game anyway, and probably have had ample opportunity to obtain one of the several ways of halting impending calcification.

Prayer is nearly a universal panacea, if it’s available. But there is one other thing that can block prayer: if your luck is negative. Even if it’s by just one point, prayer will never work.

That’s where the only other date effect in Nethack comes into play: on Friday the 13th, your luck defaults to -1, the opposite of the full moon effect. So, unless you’ve increased your luck by one of a number of means, prayer will never work on Friday the 13th. And today is both a new moon night and Friday the 13th. Other uses for prayer won’t work either: if you’re weak from hunger? Too bad. Low on hit points? Sorry. Punished with a ball and chain? Not going to work. Wearing cursed levitation boots? LOL.

Days that both have a new moon and are a Friday the 13th are rare. The last one was in July of 2018, before that November of 2015, and the one before that was in 1999. So, um, if you’ve been thinking about trying out this weird old roguelike game you’ve heard about, you might want to wait a bit. Until tomorrow, anyway.

Roguelike Celebration Preview Videos

A little while ago Roguelike Celebration, this year on October 22 and 23 (later this month!), did a short preview as a promotional event. I mentioned this before, it came and went, and now the talks are online.

Nic Junius: Play as in Stage Play (38 minutes):

David Brevik on the Making of Diablo (30 minutes):

And, Aron Pietroń, Michał Ogłoziński on Against the Storm (35 minutes):

The Digital Antiquarian on Rogue and Successors

[EDIT: link fixed, thanks to the Grogpod Roguelike Podcast for pointing it out!]

I’ve been thinking about doing more @Play lately, but in the meantime, please read this mostly nice, lengthy article from The Digital Antiquarian on Rogue and its legacy. I say mostly because there are a few minor points I disagree with. Maybe I’ve played too much of it, but experienced players tend to view vanilla Nethack as maybe a bit too easy. There’s a ton to learn, but once you’ve internalized it all, you come to realize that most situations have counters, and it comes down to knowing what they are, and not pushing your luck too far. Ah! I’ve not said much on Nethack for years now! I should get back to doing that….

A screen of Amiga Rogue, from the linked article

The Digital Antiquarian: Going Rogue

Broken Connections

Broken Connections is a little game by prolific roguelike creator Slashie, Santaigo Zapata (Facebook), that puts you in the shoes of Rogue co-creator Glenn Wichman (also on Facebook) in 1980. His then-roommate Michael Toy (yep, also on Facebook) worked on Rogue over a dialup connection to the mainframe at the University of California at Santa Cruz. The game poses a (probably fictional) situation that the connection is lost, and you are tasked with traveling to campus and finding out what is wrong with the connection and reestablishing it before the system reboots and a weekend’s work is lost.

There’s no enemies or anything like that. It’s a turn-limited quest that only requires that you find your way to the machine in time and plug in a cable, but along the way you encounter a number of people who have minor problems, or recognize you and want to tell you about something, or are just about on their day. Glenn is a very nice person, but it’s up to you if you want to engage with them or continue along on the task you’re there to do. If you feel up to it, you can go back after plugging the cable in, when there isn’t a pressing time limit.

The stakes are pretty minor. If you don’t make it, a weekend’s work is lost. I’m sure Michael Toy can recreate his work, but it’d still be very nice to be able to save it. There is no big win condition, or reward for being nice to people, other the just being a good person. In that way it’s like real life.

If you want to know more about Glenn, Michael and the game, Slashie discusses it on his blog.

Broken Connections (itch.io, $0, playable in browser)

7DRL 2023: Blunt Quaternion

It’s a silly NetHack-themed game about exploring a dungeon, presented through a bunch of characters sitting around passing a blunt between them. It’s not really that hard, but there is a bit of strategy to it.

You and your pet sit around a campfire with other characters from that dungeon level and talk about things. Your character and your pet can say things like, they want to be less or more aggressive on the next level, or they want to invoke Elbereth, or they want to use an item; other characters may say things like telling you where fewer or more fights will be, or where treasure is. Or they may have nothing of importance to say.

Every time a character says something, they must pass the blunt, which when it’s depleted signals it’s time to go to the next level. (C’mon, you know all the characters in this dungeon have to be potheads.) All of the fighting and stuff happens in simulation between conversations. Your character or their pet may be wounded (observe their hit points when their conversation turn comes up), or even die at this phase. It’s possible for your pet to die but your character go on to win. It’s also possible for your character die and your pet go on to win the game, which is not something that can occur in NetHack.

It’s a very simple game, and as stated, not really that difficult. But it’s fun, and might give a chuckle to NetHack fanatics. It’s free and completely playable in browser!

Blunt Quaternion (itch.io, $0)