Skip to content

Commit

Permalink
Pure Continuous version of ALE on CPP (#550)
Browse files Browse the repository at this point in the history
Co-authored-by: Jet <[email protected]>
  • Loading branch information
jjshoots and jet-sony authored Aug 8, 2024
1 parent b24830f commit 11bbfdb
Show file tree
Hide file tree
Showing 14 changed files with 209 additions and 391 deletions.
2 changes: 1 addition & 1 deletion pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ authors = [
{name = "Michael Bowling"},
]
maintainers = [
{ name = "Farama Foundation", email = "[email protected]" },
{name = "Farama Foundation", email = "[email protected]"},
{name = "Jesse Farebrother", email = "[email protected]"},
]
classifiers = [
Expand Down
13 changes: 3 additions & 10 deletions src/ale_interface.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -259,16 +259,9 @@ int ALEInterface::lives() {
// user's responsibility to check if the game has ended and reset
// when necessary - this method will keep pressing buttons on the
// game over screen.
reward_t ALEInterface::act(Action action) {
return environment->act(action, PLAYER_B_NOOP);
}

// Applies a continuous action to the game and returns the reward. It is the
// user's responsibility to check if the game has ended and reset
// when necessary - this method will keep pressing buttons on the
// game over screen.
reward_t ALEInterface::actContinuous(float r, float theta, float fire) {
return environment->actContinuous(r, theta, fire, 0.0, 0.0, 0.0);
// Intentionally set player B actions to 0 since we are in single player mode
reward_t ALEInterface::act(Action action, float paddle_strength) {
return environment->act(action, PLAYER_B_NOOP, paddle_strength, 0.0);
}

// Returns the vector of modes available for the current game.
Expand Down
8 changes: 1 addition & 7 deletions src/ale_interface.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -86,13 +86,7 @@ class ALEInterface {
// user's responsibility to check if the game has ended and reset
// when necessary - this method will keep pressing buttons on the
// game over screen.
reward_t act(Action action);

// Applies a continuous action to the game and returns the reward. It is the
// user's responsibility to check if the game has ended and reset
// when necessary - this method will keep pressing buttons on the
// game over screen.
reward_t actContinuous(float r, float theta, float fire);
reward_t act(Action action, float paddle_strength = 1.0);

// Indicates if the game has ended.
bool game_over(bool with_truncation = true) const;
Expand Down
1 change: 0 additions & 1 deletion src/emucore/Settings.cxx
Original file line number Diff line number Diff line change
Expand Up @@ -415,7 +415,6 @@ void Settings::setDefaultSettings() {
boolSettings.insert(std::pair<std::string, bool>("send_rgb", false));
intSettings.insert(std::pair<std::string, int>("frame_skip", 1));
floatSettings.insert(std::pair<std::string, float>("repeat_action_probability", 0.25));
floatSettings.insert(std::pair<std::string, float>("continuous_action_threshold", 0.5));
stringSettings.insert(std::pair<std::string, std::string>("rom_file", ""));
// Whether to truncate an episode on loss of life.
boolSettings.insert(std::pair<std::string, bool>("truncate_on_loss_of_life", false));
Expand Down
Loading

0 comments on commit 11bbfdb

Please sign in to comment.