 
  The Undergraduate Research Assistantship program is a 10-week part-time opportunity for exceptional undergraduate students curious about research during a study term in CS. The URA is an excellent option to prepare students interested in pursuing full-time research or students who are considering graduate studies.
Application deadlines
| Term | Deadline | 
|---|---|
| Winter 2026 | Closed (will open December 2025) | 
| Spring 2025 | Closed | 
| Fall 2025 | Tuesday, September 30, 2025 (Closed) | 
Questions?
Interested students with questions should first refer to the Undergraduate research FAQ for more information on eligibility, finding supervisors, and more.
If you have difficulties regarding the applications forms or any parts of the URA process not listed here or on the FAQ, please contact Daniel Huab.
Full-time research assistantships
Compensation
As of Fall 2024, URA recipients will receive a minimum of $1,100 / term:
- The supervisor’s contribution: $650 (minimum)
- The value of the school top-up: $450
President's Research Award (PRA)
Students who intend to claim the President's Research Award ($1500) for a URA research experience are not entitled to receive any of the CS URA payment ($1100) for the same research experience.
Upon completing the CS URA Application Form you will be prompted to complete the PRA Application.
For more information regarding the President's Research Award please contact Student Awards and Financial Aid directly.
Eligibility
- Must be enrolled in a program in the Faculty of Mathematics. Preference is given to students enrolled in Computer Science major plans.
- Must have completed the second year of study (i.e. term of 3A or higher)
- Must have a cumulative average (CAV) of at least 80%
- A student can only do one URA per term.
- A student cannot be on a co-op term while doing a URA.
Students who do not meet the URA eligibility criteria (e.g. not 3A, less than 80 CAV) may still undertake a URA at a supervisor's discretion but will not receive the School top-up.
Supervisors of non-eligible students must contribute a minimum of $1100 for the research term unless the student is claiming a PRA.
International students must have a valid SIN to work in Canada. Please refer to the Student Success Office for more information on applying for a SIN.
Engineering students need to follow Engineering URA procedures. For an Engineering student to do a URA with a CS professor, please follow the application procedures explained on the Engineering URA page.
How to apply
Check eligibility stated above. Make sure you are eligible before taking the following steps.
- Find a project, send a resume and recent grade report to the professor, request an appointment, and reach a verbal agreement on the details of the project.
- Complete the Student Application form.
- Your supervisor must then complete the Supervisor Application Form.
Both the CS URA Student and Supervisor Application Forms must be submitted to receive your URA payment. Upon completing the webforms, you and your supervisor should receive email confirmations containing copies of each forms' responses.
URA supervisor list
Students may contact the faculty members here to see if they have projects that are not listed here but may be interested in supervising a URA for the upcoming term. The following faculty members have confirmed that they are willing to be contacted by potential URA students.
          URA supervisors
        
        URA project list
Below you will find a list of research projects that faculty members are actively seeking URA students for the upcoming term. For your convenience, the projects are grouped by the project supervisor's research area.
Students are encouraged to browse through all of the projects, even if it seems like you don't have the right background. There are many projects that benefit from a wide range of experiences or a genuine sense of curiosity from its URA students.
If you are a supervisor who would like to add/remove a research project from this list or would like to have it featured in a different research area, please notify Daniel Huab.
Algorithms and complexity research projects
          Reformulate the IESO's algorithm - Robert Guglielmi
        
        The objective of this project is to reformulate the IESO’s algorithm to balance supply and demand based on societal gain. Societal gain as defined by this project is the cumulative difference between the carbon intensity (kg CO2e/MWh) consumers are willing to accept for the electricity consumed and that at which generators can produce that electricity. The solution to the reformulated optimization problem will present a different mix of generators and allow the calculation of an implied carbon tax required to achieve the least carbon intensive solution. Another objective of the project is to perform a sensitivity analysis by constraining the solution to varying maximum electricity prices.
The role for the URA student in this project is to take a leading role in the development of the code for the reformulated algorithm. The URA student will work directly with the involved graduate student and supervisor, and will be expected to perform independent research on the IESO market rules. The URA student’s efforts will contribute to the involved graduate student’s thesis.
The student would ideally have a background in CS, or in other programs with a focus on computational skills. The student is expected to master either Matlab or Python, and their optimization packages. The student is expected to be able to work independently and as part of a team. They must be highly motivated, goal-oriented, comfortable with high degree of freedom in their daily work and have excellent written and oral communication skills. The student is expected to have an interest in power grids and utility distribution, or to be willing to learn about them.
If interested, please email Robert Guglielmi.
Artificial intelligence and machine learning research projects
          Speculative Decoding and Inference Acceleration for LLMs - Hongyang Zhang
        
        I am interested in working with (multiple) undergraduate students on the topic related to hardware for speculative decoding. Students will work with the team on building a practical LLM inference engine and related FPGA hardware. Students with familiarity on FPGA or existing inference engines such as SGLang, vLLM and TensorRT-LLM are highly encouraged to contact me and apply.
Excellent students will get my strong recommendation letter and the opportunity of joining my research team for MMath and Ph.D. study. There might be weekly discussions.
Prerequisites: Received a high grade in ECE 327: Digital Hardware Systems and ECE 320: Computer Architectures or equivalent. Basic understanding about LLMs and speculative decoding is required. Experience with SGLang, vLLM or TensorRT-LLM will be a plus.
For more information, please contact Professor Hongyang Zhang at: hongyang.zhang@uwaterloo.ca.
          Open call for multimodal, language‑driven agents at the R2L Lab - Victor Zhong
        
        Our lab develops multimodal, language‑driven agents that can perceive visual interfaces, generate code, and interact with real‑world computer environments, while creating open benchmarks and feedback‑based learning methods to evaluate and improve their performance. We also build enabling technologies—such as open data frameworks, reasoning‑rich models, and safety‑focused monitor systems—to advance safe, general‑purpose agents that can reliably assist users across diverse tasks. See more at r2llab.com/openings. You must be self-motivated and capable of leading your own project. Requirements: Experience with training/using machine learning models. Strong programming skills. Experience in leading projects.
          Analyzing the Cryptocurrency DeFi Market - Raouf Boutaba
        
        Unlike the traditional stock market, the cryptocurrency market operates 24/7 and exhibits significantly higher volatility. In this market, company fundamentals play a less crucial role. This project aims to uncover key patterns in the DeFi ecosystem by analyzing data from decentralized exchanges (DEXs) across multiple blockchains, as well as centralized exchanges (CEXs). The URAs will leverage advanced AI techniques, machine learning models, and statistical analysis to process diverse datasets, including on-chain transactions, automated market makers (AMMs), order books, token prices, crypto derivatives, bot and human trading behavior, sentiment analysis, and news data.
 
The study will focus on trading signal generation, token contagion effects, market manipulation, arbitrage opportunities, and the detection of pump-and-dump schemes. Additionally, the project will examine how trading bots interact with the market, their strategies, and their impact on liquidity and volatility. Understanding user behavior, including liquidity provision patterns and trading psychology, will also be a key aspect. This research will contribute to the development of analytical tools and automated strategies with real-world applications, such as trading bots, risk monitoring systems, and market surveillance solutions.
Interested students should contact Raouf Boutaba at: rboutaba@uwaterloo.ca with an unofficial transcript and a resume.
          Fast Matrix Multiplication in Machine Learning - Xiao Hu & Victor Zhong
        
        Matrix multiplication is a cornerstone of modern machine learning (ML), pivotal in transformer and large language models (LLMs). This project seeks to investigate novel methods to accelerate matrix multiplication, drawing from our recent state-of-the-art research [1, 2] . By optimizing this fundamental operation, we aim to enhance the efficiency and performance of ML systems.
You will engage with cutting-edge ML models and real-world data workloads, gaining invaluable experience in both academic research and practical applications. You must have a strong software engineering background, including experience with C++ and Python. Experience in ML model training and inference, as well as CUDA programming, is preferred.
This research endeavor offers a unique chance to collaborate with faculty mentors in ML/NLP and data systems, providing mentorship and networking opportunities that can significantly enhance your academic and professional trajectory. Successful students will have the opportunity to further work with our research labs, offering a pathway to deeper academic engagement and contribution to ongoing projects.
[1] Fast Matrix Multiplication meets the Submodular Width. Abo-Khamis, Mahmoud and Hu, Xiao and Suciu, Dan. PODS 2025.
[2] Fast Matrix Multiplication for Query Processing. PODS 2024.
For further information please contact Xiao Hu (xiaohu@uwaterloo.ca) and Victor Zhong (victor.zhong@uwaterloo.ca) with your CV/resume.
          Diffusion Language Models - Yuntian Deng
        
        This project investigates diffusion-based language models as an alternative to traditional autoregressive models, which generate text sequentially from left to right. Diffusion language models employ an iterative denoising process: they start with a sequence of mask tokens and progressively replace them with appropriate words until the full sequence is generated.
The project is based on a fully developed idea from my PhD advisor, Prof. Alexander Rush, and builds upon the approach presented in Simple and Effective Masked Diffusion Language Models (PDF). Specifically, it will incorporate inter-word dependencies inspired by concepts introduced in Cascaded Text Generation with Markov Transformers (PDF). The work will involve implementing the idea and conducting experiments, with the ultimate aim of producing a publication in a machine learning or natural language processing conference.
I am looking for a motivated student with strong programming skills to collaborate on this project. I will work closely with the student. Interested students may visit my personal website or contact me via email.
          Building out an Experimental Infrastructure for Human-AI Collaboration - Ana Crisan
        
        This URA will help to develop a computational infrastructure for prompting, retrieving, and storing, responses from large language models (LLMs) and humans. Their work will support the development of a broad experimental infrastructure for examining human-AI collaboration across a variety of application contexts. An ideal candidate should be a capable full stack developer, versed in front-end (e.g., Java Script, React, Svelte, Vega-lite, etc.), back-end (PostGreSQL, Duckdb, Docker, etc.), and data analysis (Python), languages and frameworks.
Interested students should review recent projects on INSIGHT LAB webpage and contact Dr. Crisan with a statement of interest and the subject line "W25 URA applicant { student name }".
          Model Serving Systems for LLMs - Hong Zhang
        
        We are witnessing an explosion of large language models (LLMs). The latest models such as GPT-4 have achieved unprecedented performance in various tasks such as code generation, text classification, and problem reasoning. However, serving LLM-based applications, i.e., deploying trained LLMs on a compute cluster and conducting model inference for incoming user requests, presents challenges in system design. GPT-4, for example, can take seconds to tens of seconds to generate responses, causing suboptimal user experiences for many interactive applications. Second, serving LLMs requires expensive hardware accelerators (e.g., GPUs) and results in high resource consumption. For instance, ChatGPT is estimated to cost over $700,000 per day to operate. Moreover, scaling LLM-based applications to meet the demands of large user bases can be challenging. Deploying the current ChatGPT model to power every Google search would require a cluster of over four million A100 GPUs. To address these problems, this project aims to design an LLM serving system with high utilization, low latency, and good scalability.
Interested students are expected to have programming capabilities (C, C++, and Python) and systems background (e.g., CS 350). Familiarity with LLM structures (or other ML models), and programming capabilities with TensorFlow or PyTorch can be a plus. For more information, please contact honzhang@uwaterloo.ca with your CV/resume.
          Data-driven Security and Reliability in 5G Networks - Raouf Boutaba
        
            This    project    focuses    on    data-driven    approaches    to    secure    5G    network    services    (i.e.,    eMBB,    mMTC    and    URLLC).    In    this    project,    the    URAs    will    be    tasked    to    generate    realistic    datasets    for    benign    5G    traffic    and    varying    attack    scenarios    that    could    lead    to compromised    5G    services.    The    datasets    generation    will    be    carried    out    in    our    emulated    and/or    in-lab    5G    testbed    environment.    The    URAs    will    also    leverage    generative    adversarial    networks    to    up-scale    the    datasets,    while    ensuring    that    the    statistical    distribution    of the    generated    datasets    is    preserved.    Furthermore,    the    URAs    will    explore    machine/deep    learning    techniques    for    early    detection    of    attacks,    including    zero-day    attacks,    on    5G    services    using    the    generated    datasets.
    Interested    students    should    contact    Raouf    Boutaba    at:        rboutaba@uwaterloo.ca    with    an    unofficial    transcript    and    a    resume.  
          xApp implementation for 5G Open RAN control - Raouf Boutaba
        
            In    mobile    networks,    radio    access    networks    (RANs)    have    been    traditionally    deployed    in    vendor-specific    and    closed    architectures.    This    makes    it    difficult    to    manage    and    control    the    network    and    integrate    new    services.    To    address    these,    Open    RAN,    a    service-oriented    software-based    architecture    has    been    proposed    based    on    the    softwarization    of    different    RAN    elements.    Open    RAN    introduces    the    radio    intelligence    controller    (RIC),    a    centralized    abstraction    that    allows    for    enhancing    traditional    RAN    functions    with    intelligent    closed-loop    control    powered    by    machine    learning    (ML).    To    this    end,    customized    RAN    control    applications    (called    xApps)    are    deployed    on    RIC    and    communicate    with    RAN    components    to    manage    different    aspects    of    the    network    including    the    radio    resource    allocation.    The    student    is    expected    to    study    existing    open-source    RIC    frameworks    and    contribute    to    the    development    of    xApps    and    ML    algorithms    for    RAN    control.    The    student    will    also    have    the    chance    to    integrate    and    test    xApps    with    our    in-lab    5G    testbed.
    Interested    students    should    contact    Raouf    Boutaba    at:        rboutaba@uwaterloo.ca    with    an    unofficial    transcript    and    a    resume.  
Computer graphics research projects
          Rendering and Wave Simulations - Shlomi Steinberg
        
        Simulations of complex wave phenomena brings together fascinating topics in physics and computer science. Such simulations have many diverse applications: like simulation of electromagnetic radiation, for example for propagation of RADAR or cellular signals in real-world environments; simulations of optical medical devices; as well as accurate light transport and rendering in computer graphics.
This project involves research and development of relevant tools, implementing simulation software (like path tracers), and performance analysis of algorithms or methods. Students are expected to have strong programming skills, and ideally some knowledge of computer graphics (e.g., CS488), optics or electrodynamics. Interested students should contact Shlomi Steinberg (steinberg@uwaterloo.ca).
Cryptography, security, and privacy (CrySP) research projects
          Adversarial Purification with Bridge Models - N Asokan
        
        Denoising diffusion models can purify adversarial examples into clean samples, thereby improving the adversarial robustness of a downstream classifier. This approach is called adversarial purification. Recently, several bridge models — including Schrödinger bridges, diffusion bridges, and flow bridges — have appeared and shown superior performance in modeling transformations between two distributions. This project aims to explore using bridge models to transform adversarial distributions into clean distributions, achieving reliable and powerful adversarial purification.
NOTE: This project is available during Winter 2026.
Skills Required:
- Proficiency in using PyTorch to complete machine learning tasks.
- Familiarity with diffusion models.
- Basic understanding of trustworthy machine learning.
Contact:
If you are interested in this URA, please email Yihan Wang (yihan.wang@uwaterloo.ca) and N. Asokan (n.asokan@uwaterloo.ca) with an unofficial transcript and a resume.
          Assessing the security implications of generative AI applications - Sihang Liu
        
        Generative AI applications are becoming widely used today. Examples include large language models (LLMs) for text generation and diffusion models for image/video generation. These models are powerful but at the same time can lead to security issues. Prior work has shown that the token length in ChatGPT messages can leak the message. This project aims to explore security vulnerabilities of generative AI applications, e.g., through side-channel attacks. 
