I’m thrilled that the NSF has funded my grant proposal with Oscar Chaparro to further investigate the relationship between when and how verification tools fail to prove that code is correct and when and how humans struggle to understand code that we discovered in our FSE 2023 paper.
I’m an assistant professor at the New Jersey Institute of Technology, in the Department of Computer Science. You can find me most days in my office: GITC 4314; feel free to come by any time that my calendar says that I’m free.
My research focuses on making software verification practical for every developer: that is, on making verification a standard part of every developer’s toolkit, in the way that techniques like unit testing or code review are today. My focus is primarily on two approaches to making verification more practical:
- improving the expressivity of simple verification technologies: making it possible to prove more facts about a program within the constraints that developers actually work under. Examples of this approach include my work on accumulation analysis for resource leaks (ESEC/FSE 2021) and for initialization (ICSE 2020).
- convincing developers of the benefits of verification: by deploying verification technologies in new domains, and by improving the usability of verification. An example of this approach is my work on compliance verification (ASE 2020).
I completed my Ph.D. at the University of Washington Paul G. Allen School of Computer Science & Engineering. I worked in the PLSE group under the supervision of Michael Ernst.
Outside of work, I enjoy playing all kinds of games—video, tabletop, board, etc.—skiing, watching baseball and soccer, reading, and a little bit of tea snobbery. Some of my favorite games include Civilization, Dungeons and Dragons, and Dominion. I’m a big fan of the Washington Nationals and of the Seattle Sounders.
I’ve made my academic job market materials publicly available: CV Research statement Teaching statement Diversity and Inclusion statement Job Talk: “Verification for working developers”
News
I’m giving a talk today at ESEC/FSE in San Fransisco on our paper “On the Relationship Between Code Verifiability and Understandability” (joint work with Oscar Chaparro and his student Kobi Feldman at William and Mary) in the Empirical Studies I session (at 14:30). Slides available here.
I’m thrilled that our paper “Inference of Resource Management Specifications” will appear at OOPSLA in October! This is joint work between the original Resource Leak Checker team (FSE ‘21) and folks at Microsoft Research who have implemented an RLC-inspired system for C#; we joined forces to solve the tricky inference problems that resource leak checking brings up.
I’m excited that our paper “Pluggable Type Inference for Free” with my students Daniel, Loi, and Muyeed and our collaborator Michael Ernst has been accepted at ASE! Looking forward to seeing everyone in Luxembourg in September!
I’m excited that my paper “On the Relationship Between Code Verifiability and Understandability” with Kobi Feldman and Oscar Chaparro has been accepted at ESEC/FSE! See you in San Fransisco in December!
Papers
- On the Relationship Between Code Verifiability and Understandability
- European Software Engineering Conference/Foundations of Software Engineering (ESEC/FSE), December 2023
- [bibtex] [artifact] [slides] [talk video]
- Inference of Resource Management Specifications
- Proceedings of the ACM on Programming Languages (OOPSLA), October 2023
- [bibtex] [artifact]
- Pluggable Type Inference for Free
- Automated Software Engineering (ASE), September 2023
- [bibtex] [scripts and data] [slides] [implementation]
- Accumulation Analysis
- European Conference on Object-Oriented Programming (ECOOP), June 2022
- [bibtex] [artifact (data for literature survey)] [slides (pdf)] [slides (pptx)]
- Lightweight Verification via Specialized Typecheckers
- PhD Thesis, University of Washington, Seattle, USA, June 2022
- [bibtex]
- Lightweight Verification via Specialized Typecheckers
- doctoral symposium at ESEC/FSE 2021, August 2021
- [bibtex] [slides]
- Lightweight and Modular Resource Leak Verification
- European Software Engineering Conference/Foundations of Software Engineering (ESEC/FSE), August 2021
- (note that this version of the paper has been updated to correct a minor error in table 3)
- [bibtex] [artifact (scripts and data)] [slides (pdf)] [talk recording]
- Continuous Compliance
- Automated Software Engineering (ASE), August 2020
- [bibtex] [artifact (scripts and data)] [slides (pdf)] [slides (pptx)] [key-length checker] [crypto-policy checker] [bucket-compliance checker] [no-literal checker]
- Verifying Object Construction
- International Conference on Software Engineering (ICSE), May 2020
- [bibtex] [code] [artifact (VM image)] [talk video] [slides (pdf)] [slides (pptx)]
- Compile-time Detection of Machine Image Sniping
- ASE 2019 Student Research Competition, Graduate Division, November 2019
- Won 1st place at ASE ‘19’s Student Research Competition
- [bibtex] [slides (PDF)] [poster (PDF)]
- Lightweight Verification of Array Indexing
- International Symposium on Software Testing and Analysis (ISSTA), July 2018
- [bibtex] [slides (PDF)] [slides (PPTX)] [artifact] [docker image]
- Combining Bug Detection and Test Case Generation
- FSE 2016 Student Research Competition, Undergraduate Division, November 2016
- Won 1st place at FSE ‘16 and 3rd place in the SRC Grand Finals
- [bibtex]
- Combining Bug Detection and Test Case Generation
- Technical Report, September 2016
- [bibtex]
Teaching
Spring 2025: CS 485: Compilers (under construction)Fall 2024: CS 490: Guided Design in Software Engineering
Spring 2024: CS 684: Testing and Quality Assurance
Fall 2023: CS 490: Guided Design in Software Engineering
Spring 2023: CS 490: Guided Design in Software Engineering
Fall 2022: CS 785: Practical Program Analysis
Students and Alumni
This section lists all of the past and present PhD students that I've supervised, and a selection of past undergraduate and masters students who have stayed in academia after working with me. If you're a past undergraduate or masters student and you think you should be on this list, send me an email.Kazi Amanul Islam Siddiqui, PhD student, 2023-present
Erfan Arvan, PhD student, 2023-present
Loi Nguyen, undergraduate student, 2022-2024 (starting a PhD at UC Riverside in Fall 2024)
Professional Service
Program Committee member, FSE 2025Sponsorship Chair, SPLASH 2024
Program Committee member, ISSTA 2023-24
Student Research Competition judge, ESEC/FSE 2023
Co-chair for Student Volunteers, ISSTA 2023
Student Research Competition judge, PLDI 2023
External Review Committee member, OOPSLA 2022-23
Artifact Evaluation Committee member, PLDI 2020
Program Committee member, testing tools track, ICST 2020
Artifact Evaluation Committee member, VMCAI 2020
Funding
- Collaborative Research: SHF: Small: Verification-guided Assessment and Reduction of Code Complexity
- $600,000 from the NSF CCF over 3 years (my share $300,000), July 2024
- Collaborative Research: SHF: MEDIUM: General and Scalable Pluggable Type Inference
- $900,000 from the NSF CCF over 4 years (my share $450,000), June 2023