Skip to main content

A Python package designed to play, develop strategies/algorithms, and implement the classic MasterMind board game.

Project description

pymastermind

Description

A Python package designed to play, develop strategies/algorithms, and implement the classic MasterMind board game. It even includes a functioning, text-based implementation of MasterMind!

Installation

The source code for pymastermind is hosted on GitHub. You can install matermind through PyPI, with pip:

pip install pymastermind

Requirements

pymastermind requires the following libraries:

  • pandas, used by the SelfGame object
  • tqdm, used to display progress bars when finding next guess. Note: only some algorithms support progress bars. See "Algorithms" below.

Documentation

Read the full documentation for pymastermind here.

Example Usage

Play

Play a game against your computer, or have your computer play itself, by running main() and following text-based instructions.

>>> main() # initiate the game; print instructions & wait for inputs

Classes

Several useful classes are defined in the pymastermind module.

Code

Code objects are list instances designed to store a MasterMind codes. You can compare two codes by using the .compare() method. What's comparing?

>>> secret_code = Code(['a', 'b', 'c', 'd'])
>>> guess = Code(['b', 'c', 'j', 'd'])
>>> len(secret_code) == len(guess)
True
>>> secret_code.compare(guess)
(1, 2)

Note: code objects must be of the same length to comapre.

Game

Game objects are used to immitate gameplay.

>>> my_game = Game() # default: slots == 4, colors == ['a', 'b', 'c', 'd', 'e', 'f']
>>> secret_code = Code(['e', 'a', 'f', 'f'])
>>> my_game.guess # always the same for given setup; see Wikipedia article
['a', 'a', 'b', 'b']
>>> blacks_and_whites = secret_code.compare(my_game.guess)
>>> blacks_and_whites
(1, 0)
>>> my_game.new_guess(response, algorithm='minmax') # new guess using minmax algorithm (see below)
>>> my_game.guess
['a', 'c', 'c', 'd']
>>> my_game.back() # go back one turn
>>> my_game.guess
['a', 'a', 'b', 'b']

Read the documentation for an in-depth look at all the attributes and methods of a Game.

Algorithms

A new guess can be generated using several different algorithms. Currently, pymastermind has two algorithms implemented:

  • random (default algorithm)
    • Set the guess to a random secret code possibility
    • No progress bar support yet
  • minmax
    • Set the guess to the guess that has the highest min-max score of all guesses. Read more here.
    • Supports progress bars

See the full documentation for a more detailed description of the algorithms.

SelfGame

SelfGame is a subclass of Game that is used to "play" games with specified algorithms and obtain a pandas DataFrame full of information about the games played.

>>> my_self_game = SelfGame() # same defaults, so slots == 4, colors == ['a', 'b', 'c', 'd', 'e', 'f']
>>> df = my_self_game.play() # default: games == 10, algorithm == 'random'
>>> type(df)
<class 'pandas.core.frame.DataFrame'>
>>> df.loc['Game 3', 'Turn 2'] # example query
Time                   0 days 00:00:00.000610
Start Possibilities                        23
End Possibilities                           4
Name: Game 3, dtype: object

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pymastermind-1.2.tar.gz (10.8 kB view details)

Uploaded Source

File details

Details for the file pymastermind-1.2.tar.gz.

File metadata

  • Download URL: pymastermind-1.2.tar.gz
  • Upload date:
  • Size: 10.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.19.1 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.35.0 CPython/3.7.0

File hashes

Hashes for pymastermind-1.2.tar.gz
Algorithm Hash digest
SHA256 4055b4b4d8c796138bcefb76883099b5285bc0d1beccf005fba2afa849069197
MD5 b77c95ecf440fc208cb72f36051c62da
BLAKE2b-256 ad6f4ac3be7be642e6c19fa3fddf56469afe7e5af149dbabc42672f9260f28d1

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page