Gamejam: Bacteria Pili

In this Game Jam “Chili Code Jam” we worked on a game with two people on and off around the new year time.

Bacteria Pilli is an incremental game where you have to manage how much food you put out to not overfeed the bacteria and cause them to die.

We even won the Theme category and got 5$ price money, after the #1 place in basically all categories by a mile was found to be cheated and disqualified.

There were 49 Entries (excluding the 5 or so cheated entries). So the overall #7 is top 14.2%.

Link to Game: https://misterixi.itch.io/pili
Link to repo: https://github.com/MisterIXI/chili-code-jam-4

CriteriaRank Score* Raw Score
Theme#23.5833.583
Creativity #53.1673.167
Overall#72.8002.800
Gameplay/Fun #142.7502.750
Graphics#172.5832.583
Music and Sound #371.9171.917

Time Wipers

For the GMTK Game jam 2025, my team of 4 people made a game with the goal of showing the one friend (a complete beginner) how godot works.

Time Wipers is a puzzle game where you have multiple overlapping “time disks”, that keep swapping out including the objects present. Figure out when to go where, and how to press the buttons to unlock the exits.

Due to the nature of one trying out Godot for the first time, and another having time issues, we mainly created the project with 2 people.

Link to game: https://misterixi.itch.io/time-wipers
Link to repo: https://github.com/MisterIXI/gmtk25

Averaging the position in the 9558 overall entries, we got overall #3452 (~36.11% of placements).

CriteriaRank Score* Raw Score
Creativity#16993.8003.800
Enjoyment#23703.2863.286
Narrative#42842.2572.257
Audio#43832.6572.657
Artwork#45242.8572.857

Gamejam: Leberkäß

In this Godot Wild Jam #80 we had a team of 6 people. Two of which have never used the godot engine before, so it was a learning jam for them. This was a 9 day jam.

GitHub repo: https://github.com/MisterIXI/godot-wildjam-80
Itch.io page: https://misterixi.itch.io/leberkaes

The jam hat 202 participants and we got this rating:

CriteriaRankScore*Raw Score
Graphics#74.6094.609
Originality#94.1304.130
Overall#173.6773.677
Audio#193.7393.739
Fun#283.5653.565
Theme#493.6093.609
Accessibility#872.9572.957
Controls#913.1303.130

Gamejam: Crystal Catch

In this Weekend long game jam “PULS GAME JAM 2025“, we (a team of 3), have created a game in Unity. An engine that I have not used in a while and was kind of rusty. Nonetheless we have created a small cozy fishing game in which you are on a frozen lake that breaks over time.

Also we had time problems and two people could not participate in development for a day each.

GitHub repo: https://github.com/MisterIXI/puls-jam-25
Itch.io page: https://naddelxd.itch.io/crystal-catch

The ranking only had community voting on overall (with 164 submissions):

CriteriaRankScore*Raw Score
Overall992.4652.700

Reinforcement Learning with Sim2Real on the Turtlebot3 platform (experiments)

While creating the concept of a new University module that has the students do a project with the Turtlebot3 robots and RL, a few ideas emerged. While evaluating different robot simulation tools for Reinforcement Learning, one in particular caught my eye: the Godot plugin “godot_rl_agents” by edbeeching. This was the result of a paper creating a bridge from Godot to RL libraries like StableBaselines3.

After trying the plugin it was clear that good result can be achieved quickly, there emerged the idea that students might be more encouraged learning the whole software stack when it involves a popular game engine instead of a “random” simulator with its own proprietary structure and configuration. So now it had to be proven that Sim2Real works with this Situation.

A friend modelled a “digital twin” of a turtlebot3, as the existing open source models usually used were very unoptimized and would hinder performance of actual training. It was purposefully minimal, but with accents to make it recognizable.

At first there was an example with just driving to a target point based on the map. No sensors needed.
Simulation:

This was the first result:

The robot visible moves pretty badly in this clip. The reason which was later found: When the sent velocity commands would result in a jerky movement, the controller kind of rejects it and sometimes only does a part of the movement. Or sometimes no movement at all. To counteract this, the input has to be smoothed out beforehand to resist rejection from the controller.

Here is the next experiment with the lerp in mind:

This was the result:

The video shows that the robots performance can definitely be improved regarding stability and sensor calculations. Another big problem is also very visible here in that the small metal caster on the back of the turtlebot is very incompatible with the labs’ carpet flooring. This will be mitigated in the future with wooden plates that will make up the box’s floor.

Gamejam: Glenwich Station

In this 9 day long game jam, the team of three of us aimed to swap the main roles in the team. So the programmers were to create art, and the artist was supposed to code the game. We did not pull this through completely and had more of a mix towards the end. But we stepped out of our usual roles more than usual. We chose the “Godot Wild Jam #74” for this.

