Skip to content

RIT-MDRC/mdrc-pacbot

Repository files navigation

Welcome to MDRC Pacbot!

Our team focuses on developing a small fully autonomous robot to play the arcade game Pac-Man on a physical field. You can read more about the game and grid system in our book.

Crates

Our code is divided into parts to improve maintainability:

  • core_pb contains structs and logic that are used by multiple apps, such as code that runs both on the robot or in the simulator, or messages that are passed from clients to servers.
  • pico_pb contains code that runs directly on the robot. Note: pico_pb is not part of the Rust workspace because it builds on a special target with special dependency and core_pb features.
  • sim_pb contains code to run a simulator that can emulate multiple robots and a game server. From the POV of server_pb, there is no difference between connecting to a robot from the simulator vs a robot in real life. The simulated game server, however, does offer extra functionality not available in the official game server (but it is compatible with the official web client).
  • server_pb handles networking between the other apps, as well as high level strategy
  • gui_pb works both as a native Rust app and a WASM app to display the user interface

Additionally, the official Pacbot competition code offers a game server and a web client that will be used during competition. Our simulator and gui offer the same functionality and more, but it is important that our code can work with the official software.

Finally, we use Python code to create machine learning models to play Pacman here.

Getting Started

  1. Install Rust from https://www.rust-lang.org/tools/install
  2. Install additional targets for this project
rustup target add wasm32-unknown-unknown
rustup target add thumbv6m-none-eabi
  1. Install Trunk (for serving WASM code)
cargo install trunk --locked
  1. Build & run the server, from repository root
cargo run --release
  1. Start the GUI, from gui_pb/
trunk serve

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

pFad - Phonifier reborn

Pfad - The Proxy pFad of © 2024 Garber Painting. All rights reserved.

Note: This service is not intended for secure transactions such as banking, social media, email, or purchasing. Use at your own risk. We assume no liability whatsoever for broken pages.


Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy