The Algobattle lab course package.
Project description
Algorithmic Battle
The lab course "Algorithmic Battle" is offered by the Computer Science Theory group of RWTH Aachen University since 2019. This repository contains the necessary code and documentation to set up the lab course yourself.
In an Algorithmic Battle, pairs of teams compete against one another
in order to solve a problem of your choice, e.g. a problem from the
class NP. The teams each design a generator
, that outputs
hard-to-solve instances for a given instance size, as well as a
solver
that accepts an instance and outputs a solution to it as
quickly as possible.
The framework is written to be completely language-agnostic regarding
the code of the generator
and the solver
, as each is wrapped in a
docker container that only needs to adhere to an I/O structure of your
choice (by default, in the form of json
-files.)
If you are interested in how to use the framework for a lab course of your own, please consult the teaching concept in the documentation.
Installation and Usage
This project is developed and tested on all major operating systems.
Please consult the official documentation for detailed instructions on installation and usage.
Related projects
This repository only includes the core framework for executing an
Algorithmic Battle
. For a selection of concrete problems that you
can use to play around with the framework, have a look at the
algobattle-problems
repository. These are problems that have been posed to students in
some form over the past years.
While the framework provides all essential tools to host a tournament
yourself, e.g. in the form of a lab course, you may be interested in
the algobattle-web
project. The algobattle-web
project implements a webframework with
which you are able to comfortably manage your students teams and their
code, your problem files and their documentation as well as schedule
matches to be fought between registered student teams, using the
algobattle
API.
Contributing
We welcome any input on how to make this project accessible to as many people as possible. If you have feedback regarding the usage of the framework, the documentation or would even like to help us out with corrections, new features, or translations, feel free to open an issue or pull request. We have developed this project on the basis of practical experience inside our lab courses, thus some design elements may be unintuitive to you. Feel free to point out anything that appears odd to you.
Funding
The development of version 4.0.0
was funded by
Stiftung Innovation in der Hochschullehre
(Project
FRFMM-106/2022 Algobattle
) and by the Department of Computer Science of
RWTH Aachen University.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file algobattle_base-4.3.1.tar.gz
.
File metadata
- Download URL: algobattle_base-4.3.1.tar.gz
- Upload date:
- Size: 67.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: pdm/2.19.3 CPython/3.10.12 Linux/6.5.0-1025-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 40b32b43537d0eb866954b0ee6404031100bc5813e676c548f7eb3d899be58b4 |
|
MD5 | 663cf7c288e6489c9d36205179b7a7c1 |
|
BLAKE2b-256 | f7e81040445363ee6297d3b2e9f9202b17428f923334ec6b378a532b740f381d |
File details
Details for the file algobattle_base-4.3.1-py3-none-any.whl
.
File metadata
- Download URL: algobattle_base-4.3.1-py3-none-any.whl
- Upload date:
- Size: 70.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: pdm/2.19.3 CPython/3.10.12 Linux/6.5.0-1025-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | cb8c131317e3462303ae57096883ae1995f94653a5668934c787183145ca6da5 |
|
MD5 | ffae673443875e12c0c6da11711feb05 |
|
BLAKE2b-256 | 812a16a300cc7fedc234e26ad8b51e4132439c4ee170fdb02480ffe5e4718648 |