OUR SPEAKERS 2025
Stephan Bökelmann
data:image/s3,"s3://crabby-images/2c057/2c057fe59b3f6fe1de1827c15b06cd78bbbe131d" alt="Stephan Bökelmann"
Graph Based Curricula
Programming curricula are usually organized linearly, with a fixed start and end, gathering a set of experiences along the way. Despite calls for more individualized learning, this has remained the norm.
An individual's traits and skills can be modeled as a multidimensional vector, where learning is a translation through skill space. Optimizing this process has parallels to the brachistochrone problem in physics.
General-purpose transformers (GPTs) are powerful for text generation but lack precision for structured educational outcomes. Based on my experience teaching programming in Bochum, I have developed a refined learning system, now in an experimental phase.
This talk explores my curriculum’s modeling, implementation, and workflows. It is especially relevant for professionals in embedded development, offering insights into algorithm-driven teaching methods.
From Code to the Outback: Embedded Systems in Solar Racing (working title)
The Sonnenwagen Aachen team is a student organization dedicated to designing and building solar-powered race cars to compete in the World Solar Challenge — a grueling 3,000 km race across Australia, powered solely by the sun. The vehicles competing in this challenge are among the most energy-efficient in the world.
In this talk, Lennart Kling and Julian Falk will introduce their project and team structure before diving deep into the onboard computer — the brain of the vehicle. As part of the electrical engineering team, they developed a real-time operating system (RTOS) to optimize power consumption and enhance vehicle efficiency.
They will share insights into how their embedded system is structured, what challenges they faced, and how they implemented power-saving techniques through smart software design. Expect a mix of high-level project insights and deep technical details straight from the Sonnenwagen development process!
Julian Falk and Lennart Kling
data:image/s3,"s3://crabby-images/e3831/e383199629aecdfd199986661edfc719b52e3d4a" alt="Platzhalter für die TBA-Speaker"
Stefan Fuhrmann
data:image/s3,"s3://crabby-images/f88ec/f88eceea763b62a01f79e78aa48c35988830fb67" alt="stefan_square"
Balancing Coding Rules with Embedded Systems Constraints
Most organizations and projects establish coding rules or guidelines to help developers write clean, safe, readable, and maintainable code. However, these rules sometimes conflict with the need for performance efficiency and memory usage – especially when dealing with specific hardware and compilers. Since these attributes are critical to the success of embedded projects, we need to adapt certain rules to strike the right balance. In this talk, we will share our experiences and insights on this topic, focusing specifically on the challenges in embedded software development. This will give you guidance on what pitfalls to look out for and how to address them.
Data Mining Hardware Descriptions from Code, Tools, and Docs
There are a lot of slightly different microcontrollers out there. So many, that it is difficult to answer simple questions about what features they support, especially in detail. In this talk we'll look at what data sources exist for STM32 devices and how easily they are to access and how accurately they are compared to each other. May contain actual data science!
Niklas Hauser
data:image/s3,"s3://crabby-images/86261/86261f5c48d62e2c0f95727e67bf5e6634f14069" alt="niklas hauser"
Max Hoffmann
data:image/s3,"s3://crabby-images/f39c2/f39c2dbdac8675df1fb453aad6abb5f9afb15e2f" alt="RUB; Eickhoff Preise"
Security Beyond Memory Safety - Using Modern C++ to Avoid Vulnerabilities by Design
Nowadays, there is one topic that comes up in virtually all discussions on system programming languages: memory safety.
However, even though memory safety rules out many of the most common sources of vulnerabilities, there are still plenty of ways how a vulnerability may find its way into the codebase. In this talk, we look beyond memory safety and explore how we can prevent vulnerabilities through simple yet effective C++ constructions.
To this end, we discuss security engineering, attacker models, threats, and implementation pitfalls, before looking at solutions that are not just secure by themselves but also protect developers from accidentally introducing vulnerabilities in the future.
Together, we iteratively apply these solutions to an elaborate example inspired by real-world products, use cases, and vulnerabilities, to end up with a sustainably secure software.
Attendees will leave with a deeper understanding of security engineering and with inspirations for leveraging C++ to prevent potential security issues by design.
Experiences with codebases of three C++ Quantum Libraries: Quantum++ (qpp), Staq, and Qulacs
This talk presents experiences on working with the codebases of three C++ quantum libraries: Quantum++ (qpp), Staq, and Qulacs. Specifically, the talk will compare coding paradigms, performance trade-offs, and compatibility considerations. Key takeaways include coding guidelines for leveraging C++ in quantum software development and lessons learnt for selecting the most suitable library based on specific requirements.
Babar Khan
data:image/s3,"s3://crabby-images/502e1/502e1895afb4db807f7de4f3da536663fa883d09" alt="babar-embo2024"
Frank Landgraf
data:image/s3,"s3://crabby-images/c2b28/c2b283bcd5e6a7dc777cfbd1b8605dae004156c8" alt="frank_Landgra"
In 2020, he co-founded a cooperative of IT professionals: https://wtf-eg.de.
Collecting time-synchronized measurements - the LabstreamLayer ecosystem
The talk will give a short overview of the labstreamlayer library and the xdf fileformat and how I used it to combine different measurements for neuromotorical experiments. It will show some open source tools for storing and visualizing data from these measurements and will give some coding samples how to sample data in C++ and python, the same for reading sample data from a stream.
Specifiers, qualifiers and the long road to const
In C++98, we already had const, volatile, static, extern and inline. In C++11, thread_local and constexpr were added. In C++17, inline variables were introduced. In C++20, we've got consteval and constinit. But have you ever wondered what a static inline thread_local constexpr const volatile variable is? In this talk, Mikhail will attempt to break down all this variety of keywords. We'll recall linkage and storage duration. We'll understand the connection between static and constexpr, between extern and inline. And we'll realize why it took us almost 20 years to learn how to properly declare constants.
Mikhail Matrosov
data:image/s3,"s3://crabby-images/07a92/07a92a00fada1913383e54c9ae0ce5010ae39604" alt="Mikhail_Matrosov"
Filipe Mulonde
data:image/s3,"s3://crabby-images/5bf9e/5bf9e5280e1b57b3c92cddb9f5c5b8d3420bafd9" alt="filipe_mulonde"
Behind the Scenes of OpenGL: From Object Space to Screen – Transformations, Projection, Clipping, and Depth Testing
How does OpenGL transform 3D objects into a final 2D image on your screen? This talk explores the full journey from object space to screen space, covering key transformations, projection, clipping, culling, and depth testing. We’ll break down how OpenGL processes geometry, applies perspective, and optimizes rendering for efficiency. By the end, you’ll have a solid understanding of how objects are projected, transformed, and displayed.
The Evolution of Hammer
Software development is not only about writing code, it’s also selection of tools, processes and infrastructure. Some of them is visible in day-to-day work, some hidden in background. All of it affects quality and comfort of our work. This talk is a case study on how we (Flight Software team in KP Labs) evolved out infrastructure and tools for (mostly) embedded development over 6 years.
Maciej Nowak
data:image/s3,"s3://crabby-images/1e307/1e30746c4d4344819bf8af6f51dbd3d64d309a1c" alt="Maciej_Nowak"
Salim Ullah
data:image/s3,"s3://crabby-images/43d3b/43d3b77e898c62118adc141fbca32e0e0a95b4b4" alt="salim"
Cross-Layer Approximations for Enabling Energy-Efficient Edge Computing
Approximate Computing (AxC) has emerged as a powerful technique for enhancing the efficiency of AI and machine learning (ML) workloads on resource-constrained edge devices. By intentionally introducing controlled inaccuracies in computations, AxC takes advantage of the inherent resilience of AI/ML models, leading to significant improvements in power, performance, and area (PPA). AxC can be applied across various layers of the computing stack, but approximate arithmetic operators have a particularly direct impact on the PPA costs associated with arithmetic operations during AI inference. Therefore, researchers are actively exploring approximate arithmetic operators that offer substantial PPA benefits while capitalizing on the error tolerance of AI models. In this presentation, we will introduce the topic and highlight the importance of the cross-layer approximation framework. We will emphasize the need for a generic and scalable approach to designing approximate arithmetic operators. Additionally, the presentation will discuss the crucial role of considering the architectural specifics of the underlying platform when developing approximation techniques, particularly those suited for FPGA-based approximate computing.
Hardware-in-the-Loop testing using low-cost hardware and C++OS
Hardware-in-the-loop (HIL) testing is an important step in the development of embedded systems. Most interaction in embedded systems are based on digital protocols like I2C, U(S)ART, SPI or even simple high/low GPIOs. For testing the correct handling of such interfaces the external counterpart can easily be provided by low-cost boards running C++OS. This presentation shows how you can use C++OS on a such a low-cost board to run HIL tests on your embedded system.
Detlef Vollmann
data:image/s3,"s3://crabby-images/ae2cd/ae2cdcd8346891daa19444e7e0557b2b3581b43b" alt="emBO__0017_Detlef_Vollmann_03"
Detlef Vollmann
data:image/s3,"s3://crabby-images/ae2cd/ae2cdcd8346891daa19444e7e0557b2b3581b43b" alt="emBO__0017_Detlef_Vollmann_03"
Don't Use C OS Interfaces From C++
HIf your embedded OS provides a C API to start a thread, it's probably ok to use it from a C++ program. But if your embedded OS provides a concurrent queue with a C API, and you use it from C++, you're hosed.
This talk tells you why.