pacman.controllers.examples.po.POGhosts Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of pacman-main Show documentation
Show all versions of pacman-main Show documentation
The main code for Ms. Pac-Man Vs Ghosts
package pacman.controllers.examples.po;
import pacman.controllers.Controller;
import pacman.game.Game;
import java.util.EnumMap;
import java.util.Random;
import static pacman.game.Constants.*;
/**
* Created by Piers on 15/02/2016.
*/
public class POGhosts extends Controller> {
EnumMap ghosts = new EnumMap(GHOST.class);
EnumMap myMoves = new EnumMap(GHOST.class);
public POGhosts() {
ghosts.put(GHOST.BLINKY, new POGhost(GHOST.BLINKY));
ghosts.put(GHOST.INKY, new POGhost(GHOST.INKY));
ghosts.put(GHOST.PINKY, new POGhost(GHOST.PINKY));
ghosts.put(GHOST.SUE, new POGhost(GHOST.SUE));
}
@Override
public EnumMap getMove(Game game, long timeDue) {
myMoves.clear();
for (GHOST ghost : ghosts.keySet()) {
MOVE move = ghosts.get(ghost).getMove(game.copy(ghost), timeDue);
if (move != null) {
myMoves.put(ghost, move);
}
}
return myMoves;
}
}
class POGhost {
private final static float CONSISTENCY = 0.9f; //attack Ms Pac-Man with this probability
private final static int PILL_PROXIMITY = 15; //if Ms Pac-Man is this close to a power pill, back away
Random rnd = new Random();
private GHOST ghost;
public POGhost(GHOST ghost) {
this.ghost = ghost;
}
public MOVE getMove(Game game, long timeDue) {
if (game.doesGhostRequireAction(ghost)) //if ghost requires an action
{
if (game.getGhostEdibleTime(ghost) > 0 || closeToPower(game)) //retreat from Ms Pac-Man if edible or if Ms Pac-Man is close to power pill
{
return game.getApproximateNextMoveAwayFromTarget(game.getGhostCurrentNodeIndex(ghost),
game.getPacmanCurrentNodeIndex(), game.getGhostLastMoveMade(ghost), DM.PATH);
} else {
// If can observe pacman and random says ok
// if(rnd.nextFloat() < CONSISTENCY) {
if (game.getPacmanCurrentNodeIndex() != -1 && rnd.nextFloat() < CONSISTENCY) { //attack Ms Pac-Man otherwise (with certain probability)
MOVE move = game.getApproximateNextMoveTowardsTarget(game.getGhostCurrentNodeIndex(ghost),
game.getPacmanCurrentNodeIndex(), game.getGhostLastMoveMade(ghost), DM.PATH);
// if(game.getPacmanCurrentNodeIndex() == -1) System.out.println("Was -1: " + move);
return move;
} else //else take a random legal action (to be less predictable)
{
MOVE[] possibleMoves = game.getPossibleMoves(game.getGhostCurrentNodeIndex(ghost), game.getGhostLastMoveMade(ghost));
return possibleMoves[rnd.nextInt(possibleMoves.length)];
}
}
}
return null;
}
//This helper function checks if Ms Pac-Man is close to an available power pill
private boolean closeToPower(Game game) {
int[] powerPills = game.getPowerPillIndices();
for (int i = 0; i < powerPills.length; i++) {
Boolean powerPillStillAvailable = game.isPowerPillStillAvailable(i);
int pacmanNodeIndex = game.getPacmanCurrentNodeIndex();
if (powerPillStillAvailable == null || pacmanNodeIndex == -1) {
return false;
}
if (powerPillStillAvailable && game.getShortestPathDistance(powerPills[i], pacmanNodeIndex) < PILL_PROXIMITY) {
return true;
}
}
return false;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy