Blog

Welcome to my blog, where I mostly discuss things related to my academic interest and occasionally other musings.

Latest Posts

Jan 2, 2025

Unsolicited Advice for (soon-to-be) Undergrads

Having somewhat recently finished my undergrad and MEng, I wanted to take some time to reflect on my educational experience so far. I’ve only experienced a small slice of the potential pathways in the US education system. I will try to generalize, but who knows how that will go. This is a collection of things I would say to my younger self, advice I have given to people before, and things I just feel like should be said. Read more


Nov 30, 2024

Synthesizing Variable Initializations in CPS Programs

I recently added holes in the caiman frontend. These enable a user to only write part of a schedule, and have the compiler determine the details, using user provided specs. A hole is essentially an expression or statement that can stand in for anything the compiler might want to put there. The frontend is responsible for performing type deduction, and part of a type in caiman is a linear representation of whether the type is “usable” (initialized and not used) or “dead” (uninitialized or initialized but consumed). Read more


Jun 3, 2024

Chordal Graph Register Allocation

Register allocation is commonly framed as a vertex coloring problem on an interference graph, where vertices represent virtual registers and edges connect two virtual registers that interfere (belong to the same live-out set of a program point). A classic method, due to Chaitin1, is to do register allocation via graph coloring with a set of heuristics to make the problem more easily computable, as vertex coloring is an NP-Hard problem. Read more


May 31, 2024

A Year in Caiman

Caiman is a language designed for heterogeneous programming that formalizes the communication between devices, allocations, and computations performed. This post details the current state of the Caiman Frontend and includes a brief overview of the implementation of some features such as lowering to continuation passing style and the e-graph-based type inference. Background In heterogeneous programming, communication and synchronization between devices is extremely important for performance, but it’s not at all obvious what the optimal communication strategy should be. Read more


Jan 12, 2024

Z3-Powered Constraint Solving for Static Analysis

In a previous post, we discussed implementing an analysis to detect potential uses of null pointers. The workhorse of this analysis was an interval analysis that could (conservatively) determine all possible values an integer could take on. We used this information to prove whether or not an array access could be determined to always be in-bounds. This worked, but it could not handle cases such as a dynamically sized buffer. Suppose we know that a buffer has $a$ elements. Read more


Dec 20, 2023

Fuzzing Compilers With Genetic Programming

Ensuring good test coverage of a compiler is hard. That’s why I developed Bear, a compiler fuzzer that generates random test cases for compiler optimization passes. (Named as such because bears are fuzzy?) Bear uses genetic programming to evolve novel programs in the search space. Bear generates programs in a custom DSL (domain-specific language) known as Bare C before being lowered into the target IR. The IR Bear currently targets is BRIL (Big Red Intermediate Language), which is the IR used in Cornell’s PhD level compilers course. Read more


Nov 15, 2023

Scheduling LLVM Passes with the New Pass Manager

Figuring out how to run a pass with LLVM feels needlessly complicated. This short post will briefly lay out two different methods of doing so using the new Pass Manager. Invoking via Clang One simple method of running a compiler pass is to directly invoke it via Clang as outlined in this blog post. This method is fairly straightforward and super easy, we just need to: Create a class that inherits from PassInfoMixin, as described here. Read more


Oct 7, 2023

Not Now Null Pointers: LLVM Null Analysis

I’ve always been interested in being able to make guarantees about the correctness of a program without the high cost of doing something like a full-on verification in an automatic theorem prover such as Coq. Moreover, avoiding extra runtime costs would be extremely nice as well, especially for systems programming domains. I recently began working on an LLVM pass which aims to guarantee the absence of loading and storing of null pointers. Read more


Aug 18, 2023

Do Your Units Match? An Embedded DSL for Physical Quantities

Computations of physical values in programming languages can quickly get out of hand due to the complex units that the programmer has to keep track of. Good variable naming and comments can help, but nothing is stopping double run_time_sec from storing a time measured in milliseconds. Furthermore, different functions might use the same value, but measured in different units, requiring manual conversions. Overall, it’s just an unpleasant burden placed on the programmer and a cause of many errors. Read more


Aug 1, 2023

Real-Time, Accurate Collision Detection

Accurate collision detection is a vital part of video games and simulation, and fast collision detection is paramount for real-time applications such as games. In high school, building such a fast and accurate collision engine eluded me. This post describes, conceptually, the algorithm I settled upon when developing Project Oort. I will assume a basic familiarity with the problem of collision detection, including bounding spheres and axis-aligned bounding boxes, simple data structures like trees, and the basics of concrete linear algebra including vectors, matrices, and linear transformations. Read more


Jul 20, 2023

The Case of the Disappearing Shadow: Gradual Shadow Fading

When implementing the cloaking ability for Project Oort, I came upon a somewhat interesting problem: At what point during the gradual disappearing process should the object’s shadow disappear? At first, I just had the object abruptly stop writing to the depth buffer at a certain transparency threshold. This would cause the shadow to simply cut out at an arbitrary point. I didn’t like the look of that and decided that I wanted the shadow to fade in and out gradually. Read more


All Posts

2025

  • Jan 2, 2025 - Unsolicited Advice for (soon-to-be) Undergrads
  • 2024

  • Nov 30, 2024 - Synthesizing Variable Initializations in CPS Programs
  • Jun 3, 2024 - Chordal Graph Register Allocation
  • May 31, 2024 - A Year in Caiman
  • Jan 12, 2024 - Z3-Powered Constraint Solving for Static Analysis
  • 2023

  • Dec 20, 2023 - Fuzzing Compilers With Genetic Programming
  • Nov 15, 2023 - Scheduling LLVM Passes with the New Pass Manager
  • Oct 7, 2023 - Not Now Null Pointers: LLVM Null Analysis
  • Aug 18, 2023 - Do Your Units Match? An Embedded DSL for Physical Quantities
  • Aug 1, 2023 - Real-Time, Accurate Collision Detection
  • Jul 20, 2023 - The Case of the Disappearing Shadow: Gradual Shadow Fading