- About the Game
- Game World
- Quantum Puzzles
- Feedback
- Installation
- Prerequisites
- Dependencies
- Windows-build
- Notes
- Playing the Game
- Terminal
- Launch Options
- Controls
- Difficulty Modes
- Main Menu
- Screen check
- Pause Menu
- Mathematical Background
- Quantum Bits
- Quantum Operations
- Applying Operations in series
- Working with multiple Qubits
- Applying Operations in parallel
- References
QRogue is an educational game about Quantum Computing, inspired in look and feel by the 1980s released classical game Rogue. You will play as a student who's dreaming about traveling the galaxy. As you hear about "Mission Quniverse", you immediately apply for its training program to be able to join this fascinating Quantum Computing powered universe exploration mission. In the lessons of the training program and later on during expeditions of Mission Quniverse you will come across a variety of quantum gates. Your Qubot - a robot you control to manipulate quantum circuits - will be able to use them to steadily increase its capabilities and even design small scale quantum algorithms at some point.
But beware of ill-disposed Decoherers - or Deqos for short! They got their name from Decoherence, a phenomenon of the quantum realm that describes how interactions with the environment can destroy a quantum state and turn it classical. And these Deqos will do their best to stand in your way. But luckily, they are in Superposition and your Qubot is equipped with a Measurement ability. This means, you can collapse their quantum state to 0 or 1 by moving towards them. Depending on the result, they will either manifest and block your path until you solve their quantum puzzle, or vanish without a trace. Be ready to combine various quantum gates into all kinds of quantum circuits should you be challenged to solve a puzzle. And some Deqos will be entangled, forming a group that collectively collapses to the same classical state upon measurement.
The game world of QRogue consists of multiple elements described in Fig. 1.
Figure 1: Screenshot of QRogue's game world with descriptions of what you can see in a typical level.Progress in QRogue is achieved by solving Quantum Puzzles. They consist of a given Input State Vector and Target State Vector. Your goal is to place Quantum Gates in your Quantum Circuit to adjust the corresponding Circuit Matrix until the Output State Vector is equal to the Target State Vector. This is visualized and described in more detail in Fig. 2. Don't worry if it looks confusing at firs, the game will gradually introduce elements and teach you all you need to know. Additionally, there is a description further down in the Section "Mathematical Background".
Figure 2: Screenshot of QRogue's puzzle screen with descriptions of what you can see.We'd be very happy if you share any feedback with us, regardless whether you liked the game or not. Just send it via email to qrogue.game@gmail.com with the subject "QRogue Feedback". It would also be nice if you could add your user-data folder with the log files. You can find its destination by pressing "Tab" in the Main Menu. Thanks!
If installing QRogue with a package manager, we highly recommend doing so in a virtual environment.
With conda you can use the following commands:
conda create -n QRogue python=3.8
conda activate QRogue
Installation is as simple as executing pip install qrogue
.
Afterwards, you can launch the game simply by executing qrogue
in the Python environment you installed QRogue in.
QRogue should work on most systems Python 3.8 and its dependencies can be installed successfully.
- Python 3.8
- pip
- conda (not necessary, but recommended)
- antlr4-python3-runtime 4.13.2
- numpy 1.22.3
- py_cui 0.1.4
- qiskit 0.34.2
- qiskit-aer 0.10.3
However, these dependencies are installed automatically if you install QRogue via pip.
Alternatively, you can download a Windows-build from here and simply launch qrogue.exe.
py_cui.errors.PyCUIOutOfBoundsError
Should you ever encounter this error when starting the game, please try to maximize the console you use for playing. This is because currently there is no automatic font size adaption, so depending on your console settings a minimum width and height is required. Alternatively, or if maximizing doesn't help, you can also lower the font size of the console.
- newer Python versions
Usually also Python 3.9 should perfectly work for playing QRogue, but testing is currently done for Python 3.8, so there is no official support yet for other versions. The same is true if you decide to manually install the dependencies; newer version will likely work, but are not recommended. Python 3.10 is not yet supported due to changes in import locations.
While the game can be played on any terminal, we developed the game while playing on Windows Terminal with the following settings (should be mostly applicable to other terminals as well):
-
Font
Font face and font size are most important and should be available in all terminals. Don't worry if you cannot adjust font weight or line height.- Font Face = Cascadia Mono
Use a monotype font face because otherwise the game will not be displayed in a straight grid. - Font Size = 13
Depends on used font face and screen size (we used 1920x1080, Full HD). In general, this font size allowed us to display 46 rows and 189 characters per row (more details further down or in the game's Screen check-menu). - Font Weight = Bold
Depends on your specific font face and your preferred look. - Line Height = 1.2 (default value)
Again, font face dependent.
- Font Face = Cascadia Mono
-
Colors
QRogue uses colors to highlight certain words in explanations, objects in the game world or elements of the puzzle screen. The following list is what we used, but can freely be adjusted based on your preferences (although they should be distinguishable from each other, so players have an easy time reading texts, the game world or puzzles - more on that further down in Screen Check).- "red": "#C50F1F"
- "brightRed": "#E74856"
- "green": "#13A10E"
- "brightGreen": "#16C60C"
- "blue": "#0037DA"
- "brightBlue": "#3B78FF"
- "purple": "#881798"
- "brightPurple": "#B4009E"
- "yellow": "#C19C00"
- "cyan": "#3A96DD"
- "black": "#0C0C0C"
- "brightBlack": "#767676"
- "white": "#CCCCCC"
- "brightWhite": "#F2F2F2"
- "foreground": "#CCCCCC"
- "background": "#0C0C0C"
- "cursorColor": "#FFFFFF"
-
--user-data
/-ud $path
:
Path to the folder where you want to store/load user data (options, save data) from. By default, QRogue will create a new folder in its installation directory. -
--game-data
/-gd $path
:
Path to the folder where you want to store/load game data (levels, default config, clean save) from. Only specify if you know what you're doing!
For debugging purposes only:
-
--debug
/-d
:
Activates debug-mode and certain options like additional logs, rendering additional information, cheat codes, simulation of runs, ... -
--from-console
/-fc
:
Skips the closing prompt when you exit the game. Necessary to see errors if you're not starting the game from a console. -
--validate-map
/-vm $path
:
Check whether a level can be generated successfully from the given.qrdg
file. -
--test-level
/-tl $path
:
Specifies a level to play. -
--simulation-path
/-sp $path
:
Specifies the.qrkl
(key log) file to use for simulating a run of the game.
- Navigate in menus: Arrow Keys, wasd
- Move in game world: Arrow Keys, wasd
- Scroll in popup: Arrow Keys, wasd
- Close popup: Space, Enter
- Reopen last popup: H
- Select answer in question popup: horizontal Arrow Keys, ad
- Confirm selection (also in question popup): Space, Enter
- Cancel/back: Shift+A, Shift+Left, Backspace
- Pause: P, Tab
- Situational
- shortcut keys: 0-9
- Debug Keys (not for use in standard play through!)
- Print screen: CTRL+P
- Force re-render: CTRL+R
The first time you launch the game, you will be asked to choose a difficulty:
-
Quantum Newbie:
The training program will use easier puzzles and explain both game mechanics and Quantum Computing in full detail. Pick this difficulty if you are unsure. -
Quantum Experienced:
The training program will use harder puzzles and only explain game mechanics. Explanations about Quantum Computing can still be read via the in-game manual.
The game does not support adjusting the difficulty. Because after completing the training program (45-60min), both modes behave the exact same way.
On a fresh save, the main menu will have the following options:
-
START YOUR JOURNEY
Starts the training program. Changes toCONTINUE
after completing the first lesson of the training program. -
SCREEN CHECK
See section below for more info. -
SAVE
Saves the game. -
EXIT
Exit the game.
As you progress through the training program, you will unlock the following two options:
-
LEVEL SELECT
Replay completed Lessons or start specific Expeditions, with the option to choose which Quantum Gates you want to bring with you -
WORKBENCH
Manage your Quantum Gates to combine them into new, more complex ones.
Since QRogue is played in a terminal, it cannot control its exact look. Hence, it is recommended to quickly verify with the screen check-menu if the used colors are distinguishable (see previous Section Terminal→Colors) and, most importantly, your window is big enough. The minimum required window dimensions (referring to the number of rows and the number of characters per row) and the actual window dimensions can be found in the top right.
The texts in the screen check-menu already explain what you should see and be able to distinguish, but here are some screenshots for reference:
Figure 3: Screen check showcasing the different parts of a level and their different colors.
Figure 4: Top-right = Screen check showcasing the colors used in a popup (1).
Figure 5: Screen check showcasing the colors used in a popup (2).
Figure 6: Screen check showcasing the colors used in a quantum puzzle (not enough space for whole matrix).
Figure 7: Screen check showcasing the matrix popup.
Figure 8: Screen check showcasing a popup describing the actually available versus required space to display the whole matrix.
You can do several things in the Pause Menu:
Continue
Continue from where you opened the Pause Menu.Restart
Re-randomizes puzzles and restarts the current level.Save
Saves the game (only if progress changes since the last save).Manual
An encyclopedia of all things important to play the game.Options
Tweak some options to your liking.Exit
Exit the current level and go back to the Main Menu.
Quantum computations are the heart of QRogue's puzzles. They boil down to matrix-vector multiplication, whereas states (e.g., input or output state) are described by vectors and operations (i.e., gates) by matrices. To get a glimpse of what this means, we will describe the basics in the following sections.
Unlike classical (i.e., electrical) bits, quantum bits can not only be
we can introduce so-called amplitudes
In case
To conduct computations on qubits QRogue uses quantum gates corresponding to certain quantum operations. All of them can be described by
Let's take a look at a counterpart to the classical NOT operation (i.e., not
The effect of applying this operation onto a single qubit
If
For a second example we consider the Hadamard operation
Now we assume our qubit
As we can see,
In QRogue the last example would correspond to an H Gate being placed on
Since we usually want to conduct more than a single operation, we can combine sequentially applied operations by matrix-matrix multiplication:
Again, these two operations can be applied onto the state
This algorithm is equivalent to the following circuit in QRogue:
Note that the order of
To work with more than a single qubit we first need to extend our state vector. This is done by computing the Kronecker product of two single qubit states:
Alternatively, this can be also written as
In case of
corresponding to the classical state
To conduct single qubit operations on our two qubit state, we also need to extend the operations via Kronecker products. Luckily, the identity operation
Or alternatively
This algorithm is equivalent to the following circuit in QRogue:
Just like we previously extended
Once again, this algorithm corresponds to the following circuit in QRogue:
Which is also equivalent to:
-
Short Paper
Presented at FDG2023 conference -
PyPI
Python packages for installation via pip