diff --git a/README.md b/README.md index 9114438..5d144ba 100644 --- a/README.md +++ b/README.md @@ -1,13 +1,13 @@ # GamesmanNova -Nova is a research project primarily built for efficiently searching extensive-form games, such as Tic-Tac-Toe, Connect4, and Chess (if it weren't so darn big). In particular, the prupose of this project is to take learnings and ambitions from [Prof. Dan Garcia's](https://people.eecs.berkeley.edu/~ddgarcia/) multi-decade project [GamesmanClassic](https://github.com/GamesCrafters/GamesmanClassic) and provide a software system that is more general, performant, and ergonomic. +Nova is a UC Berkeley research project primarily built for efficiently searching extensive-form games, such as Tic-Tac-Toe, Connect4, and Chess (if it weren't so darn big). In particular, the prupose of this project is to take learnings and ambitions from [Prof. Dan Garcia's](https://people.eecs.berkeley.edu/~ddgarcia/) multi-decade project [GamesmanClassic](https://github.com/GamesCrafters/GamesmanClassic) and provide a software system that is more general, performant, and ergonomic. ## Installation Before doing anything, you will want to install [the Rust compiler and toolchain](https://www.rust-lang.org/tools/install). GamesmanNova is on [crates.io](https://crates.io/crates/gamesman-nova), so to get the `nova` executable, you can then run: ``` -$ cargo install gamesman-nova +cargo install gamesman-nova ``` Otherwise, if you would like to build Nova from source, you can also: @@ -15,37 +15,31 @@ Otherwise, if you would like to build Nova from source, you can also: 1. Clone this repository to your preferred `location`. ``` -$ git clone https://github.com/GamesCrafters/GamesmanNova.git location +git clone https://github.com/GamesCrafters/GamesmanNova.git location ``` 2. Go to your installation (`cd location`), and install the executable: ``` -$ cargo install --path . +cargo install --path . ``` This will add the `nova` executable to your list of cargo binaries. -## Development - -### Important Fronts - -The current big objectives for this project are: +## Usage -* Supporting transferrable utility coalitional games (i.e., games where you can re-distribute winnings at the end among those who helped you win). -* Creating a memory-efficient and thread-safe implementation of GamesmanClassic's database engine. -* Designing a database file serialization protocol to make GamesmanClassic's databases compatible with Nova. -* Building a wonderful terminal user interface and expanding the current command-line interface. -* Implementing and wrapping a distributed MPI controller for distribution. +Once you have the `nova` executable in a directory that is part of your `PATH`, you can run: -### Subprojects +``` +nova --help +``` -Smaller modules currently being built: +This will display a list of sub-commands and their descriptions. Nova uses [`clap`](https://docs.rs/clap/latest/clap/) for Unix-like command-line argument parsing. -* An implementation of the [Crossteaser](https://www.jaapsch.net/puzzles/crosstsr.htm) puzzle. +## Development -### Contributing +As a research project, the primary users of Nova will be people who intend to build on it as a platform. In the long-term, we wish to make this evident by splitting Nova into multiple modular crates that better express this, in a way that makes the project more accessible. -This project was created in affiliation with GamesCrafters, a computational game theory applied research group at UC Berkeley. If you would like to contribute as someone outside the GamesCrafters org, feel free to fork the repository and open a PR. If you are part of the org, create a branch anytime and code away (but do let others know, so we can help or thank you). Some light CI is set up to ensure some loose measure of quality on the main branch (namely compilation, testing, and formatting checks). +For now, we make our best attempt at providing a good experience when building from this repository via rustdocs and a reasonable architecture. The project adheres to semantic versioning per Rust's standards, and is currently unstable. -- Cheers, [Max Fierro](https://www.maxfierro.me/)