Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/atesgoral/hrm-solutions
Human Resource Machine solutions and size/speed hacks
https://github.com/atesgoral/hrm-solutions
assembly benchmarking game human-resource-machine
Last synced: 3 days ago
JSON representation
Human Resource Machine solutions and size/speed hacks
- Host: GitHub
- URL: https://github.com/atesgoral/hrm-solutions
- Owner: atesgoral
- Created: 2015-10-18T17:47:31.000Z (over 9 years ago)
- Default Branch: main
- Last Pushed: 2024-11-24T22:00:04.000Z (about 2 months ago)
- Last Synced: 2025-01-10T18:05:22.468Z (10 days ago)
- Topics: assembly, benchmarking, game, human-resource-machine
- Language: Assembly
- Homepage: http://atesgoral.github.io/hrm-solutions/
- Size: 4.27 MB
- Stars: 433
- Watchers: 27
- Forks: 178
- Open Issues: 11
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
[![Build and Deploy](https://github.com/atesgoral/hrm-solutions/actions/workflows/build-and-deploy.yml/badge.svg)][1]
[1]: https://github.com/atesgoral/hrm-solutions/actions/workflows/build-and-deploy.yml
# Human Resource Machine solutions
This repo contains working solutions, in hopes of exchanging ideas to collaboratively come up with the most/size.speed optimized solutions (or simply to help those out there who are stuck). Even though the programs are created through a drag-and-drop interface within the game, copy/paste from/to the clipboard works as assembly source code seen in this repo.
[Top Scores and more info.](https://atesgoral.github.io/hrm-solutions/)
## File Naming Convention
The file naming convention used is:
Under the `solutions` folder, inside a subfolder called `--.`, `.[.]-.asm`
Where `size` and `speed` are the number of commands and steps of the solution, which is deemed by the game as size and speed optimized if they are equal to or less than the par numbers in its folder's name.
The optional `type` field is a descriptor for the type of solution (e.g. the algorithm used, whether it's an exploit etc.)
`author` is the GitHub username of the author of the solution.
For example, `solutions/07-Zero-Exterminator-4.23/4.23-atesgoral.asm` means the solution is both size and speed optimized and is by user atesgoral.
## Contributing
Please issue a pull request while keeping in mind:
- The file naming convention is met
- If you're a new contributor, edit the contributors.yml file to add yourself
- Make sure your new solution passes tests (see below)## Testing
You need Node.js 18+ and Yarn to be installed.
`yarn` to install all dependencies
`yarn test` to run tests.
## Tools Used
The tests involve the static/runtime analysis and benchmarking of each solution by utilizing:
- [hrm-parser](https://github.com/nrkn/hrm-parser) by [@nrkn](https://github.com/nrkn) for static analysis of programs
- [hrm-cpu](https://github.com/nrkn/hrm-cpu) by [@nrkn](https://github.com/nrkn) for running programs and runtime analytics
- [hrm-level-data](https://github.com/atesgoral/hrm-level-data) by [@atesgoral](https://github.com/atesgoral) for level metadata for providing level constraints
- [hrm-level-inbox-generator](https://github.com/atesgoral/hrm-level-inbox-generator) by [@atesgoral](https://github.com/atesgoral) for randomly generating level-appropriate inboxes for benchmarking
- [hrm-level-outbox-generator](https://github.com/atesgoral/hrm-level-outbox-generator) by [@atesgoral](https://github.com/atesgoral) for determining the expected outboxes for given level + inbox for benchmarking