This project is for recreating the boards and character dice of Super Mario Party, and running simulations on those boards to learn all kinds of fun statistical things about the game such as:
- Min, average, and max coins gained during any single game.
- Min, average, and max distance gone during any single game.
- Min, average, and max stars gained during any single game.
- The average place (1st, 2nd, etc) gained at the end of all the games.
- All of the above per the number of allies gained during that game.
- How frequently that number of allies was able to be gained.
- Min, average, and max of which turn each amount of allies was able to be gained.
- All of the above per character dice.
- All of the above per game board.
These simulations are run for each of the four game boards since one of the main questions is how each character die ends up impacting which spaces on each board you're more likely to land on, and how that goes on to affect everything else.
Not sure it's the greatest design, lol. Contrary to what may seem fine at the time, the hours between 8 PM and midnight are not the optimal times to be programming and bashing away at these kinds of simulations, lol.
Because I'm a giant nerd, lol.
For real though, with the introduction of the unique character dice in SMP, this now means that which character you choose to play has could potentially have very interesting consequences for all of the above pieces of data. This project is, at its core, to determine how significant the different character dice can impact all of this. Maybe even to the point of significantly impacting your odds of winning, and I find this an incredibly fascinating series of questions to try and answer.
The current version of these simulations is much more limited than the real SMP games due to complexity and setting more incremental, obtainable goals for myself. With this current state (plus any current goals/questions addressed), I believe that's at least a really good pausing place that still yields really good results that a SMP player could still use.
- The stars work....mostly.
- Stars are on the board and work as you would expect.
- When the agent arrives at a branching path, it will choose which path to take based on whether it can currently afford the star and which path is the shortest to the star.
- Character dice only.
- The agents only ever use the character die that they have from the beginning, though yes, in a real game a player can choose between their own character die, the character dice of any allies they have, and a standard d6. For now, this project is really about answering how effective each character die is on their own, so we can leave adding this choice for a later version of this.
- Though yes, that could end up changing things, as maybe even the standard d6 compliments some character dice far better than others.
- Another reason to hold off on this is that I'm really worried that this will introduce even more variables. It seems likely to me that different character dice are actually better or worse vs different other character dice, and I can't handle even thinking about that right now, lol.
- All four players
- While each simulation is centered on testing one main player, all four characters in a typical Mario Party game are running around the board, collecting coins and stars using the same strategies.
- Who the other three characters are for each game is chosen randomly, so the resulting statistics say how each character does generically against all characters.
- Minigames...kind of.
- As you can imagine, somehow re-implementing the entire suite of minigames and also simulating them being played is a nightmarishly tall order. Instead, I've done what I feel like is the important part for this program: This program still creates the minigame teams the same way Super Mario Party does, but then randomly decides which one of the teams won, and gives out the coins accordingly.
- I actually think this is better than trying to recreate all of the games and program AIs to actually try to beat them, because choosing a random winner removes the individual player skill from the equation, while still getting that regular injection of coins from the minigame rewards into the system.
- No Items.
- This would be a lot of work, and be tied into creating an AI that makes smarter decisions. I really don't see currently how the items could be done well in this program without an agent having some sort of decent decision making around when to buy an item, which one, and when to use it. So, for now at least, despite how helpful they can be in a game, I'm hoping the simulations are still really valuable without them.
- Bonus stars are mostly implemented.
- Specifically all but one. I don't have the Item Star, since no items.
- Fine-tune the Sand Bridge collapsing in Megafruit Paradise. I've heard it can randomly collapse after 3-5 uses, but in the four cases I've witnessed it's been 5. Either that's coincidence, or it's not 3-5, or the randomness isn't uniform. Without more data I don't know which it is for certain.
- Partially done. I did find video evidence of the bridge collapsing after four crossings, and coded that in. That really messed up Diddy and Wario's ability to gain allies, lol.
- Confirm whether the bonus Coin Star is given for having the most coins at the end, or the most coins at any point in the game.
- Any performance gains I can find in the simulations. It's slower than I'd like.
- This is really a continuous task that I should always check, but at least for now I've done everything I can.
These are goals that are a long way off, and would be done as a proper next version rather than any time soon.
- Implement an AI.
- With the stars in place, that gives the AI the goal of what they need to gather, and if it'd be great to make a proper learning agent so that it can figure out on its own just how important coins, allies, etc are towards the goal of gathering the most stars.
- In some games, like Super Smash Bros, this is ends up being a lot of waiting for the agents to train, because each character is different enough that you can't simply train an agent once, and expect it to do well for other characters. I don't believe that's the case here, as the strategies and tools available to you don't really change, only what spaces in front of you you're likely to land on based on your dice.
- Items
- Definitely a long ways off, for all the reasons listed in the "No Items" section of "Current State".
- Extend the AI to choose which dice to use.
- Phase 1 can be being able to choose between their character dice and the d6.
- Phase 2 would be also having access to their ally dice they could use.
These are measurements done on my personal PC. Looks like the current multithreading that's being done is able to provide more and more benefit as I ask this program to perform more simulations, though still sticks pretty close to being around 1 simulation per millisecond.
Board Name | 5,000 | 10,000 | 50,000 | 100,000 | 500,000 | 1,000,000 |
---|---|---|---|---|---|---|
Whomp's Domino Ruins | 6.029 | 11.811 | 54.568 | 106.939 | 535.098 | 1,027.327 |
Megafruit Paradise | 5.556 | 10.552 | 50.528 | 94.915 | 484.787 | 983.276 |
King Bobomb's Powderkeg Mine | 5.926 | 11.440 | 53.658 | 105.891 | 519.937 | 1012.499 |
Kamek's Tantalizing Tower | 4.577 | 9.008 | 41.031 | 80.294 | 407.605 | 755.122 |
Board Name | 5,000 | 10,000 | 50,000 | 100,000 | 500,000 | 1,000,000 |
---|---|---|---|---|---|---|
Whomp's Domino Ruins | 1.206 | 1.181 | 1.091 | 1.069 | 1.070 | 1.027 |
Megafruit Paradise | 1.111 | 1.055 | 1.011 | 0.949 | 0.970 | 0.983 |
King Bobomb's Powderkeg Mine | 1.185 | 1.144 | 1.073 | 1.059 | 1.040 | 1.012 |
Kamek's Tantalizing Tower | 0.915 | 0.901 | 0.821 | 0.803 | 0.815 | 0.755 |