Google Scholar
ankushd [AT] bu [DOT] edu
Github
Bitbucket
ResearchGate
CDS 1024
665 Commonwealth Ave,
Boston, MA 02215
I am a tenure-track assistant professor in the Computer Science Department at Boston University and I am looking for motivated PhD students. My research interests are broadly in the area of programming languages, with applications in cryptographic protocols, distributed systems, and recently in probabilistic and machine learning models.
Interested in working with me? Please reach out to me directly and/or apply to the CS PhD program at Boston University.
Until Dec 2023, I worked as an applied scientist at Amazon working in the Automated Reasoning Group. At Amazon, I worked on testing and verification of distributed protocols and proving security and privacy of distributed systems.
I graduated with a PhD from Carnegie Mellon University in 2021 where I was advised by Prof. Jan Hoffmann and closely worked with Prof. Frank Pfenning. I am broadly interested in programming languages with a specific focus on resource analysis, session types, distributed protocols, and language design for smart contracts on the blockchain.
I am the lead designer and developer of Nomos, a domain-specific language for implementing smart contracts. This language provides 4 key features, i) a session type based mechanism for expressing the contract protocol, ii) a resource type system for expressing and automatically verifying the gas bound of a transaction, iii) a linear type system to handle assets, and iv) a design guarantee of no re-entrancy attacks.
I have also designed Rast along with Prof. Frank Pfenning, a language implementing resource-aware session types with arithmetic refinements. This implementation complements my work on designing temporal and ergometric session types for parallel and sequential complexity analysis of concurrent session-typed programs.
Before joining CMU, I worked as a Research Fellow at Microsoft Research, India with Akash Lal where I developed an efficient method to perform precise alias analysis for C and C++ programs for Windows driver modules to automatically infer safe null pointer dereferences.
I completed my undergraduate at IIT Bombay, India in 2015 where I worked with Prof. Supratik Chakraborty and Prof. Akshay S on deciding termination of linear loop programs.
Jan 2024 | Our paper Parametric Subtyping for Structural Parametric Polymorphism has been recognized with a distinguished paper award at POPL 2024! |
Jan 2024 | Big update! I have joined Boston University as an assistant professor. |
Nov 2023 | Our submission Parametric Subtyping for Structural Parametric Polymorphism has been accepted to POPL 2024. |
Nov 2022 | Our submission Probabilistic Resource-Aware Session Types has been accepted to POPL 2023. |
Jul 2021 | Big news! I have joined Amazon as an Applied Scientist! |
May 2021 | I have successfully defended my thesis! |
Sep 2020 | Super excited to release the web interface for the Nomos language. You can now use our implementation to check and execute transactions, as well as infer their gas bounds automatically! |
Jun 2020 | Our paper Rast: Resource-Aware Session Types with Arithmetic Refinements has been awarded the best system decription paper by a junior researcher of FSCD 2020! |
Henry DeYoung, Andreia Mordido, Frank Pfenning, and Ankush Das.
In Proceedings of the 51st ACM SIGPLAN Symposium on Principles of Programming Languages.
Distinguished paper award
Andrew Apicelli, Sam Bayless, Ankush Das, Andrew Gacek, Dhiva Jaganathan, Saswat Padhi,
Vaibhav Sharma, Michael W. Whalen, and Raveesh Yadav.
In Proceedings of the 35th International Conference on Computer Aided Verification.
Ankush Das, Di Wang and Jan Hoffmann.
In Proceedings of the 50th ACM SIGPLAN Symposium on Principles of Programming Languages.
Ankush Das and Frank Pfenning.
Logical Methods in Computer Science, Volume 18, Issue 1.
Ankush Das, Henry DeYoung, Andreia Mordido, and Frank Pfenning.
ACM Transactions on Programming Languages and Systems, Volume 44, Issue 3.
Zeeshan Lakhani, Ankush Das, Henry DeYoung, Andreia Mordido, Frank Pfenning.
In Proceedings of the 31st European Symposium on Programming.
Ankush Das, Henry DeYoung, Andreia Mordido and Frank Pfenning.
In Proceedings of the 30th European Symposium on Programming.
Ankush Das, Stephanie Balzer, Jan Hoffmann, Frank Pfenning and Ishani Santurkar.
In Proceedings of the 34th IEEE Computer Security Foundations Symposium.
Ankush Das and Shaz Qadeer.
In Proceedings of the 27th International Static Analysis Symposium.
Ankush Das and Frank Pfenning.
In Proceedings of the 22nd International Symposium on Principles and Practice of Declarative
Programming.
Ankush Das and Frank Pfenning.
In Proceedings of the 31st International Conference on Concurrency Theory.
Ankush Das and Frank Pfenning.
In Proceedings of the 5th International Conference on Formal Structures for Computation and
Deduction.
Best system decription paper award by a junior researcher
Ankush Das and Frank Pfenning.
Ankush Das, Jan Hoffmann and Frank Pfenning.
In 23rd International Conference on Functional Programming.
Ankush Das, Jan Hoffmann and Frank Pfenning.
In Proceedings of the 33rd Annual ACM/IEEE Symposium on Logic in Computer Science.
S. Akshay, Supratik Chakraborty, Ankush Das, Vishal Jagannath and Sai Sandeep.
In Proceedings of the 28th International Conference on Concurrency Theory.
Ankush Das and Akash Lal.
In Proceedings of the 15th International Symposium on Automated Technology for Verification and
Analysis.
Ankush Das and Jan Hoffmann.
In Proceedings of the 23rd International Conference on Tools and Algorithms for the Construction and
Analysis of Systems.
Jan Hoffmann, Ankush Das and Shu-Chun Weng.
In Proceedings of the 44th ACM SIGPLAN Symposium on Principles of Programming Languages.
Ankush Das and Jan Hoffmann.
Workshop on Syntax and Semantics of Low-Level Languages
Ankush Das, Shuvendu K. Lahiri, Akash Lal, Yi Li.
In Proceedings of the 27th International Conference on Computer Aided Verification.
Ankush Das, Shankara Narayanan Krishna, Lakshmi Manasa, Ashutosh Trivedi, Dominik
Wojtczak.
In Proceedings of the 12th Annual Conference on Theory and Applications of Models of Computation.
Ishani is a second year BS student in the Computer Science department in Carnegie Mellon University.
Project: The base language of session types supports no functional programming or data structures, thus not practical for real-world programming. Nomos integrates session-based programming into a functional core using a linear contextual monad. Ishani was responsible for developing the theory and implementation for this integration. In a second project, Ishani has been adding subtyping to Nomos, again both in theory and implementation.
Stephen is a third year BS student in the Computer Science department in Carnegie Mellon University.
Project: Nomos is a general-purpose programming language integrating session types with functional programming with support for resource analysis. To support smart contract programming with Nomos, we need to also introduce blockchain-specific syntax and create blockchain-related data structures. Stephen is responsible for maintaining smart contracts in a session-type configuration to create the blockchain state, and the log of transactions to create the blockchain.
CS 599 A1, Boston University, Spring 2025.
CS 320, Boston University, Fall 2024.
CS 599 D1, Boston University, Spring 2024.
CS 15-317, Carnegie Mellon University, Fall 2018.
Instructor: Karl Crary
CS 15-814, Carnegie Mellon University, Fall 2016.
Instructor: Karl Crary