New strategies, increased test coverage, refactor of some tests, documentation and minor bug fixes.
- New strategy: VeryBad Axelrod-Python#869
- New strategy: Resurrection Axelrod-Python#865
- Documentation of docstring requirements for contributions Axelrod-Python#872
- Refactor tests: Axelrod-Python#875 Axelrod-Python#907 Axelrod-Python#908 Axelrod-Python#909 Axelrod-Python#911 Axelrod-Python#914
- Improved coverage: Axelrod-Python#899 Axelrod-Python#900 Axelrod-Python#901 Axelrod-Python#902 Axelrod-Python#904 Axelrod-Python#905 Axelrod-Python#910
- Bug in plot: Axelrod-Python#897
- Bug fix in deterministic cache: Axelrod-Python#882
- Bug in average copier: Axelrod-Python#912
- Minor function rename: Axelrod-Python#906
Here are all the commits for this PR: https://github.com/Axelrod-Python/Axelrod/compare/v2.6.0...v2.7.0
New strategy, state to action analysis and internal improvements
- A number of type hints added to the library Axelrod-Python#860 Axelrod-Python#863 Axelrod-Python#864
- New strategy: SelfSteem Axelrod-Python#866
- Add state to action analysis Axelrod-Python#870
Here are all the commits for this PR: https://github.com/Axelrod-Python/Axelrod/compare/v2.5.0...v2.6.0
Internal improvements, type hints, documentation and a new strategy
- New strategy: ShortMem Axelrod-Python#857
- A number of type hints added to the library Axelrod-Python#828 Axelrod-Python#831 Axelrod-Python#832 Axelrod-Python#833 Axelrod-Python#834 Axelrod-Python#835 Axelrod-Python#836 Axelrod-Python#840 Axelrod-Python#846 Axelrod-Python#847 Axelrod-Python#849 Axelrod-Python#850 Axelrod-Python#851 Axelrod-Python#853 Axelrod-Python#854 Axelrod-Python#856 Axelrod-Python#858 Axelrod-Python#824 Axelrod-Python#821 Axelrod-Python#815 Axelrod-Python#814
- internal improvement to how players are cloned Axelrod-Python#817
- Refactor/removal of dynamic classes Axelrod-Python#852
- Run windows CI for py3.6 Axelrod-Python#844
- Run mypi on travis Axelrod-Python#843 Axelrod-Python#837
- Small update to the readme Axelrod-Python#829
- Docstring fix for random Axelrod-Python#826
- Improve efficiency of neural network strategy Axelrod-Python#819
- Improve efficiency of cycle detection Axelrod-Python#809
- Refactor of a number of tests and test documentation Axelrod-Python#820
- Large refactor thanks to dropping of python 2 Axelrod-Python#818
Here are all the commits for this PR: https://github.com/Axelrod-Python/Axelrod/compare/v2.4.0...v2.5.0
New machine learning strategies and moran processes on graphs.
- Moran processes on graphs Axelrod-Python#799
- Machine learning strategies Axelrod-Python#803
Here are all the commits for this PR: https://github.com/Axelrod-Python/Axelrod/compare/v2.3.0...v2.4.0
Support for py3.6, new strategies, more tournament result information, and internal improvements.
- Helpful list of short run time strategies Axelrod-Python#792
- Nice Meta strategy Axelrod-Python#794
- New strategies: Mem2, Pun1, Collective Strategy Axelrod-Python#795
- New strategies: Mem2, Pun1, Collective Strategy Axelrod-Python#795
- Python 3.6 supported Axelrod-Python#800
- Keep track of initial play rate in results Axelrod-Python#797
- Fix depreciation warning Axelrod-Python#793
- Moran processes are always stochastic Axelrod-Python#796
Here are all the commits for this PR: https://github.com/Axelrod-Python/Axelrod/compare/v2.2.0...v2.3.0
Minor update: ability to pass axes object to plots and internal documentation build fix.
- Pass axis object to plots Axelrod-Python#791
- Build docs with py3 Axelrod-Python#788
Here are all the commits for this PR: https://github.com/Axelrod-Python/Axelrod/compare/v2.1.0...v2.2.0
Dropping support for python 2, bug fixes, minor tidy of code (thanks to dropping python 2 support!) and progress bars for fingerprinting.
- Dropping support for python 2 Axelrod-Python#774
- Fix bug in cache Axelrod-Python#782
- Fix bug in stochastic classification of Random player Axelrod-Python#783
- Fix docstrings in fingerprint Axelrod-Python#784
- Use python 3 function caching Axelrod-Python#775
- More progress bars for fingerprinting Axelrod-Python#778
Here are all the commits for this PR: https://github.com/Axelrod-Python/Axelrod/compare/v1.19.0...v2.0.0
New strategy using a trained neural network and documentation.
- Implement the EvolvedANN Axelrod-Python#773
- More strategy documentation Axelrod-Python#772
Here are all the commits for this PR: https://github.com/Axelrod-Python/Axelrod/compare/v1.18.1...v1.19.0
There are no changes between 1.18.1 and 1.18.0. This release is due to an error during the uploading to pypi.
There are no changes between 1.18.0 and 1.17.1. This release is due to an error during the uploading to pypi.
Minor bug fix and a title option for fingerprints and a small internal improvement.
- Correct the range for the fingerprint Axelrod-Python#766
- Include ability to have a title for fingerprint plot Axelrod-Python#769
- Calculate score per turn for Moran process using internal method. Axelrod-Python#764
Here are all the commits for this PR: https://github.com/Axelrod-Python/Axelrod/compare/v1.17.0...v1.17.1
Ahslock fingerprinting.
- Add a class for fingerprinting of strategies according to a paper by Ashlock et al. Axelrod-Python#759
Here are all the commits for this PR: https://github.com/Axelrod-Python/Axelrod/compare/v1.16.0...v1.17.0
Minor internal change, new strategy and new strategy transformers
- Random_choice method does not sample if not necessary Axelrod-Python#761
- New strategy: Meta Winner Ensemble Axelrod-Python#757
- New strategy transformers: Dual transformer and Joss-Ann transformer Axelrod-Python#758
Here are all the commits for this PR: https://github.com/Axelrod-Python/Axelrod/compare/v1.15.0...v1.16.0
Mutation in Moran process, players track state pairs, save all plots method, new strategies and PEP8.
- Mutation in Moran processes: Axelrod-Python#754
- Save all plots to file method: Axelrod-Python#753
- Players track state pairs: Axelrod-Python#752
- New strategies: - StochasticCooperator (re introduced): Axelrod-Python#755 - SpitefulTitForTat Axelrod-Python#749
- PEP8: Axelrod-Python#750
Here are all the commits for this PR: https://github.com/Axelrod-Python/Axelrod/compare/v1.14.0...v1.15.0
Two new strategies.
- Adding Negative strategy Axelrod-Python#748
- Adding Doubler strategy Axelrod-Python#747
Here are all the commits for this PR: https://github.com/Axelrod-Python/Axelrod/compare/v1.13.0...v1.14.0
New strategy, state distribution and documentation
- Adding Prober4 strategy Axelrod-Python#743
- Adding state distribution to results set Axelrod-Python#742
- More references for strategies Axelrod-Python#745
Here are all the commits for this PR: https://github.com/Axelrod-Python/Axelrod/compare/v1.12.0...v1.13.0
Human interactive player, new strategy, under the hood improvements and documentation.
- You can play against an instance of
axelrod.Human
Axelrod-Python#732 - Improved efficiency of result set from memory Axelrod-Python#737
- Documentation improvements Axelrod-Python#741 Axelrod-Python#736 Axelrod-Python#735 Axelrod-Python#727
- New strategy CyclerCCCDCD: Axelrod-Python#379
Here are all the commits for this PR: https://github.com/Axelrod-Python/Axelrod/compare/v1.11.0...v1.12.0
Human interactive player, new strategy, under the hood improvements and documentation.
- You can play against an instance of
axelrod.Human
Axelrod-Python#732 - Improved efficiency of result set from memory Axelrod-Python#737
- Documentation improvements Axelrod-Python#741 Axelrod-Python#736 Axelrod-Python#735 Axelrod-Python#727
- New strategy CyclerCCCDCD: Axelrod-Python#379
Here are all the commits for this PR: https://github.com/Axelrod-Python/Axelrod/compare/v1.11.0...v1.12.0
State distribution functions, new strategies and minor test fix.
- Matches have a method to give state distribution: Axelrod-Python#717
- Two new strategies: Worse and Worse and Knowledgeable Worse and Worse. Axelrod-Python#724
- Minor fix of a test that would sometimes fail due to floating point error. Axelrod-Python#725
Here are all the commits for this PR: https://github.com/Axelrod-Python/Axelrod/compare/v1.10.0...v1.11.0
Windows support! Summarise method for results, new strategies, and code of conduct as well as minor fixes.
- Various fixes to windows bugs (thanks to the PyConUK sprint!): Axelrod-Python#711 Axelrod-Python#714 Axelrod-Python#721
- The result set has a summary: Axelrod-Python#707
- Three new strategies (Gradual killer, easy go, Grudger alternator): Axelrod-Python#715
- Code of conduct: Axelrod-Python#705
- Fix of some tests: Axelrod-Python#716
- Fix of link in docs: Axelrod-Python#722
Here are all the commits for this PR: https://github.com/Axelrod-Python/Axelrod/compare/v1.9.0...v1.10.0
Filtering of strategy classes with a filterset dictionary.
Here are all the commits for this PR: https://github.com/Axelrod-Python/Axelrod/compare/v1.8.0...v1.9.0
New strategies:
- Adaptive TitForTat: Axelrod-Python#697
- Desperate, Hopeless, Willing: Axelrod-Python#686
Here are all the commits for this PR: https://github.com/Axelrod-Python/Axelrod/compare/v1.7.0...v1.8.0
Probabilistic ending spatial tournaments, classifier for long run time, style improvements, documentation improvements (including a bibliography) and bug fix.
- Probabilistic ending spatial tournaments: Axelrod-Python#674
- Classifier for strategies that have a long run time: Axelrod-Python#690
- Documentation and style cleanup:Axelrod-Python#675, Axelrod-Python#687, Axelrod-Python#685, Axelrod-Python#682
- Fix the noise in spatial tournaments: Axelrod-Python#679
Here are all the commits for this PR: https://github.com/Axelrod-Python/Axelrod/compare/v1.6.0...v1.7.0
Renaming of strategies, big performance improvement for result analysis and bug fixes
- axelrod.strategies is a list of well behaved (non cheating strategies): Axelrod-Python#665
- The results set now has much lower memory footprint and is much faster: Axelrod-Python#672
- Correct calculation for mean score diffs: Axelrod-Python#671
- Error catching for bug with OSX, virtual envs and matplotlib: Axelrod-Python#669
Here are all the commits for this PR: https://github.com/Axelrod-Python/Axelrod/compare/v1.5.0...v1.6.0
New tournament type, new strategy, seeding, dev tools, docs + minor/bug fixes
User facing:
- Spatial tournaments: Axelrod-Python#654
- New strategy, slow tit for tat: Axelrod-Python#659
- Seed the library: Axelrod-Python#653
- More uniform strategy transformer behaviour: Axelrod-Python#657
- Results can be calculated with non default game: Axelrod-Python#656
Documentation:
- A community page: Axelrod-Python#656
- An overall results page that replaces the payoff matrix page: Axelrod-Python#660
Development:
- A git hook script for commit messages: Axelrod-Python#648
- Caching of hypothesis database on travis: Axelrod-Python#658
Here are all the commits for this PR: https://github.com/Axelrod-Python/Axelrod/compare/v1.4.0...v1.5.0
New strategy.
- contrite TitForTat: Axelrod-Python#639
Here are all the commits for this PR: https://github.com/Axelrod-Python/Axelrod/compare/v1.3.0...v1.4.0
New strategy, a bug fix and more explicit copyright notice
- Remorseful Prober: Axelrod-Python#633
Bug fix:
- The finite state machines were not reseting state properly.
Here are all the commits for this PR: https://github.com/Axelrod-Python/Axelrod/compare/v1.2.0...v1.3.0
New strategies and some minor improvements
- Naive Prober: Axelrod-Python#629
- Gradual: Axelrod-Python#627
- Soft grudger and reverse pavlov: Axelrod-Python#628
Minor improvements include:
- Progress bar for result set reading of data: Axelrod-Python#618
- Prob end tournament players do not know match length (this was in essence a bug): Axelrod-Python#611
- Doc fixes
Here are all the commits for this PR: https://github.com/Axelrod-Python/Axelrod/compare/v1.1.1...v1.2.0
Minor changes, bug fixes.
Here are all the commits for this PR: https://github.com/Axelrod-Python/Axelrod/compare/v1.1.0...v1.1.1
User facing:
- The matches can tell the players different match attributes than the ones actually being played (helpful for prob end tournaments where players cannot know the length of the match for example): Axelrod-Python#609
- A progress bar for the result set: Axelrod-Python#603
Internal:
- Reducing some test sizes: Axelrod-Python#601
- PEP8 improvements: Axelrod-Python#607
- Refactor of the match generator (noise is an attribute): Axelrod-Python#608
New strategies and minor changes to the test suite
Here are all the commits for this PR: https://github.com/Axelrod-Python/Axelrod/compare/v1.0.1...v1.1.0
This introduces various new strategies to the library:
- Adaptive
- Handshake
- CyclerDC and CyclerDDC (used in the literature)
- 8 Finite State Machine strategies: Fortress3, Fortress4, Predator, Raider, Ripoff, SolutionB1, SolutionB5, Thumper
This version also includes a minor change to the test suite: shortening the size of the tournaments being run in the integration tests.
Here is the PR that incorporated all of the above: Axelrod-Python#591
Bug fix.
Here are all the commits for this PR: https://github.com/Axelrod-Python/Axelrod/compare/v1.0.0...v1.0.1
During the previous refactor of the Tournament, the ability to create noisy tournaments was lost. An integration test has been written to catch this in the future: Axelrod-Python#596
Internal improvements, progress bar, minor interface change
Here are all the commits for this PR: https://github.com/Axelrod-Python/Axelrod/compare/v0.0.31...v1.0.0
This release is the first major release stating the stability and maturity of the library.
There are some user facing improvements:
- A progress bar: Axelrod-Python#578
- Whether or not a tournament is to be run using parallel processing is no longer a property of the tournament itself but an argument of the play method: Axelrod-Python#582
There were some extensive internal changes:
- The tournament attributes are passed to the players from the matches and not the tournament. This should make further things like changing what the players know about the tournament more straightforward: Axelrod-Python#537
- A huge re write of the actual way the tournament runs. This is the biggest such re write to date. The parallel workers now execute repetitions of matches which are written to disk as and when they complete. This greatly reduces the memory footprint of the tournament. A side effect of the above is a change of how the tournament is written to disk: the format is now much clearer (every row is a match): Axelrod-Python#572
Moran processes, better caching architecture and match generator
Reading and writing tournaments to file, better pickling.
Bug fix with parallel processing.
New strategy, enhanced matches and prob end tournaments.
Minor fixes, rewrite of tournament engine: interactions now available.
Bug fix and two new strategies based on ThueMorse sequence.
Minor documentation changes.
New strategy (FirmButFair) and hypothesis testing
Mixed strategies (decorator and meta player)
Including a DOI.
Match class with sparklines.
Strategies have 'makes_use_of' attribute, improved docs/doctests,
Efficiency improvements, new default colour maps
New strategies
Strategy transforms and bug fixes
Tidying strategies, action classes, flip action method and new docs
Distribution of wins plots, and is_cheater becomes obey_axelrod
Change to use distutils, mirror strategy and readthedocs bug
Adding classifier dictionary and dynamic strategy list.
Further behaviour and more info being passed to players.
Updating Core team
Python 3 support and behaviour metrics
Various improvements including noisy tournaments
Change default behaviour to maximisation
Perhaps removes long description
Removes long description
Corrects formatting of authors
Adding all authors
Minor fix
Minor fix
Initial release