We are looking for self-motivated students with security and machine learning backgrounds, and strong programming capabilities (C, C++, and Python). For more information, please contact sihangliu@uwaterloo.ca, and send an unofficial transcript and your CV/resume.  
          Computation Over Encrypted Data - Florian Kerschbaum
        
        Cryptography can protect data in rest and during transit. However, keeping data encrypted during computation is still often too inefficient. There exist cryptographic techniques such as homomorphic encryption and secure multi-party computation but they require careful application in order to be practically efficient. We work on several projects that apply these techniques, such that the computational overhead is reduced, e.g., by performing some computations on plaintext data, combining different cryptographic primitives or optimizing the protocols to reduce the performance bottleneck, e.g., communication cost. We focus on applications for big data, such as private set intersection, private information retrieval or private inference over data models, because these applications are already deployed in industry. We build cryptographic protocols using different toolkits and libraries, such as Microsoft's SEAL or MP-SPDZ, which are usually written in C++.
If you are interested in this URA, please email Florian Kerschbaum (florian.kerschbaum@uwaterloo.ca) with an unofficial transcript and a resume.
          Security and Privacy in Machine Learning - Florian Kerschbaum
        
        More and more applications use machine learning to derive insights from large data collections. However, this process is susceptible to several security and privacy threats. For example, the data collection may contain sensitive, private information that may still be derived from the model or the learning and inference process. We work on several projects that help ensure that such threats are contained. We work on devising improved attacks that demonstrate that protection mechanisms are not as successful as they claim to be or processes that are assumed to be safe are not. We also work on defense mechanisms that provide better protection based on the latest developments in cryptography, differential privacy, and machine learning. Our work involves designing algorithms, developing prototypes, mostly in Python, and evaluating their performance and security.
If you are interested in this URA, please email Florian Kerschbaum (florian.kerschbaum@uwaterloo.ca) with an unofficial transcript and a resume.
Data systems research projects
          Fast Matrix Multiplication for Database Query Processing - Xiao Hu
        
        I am interested in working with undergraduate students on a research project that aims to apply fast matrix multiplication techniques to speed up the processing of database analytical queries. This research has practical applications in social network analysis, statistical inference, visualization, graph mining, and machine learning over relational data. Students will be able to learn about the latest breakthroughs in fast matrix multiplication for query processing from the theoretical aspects and develop efficient algorithms that can be implemented in practical database systems.
I am looking for self-motivated students with strong programming capabilities (C, C++, and Python) and basic knowledge of algorithm design. For more information, please contact xiaohu@uwaterloo.ca with your transcript and CV/resume.  
 
          A Dashboard for an Internet Censorship Observatory - Diogo Barradas
        
            ICLab    is    a    global    and    longitudinal    Internet censorship    measurement    platform    that    collects    data    on    censored    webpages    around the    world    since    2016. ICLab    makes    use    of commercial    VPNs    as    vantage points    on    multiple    countries    to    detect    censorship    activity    based    on    DNS manipulation,    TCP    packet injection,    and    the    serving    of    “blockpages”.
    Currently,    however, ICLab    is    only    able to    archive    raw    measurement    data    for    posterior    analysis    and    lacks    the    ability    to provide    non-technical    users    with    a data    visualization    dashboard    that    facilitates an    easy    exploration    of    the    platform’s    measurements    as    new    data    is    collected.
    The    goal    of    this    project    is    to    design and    develop    an    ICLab    visualization    dashboard,    based    on    web    technologies,    that    enables a    user-friendly    exploration ICLab    measurement    data    (e.g.,    at    a    country    and measurement    type    granularity).
    Interested    students    should    have    practical experience    with    information    visualization    technologies    (e.g.    React-D3,    Plotly    Dash, etc.)    and    relational databases    (SQL).    For    more    information,    please    contact Prof.    Diogo    Barradas    at dbarrada@uwaterloo.ca and    send    an    unofficial    transcript    and    a    resume.  
          Cloud and Distributed Big Data Systems - Khuzaima Daudjee
        
        If you are a senior undergraduate student interested in working with large scale distributed systems that involve managing big data and storage in the cloud to achieve scalability and deliver good performance, please e-mail Khuzaima Daudjee at: kdaudjee@uwaterloo.ca
          Building privacy-preserving data systems - Sujaya Maiyya
        
        Data privacy is becoming one of the major challenges of the tech industry. With many applications outsourcing their data storage needs to third party cloud vendors such as Amazon AWS or Google Cloud Platform, the lack of trust in third party storage services aggravates the privacy challenges. While encrypting an end user's data forms the first layer of protection against the loss of data privacy, many recent attacks have shown that the access patterns on encrypted data reveal sensitive information. For example, the duration and frequency with which an oncologist accesses (encrypted) data can reveal the type of a patient’s cancer (e.g., based on the frequency and intervals of chemotherapy treatments). In this project, we will explore efficient techniques to hide the data access patterns from an adversary and integrate these techniques in building a privacy-preserving datastore.
