2 releases

Uses old Rust 2015

0.1.2 Jun 15, 2018
0.1.1 Jun 15, 2018
0.1.0 Jun 14, 2018

#904 in Games

MIT license

28KB
310 lines

2048-rust

A 2048 implementation that uses bit-shifting and a pre-computed move table this implementation is designed to provide low overhead when testing an algorithm on a large amount of games. On a mid-2015 MBP Retina (2.5GHz i7) 10,000,000 games take about 80 seconds to complete running on 8 threads (1,250,000 games per thread) by executing random moves, avg score ~2k.

The board itself is encoded as a u64. This means that each tile has 4 bits (64 / 16 = 4) to store its value. Since the maximum value of setting all four bits to 1 is 15 we cannot use it to display the value directly. Instead we use these 4 bits as the power value: 2 << 15 = 65536, 2 << 14 = 32768, 2 << 13 = 16384, 2 << 12 = 8192, etc...

Installation

Add the following to your Cargo.toml file:

[dependencies]
tfe = "0.1"

Usage

A simple way to play the game automatically is to use the tfe::Game::play method:

extern crate tfe;
use tfe::{Game, Direction};

// Direction enum contains the following valid moves:
// - Direction::Left
// - Direction::Right
// - Direction::Down
// - Direction::Up

let game = Game::play(|board, failed| Direction::sample_without(failed));
println!("score: {:<6} board hex: {:016x}", Game::score(game.board), game.board);

The play method takes a closure that accepts a board: u64 and failed: &Vec<Direction> as parameters and returns the next Direction to move in.

The game will terminate if each distinct move has been attempted and failed without any successfull move in between.

Documentation

The documentation for this crate can be found here on docs.rs.

References

I certainly did not invent this implementation, large parts are taken from @nneonneo's implementation in c++.

Honorable mentions to good references:

Dependencies

~2MB
~32K SLoC