Skip to content

Latest commit

 

History

History
126 lines (96 loc) · 6.41 KB

README.md

File metadata and controls

126 lines (96 loc) · 6.41 KB

chess.com Game Analysis App

Goal

Improve my chess rating by leveraging Chess.com's Public API to build a data pipeline and analyze game performance.

Overview

This application uses chess.com's public API for to query data about players' games, openings, positions, wins vs. losses, and overall performance. This information is compiled into an interactive dashboard where users can:

  • Visualize their rating trends
  • Analyze their opening choices
  • Identify blunders and mistakes using Stockfish

Quick Start

  1. Download the stockfish binaries and drop the folder in the root directory with the name stockfish/
  2. Update the value of STOCKFISH_PATH in the .env file. (The ARM/Android download works within the Docker architecture)
  3. Create a .env file and fill in the RHS of these variables
    STOCKFISH_PATH=/usr/local/bin/stockfish/stockfish-android-armv8
    
    AIRFLOW_UID=501 
    _AIRFLOW_WWW_USER_USERNAME=
    _AIRFLOW_WWW_USER_PASSWORD=
    
    MONGO_HOST=
    MONGO_PORT=27017
    MONGO_INITDB_ROOT_USERNAME=
    MONGO_INITDB_ROOT_PASSWORD=
    
    POSTGRES_USER=
    POSTGRES_PASSWORD=
    POSTGRES_DB=
    
  4. Run docker compose up airflow-init
  5. Run docker compose up --build -d
  6. Run docker ps and copy the ID of the app container
  7. Enter the app container by running docker exec -it <container_id> bash
  8. Once in the app container, initialize MongoDB by running python mongo_init.py

With the setup complete, you can:

Technical Documentation

Tools

This app is written primarily in Python. The game data is stored in a MongoDB instance. The Airflow webserver provides a UI for users to easily manipulate/manage the data and trigger jobs that facilitate deeper analysis. The dashboard was created using Streamlit. Most of the MongoDB logic is written using pymongo. The entire application is containerized using Docker for easy deployment.

Usage

The players' game data will be saved to the data/ directory under the directory name data/game_archives/<player_username>/<year>_<month>. The data/ directory is also where the volumes for the database services are mounted. data/mongo_data/ and data/postgres-db-volume/ will be created automatically when the Docker image is built.

Setup

Stockfish

Stockish is the accepted chess engine within the chess community. You will need to download the binaries here in order to use it for deep analysis. Place the binaries in the stockfish/ directory at the root level. You will need to enter the path under the STOCKFISH_PATH variable in the .env file. Running this on a MacOS, I needed to use the ARM binaries here (due to Docker creating a Linux environment).

Configure Docker and Environment

It's bad practice to use the default values for usernames/passwords that are defined in docker-compose.yml. Instead, create a .env file in the root directory and fill in new values for these credentials.

STOCKFISH_PATH=/usr/local/bin/stockfish/stockfish-android-armv8

AIRFLOW_UID=501
_AIRFLOW_WWW_USER_USERNAME=
_AIRFLOW_WWW_USER_PASSWORD=

MONGO_HOST=
MONGO_PORT=27017
MONGO_INITDB_ROOT_USERNAME=
MONGO_INITDB_ROOT_PASSWORD=

POSTGRES_USER=
POSTGRES_PASSWORD=
POSTGRES_DB=

Run Docker

If you're running this app on a Linux machine, you need to set AIRFLOW_UID. Otherwise, the files created in airflow/ will be created with root user ownership. If you're not on Linux, you'll get a warning that can be ignored. Configure the user by running this (or just enter it manually in the .env file):

echo -e "AIRFLOW_UID=$(id -u)" > .env

Now, you need to run db migrations and create the first user account. You only need to run this once:

docker compose up airflow-init

Build the Docker images and start the mongo and app services. Remember to run --build if you are building this container for the first time or you add a new line to the requirements.txt file:

docker compose up [--build] -d

If you want to enter the app container to run specific files and functions, use this:

docker exec -it <python_container_id> bash

Then you can simply run python main.py.

Initialize MongoDB

Once inside the app container, you'll need to initialize MongoDB. This only needs to be done once. Run the following command:

python mongo_init.py

Opening Analysis

Chess.com returns games as a PGN (Portable Game Notation) format. The codes that represent each opening identified in the PGN were mapped using ECO mappings.

Screenshots

This section contains screenshots from the application that illustrate what the user experience is like.

Personal Stats

Dive into your personal game history and analyze your performance with the help of the filters on the left side of the screen. Performance can be broken out by time control, color, date, opening, and more! personal_stats

Airflow

There are several jobs in Airflow that you can use to augment your data exploration experience. For example, use the DAG pictured below to pull or refresh a player's game data, and load it into Mongo where it will be instantly available in the dashboards. airflow_player_dag

Stockfish Analysis

Analyze a single game's performance. See how your likelihood to win changes over the course of the game, and Stockfish will tell you where you made errors as well as how severe they were. stockfish_dashboard

Steps to run in AWS

You'll need to have a valid SSL certificate for ECS to query from DocumentDB. I put the .pem file in the dashboard/ directory (sibling to the Dockerfile) and referenced its respective location in the Docker container when running connect_to_mongo.py

As part of the AWS deployment, only the dashboard Docker container is pushed to ECR. Therefore, the docker build must be done in a specific way that references only that Dockerfile and rearranges the directory structure slightly. See dashboard/Dockerfile for the AWS comments.