about summary refs log blame commit diff
path: root/users/grfn/resume/resume.tex
blob: fb226c4ddffc2f93942bb2f4893f01ecd7a612dc (plain) (tree)
1
2
3

                                                         
                                                    

























                                                                                                                                                                                                                                                          

                   

                              



                     



                


                                                                           

                                                                           

                                                                             







                                                                                








                                                                               



                                                                                




                             
                               

                        
                       
                 
                 


                           
                    
                  
                   
                                            
                    





                          








                        


































                                                                                    























































































                                                                                               






















                                                                                               


                                
%% start of file `template.tex'.
%% Copyright 2006-2013 Xavier Danaux (xdanaux@gmail.com).
%% Copyright 2014-2023 Griffin Smith (root@gws.fyi).
%
% This work may be distributed and/or modified under the
% conditions of the LaTeX Project Public License version 1.3c,
% available at http://www.latex-project.org/lppl/.


\documentclass[10pt,a4paper,sans]{moderncv}        % possible options include font size ('10pt', '11pt' and '12pt'), paper size ('a4paper', 'letterpaper', 'a5paper', 'legalpaper', 'executivepaper' and 'landscape') and font family ('sans' and 'roman')

\usepackage[inline]{enumitem}


% moderncv themes
% style options are 'casual' (default), 'classic', 'oldstyle' and 'banking'
\moderncvstyle{casual}
% color options 'blue' (default), 'orange', 'green', 'red', 'purple', 'grey' and 'black'
\moderncvcolor{black}
% to set the default font; use '\sfdefault' for the default sans serif font,
% '\rmdefault' for the default roman one, or any tex font name
%\renewcommand{\familydefault}{\sfdefault}
\nopagenumbers{}

\usepackage[utf8]{inputenc}

\usepackage[scale=0.8, margin=0.65in]{geometry}
\setlength{\hintscolumnwidth}{2.6cm}

\name{Aspen}{Smith}
\pronouns{she/her}
\title{Software Engineer}
\phone[mobile]{(720) 206-7218}
\email{aspen@gws.fyi}
\homepage{gws.fyi}
\extrainfo{she/her}


\begin{document}
\makecvtitle{}
\section{Skills}
\cvitem{Rust}{Expertise in high-performance, low latency, low-level systems
development with Rust, including everything from fundamental data structure
implementation to asynchronous distributed systems development}
\cvitem{Clojure}{Extensive experience architecting, deploying, and building
complex web applications in Clojure and Clojurescript, with a focus on
Re-Frame and Reagent. Experience testing distributed systems in Clojure using
Jepsen.}
\cvitem{Haskell}{Passionate love for pure functional programming as a hobbyist
pursuit, but also practical experience building production systems in Haskell at
scale, and using Haskell's advanced type system extensions where appropriate to
deliver increased ergonomics and safety.}
\cvitem{Nix}{Experience with adopting and teaching nix at scale in a production
stack both for local development dependencies and for configuring and building
production software. Core contributer to a fork of the nix implementation itself
(tvix) aimed at providing increased safety, performance, and flexibility.}
\cvitem{Unix/Linux}{Experience with administrating highly available distributed
systems. Passion for the Unix philosophy of discrete, composable units of
functionality.}
\cvitem{Ruby}{Experience building both full-stack applications with Ruby on
Rails in addition to smaller microservices and custom frameworks. Deep
understanding of the internals of the Ruby interpreter and object system.}
\cvitem{Javascript}{Experience developing real-time responsive single-page web
applications using React, in addition to significant contributions to the React
open-source community.}
\cvitem{SQL}{Deep understanding of relational databases as an
implementer, in the context of an innovative new database implementing a query
planner and incremental materialization for the PostgreSQL and MySQL dialects of
SQL from the ground up -- and of course also a user}

\subsection{Additional Tools}
\cvitem{}{\footnotesize
    \begin{itemize*}
        \item Vim
        \item Emacs (yes, also)
        \item Kubernetes
        \item Git
        \item Terraform
        \item AWS
        \item GCP
        \item Datomic
        \item Elasticsearch
        \item Redis
        \item Docker
        \item Java
        \item Scala
        \item QuickCheck (and similar tools)
        \item Jepsen
        \item Python
        \item Elixir
    \end{itemize*}
    \newline
    \textbf{Novice Level:}
    \begin{itemize*}
        \item C++
        \item Erlang
        \item Prolog
        \item Idris
        \item Agda
        \item Tensorflow
    \end{itemize*}}

\section{Experience}
\cventry{2020--2023}{Staff Software Engineer}{ReadySet}{Remote}{}
{Founding engineer at a startup bringing a high performance
  partially-stateful, incrementally-maintained SQL database based on the Noria
  thesis to market
  \begin{itemize}
    \item Served as the main technical leadership for the project throughout its
          maturation from a research codebase to a production-grade system
    \item Extended the Noria PhD thesis by implementing methods from multiple
          research papers, masters theses, and other papers from database
          research, in addition to original database research and development.
    \item Invented or helped develop multiple novel database techniques in
          partially materialized dataflow, including index planning and
          selection, pagination, post-lookup aggregate processing, partial
          ``straddled'' joins, weak indexes for correct execution of partial
          joins, and more.
    \item Invented novel ways to test SQL databases, including a new deterministic
          generator for SQL queries.
    \item Developed the clustered high availability distributed runtime mode from
          a buggy research feature into a production ready distributed system
          that passed a suite of Jepsen tests.
    \item Implemented a significant fraction of the SQL query planner, which
          required both implementing algorithms specified in database research
          papers and inventing new techniques to work around the limitations of
          partially materialized dataflow
    \item Optimized critical components of the code base, including algorithmic
          optimizations, CPU cache analysis, low-level data structures, and
          broad system runtime analysis
    \item Implemented a type inference engine and expression evaluator that
          supported multiple dialects of SQL configured at compile-time, with
          maximum code reuse while preserving maintainability
    \item Mentored multiple junior and senior engineers
    \item Open-Source contributions visible at
          \url{https://github.com/readysettech/readyset/commits?author=glittershark}
  \end{itemize}}
\cventry{2019--2020}{Engineering Manager}{Urbint}{New York, NY}{}
{\begin{itemize}
   \item Lead of the platform team with two direct reports - a senior SRE and
     a senior software engineer.
   \item Performed user research on developers, project managers, product
     managers, and other internal stakeholders to build the roadmap for the
     platform team.
   \item Built and maintained a system to deploy one-off full stack
     application instances from pull requests to enable easier testing.
   \item Led a large, multi-project migration between CI systems that resulted
     in a decrease of average build times from 2 hours to less than 10 minutes.
   \item Maintained and extended Nix-based build and development
     infrastructure for both software engineers and machine learning engineers.
 \end{itemize}}
\cventry{2018--2019}{Senior Software Engineer}{Urbint}{New York, NY}{}
{\begin{itemize}
   \item Built, trained, and maintained a large, deep-learning-based
     image-detection model for semi-automated (human-in-the-loop) video
     classification.
   \item Designed, built, and maintained a novel in-house tool for collection of
     training data.
   \item Maintained and guaranteed reliability of a large data pipeline for
     video processing and classification.
 \end{itemize}}
\cventry{2017--2018}{Senior Software Engineer}{Urbint}{New York, NY}{}
{\begin{itemize}
   \item Integral in the architecture of a novel, serializable ACID
     transactional graph database built on RocksDB, first in Elixir then in
     Haskell.
   \item Helped ship customer deliverables involving multi-day data
     processing jobs for disparate data sources.
   \item Instructed other developers in the use of and theory behind Haskell
   \item Brought computational graph theory to bear on the problem of unifying
     disparate, highly heterogeneous data sources across the world of open data.
 \end{itemize}}
\cventry{2016--2017}{Senior Software Engineer}{SecurityScorecard, Inc.}{New York, NY}{}
{Lead frontend developer for a rapidly-moving and growing security software startup.
  \begin{itemize}
    \item Took part in collaborative product design meetings to make UX
      tradeoffs with product designers and managers.
    \item Drove application architecture for a large, complex, data-driven frontend
      application.
    \item Championed increased use of production monitoring and alerting.
    \item Worked with business stakeholders to set long- and short-term priorities for
      application development.
    \item Mentored junior team members.
  \end{itemize}}
\cventry{2015--2016}{Lead Developer}{Nomi, Inc.}{New York, NY}{}
{Lead web services developer transitioning to a full-stack role implementing
  shared software components and architecting a large, complex microservices
  application ingesting hundreds of gigabytes of IoT data per week.
  \begin{itemize}
    \item Lead application architecture of the majority of the backend services to
      encourage consistent REST API design and code sharing.
    \item Championed the use of Haskell for rapid, safe development of the API Gateway
      service.
    \item Took ownership of operations and server maintenance of a >100-instance AWS
      account using Puppet.
  \end{itemize}}
\cventry{2014--2015}{Lead Developer}{LandlordsNY, LLC}{New York, NY}{}
{Sole engineer for a small startup connecting landlords and property managers and
  facilitating the online sharing of information in a historically technology-averse
  industry.
  \begin{itemize}
    \item Drove product design, visual design, and UX architecture for a major revamping
      of the core product.
    \item Interfaced with customers to set priorities for new feature development.
    \item Conducted hiring and recruiting to build out an engineering team.
  \end{itemize}}
\cventry{2012--2014}{Associate Developer}{Visionlink Inc.}{Boulder, CO}{}
{Integral member of an agile development team building the nation's most-used Information
  and Referral platform for organizations such as United Way Worldwide and the American Red
  Cross.
  \begin{itemize}
    \item Refactored and revamped legacy code to increase performance and long-term
      maintainablity.
    \item Worked on several triage-teams to rapidly fix production bugs with strict deadlines.
    \item Built a complex, yet highly-performant tool for searching human services by category.
    \item Acted as a core designer and developer of a major product revamp.
      \begin{itemize}
        \item Drove a complete rethinking of the data model in the product, leading to greater
          unification, simplicity, and consistency;
        \item Championed the adoption of a test-driven-development model;
        \item Drove product documentation and code standardization.
      \end{itemize}
  \end{itemize}}

\section{Project Highlights}
\newcommand{\project}[3]{\item \textbf{#1} -- \textit{#2}\newline{}#3}
\cvitem{}{
  \begin{itemize}
    \project{How much does Rust's bounds checking actually cost?}
    {\url{https://blog.readyset.io/bounds-checks/}}{Blog post providing a deep
        evaluation of the runtime cost of bounds checking in safe languages like Rust.
        Front page of Hacker News, doubled month-over-month ReadySet waitlist signups}
    \project{Tvix}{\url{https://cs.tvl.fyi/depot/-/blob/third\_party/nix/README.md}}{
        Fork of the Nix build tool delivering increased reliability, code
        quality, and pluggability}
    \project{Panettone}{\url{https://cs.tvl.fyi/depot/-/tree/web/panettone}}{
        Aggressively simple bug-tracker developed in Common Lisp for the community
        involved in the development of Tvix. Hosted at https://b.tvl.fyi}
    \project{Org-Clubhouse}{\url{https://github.com/glittershark/org-clubhouse}}{
        Emacs library for integration between org-mode and the Clubhouse issue
        tracker}
    \project{Github Bug Bounty}{\url{https://bounty.github.com/researchers/glittershark.html}}{
        Discovered and responsibly disclosed a persistent XSS on Github's main
        website}
    \project{core-async-storage}{\url{https://github.com/glittershark/core-async-storage}}{
        Simple Clojurescript wrapper around React Native's AsyncStorage using
        core.async}
  \end{itemize}
}

\end{document}
% vim: set tw=95 colorcolumn=-1: