Reproduce the Axelrod iterated prisoners dilemma tournament
Project description
Axelrod
A library with the following principles and goals:
Enabling the reproduction of previous Iterated Prisoner’s Dilemma research as easily as possible.
Creating the de-facto tool for future Iterated Prisoner’s Dilemma research.
Providing as simple a means as possible for anyone to define and contribute new and original Iterated Prisoner’s Dilemma strategies.
Emphasizing readability along with an open and welcoming community that is accommodating for developers and researchers of a variety of skill levels.
Currently the library contains well over 100 strategies and can perform a variety of tournament types (RoundRobin, Noisy, Spatially-distributed, and probabilistically ending) and population dynamics while taking advantage of multi-core processors.
Please contribute via pull request (or just get in touch with us).
For an overview of how to use and contribute to this repository, see the documentation: http://axelrod.readthedocs.org/
If you do use this library for your personal research we would love to hear about it: please do add a link at the bottom of this README file (PR’s welcome or again, just let us know) :) If there is something that is missing in this library and that you would like implemented so as to be able to carry out a project please open an issue and let us know!
Installation
The simplest way to install is:
$ pip install axelrod
Otherwise:
$ git clone https://github.com/Axelrod-Python/Axelrod.git $ cd Axelrod $ python setup.py install
Note that on Ubuntu some users have had problems installing matplotlib. This seems to help with that:
sudo apt-get install libfreetype6-dev sudo apt-get install libpng12-0-dev
Usage
The full documentation can be found here: axelrod.readthedocs.org/.
The documentation includes details of how to setup a tournament but here is a brief example showing how to get a simple tournament:
>>> import axelrod as axl >>> axl.seed(0) # Set a seed >>> players = [s() for s in axl.demo_strategies] # Create players >>> tournament = axl.Tournament(players) # Create a tournament >>> results = tournament.play() # Play the tournament >>> results.ranked_names ['Defector', 'Grudger', 'Tit For Tat', 'Cooperator', 'Random: 0.5']
There is also a notebooks repository which shows further examples of using the library.
Results
A tournament with the full set of strategies from the library can be found at https://github.com/Axelrod-Python/tournament. These results can be easily viewed at http://axelrod-tournament.readthedocs.org.
Contributing
All contributions are welcome!
You can find helpful instructions about contributing in the documentation: http://axelrod.readthedocs.org/en/latest/tutorials/contributing/index.html
Example notebooks
https://github.com/Axelrod-Python/Axelrod-notebooks contains a set of example Jupyter notebooks.
Projects that use this library
If you happen to use this library for anything from a blog post to a research paper please list it here:
A 2015 pedagogic paper on active learning by drvinceknight published in MSOR Connections: the library is mentioned briefly as a way of demonstrating repeated games.
A repository with various example tournaments and visualizations of strategies by marcharper.
Evolving strategies for an Iterated Prisoner’s Dilemma tournament by mojones.
An Exploratory Data Analysis of the Iterated Prisoner’s Dilemma, Part I and Part II by marcharper.
Survival of the fittest: Experimenting with a high performing strategy in other environments by drvinceknight
An open reproducible framework for the study of the iterated prisoner’s dilemma <https://arxiv.org/abs/1604.00896>_: a pre print of a paper describing this library (20 authors).
Contributors
The library has had many awesome contributions from many great contributors. The Core developers of the project are:
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for Axelrod-1.9.0-py2.py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | db5f899c70893c3302dc85501ef5d6a68337226e7dd99e3cdde7adf46844e2e1 |
|
MD5 | 179eb265e43f31e7903c73010a43edb6 |
|
BLAKE2b-256 | a534b70a284fe2313021f8de8b8c0ec66686e094bb9f18f4085d2c7974ba6493 |