You are here

Undergraduate Research Assistantship (URA) program

The David Cheriton School of Computer Science offers opportunities to exceptional students through the Undergraduate Research Assistant (URA) program that allows students to earn $600 a term for part-time research with a faculty member. The money is paid once near the end of the term.

Faculty members post openings each term so interested, eligible students can apply. Students can also contact faculty members if they are interested in specific research areas to see if a URA opportunity might be available.

Any student who has completed their second year in the Faculty of Mathematics with an average of at least 80% is eligible. Preference is given to students enrolled in Computer Science major plans. A student can only do one URA per term. A student cannot be on a co-op term while doing a URA.

Fall 2016 positions

Title: Preference Elicitation for Stable Matching with Couples

Given two disjoint sets, M  and W, of equal size, where each element in M has a ranking (preferences) over elements of W and vice versa, the stable matching problem asks is there some way to form pairs (m,w) such that there is no pairs (m_i,w_j) and (m_k, w_l) such that m_i prefers w_l to w_j and w_l prefers m_i to m_k. This problem has been well studied in the mathematics, economics and computer science literature, and forms the foundation of many market models such as  corporate hiring, school admissions, and residency matching for doctors.

However, algorithms for the stable matching problem usually assume that full ranking/preference  information is available. For large-scale matching market problems with hundreds or thousands of options it is not reasonable to assume the participants can provide such information directly. Instead, we have been working on developing algorithms that elicit preference information incrementally for matching markets. We are now interested in extending our current algorithms to situations where there are couples in the markets who may have preferences over pairs of options or alternatives.

We are looking for a student who can extend our current preference elicitation code so to handle couples.  Students working on this project should have a background in data structures and algorithms and have experience programming in Python. An interest in artificial intelligence and market models would be an asset.

Interested students should contact: Kate Larson kate.larson@uwaterloo.ca


Title: Perceptions and Effectiveness of Crowd-training Instructors

I am looking for a URA to pursue research in the area of training for crowdsourcing. Crowdsourcing is a form of online distributed computing where tens, hundreds, or thousands of people (i.e., workers) perform a specific task in exchange for monetary compensation. The vast majority of crowdsourcing tasks train workers by supplying them with a set of static training examples. However, this form of training likely insufficient for many complex tasks that either require domain-specific expertise or are composed of many sub-tasks. In this project, we are interested in investigating the effectiveness of a training tool that allows a worker, or set of workers, to be taught by a recording of a person that the workers deceptively believe to be present. We are specifically interested in understanding (1) how workers perceive their instructor and (2) how the effectiveness of the instruction changes with the perception of the instructor. The goal of this project is an academic publication. 

This work will be mostly research-oriented with occasional web development. Applicants should have solid knowledge of web-based programming (e.g. JavaScript), a scripting language (e.g. Python), and be comfortable with reading and writing academic publications. Knowledge of web frameworks (e.g. Django) is also useful. Although not necessary, an understanding of statistics and experimental design is desired.  

Interested students should contact Dr. Edith Law (edithlaw@uwaterloo.ca) or Alex Williams (Alex.Williams@uwaterloo.ca).



Title: Pricing Models for Cloud Services


Cloud service providers such as Amazon charge fees for using different machines instances from their infrastructure-as-a-service offering.  I am looking for a URA to study current pricing models and to analyze and propose a new model for cloud pricing.  A strong background in statistics/applied math is required. 

Senior undergraduate students should email Khuzaima Daudjee at kdaudjee@uwaterloo.ca



Database for Specialized Optometric Records

Data collected by specialized optometric equipment is available as comma-separated files, which are currently manipulated through spreadsheet software to produce patient-specific clinical reports. Through previous URAs, we have built a web interface and relational database backend for managing data collected from one of the optometric measurement devices. We’d like to continue to design and implement a federated database system that provides access to such data repositories in a clinical setting.

The first task for this URA is to extend the front end to provide informative data visualizations and to produce comparative reports. We also wish to extend the database to support additional optometric devices, adapting the relations and creating software to load spreadsheet data into the database and produce additional reports.
The computer science aspects of the work will be supervised by Prof. Frank Tompa (CS).  Prof. Kristine Dalton (Optometry) will provide sample data and help to specify the content and user-interface requirements of the project.
Familiarity or experience with using Python, the Django framework, MySQL, and GitHub is a definite asset.

For more information please contact Dr. Frank Tompa (fwtompa@uwaterloo.ca)


Title: Cache Management for Graph Database Systems

I am looking for a senior URA to study caching protocols in graph database systems.  The task would be to understand existing cache management protocols for an open source graph database system such as Neo4j and to then design, implement and test an improved cache management scheme for graph database workloads. 

Senior undergraduate students interested and comfortable with working and building systems (operating systems, distributed systems, database systems) should email Khuzaima Daudjee at kdaudjee@uwaterloo.ca


Title: Privacy Vulnerabilities on Android

We have developed an app that analyzes the network traffic of all apps on a smartphone in order to detect leakage incidents, where an app sends sensitive user information across the network https://www.cs.uwaterloo.ca/~uhengart/publications/spsm15.pdf

In a previous URA, a UI that informs users of leakage incidents was added to the app.

The first goal of the proposed URA is to thoroughly test the app and UI with several applications and address any issues that may arise so that the app can be released on Google Play. The second goal is to add additional features to the app, such as providing more detailed information about leakage incidents or coming up with simple ways to distinguish between legitimate and illegitimate leakage incidents.

Android development experience is required.

Interested students should email Urs Hengartner urs.hengartner@uwaterloo.ca


Title: Shatter Client for iOS

Shatter is a framework that allows a user's devices to jointly perform cryptographic operations such that the impact of a lost or stolen device remains limited. For example, you need both your watch and your smartphone to initiate an encrypted IM session. A thief stealing your smartphone will not be able to impersonate you. Shatter is implemented in Java and currently runs on Android, Android Wear, and Linux. The goal of this URA is to port Shatter to iOS.

Ideal applicants are experienced iOS developers. Cryptography background would also be an asset.

Interested students should contact: Urs Hengartner urs.hengartner@uwaterloo.ca


Title: Enhancing a Main-Memory DBMS

We are looking for up to three students to fill URA positions to work on a main-memory database management system. The system is mainly coded in common lisp, but also has components written in C, Bison, Flex and csh. It is a "compiling" DBMS that has a simple extensible runtime and operates by translating SQL-like data manipulation requests directly to C code that interfaces with this runtime. The underlying data model is a generalization of the relational data model in which, among other things, arbitrary inheritance hierarchies may be declared.

During the course of the project, students will increase their familiarity with a range of topics, among which: semantic data modelling, query optimization, A* search, transaction compilation, legacy data integration, rule-based translation and source code synthesis.

Ideal applicants will have a solid background in algorithms and data structures, and a particular interest in program translation. Experience with programming in a functional style would also be an asset.

Interested students should contact Grant Weddell gweddell@cs.uwaterloo.ca


How do I apply?

Both of these forms must be fully completed and returned to Simone Paull in MC 4036, Please email spaull@uwaterloo.ca to arrange a time.

A faculty member must sign and fill out the account number on both the URA form and the Casual or Additional Pay Request form.

International Students need an SIN # to work in Canada

Please refer to the Student Success Office for this information:

https://uwaterloo.ca/international-students/social-insurance-number

For more information, please contact:

Simone Paull
Office: MC 4036
Phone: (519) 888-4567 ext. 36826
Email: spaull@uwaterloo.ca