A URA candidate would begin the project by reading the necessary background research papers, will be actively involved in research meetings, and will be involved in implementing the newly designed data system
If interested, please email Sujaya Maiyya at: smaiyya@uwaterloo.ca
Human computer interaction (HCI) research projects
          Teaching the Agent - Edith Law
        
        This project explores how students can learn more effectively by teaching an AI agent. Instead of acting as an all-knowing tutor, the AI is designed as a conversational peer, less knowledgeable and intentionally flawed, so that students must explain, justify, and correct it.
We are looking for a curious and motivated student with some experience in Python and React (or JavaScript and web development more generally) to work on the design of the interface and the agent.
For further information, please contact Edith Law (edithlaw@uwaterloo.ca) and Lucas Gomez-Tobon (lgomezto@uwaterloo.ca) with your CV/resume and the subject line “W25 URA applicant { student name }”.
          Interacting with visual representations of time-oriented data in augmented reality - Matthew Brehmer
        
        This URA project will compare egocentric vs. exocentric / world-anchored positioning of time-oriented data in mobile augmented reality. Candidates should have experience working with frameworks such as Apple's ARKit or Google's AR Core, prototyping with tools like Reality Composer or Unity, and implementing gesture- and / or proxemic-based interactions.
Interested students should review recent projects on Prof Matt Brehmer's website and contact him with a statement of interest and the subject line "W25 URA applicant { student name } for Mobile AR project".
          Semantically-resonant inline information graphics for text-based conversations - Matthew Brehmer
        
        This URA project will build upon our recent research [*] dedicated to fostering engaging communication around data on (primarily) text-based conversation platforms (e.g., Slack, Teams, Discord) with support for composing evocative pictographic representations. Candidates should be comfortable building interfaces with frameworks / libraries such as Svelte, React, or Vue, and have a basic familiarity with information design conventions. Experience in applied natural language processing and / or conducting research with human participants would also be an asset.
Interested students should review recent projects, and especially the two projects linked 👇 on Prof. Matt Brehmer 's website and contact him (mbrehmer@uwaterloo.ca) with a statement of interest and the subject line "W25 URA applicant { student name } for Inline Infographics project".
          Intelligent and Interactive Visualization Techniques - Jian Zhao
        
        This URA project will be related to the design, development, and evaluation of interactive visualizations that facilitate human-data and human-AI interaction. An idea candidate should be comfortable in full-stack development (e.g., JavaScript, NodeJS, React, D3.js, Boostrap), data analytics (e.g., Python, numpy, scipy, pandas), and machine learning (e.g., tensorflow, pytorch, LLMs). 
Interested students should view a list of current and past projects on Prof. Jian Zhao’s webpage and submit an application online.
          Supporting Virtual Reality State Change and Transitions - Zachary McKendrick
        
        We are currently seeking research collaborators for The VR Thresholding Protocol, a research project investigating the experience of user state change and transitioning into and back out of immersive virtual reality (VR). Using the v1 prototype as a starting point we are looking for a URA to implement the next phase of the protocol and (potentially) test its viability with a small user study. If selected, the successful URA will help design and develop an environment and digital 'host' to guide participants through the Thresholding process and attach the process to the start and end of an existing VR game/environment.
Experience with Unity Game Engine (or Unreal) and VR/AR development is required. Familiarity with motion capture is an asset as is previous experience conducting research with human participants (though this is not necessary).
Interested applicants should apply online and email Dr. Zachary McKendrick, MFA with a (brief) statement of interest.
Programming languages research projects
          A New Programming Language with Effect handlers: Implementation and Application - Yizhou Zhang
        
        Effect handlers are a powerful language abstraction: they subsume a variety of control-flow features such as coroutine iterators and async/await, and they can be applied to domains such as probabilistic programming and automatic differentiation. Recently, a team of researchers at Waterloo have created Lexa, a new programming language supporting effect handlers. This URA project focuses on enhancing Lexa's compiler implementation and building cool applications in Lexa.
Prior experiences with compiler construction are required.
To join the project, reach out to Yizhou Zhang with your unofficial transcript and resume.
          A Compiler for Probabilistic Programs - Yizhou Zhang
        
        Probabilistic programming languages (PPLs) are powerful means for expressing probabilistic models and performing inference on them. We are working on the design and implementation of a new PPL to tackle the challenge of scalable probabilistic inference through an innovative compiler framework. This research synthesizes important ideas from compilers, statistics, combinatorics, and artificial intelligence, with a wide range of real-world applications.
The student should have experience writing compilers, a solid understanding of probability and statistics, and strong programming skills.
Interested, competent students can reach out to Yizhou Zhang at yizhou.zhang@uwaterloo.ca.
 
          Building Certified Compilers with a Proof Assistant - Yizhou Zhang
        
        It is imperative that compilers be correct; compiler bugs invalidate application-level correctness guarantees. In this project, the student will use the Coq proof assistant to certify the correctness of compilers for a family of C-like languages.
The student should have prior experiences with compilers and proof assistants. The student should be able to quickly learn and adapt to mechanizing proofs similar to those in CompCert.
To join the project, reach out to Yizhou Zhang at yizhou@uwaterloo.ca with your unofficial transcript and resume.
          Writing a Compiler for the Familia Programming Language - Yizhou Zhang
        
                Familia is    a    language    design    that    promises    a    lot    of    polymorphism    and    extensibility    in    a    lightweight,    type-safe    package.    This    project    is    aimed    at    materializing    all    this    expressive power    by    creating    a    compiler    for    Familia.    In    particular,    students    will    implement    compiler    passes    transforming    Familia    code    into    lower-level    languages.
    We    are    seeking    ambitious    students    who    have    compiler-hacking    experiences    and, ideally,    are    familiar    with    LLVM.
    Interested    students    should    contact    Yizhou    Zhang:        yizhou.zhang@uwaterloo.ca  
          C∀ (Cforall) Programming Language and Runtime System - Peter Buhr
        
        The C∀ project is an open-source project extending ISO C with modern safety and productivity features, while still ensuring backwards compatibility with C and its programmers. C∀ is designed to have an orthogonal feature-set based closely on the C programming paradigm (non-object-oriented) and these features can be added incrementally to an existing C code-base allowing programmers to learn C∀ on an as-needed basis. In many ways, C∀ is to C as Scala is to Java, providing a research vehicle for new typing and control-flow capabilities on top of a highly popular programming language allowing immediate dissemination. There are many small development and evaluation activities within the C∀ project suitable for URAs. A URA candidate should be interested in programming languages and associated runtime internals with experience in C/C++ programming. Hence, interested students need some programming-language/systems background, for example, have taken one of CS350, CS343, CS442, CS444, or learned the equivalent material from some other place, like a work term or project involvement.
