A dominion simulator for playing the card game of dominion. It now includes a front end UI. The UI is a card picking UI that will help you setup a game of dominion. Unlike most card pickers, you have the ability to run simulations of simple card combinations. A report will be generated which gives insights that can guide you into how to play this set of cards
The goals of the project are as follows.
- Create a game engine which enforces the rules of Dominion the game. Separation of Game Rules from AI or heuristics is required.
- Simulation of all available dominion cards.
- Ability to easily extend the game engine with custom cards.
- Include a foundation for easily composing strategies from simple build orders.
- Include default strategies for playing most cards.
- Create a strategy optimizer that given a set of 10 cards, finds the best combination to play.
- Includes ability to generate a standalone HTML report, detailing the play of the strategies
- A windows 8 UI for composing strategies
Goal 6 is lofty - but would be very nice :).
Install Visual Studio community edition
- Load Dominion.sln from the root of the repository
- Make sure a Results folder exists in the root of your enlistment
- In the TestPrograms folder, select one of the test programs for startup.
OR to contribute to the UI
- Load Win8Client.sln from the root of the repository
Contains the logic of the game and all card definitions. Enforces the rules of the game.
Exposes the IPlayerAction interface that must be implemented to create player behavior.
Also contains human readable game log output and debug log output.
Contains a framework for defining dominion strategies.
PlayerAction can be customized with a purchase order, action order, gain order, trash order, discard order etc ... This emulates
the strategy definition patterns seen in other common simulators.
PlayerAction also has a set of default play rules for each card. There are many more default play rules that need to be defined
Contains an implementaiton of the GameLog that gathers various statistics about the game. These statistics are used to create pretty graphs in the html renderer and in the webservice
Lots of examples of built in strategies. All of these strategies demonstrate how to use the strategy framework defined in Dominion.Strategy
Contains a copy of all the strategies in Dominion.BuiltInStrategy. In this module, they are compiled as embedded resources. The module includes methods to dynamically compile and load strategies at run time.
Some rudimentary code that searches for the best set of parameters in a given strategy to optimize the win rate vs a control strategy
An exe that launches a local webservice exposing most of the functionality of the simulator. The dynamic strategy loader allows the user to type in new strategies into the web app - which can then be compared against one another.
Code for generating Html Reports
Misc helper methods for working with resources
Common methods used by the various test programs.
There are several different test programs that you can use to test the functionality of the simulator. These can all be found in the TestPrograms folder
It compares 2 strategies against each other, and tells you which one is better. There are lots of example strategies to
try in the Strategies namespace. Modify the program to use one of the different built in strategies, or create your own.
There are various verbosity options on the compare method for seeing the results. Setting CreateHtmlReport to true
writes out a detailed html file with graphs and gamelogs. There are also code for various other simulations in this project
that I haven't factored out yet
This is a regression test that will test all of the existing cards with their default strategies against a bigmoney strategy.
When you write a new strategy, this program will rank it against all of the built in strategies that have been checked in so far. As checked in, it compares all of the strategies to bigmoney. Change bigmoney to someother strategy to see how yours compares
The strategy optimizer allows strategies to be parameterized. Use this program for a relatively simple genetic algorithm that will find the best parameters. A work in progress still.
You can also set the Default Startup project to the Webservice project.
The webservice is a playground I have been using. Once launched, browse to http://localhost:8081/dominion You will see a webapp that is capable of dynamically loading all included strategies (in the dynamic strategy loader module). You can edit the strategies in the web browser and get some quick reports on how they compare.
This folder contains the UI of the project.
Test programs output to the console. They will also output files in the Results directory of the root of the git repository.
Most test programs can be configured to output individual game logs and also an html summary report.
The Webservice provides a more interactive view of the output
You can write a strategy to behave any way you want, but that's a lot of work.
Most strategies right now derive from PlayerAction. You specify a purchase order, discard order, trash order etc... along with a few method overrides and voila!
There are many example strategies included already. Look in the Dominion.BuiltInStrategies project.
I am the only ones making checkins right now, but please send me a changelist of anything you would like and I will try to get it included.
Though the project is public, please refrain from forking the code. When I'm making changes, there will be large amounts of refactoring and re-organization. I will keep everything checked in working, but will not be worried about breaking external dependencies.
I have decided to begin collaboration on this project before it is complete. It's already useful enough for people to play around with it. Expect to find bugs.
- Many of the cards are implemented, but not all of them. Goal is to eventually have them all complete.
- Implement default strategies for the cards so they play as well as possible without custom strategies
- Write innovating strategies. Compare your strategy vs the others
- We need test case infrastructure. Long term, I would like to see a test case for every clarifiction in the rule book.
- Contribute to the strategy optimizer
Dominion has 205 kingdom cards. There are currently 31 cards that can throw NotImplementedException.
The game engine enforces the rules of the game. If a strategy is breaking the rules, the game engine will throw an exception. The correct fix here is to fix the strategy.
If you are implementing a player action and forget to implement a callback that a card needs, you will get an exception.
The game will also throw an exception if you use a card that hasn't been implemented yet.
There are also bugs ...