Skip to content

Latest commit

 

History

History
61 lines (42 loc) · 1.69 KB

README.md

File metadata and controls

61 lines (42 loc) · 1.69 KB

Rosen Score

https://rosenscore.com/

This is entirely a frontend application, so you can run it pretty easily on your own computer.

Your browser makes the request directly to the Lichess API to get the games. Then the games are analyzed with javascript (again, in your own browser). Each move from every game is played through and analyzed for specific positions or other criteria.

Setup

git clone https://github.com/fitztrev/rosen-score.git
cd rosen-score
pnpm install
pnpm run dev

Will start a local server at http://localhost:5173/

## Run the test suite
pnpm run test
## or
pnpm run test:watch

## Check code coverage
pnpm run coverage
open coverage/index.html

Frameworks/Libraries Used

  • chess.js, chessops, pgn-parser - JS chess libraries to handle chess logic
  • Vue.js - Framework for building the app
  • Tailwind - CSS framework for the UI

Want to contribute?

I put some ideas of things that could be done in CONTRIBUTING.md.

Understanding How It Works

Piece Structures

FENs are converted to a 64-character string representing the position:

// Starting position FEN
let fen = 'rnbqkbnr/pppppppp/8/8/8/8/PPPPPPPP/RNBQKBNR'

// Convert the FEN to a 64-character string that starts at a8 and ends at h1
let position = fenToPosition(fen)
// rnbqkbnrpppppppp................................PPPPPPPPRNBQKBNR

And now you can do regex to look for pawn/piece structures:

// To look for a white pawn cube, it is essentially:
position.match(/PP([A-Za-z\.]{6})PP/) // 2 white pawns, 6 squares, then 2 white pawns