If you are interested, please email Peter Buhr at: pabuhr@uwaterloo.ca
Software engineering
          Porting Legacy Solaris Software to Linux and Mac OSX and Porting Modern Software to Solaris - Daniel Berry
        
        My calendar is a plain text file that lists dates and events. I have a program called "remind" that reads this text file and tells me the events scheduled for today and the next three days. The remind program was written back in the 1980s in the then current C and Pascal. Each version is 3–5 pages. Since then, I have been running a binary compiled from one of these source programs, which one I no longer remember, on Solaris running on a Sun 4, a.k.a. a Sparc Station. The program is bug free or I have learned to avoid bugs in my daily use of it.
My Sparc Station died over the summer and I have been using a Sparc emulator running on Mac OS X. I would like to port the program to run on Ubuntu Linux and Mac OS X, so I can host my calender and run "remind" on any such system.
So the first task of this URA is to port to Ubuntu Linux and Mac OS X these functionally equivalent bug-free C and Pascal programs that compiled by the vintage cc and pc on the vintage Sun Sparc running the vintage Solaris.
I ran on the Sparc other binaries for which I have no source code. So I have to run these binaries on the emulated Sparc and place the Sparc on the Internet for easy login and file transfer from other machines. To do that, I need to have on SSH running on the emulated machine. The SSH on the emulated machine uses encryption that is no longer allowed because it is too easily broken.
The second task of this URA is to port to Solaris running on the Sparc emulator, the current Open SSH package with the latest encryptions.
If you are interested in this URA, please contact Daniel Berry at dberry@uwaterloo.ca. Probably you need the ability to program in C. Otherwise, you will spend most of your time learning the language rather than learning what makes porting these programs difficult.
Systems and networking research projects
          Analysis and Implementation of Network Algorithms and Protocols - Mina Tahmasbi Arashloo
        
        Computer networks have grown into a massive, shared infrastructure, connecting millions of users to thousands of online services. To support all these users and services, networks rely on a multitude of algorithms and protocols, e.g., for packet scheduling, congestion control, routing, load balancing. Together, these algorithms and protocols determine the quality of service that a network can provide to traffic flows for different applications in the network.
Understanding how different algorithms and protocols and their combinations affect network performance, finding the right set of algorithms and protocols given the specific requirements of the applications using the network, and creating robust and efficient frameworks for deploying them in the network are important open problems. We are looking for URAs to help us make progress on these problems by studying, analyzing, implementing, and experimenting with some of the most influential existing networking algorithms and protocols. Prior experience in systems-oriented courses such as Operating Systems and Computer Networks is a plus.
If you are interested, please fill out the Google Form at the following link: https://forms.gle/jvtgp7BdkaVFh3o39
          Hardware Support for Large-scale ML Applications - Sihang Liu
        
            Recent    advancements    in    ML    techniques,    such    as    large-language    models    (LLMs),    revolutionized    natural    language    processing    and    understanding.    At    the    same    time,    these    large-scale    ML    applications    pose    new    challenges.    One    of    the    main    aspects    is    the    demand    for    computation    capabilities.    For    example,    serving    LLM    costs    more    than    ten    times    as    compared    to    conventional    web    search.    This    URA    project    aims    to    improve    the    performance    of    large-scale    ML    applications    through    hardware    support,    such    as    designing    accelerators    for    ML    applications    and    optimizing    their    memory    systems. 
    Interested    students    are    expected    to    have    programming    capabilities    (C,    C++,    and    Python)    and    computer    hardware    and    systems    background    (e.g.,    CS    350    and    450).    For    more    information,    please    contact sihangliu@uwaterloo.ca,    and    send    an    unofficial    transcript    and    your    CV/resume.    
          Cloud and Distributed Big Data Systems - Khuzaima Daudjee
        
        If you are a senior undergraduate student interested in working with large scale distributed systems that involve managing big data and storage in the cloud to achieve scalability and deliver good performance, please e-mail Khuzaima Daudjee at: kdaudjee@uwaterloo.ca