Skip to content

evanofslack/balatro-rs

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

98 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

balatro-rs

Game engine and move generator for a simplified version of balatro, written in rust with python bindings

Overview

This library implements a subset of balatro's rules allowing execution of games or simulations. It provides an exhaustive list of actions a user could take at any given stage, as well as an engine to execute those actions and progress the game.

The goal of providing all valid actions is to serve as a move generator. This would be the first step to apply reinforcement learning for balatro.

Example

use balatro_rs::{action::Action, game::Game, stage::Stage};
use rand::Rng;

fn main() {
    let mut g = Game::default();
    g.start();
    while !g.is_over() {
        // Get all available moves
        let actions: Vec<Action> = g.gen_moves().collect();
        if actions.len() == 0 {
            break;
        }

        // Pick a random move and execute it
        let i = rand::thread_rng().gen_range(0..actions.len());
        let action = actions[i].clone();
        g.handle_action(action);
    }
    let result = g.result();
}

Features

This library does not implement all aspects of balatro and likely never will.

The follow features are implemented (including move generation)

  • identification and scoring of poker hands
  • playing/discarding/reordering of cards
  • blind pass/fail and game win/lose conditions
  • money/interest generation
  • ante progression (up to ante 8)
  • blind progression (small, big, boss)
  • stage transition (pre-blind, blind, post-blind, shop)
  • buying/selling/using jokers (very partial support)

The following features are missing and may or may not be added

  • buying/selling/using tarots
  • buying/selling/using planets
  • buying/selling/using spectrals
  • boss blind modifiers
  • skip blind/tags
  • card enhancements, foils and seals
  • joker foils
  • alternative decks
  • alternative stakes

Python bindings

This library uses pyo3 to provide python bindings. For more details on the python work and attempts at applying reinforcement learning, check the work in the directory /pylatro.

About

balatro (lite) game engine and move generator

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published