We did not explicitly use any of the possible “wild cards”.

This game is kind of a walking sim/narrative type.

GitHub repo: https://github.com/MisterIXI/godot-wildjam-74
Itch.io page: https://misterixi.itch.io/glenwich-station

Since it was a rated game jam, here are the results (out of 110):

CriteriaRankScore*Raw Score
Theme#633.0703.500
Audio#642.6313.000
Originality#692.7193.100
Accessibilty#742.1052.400
Overall#752.4812.829
Graphics#842.4562.800
Fun#852.1052.400
Controls#862.2802.600

Master Thesis: Dog Training

My master thesis topic was “Verbal training of a robot dog“. In this thesis I have created a program stack that tries to simulate real dog training. There are a few pre programmed actions the dog can perform, and it can either “anonymize” the actions or have a few preloaded commands for them. The usual training was done without any previous knowledge and from scratch.

The robot dog used was the Unitree Go1 with various python libraries. The implementation can be found here on the GitHub repo: https://github.com/MisterIXI/verbal-dog-training

A training step goes likes this:
– (optional: Hotword recognition “Hey Techie!” to await actual speaking intent)
– Speech recognition with “Whisper” (Open-source Speech-to-text from OpenAI)
– Check if command has confirmed matches
– Check if command has a small Levenshtein distance to a confirmed command (like “sit” and “sat”)
– Query the local LLM which command could be used
– If the LLM fails or picks a confirmed negative, a random action is rolled from the remaining actions
– The dog executes the picked action
– The dog awaits Feedback: Listens to “Yes” & “Correct” for positive, and “No” & “Wrong” for the negative feedback
– The picked Command + Action Combo is memorized
– The Loop repeats

The end result was a soft success. The training itself had to rely on quite a bit of randomness, since a very weak and small LLM was used which could’ve accelerated the process immensely. The same goes for the speech recognition, which failed a lot of times and resulted in bogus text recognized. With the stronger models it worked way better, but the calculation time was reduced from practically real time to up to 30 seconds, which was unacceptable in this case.

Gamejam: Bad Apple

In this 9 day long game jam, we wanted to created a more polished entry with our usual team of 4. We chose the “Godot Wild Jam #71” mainly because of it’s length, and with the potential of the wild cards giving us more ideas for a game.

This game is actually 4 games at once, and it plays with the idea of you being the “bad apple” that wants to punish the snake for eating all of the other apples.

GitHub repo: https://github.com/MisterIXI/godot-wildjam-71
Itch.io page: https://misterixi.itch.io/bad-apple

Since it was a rated game jam, here are the results (out of 138):

CriteriaRankScoreRaw Score
Fun#34.3754.375
Originality#84.254.25
Audio#193.7753.775
Controls#223.7253.725
Accessibility#243.453.45
Theme#253.653.65
Graphics#363.8253.825
Overall#93.8643.864

Reinforcement learning agent with visual inputs

As the module “individual profiling” in university, I created reinforcement learning agent working only on visual inputs, which could generally control anything on the computer. It was mainly built to play a certain video game, but can (in theory) generalize to do anything with visual input. It just needs an interface class to be written which converts the outputs to the desired thing to do.

For more information, visit the GitHub repo of the project (there is also in-depth documentation of the creation of the project).

Here are the two main examples used to show the best progress in two different games:

1. Driving nightmare (a game jam game created by a team of three people including me)

    This diagram shows the learning progress over 1600 iterations. The green line representing how long each run was (the higher the better) with the yellow line showing the average. The “loss” in blue being how far off the model thinks it is from the expected result.

    2. A simple Flappy bird like program built specifically for the AI. The flappy bird game can be advanced by code in specific steps, so it can wait for a slower working network without dropping any inputs.

    Gamejam: Jimmy’s Balloon Bonanza

    In our second gamjam with godot, we formed a team of 4. The jam was “Mini Jame Gam #30“, and for it we created a tower defence game.

    The gimmick is, that you can’t go too far away of the towers or they’re losing signal and stop firing. There are relay towers available to increase that range locally, but they’re expensive.

    GitHub repo: https://github.com/MisterIXI/jame-gam-30
    Itch.io page: https://misterixi.itch.io/jimmys-balloon-bonanza

    We ranked the following (out of 51):

    CriteriaRankScoreRaw Score
    Theme Implementation#644
    Visuals#123.3643.364
    Fun Factor#153.1823.182
    Special Object Implementation#173.4553.455
    Gameplay#182.8182.818
    Audio#242.8182.818
    Overall#123.2733.273