Skip to content

Pacman Artificial Intelligence Python project for UC Berkeley CS188 Intro to AI

Notifications You must be signed in to change notification settings

dimberr/Artificial-Intelligence---The-PacMan-Projects

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

19 Commits
 
 
 
 
 
 
 
 

Repository files navigation

Artificial-Intelligence---The-PacMan-Projects

Pacman Artificial Intelligence Python project for UC Berkeley CS188 Intro to AI

Project 1: Search:

  • Depth-First Search (DFS): Graph search that avoids expanding already visited states. Fringe implemented via stack.
  • Breadth-First Search (BFS): Graph search that avoids expanding already visited states. Fringe implemented via queue.
  • Uniform Cost Search (UCS): Graph search that avoids expanding already visited states. Fringe implemented via Priority Queue.
  • A* Search: uses Manhattan distance heuristic to find optimal solution
  • CornersProblem: Search problem and heuristic for pacman to reach all active corner dots on board.
  • FoodSearchProblem: Search problem and heuristic for pacman to eat all active dots on board.

Project 2: Multiagents:

  • ReflexAgent: A reflex agent uses an evaluation function (aka heuristic function) to estimate the value of an action using the current * game state. The Reflex Agent considered food locations and ghost locations, using reciprocals of distances as features.
  • MinimaxAgent: A minimax agent is implemented using a minimax tree with multiple min layers (one for each ghost) for every max layer. The agent uses an evaluation function that evaluates states, and can sometimes choose to kill itself when believed this is the best choice.
  • AlphaBetaAgent: An alpha beta agent uses alpha-beta pruning to explore the minimax tree.
  • Expectimax: The expectimax pacman makes decisions using the expected value

Project 3: Reinforcement Learning

  • ValueIterationAgent: an offline planner takes an MDP on construction and runs value iteration for the specified number of iterations before the constructor returns.
  • Q-Learning: a reinforcement learning agent does very little on construction, but instead learns by trial and error from interactions with the environment through its update(state, action, nextState, reward) method

About

Pacman Artificial Intelligence Python project for UC Berkeley CS188 Intro to AI

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages