Storage Monitor
During my internship at Two Sigma, I was tasked with building a platform for analyzing
and monitoring internal storage systems. As a data-driven company, hundreds of petabytes
of data are stored internally in various systems and data centers. To help keep track of
the growing data storage (as well as things like misconfigured storage), I built a REST
API that allowed you to query storage URIs and attributes like storage owners, total size,
etc. This was backed by a "scraper" service that communicated with the various storage
backends to collect the various metrics and settings for each storage location. The
eventual goal for this platform is enabling better resource management by eliminating
extra backups for unimportant data, cutting down on storage for abandoned data, and
helping users optimize caching/pinning for their data to enable better performance.
Python, Flask, PostgreSQL, SQLite, ElasticSearch, lots of internal tools
Safe Promise-based Programming Language
data:image/s3,"s3://crabby-images/9f12d/9f12de0dcfb0cbf2732557355ee01b0bb9042158" alt="The language's type system"
OCaml, Coq, LaTeX, Java, Type Theory
Rust Operating System for Raspberry Pi
When I took Operating Systems (CS3210), our semester long project involved building an
operating system for the Raspberry Pi Model 3B+ in Rust. Our OS featured a "networked"
bootloader over XModem+UART, support for the Pi's GPIO and timers, bin and bump memory
allocators, a FAT32 filesystem, preemptive multitasking, a number of syscalls, and
virtual memory. As our final project, my group focused on adding write support for the
filesystem along with full-disk encryption. We also added support for mounting multiple
filesystems, environment variables, file descriptors/locking files, command-line
arguments and built a userspace shell using some POSIX-like syscalls.
(Wow, too many class projects -- gotta find some time to work on some personal projects
soon).
Rust, ARMv8/aarch64 assembly, Raspberry Pi
FPGA SRAM interface
data:image/s3,"s3://crabby-images/62b00/62b0070c2c65245d674defcd420a2b16378729bc" alt="VHDL code for the interface and simulation waveform"
Altera FPGAs (DE2), VHDL, SRAM, Quartus, Logic Analyzers, Oscilloscopes
Optimizing Tiger Compiler
data:image/s3,"s3://crabby-images/a4c81/a4c81af87eb834505e968c14086615903c4229e9" alt="Control flow graph and generated assembly"
OCaml, Nanocaml (Nanopass), OCamlGraph, MIPS-32, Dataflow Analysis
Pipelined Processor Datapath
data:image/s3,"s3://crabby-images/8bf5e/8bf5e4e9ecde0700ee6f83efd84e1a38befcf4e1" alt="Pipeline Datapath"
CircuitSim (logic simulator), "LC-2200" ISA
WebAssembly N-API port
In 2019, I spent my summer at Google working with all the awesome folks on the
Node.js team. As my internship project, I was tasked with rethinking how Node.js
programs can compile with native libraries (compiled to WebAssembly). After
prototyping a tool for generating glue code for bindings in C and JS, I decided on
an approach based around the Node API (N-API). N-API's ubiquitous use for native
libraries meant it was a great choice for porting existing libraries to WebAssembly
and, more importantly, it was designed to be extremely portable. Taking advantage of
this portability, I set out creating a port of the API to WebAssembly bindings. To
do so, I created a fork of V8 that supported providing vendor "built-ins" to
WebAssembly code. I then used C++ templates to generate type-safe wrappers for all
N-API functions and finally modified the Node module loader to support these
special WebAssembly "native modules."
C++, V8, Node.js + N-API, C, WebAssembly, TypeScript, JavaScript
Scala Risk Game
data:image/s3,"s3://crabby-images/9d455/9d455cc39b2ca8902e92dfec4976cc50f2a92251" alt="Gameplay Demo"
Scala, Play, Akka, WebSockets, JavaScript, Vue, Dart, Flutter
GBA 8-ball Game
data:image/s3,"s3://crabby-images/b9f09/b9f09ada12f03c27a4bf77778669fa5953c79d18" alt="Gameplay Demo"
C, GBA BIOS
Revery
data:image/s3,"s3://crabby-images/ec02b/ec02bc0b709b4c7177d233bb3b0409c5b1aae1d0" alt="Revery in Action"
OCaml/ReasonML, C, GLFW, WebGL, JavaScript, SDL2
Quartz
Quartz is a research project that aims to create a strongly-typed language for
the world of message-passing, concurrent code. Largely inspired by the Alpaca
project, which aims to give Erlang static typing, Quartz attempts to apply
multiparty session type theory to Erlang-style code. In order to do so, the
compiler implements a novel type inference/type checking algorithm based on
Pierre-Malo DeniƩlou's and Nobuko
Yoshida's research into global session type synthesis. The language itself
is based loosely on Ruby and Elixir and compiles to Erlang code, but is designed
around a new paradigm for actor programming using first-class session objects.
OCaml, Erlang/BEAM VM, Multiparty Session Types
Rolltrax
Rolltrax started in late 2017 when my Work-Based Learning teacher, Brian
Patterson, brought up the many challenges of having student interns to me and
my friend Zach Baylin. Together, the three
of began implementing a website for managing off-campus students' attendance.
This quickly evolved into a full-fledged app, complete with user-customizable
dashboards to view metrics about student performance, a route manager for
teachers travelling between job locations, and tools for employers to evaluate
students' performance. The latest revision of the web app is written in Crystal
(using Kemal) and ReasonML (using ReasonReact), while the mobile app is written
in Flutter.
Crystal, Kemal, ReasonML, React, Python, Qt, Ruby, Sinatra, Flutter, Dart, Postgres, GCP
Nanocaml
Having been interested in compiler design for a while, I was intrigued when the
idea of nanopass architecture was first brought up to me. This style of writing
compilers utilizes a large number of passes, each of which performs only a tiny
transformation on the input program. After watching a talk and using the Racket
nanopass library for a school project, I became inspired to design a similar
system for OCaml. Using a PPX preprocessor, my friend
Milo Turner and I whipped up a quick
prototype of what such a library could look like. Though not yet battle-tested,
this library provides a number of powerful abstractions for writing compilers
quickly and easily.
OCaml, Nanopass Compilers, PPX preprocessors
Kesef
Over the summer of 2018, I became very interested in learning about finance. As part of this, I spent quite some time learning about financial statements such as those found in the 10-k/q SEC filings. To make browsing these forms easier, I used Perl6 to create a program called Kesef, which used a web scraper and RSS feeds to create a database of company filings. I also added some more features, such as rudimentary parsing of the XBRL documents to create tables of financial data and sourcing trading information from the IEX Trading API.
Perl6, XML (XPath, XQuery, and XSLT), IEX API
Bibliotech
During my senior year of high school, I competed in FBLA's Mobile Application
Development competition with Zach Baylin and
Eric Miller. For the competition, we
were tasked with creating an app for browsing and checking out library books.
After a failed first attempt using the Jasonette framework, we switched to
Flutter (and fell in love with it!). The backend of the app was implemented in
Ruby using Sinatra and PostgreSQL.
Flutter, Dart, Ruby, Sinatra, PostgreSQL