Profile picture

Hi! I’m currently a first year PhD student in the Circuits and Systems group at Imperial College London, supervised by John Wickerson.

My research focuses on formalising the process of converting high-level programming language descriptions to correct hardware that is functionally equivalent to the input. This process is called high-level synthesis (HLS), and allows software to be turned into custom accelerators automatically, which can then be placed on field-programmable gate arrays (FPGAs).

I have also worked on random testing for FPGA synthesis tools. Verismith is a fuzzer that will randomly generate a Verilog design, pass it to the synthesis tool, and use an equivalence check to compare the output to the input. If these differ, the design is automatically reduced until the bug is located.


FPGA '20
Yann Herklotz and John Wickerson. Finding and understanding bugs in FPGA synthesis tools. In ACM/SIGDA Int. Symp. on Field-Programmable Gate Arrays, 2020.
DOI | poster | slides | blog | pdf ]


Nix for Coq Development
Nix is a great package manager that can be used to control various complex environments easily, such as Coq development with ocaml extraction with various dependencies.
MSR PhD Workshop on Next-Generation Cloud Infrastructure
Summary of the microsoft talks and posters presented at the MSR PhD Workshop on Next-Generation Cloud Infrastructure.
Verilog Fuzzer to test the major verilog compilers by generating random, valid Verilog.
Realistic Graphics
Environment maps can be used to render objects with realistic lighting by indexing into the map.
Jekyll to create a Portfolio website
Jekyll can be effectively used to publish a static website, even containing multiple pages such as a portfolio.
Noise Silencer
A real-time noise cancelling processor that reduces noise from audio.
FMark is a markdown engine in F#, supporting various extensions such as latex rendered math and macros.
Emotion Classification using Images
A convolutional neural network was trained to classify images based on 6 emotions, achieving an accuracy of about 60%.
YAGE is a game engine that was built in C++ using OpenGL as a back end.
Emacs as an Email Client
Emacs can be used effectively as an email client to quickly write emails using familiar keybindings, as well as easily linking emails to org files for reminders.