stable-retro


Namestable-retro JSON
Version 0.9.3 PyPI version JSON
download
home_pagehttps://github.com/farama-foundation/stable-retro
SummaryNone
upload_time2025-01-17 07:04:09
maintainerNone
docs_urlNone
authorFarama Foundation
requires_python<3.13,>=3.8.0
licenseMIT
keywords
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            [![pre-commit](https://img.shields.io/badge/pre--commit-enabled-brightgreen?logo=pre-commit&logoColor=white)](https://pre-commit.com/) [![Code style: black](https://img.shields.io/badge/code%20style-black-000000.svg)](https://github.com/psf/black)

# Stable-Retro

A fork of [gym-retro](https://github.com/openai/retro) ('lets you turn classic video games into Gymnasium environments for reinforcement learning') with additional games, emulators and supported platforms. Since gym-retro is in maintenance now and doesn't accept new games, platforms or bug fixes, you can instead submit PRs with new games or features here in stable-retro.

Currently added games on top of gym-retro:
*	Super Mario Bros 2 Japan (Lost Levels) - NES
*	Hang On - SMS
*	Punch Out - NES
*	WWF Wrestlemania the Arcade Game - Genesis
*	NHL 94 - Genesis
*	NHL 94 (1 on 1 rom hack) - Genesis
*	Super Hang On - Genesis
*	Tetris - GameBoy
*	Virtua Fighter - 32x
*	Virtua Fighter 2 - Genesis
*	Virtua Fighter 2 - Saturn
*	Mortal Kombat 1 - Sega CD

PvP games that support two models fighting each other:
*	Samurai Showdown - Genesis
*	WWF Wrestlemania the Arcade Game - Genesis
*	Mortal Kombat II - Genesis
*	NHL 94 - Genesis

As well as additional states on already integrated games.

## Emulated Systems

- Atari
	- Atari2600 (via Stella)
- NEC
	- TurboGrafx-16/PC Engine (via Mednafen/Beetle PCE Fast)
- Nintendo
	- Game Boy/Game Boy Color (via gambatte)
	- Game Boy Advance (via mGBA)
	- Nintendo Entertainment System (via FCEUmm)
	- Super Nintendo Entertainment System (via Snes9x)
- Sega
	- GameGear (via Genesis Plus GX)
	- Genesis/Mega Drive (via Genesis Plus GX)
	- Master System (via Genesis Plus GX)
 	- 32x (via Picodrive)
  	- Saturn (via Beetle Saturn)
  	- Sega CD (via Genesis Plus GX)

**Experimental** (accessible in the fbneo branch)
- Arcade Machines:
  	- Neo Geo (MVS hardware: 1990–2004)
 	- Sega System 1 (1983–1987)
 	- Sega System 16 (And similar. 1985–1994)
 	- Sega System 18 (1989–1992)
 	- Sega System 24 (1988–1994)
 	- Capcom CPS1 (1988–1995)
 	- Capcom CPS2 (1993–2003)
 	- Capcom CPS3 (1996–1999)

[Full list of supported Arcade machines here](https://emulation.gametechwiki.com/index.php/FinalBurn_Neo)

## Installation

```
pip3 install stable-retro
```
or if the above doesn't work for your plateform:
```
pip3 install git+https://github.com/Farama-Foundation/stable-retro.git
```

If you plan to integrate new ROMs, states or emulator cores or plan to edit an existing env:
```
git clone https://github.com/Farama-Foundation/stable-retro.git
cd stable-retro
pip3 install -e .
```

#### Apple Silicon Installation (Tested on python3.10)
- NOTE: The Game Boy (gambatte) emulator is not supported on Apple Silicon

**Build from source**
1. `pip install cmake wheel`
2. `brew install pkg-config lua@5.3 libzip qt@5 capnp`
3. `echo 'export PATH="/opt/homebrew/opt/qt@5/bin:$PATH"' >> ~/.zshrc`
4. `export SDKROOT=$(xcrun --sdk macosx --show-sdk-path)`
5. `pip install -e .`

**Build Integration UI**
1. build package from source
2. `cmake . -DCMAKE_PREFIX_PATH=/usr/local/opt/qt -DBUILD_UI=ON -UPYLIB_DIRECTORY`
3. `make -j$(sysctl hw.ncpu | cut -d: -f2)`
4. `open "Gym Retro Integration.app"`

Docker image for M1 Macs:
https://github.com/arvganesh/stable-retro-docker

## Example

'Nature CNN' model trained using PPO on Airstriker-Genesis env (rom already included in the repo)

Tested on Ubuntu 20.04 and Windows 11 WSL2 (Ubuntu 20.04 VM)
```
sudo apt-get update
sudo apt-get install python3 python3-pip git zlib1g-dev libopenmpi-dev ffmpeg
```
You need to install a stable baselines 3 version that supports gymnasium
```
pip3 install git+https://github.com/Farama-Foundation/stable-retro.git
pip3 install stable_baselines3[extra]
```

Start training:
```
cd retro/examples
python3 ppo.py --game='Airstriker-Genesis'
```

More advanced examples:
[https://github.com/MatPoliquin/stable-retro-scripts](https://github.com/MatPoliquin/stable-retro-scripts)

## Citation

```
@misc{stable-retro,
  author = {Poliquin, Mathieu},
  title = {Stable Retro, a maintained fork of OpenAI's gym-retro},
  year = {2025},
  publisher = {GitHub},
  journal = {GitHub repository},
  howpublished = {\url{https://github.com/Farama-Foundation/stable-retro}},
}
```

## Tutorials

Windows WSL2 + Ubuntu 22.04 setup guide:
https://www.youtube.com/watch?v=vPnJiUR21Og

Game Integration tool:
https://www.youtube.com/playlist?list=PLmwlWbdWpZVvWqzOxu0jVBy-CaRpYha0t

How to run a custom version of RetroArch that supports overriding player input with models trained with stable-retro/stable-baselines:
https://www.youtube.com/watch?v=hkOcxJvJVjk

## Discord channel

Join here:
https://discord.gg/dXuBSg3B4D

## Contributing

[See CONTRIBUTING.md](https://github.com/Farama-Foundation/stable-retro/blob/master/CONTRIBUTING.md)

There is an effort to get this project to the [Farama Foundation Project Standards](https://farama.org/project_standards). These development efforts are being coordinated in the `stable-retro` channel of the Farama Foundation's Discord. Click [here](https://discord.gg/aPjhD5cf) for the invite

## Supported specs:

Plateforms:
- Windows 10, 11 (via WSL2)
- macOS 10.13 (High Sierra), 10.14 (Mojave)
- Linux (manylinux1). Ubuntu 22.04 is recommended

CPU with `SSE3` or better

Supported Pythons: 3.7 to 3.12

## Documentation

Documentation is available at [https://stable-retro.farama.org/](https://stable-retro.farama.org/) (work in progress)

See [LICENSES.md](https://github.com/Farama-Foundation/stable-retro/blob/master/LICENSES.md) for information on the licenses of the individual cores.

## ROMs

Each game integration has files listing memory locations for in-game variables, reward functions based on those variables, episode end conditions, savestates at the beginning of levels and a file containing hashes of ROMs that work with these files.

Please note that ROMs are not included and you must obtain them yourself.  Most ROM hashes are sourced from their respective No-Intro SHA-1 sums.

Run this script in the roms folder you want to import. If the checksum matches it will import them in the related game folder in stable-retro.
```bash
python3 -m retro.import .
```

The following non-commercial ROMs are included with Stable Retro for testing purposes:

- [the 128 sine-dot](http://www.pouet.net/prod.php?which=2762) by Anthrox
- [Sega Tween](https://pdroms.de/files/gamegear/sega-tween) by Ben Ryves
- [Happy 10!](http://www.pouet.net/prod.php?which=52716) by Blind IO
- [512-Colour Test Demo](https://pdroms.de/files/pcengine/512-colour-test-demo) by Chris Covell
- [Dekadrive](http://www.pouet.net/prod.php?which=67142) by Dekadence
- [Automaton](https://pdroms.de/files/atari2600/automaton-minigame-compo-2003) by Derek Ledbetter
- [Fire](http://privat.bahnhof.se/wb800787/gb/demo/64/) by dox
- [FamiCON intro](http://www.pouet.net/prod.php?which=53497) by dr88
- [Airstriker](https://pdroms.de/genesis/airstriker-v1-50-genesis-game) by Electrokinesis
- [Lost Marbles](https://pdroms.de/files/gameboyadvance/lost-marbles) by Vantage

            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/farama-foundation/stable-retro",
    "name": "stable-retro",
    "maintainer": null,
    "docs_url": null,
    "requires_python": "<3.13,>=3.8.0",
    "maintainer_email": null,
    "keywords": null,
    "author": "Farama Foundation",
    "author_email": "contact@farama.org",
    "download_url": null,
    "platform": null,
    "description": "[![pre-commit](https://img.shields.io/badge/pre--commit-enabled-brightgreen?logo=pre-commit&logoColor=white)](https://pre-commit.com/) [![Code style: black](https://img.shields.io/badge/code%20style-black-000000.svg)](https://github.com/psf/black)\n\n# Stable-Retro\n\nA fork of [gym-retro](https://github.com/openai/retro) ('lets you turn classic video games into Gymnasium environments for reinforcement learning') with additional games, emulators and supported platforms. Since gym-retro is in maintenance now and doesn't accept new games, platforms or bug fixes, you can instead submit PRs with new games or features here in stable-retro.\n\nCurrently added games on top of gym-retro:\n*\tSuper Mario Bros 2 Japan (Lost Levels) - NES\n*\tHang On - SMS\n*\tPunch Out - NES\n*\tWWF Wrestlemania the Arcade Game - Genesis\n*\tNHL 94 - Genesis\n*\tNHL 94 (1 on 1 rom hack) - Genesis\n*\tSuper Hang On - Genesis\n*\tTetris - GameBoy\n*\tVirtua Fighter - 32x\n*\tVirtua Fighter 2 - Genesis\n*\tVirtua Fighter 2 - Saturn\n*\tMortal Kombat 1 - Sega CD\n\nPvP games that support two models fighting each other:\n*\tSamurai Showdown - Genesis\n*\tWWF Wrestlemania the Arcade Game - Genesis\n*\tMortal Kombat II - Genesis\n*\tNHL 94 - Genesis\n\nAs well as additional states on already integrated games.\n\n## Emulated Systems\n\n- Atari\n\t- Atari2600 (via Stella)\n- NEC\n\t- TurboGrafx-16/PC Engine (via Mednafen/Beetle PCE Fast)\n- Nintendo\n\t- Game Boy/Game Boy Color (via gambatte)\n\t- Game Boy Advance (via mGBA)\n\t- Nintendo Entertainment System (via FCEUmm)\n\t- Super Nintendo Entertainment System (via Snes9x)\n- Sega\n\t- GameGear (via Genesis Plus GX)\n\t- Genesis/Mega Drive (via Genesis Plus GX)\n\t- Master System (via Genesis Plus GX)\n \t- 32x (via Picodrive)\n  \t- Saturn (via Beetle Saturn)\n  \t- Sega CD (via Genesis Plus GX)\n\n**Experimental** (accessible in the fbneo branch)\n- Arcade Machines:\n  \t- Neo Geo (MVS hardware: 1990\u20132004)\n \t- Sega System 1 (1983\u20131987)\n \t- Sega System 16 (And similar. 1985\u20131994)\n \t- Sega System 18 (1989\u20131992)\n \t- Sega System 24 (1988\u20131994)\n \t- Capcom CPS1 (1988\u20131995)\n \t- Capcom CPS2 (1993\u20132003)\n \t- Capcom CPS3 (1996\u20131999)\n\n[Full list of supported Arcade machines here](https://emulation.gametechwiki.com/index.php/FinalBurn_Neo)\n\n## Installation\n\n```\npip3 install stable-retro\n```\nor if the above doesn't work for your plateform:\n```\npip3 install git+https://github.com/Farama-Foundation/stable-retro.git\n```\n\nIf you plan to integrate new ROMs, states or emulator cores or plan to edit an existing env:\n```\ngit clone https://github.com/Farama-Foundation/stable-retro.git\ncd stable-retro\npip3 install -e .\n```\n\n#### Apple Silicon Installation (Tested on python3.10)\n- NOTE: The Game Boy (gambatte) emulator is not supported on Apple Silicon\n\n**Build from source**\n1. `pip install cmake wheel`\n2. `brew install pkg-config lua@5.3 libzip qt@5 capnp`\n3. `echo 'export PATH=\"/opt/homebrew/opt/qt@5/bin:$PATH\"' >> ~/.zshrc`\n4. `export SDKROOT=$(xcrun --sdk macosx --show-sdk-path)`\n5. `pip install -e .`\n\n**Build Integration UI**\n1. build package from source\n2. `cmake . -DCMAKE_PREFIX_PATH=/usr/local/opt/qt -DBUILD_UI=ON -UPYLIB_DIRECTORY`\n3. `make -j$(sysctl hw.ncpu | cut -d: -f2)`\n4. `open \"Gym Retro Integration.app\"`\n\nDocker image for M1 Macs:\nhttps://github.com/arvganesh/stable-retro-docker\n\n## Example\n\n'Nature CNN' model trained using PPO on Airstriker-Genesis env (rom already included in the repo)\n\nTested on Ubuntu 20.04 and Windows 11 WSL2 (Ubuntu 20.04 VM)\n```\nsudo apt-get update\nsudo apt-get install python3 python3-pip git zlib1g-dev libopenmpi-dev ffmpeg\n```\nYou need to install a stable baselines 3 version that supports gymnasium\n```\npip3 install git+https://github.com/Farama-Foundation/stable-retro.git\npip3 install stable_baselines3[extra]\n```\n\nStart training:\n```\ncd retro/examples\npython3 ppo.py --game='Airstriker-Genesis'\n```\n\nMore advanced examples:\n[https://github.com/MatPoliquin/stable-retro-scripts](https://github.com/MatPoliquin/stable-retro-scripts)\n\n## Citation\n\n```\n@misc{stable-retro,\n  author = {Poliquin, Mathieu},\n  title = {Stable Retro, a maintained fork of OpenAI's gym-retro},\n  year = {2025},\n  publisher = {GitHub},\n  journal = {GitHub repository},\n  howpublished = {\\url{https://github.com/Farama-Foundation/stable-retro}},\n}\n```\n\n## Tutorials\n\nWindows WSL2 + Ubuntu 22.04 setup guide:\nhttps://www.youtube.com/watch?v=vPnJiUR21Og\n\nGame Integration tool:\nhttps://www.youtube.com/playlist?list=PLmwlWbdWpZVvWqzOxu0jVBy-CaRpYha0t\n\nHow to run a custom version of RetroArch that supports overriding player input with models trained with stable-retro/stable-baselines:\nhttps://www.youtube.com/watch?v=hkOcxJvJVjk\n\n## Discord channel\n\nJoin here:\nhttps://discord.gg/dXuBSg3B4D\n\n## Contributing\n\n[See CONTRIBUTING.md](https://github.com/Farama-Foundation/stable-retro/blob/master/CONTRIBUTING.md)\n\nThere is an effort to get this project to the [Farama Foundation Project Standards](https://farama.org/project_standards). These development efforts are being coordinated in the `stable-retro` channel of the Farama Foundation's Discord. Click [here](https://discord.gg/aPjhD5cf) for the invite\n\n## Supported specs:\n\nPlateforms:\n- Windows 10, 11 (via WSL2)\n- macOS 10.13 (High Sierra), 10.14 (Mojave)\n- Linux (manylinux1). Ubuntu 22.04 is recommended\n\nCPU with `SSE3` or better\n\nSupported Pythons: 3.7 to 3.12\n\n## Documentation\n\nDocumentation is available at [https://stable-retro.farama.org/](https://stable-retro.farama.org/) (work in progress)\n\nSee [LICENSES.md](https://github.com/Farama-Foundation/stable-retro/blob/master/LICENSES.md) for information on the licenses of the individual cores.\n\n## ROMs\n\nEach game integration has files listing memory locations for in-game variables, reward functions based on those variables, episode end conditions, savestates at the beginning of levels and a file containing hashes of ROMs that work with these files.\n\nPlease note that ROMs are not included and you must obtain them yourself.  Most ROM hashes are sourced from their respective No-Intro SHA-1 sums.\n\nRun this script in the roms folder you want to import. If the checksum matches it will import them in the related game folder in stable-retro.\n```bash\npython3 -m retro.import .\n```\n\nThe following non-commercial ROMs are included with Stable Retro for testing purposes:\n\n- [the 128 sine-dot](http://www.pouet.net/prod.php?which=2762) by Anthrox\n- [Sega Tween](https://pdroms.de/files/gamegear/sega-tween) by Ben Ryves\n- [Happy 10!](http://www.pouet.net/prod.php?which=52716) by Blind IO\n- [512-Colour Test Demo](https://pdroms.de/files/pcengine/512-colour-test-demo) by Chris Covell\n- [Dekadrive](http://www.pouet.net/prod.php?which=67142) by Dekadence\n- [Automaton](https://pdroms.de/files/atari2600/automaton-minigame-compo-2003) by Derek Ledbetter\n- [Fire](http://privat.bahnhof.se/wb800787/gb/demo/64/) by dox\n- [FamiCON intro](http://www.pouet.net/prod.php?which=53497) by dr88\n- [Airstriker](https://pdroms.de/genesis/airstriker-v1-50-genesis-game) by Electrokinesis\n- [Lost Marbles](https://pdroms.de/files/gameboyadvance/lost-marbles) by Vantage\n",
    "bugtrack_url": null,
    "license": "MIT",
    "summary": null,
    "version": "0.9.3",
    "project_urls": {
        "Homepage": "https://github.com/farama-foundation/stable-retro"
    },
    "split_keywords": [],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "8eadb7896c4359b4bd1a3e960679a281ebffcd80e6368e508ef3787a9b2046f0",
                "md5": "7a80580e7011f60e9f569e712f671f93",
                "sha256": "c4aa475d3da61748d5bc717222534dcc20dcc91c8b930e35633627a88a0f70fe"
            },
            "downloads": -1,
            "filename": "stable_retro-0.9.3-cp310-cp310-manylinux_2_28_x86_64.whl",
            "has_sig": false,
            "md5_digest": "7a80580e7011f60e9f569e712f671f93",
            "packagetype": "bdist_wheel",
            "python_version": "cp310",
            "requires_python": "<3.13,>=3.8.0",
            "size": 96365552,
            "upload_time": "2025-01-17T07:04:09",
            "upload_time_iso_8601": "2025-01-17T07:04:09.991401Z",
            "url": "https://files.pythonhosted.org/packages/8e/ad/b7896c4359b4bd1a3e960679a281ebffcd80e6368e508ef3787a9b2046f0/stable_retro-0.9.3-cp310-cp310-manylinux_2_28_x86_64.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "793fe79eae59fb29816e0d2880a2e38033ed2b583d8e580578d80f56e3dfb3c5",
                "md5": "c64bd7268bacc00ab573219329191880",
                "sha256": "9b7ec36d9fc0fbae376397417b775801dfb6bdd1a925c04fe4f34231613dad00"
            },
            "downloads": -1,
            "filename": "stable_retro-0.9.3-cp311-cp311-manylinux_2_28_x86_64.whl",
            "has_sig": false,
            "md5_digest": "c64bd7268bacc00ab573219329191880",
            "packagetype": "bdist_wheel",
            "python_version": "cp311",
            "requires_python": "<3.13,>=3.8.0",
            "size": 96383911,
            "upload_time": "2025-01-17T07:04:22",
            "upload_time_iso_8601": "2025-01-17T07:04:22.207386Z",
            "url": "https://files.pythonhosted.org/packages/79/3f/e79eae59fb29816e0d2880a2e38033ed2b583d8e580578d80f56e3dfb3c5/stable_retro-0.9.3-cp311-cp311-manylinux_2_28_x86_64.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "6627718c1c8124a30016b79d12fc3f71c8019b70c4daf33236341685d3b7ab22",
                "md5": "b92a008e5e4aa72a1ab1636e80d21933",
                "sha256": "5d30da7225942454b1f42c3b72a0c00b1155ecfdae37f999798411f7980f306b"
            },
            "downloads": -1,
            "filename": "stable_retro-0.9.3-cp312-cp312-manylinux_2_28_x86_64.whl",
            "has_sig": false,
            "md5_digest": "b92a008e5e4aa72a1ab1636e80d21933",
            "packagetype": "bdist_wheel",
            "python_version": "cp312",
            "requires_python": "<3.13,>=3.8.0",
            "size": 96372699,
            "upload_time": "2025-01-17T07:04:35",
            "upload_time_iso_8601": "2025-01-17T07:04:35.553930Z",
            "url": "https://files.pythonhosted.org/packages/66/27/718c1c8124a30016b79d12fc3f71c8019b70c4daf33236341685d3b7ab22/stable_retro-0.9.3-cp312-cp312-manylinux_2_28_x86_64.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "a3630a2fa2bbb36bab2fcbf2a757ab95280b58e6095e70b6e667977b96add9b5",
                "md5": "7d372818249c3c9852a3faa4fa7152b2",
                "sha256": "4d84a46074c4496c5c0f42dab2a7fcc970f28019b950bc0cada5cfe5987f6721"
            },
            "downloads": -1,
            "filename": "stable_retro-0.9.3-cp38-cp38-manylinux_2_28_x86_64.whl",
            "has_sig": false,
            "md5_digest": "7d372818249c3c9852a3faa4fa7152b2",
            "packagetype": "bdist_wheel",
            "python_version": "cp38",
            "requires_python": "<3.13,>=3.8.0",
            "size": 96347760,
            "upload_time": "2025-01-17T07:04:48",
            "upload_time_iso_8601": "2025-01-17T07:04:48.577725Z",
            "url": "https://files.pythonhosted.org/packages/a3/63/0a2fa2bbb36bab2fcbf2a757ab95280b58e6095e70b6e667977b96add9b5/stable_retro-0.9.3-cp38-cp38-manylinux_2_28_x86_64.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "3235e50f3bfe144669dc0227c4dd264530ae44aa445b4b2f8c0092cbd5e45cf9",
                "md5": "88039346be20d9a0b9715d6e26255a02",
                "sha256": "5a02d77243ca4eca0794446fc4ef2c6f254f8388422880b8298aa961b714aa26"
            },
            "downloads": -1,
            "filename": "stable_retro-0.9.3-cp39-cp39-manylinux_2_28_x86_64.whl",
            "has_sig": false,
            "md5_digest": "88039346be20d9a0b9715d6e26255a02",
            "packagetype": "bdist_wheel",
            "python_version": "cp39",
            "requires_python": "<3.13,>=3.8.0",
            "size": 96370790,
            "upload_time": "2025-01-17T07:05:02",
            "upload_time_iso_8601": "2025-01-17T07:05:02.395128Z",
            "url": "https://files.pythonhosted.org/packages/32/35/e50f3bfe144669dc0227c4dd264530ae44aa445b4b2f8c0092cbd5e45cf9/stable_retro-0.9.3-cp39-cp39-manylinux_2_28_x86_64.whl",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2025-01-17 07:04:09",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "farama-foundation",
    "github_project": "stable-retro",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "lcname": "stable-retro"
}
        
Elapsed time: 0.51278s