User Tools

Site Tools


projects

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revisionPrevious revision
Next revision
Previous revision
projects [2017/08/10 18:45] jenkinprojects [2017/09/01 21:02] (current) jenkin
Line 1: Line 1:
 ~~NOTOC~~ ~~NOTOC~~
 ====== Proposed Projects   ====== ====== Proposed Projects   ======
 +
 +====== Graphical User Interface for Power System Simulator ======
 +**Supervisor:** Afshin Rezaei
 +
 +The project is to develop a user-friendly Graphical User Interface (GUI) for a power system simulator program. Similar to all circuit simulation programs, the GUI should provide a library of the system components. These elements include not only the basic circuit elements such as resistor, capacitor, and inductor but also more complex equipment models such as transformers, generators, etc. The library elements can be dragged and dropped on the design page. The user would be also able to add new elements to the library. Each element has its own dialog box for entering the parameters which is displayed by double-clicking on that element. The elements will be connected by the user. The GUI should provide the common tasks for drawing, removing, grouping, and construction of a circuit. The GUI can write an output data file of the system element parameters and connections and call an available executable program to run. After, the GUI will display the simulation results.
 +
 +**Required background:** General CSE408x prerequisites, good programming skill, good knowledge of GUI design tools
 +
 +====== Development of a Standalone Power System Optimization Toolbox ======
 +**Supervisor:** Afshin Rezaei
 +
 +Finding the optimum system condition and maximum/minimum of analytical or numerical functions are of fundamental needs and widely used in various fields of Engineering. This project is to develop a standalone optimization toolbox based on Intel Visual FORTRAN for power system applications. FORTRAN language with its highly developed math library is a powerful tool to solve complicated mathematical problems. A group of such mathematical problems are those dealing with the optimization algorithms particularly the curve fitting and global optimization methods such as genetic algorithm. 
 +In this project, the developer is expected to explore Intel FORTRAN Math Kernel Library (MKL) and Intel Mathematics and Statistics Library (IMSL) and develop a program code in FORTRAN to call built-in functions and perform the requested optimizations specified by the user. Due to compatibility of the MS Visual Studio with both FORTRAN and C++, some parts of the code can also be developed in C++.  
 +
 +**Required background:** General CSE408x prerequisites, good programming skill, good math skill, good knowledge of Intel FORTRAN and C++
 +
 +
 +====== Palpation Task Trainer ======
 +
 +**Supervisors:** Petros Faloutsos (EECS) and Iris Epstein (School of Nursing)
 +
 +Palpation of head and neck region is an integral part of a complete physical health assessment performed by both physicians (e.g., physician assistant; family doctor; Ear Nose and throat specialist and surgeon) and Nurses (Nurse practitioners, registered nurses). During palpation practitioners use their sense of touch with knowledge of anatomy of the head and neck to feel, differentiate and characterize the masses within their anatomical landmark (e.g.,lymph nodes; fat; size; texture; movements). With increase prevalence of cancer in head and neck early detection and appropriate referral and treatments are paramount. In 2016, George Brown College Capstone Engineering program together with the help of the nursing lab simulation specialist constructed a head and neck normal task trainer (prototype 1) with 32 touch sensors (see image bellow). During a multidiscipline conference in May 2017 we tested the task trainer with over 47 experts’ practitioners (Doctors and Nurses). Two important themes emerged from the survey. First, the need to render the task trainer more realistic (e.g., the touch of the skin and bonny structure). The second, focus on making the task trainer more interactive. The purpose of this project is to create a second prototype with an interactive gaming capabilities during a head to neck palpation.  Perhaps creating an algorithm gaming from simple to complex palpation assessment skills (e.g., to create a game around not only palpating to locate the mass but also to characterizing it.). Possible directions:
 +1. Head to neck anatomical structure - Making the task trainer more "real" with anatomical / bone/ cartilage/ glands structures. 
 +2. Head and neck skin - Because we are focusing on palpation touching the skin and making the skin respond to touch is important. 
 +3. Head to neck engaging and interactive - Several health care providers perform palpation. In fact there is a hierarchy among them (nurse vs doctor; family doctor vs Ear Nose and throat). Creating some kind of interactive game to find and characterize the gland with multidiscipline.
 +
 +**Required Background:** Standard prerequisites,some knowledge of C++. 
 +
 +**Other experience:** Knowledge of computer graphics (e.g. EECS3431)  and  familiarity with programming computer games would be useful for the gaming aspect, while familiarity with making and 3D printing  might be useful for developing the prototype system.
 +
 +**Resources and readings:** Here are two links to articles we published. The reference list has more resources
 +http://www.ijocs.org/clinical-journal/head-to-neck-task-trainer-to-teach-palpation-skills-back-to-basic-12036.html
 +http://www.sciedu.ca/journal/index.php/jnep/article/view/11461
 +
 +
 +====== Custom Camera App using the Andriod Camera 2 API ======
 +
 +
 +**Supervisor:** Michael S. Brown
 +
 +Cameras have a number of processing steps that convert the incoming sensor image to the final sRGB-JPEG image.  These steps are collectively referred to as the "camera processing pipeline" The camera processing pipeline has traditionally been fixed in a camera's onboard hardware. This made changing it difficult to develop a custom camera application. The new Camera 2 API for Android, however, allows developers significant more control over the entire imaging pipeline.
 +
 +The primary goal of this project is to develop custom camera applications that manipulate individual components of the imaging pipeline (e.g., custom white-balance, custom colour mapping, custom tone-manipulation, etc.).   These applications will all be built on top of the Camera 2 API for Android phones.
 +
 +**Required Background:** General EECS 408x prerequisites, knowledgeable with photography, experience with Java programming for Android platforms.
 +
 +
 +====== Ultrasound simulation/trainer ======
 +
 +**Supervisor:** Burton Ma
 +
 +Trans-esophageal echocardiography (TEE) is the standard of care for most cardiac surgeries and interventional cardiology procedures. It uses a thin and flexible ultrasound probe that is inserted down the esophagus in position beside the heart, and the echocardiographer adjusts the position and orientation of the probe from outside. For new clinicians, learning how to adjust the probe into the correct location for various views of the heart can be quite challenging.
 +
 +The primary goal of this project is to develop an open source, inexpensive software simulation for training clinicians in the use of TEE ultrasound. Starting with a 3D-plus-time CT or MRI heart dataset, we will create simulated ultrasound images, and use a mouse to simulate the translation and rotation of the ultrasound probe. The software platform will render the simulated ultrasound, and provide the user with feedback on how well they can identify the standard TEE views. This project will involve a collaboration with clinicians in Toronto and London, Ontario.
 +
 +**Required Background:** General CSE408x prerequisites,some knowledge of C++, knowledge of computer graphics would be useful (e.g. EECS3431)
 +
 +====== 3D Fractal visualizations and Music ======
 +
 +
 +**Supervisor:** Vassilios Tzerpos
 +
 +Visualizing and navigating through 3D fractals is very cool. Check out an example here: https://www.youtube.com/watch?v=oo3f2hjV_AM
 +
 +This project will investigate the connection between music and 3D fractal visualizations, both in terms of generating music to match the visualization, as well as creating a visualization to match an existing piece of music. The project will start with a literature survey of the state of the art in this field and then focus on developing a prototype music/visualization generation tool.
 +
 +**Required Background:** General CSE408x prerequisites, good knowledge of C++
 +
 +
 +====== Extracting Information from Music ======
 +
 +**Supervisor:** Vassilios Tzerpos
 +
 +While humans are quite good at extracting musical information from audio, such as tempo and time signature, computers have room for improvement in this regard.
 +
 +This project will use the JUCE framework to create software that extracts such information from audio files. Existing algorithms will be implemented and compared, and possibly improved. The output will be both a stand-alone application, as well as plugins for digital audio workstations used in the music industry, such as Pro Tools, Ableton Live etc.
 +
 +**Required Background:** General CSE408x prerequisites, good knowledge of C++
  
 ====== Data-driven conceptual modeling within on-line communities ====== ====== Data-driven conceptual modeling within on-line communities ======
Line 33: Line 111:
 ====== Distributed leader election for simple robots ====== ====== Distributed leader election for simple robots ======
  
-**Supervisors:** Professors Michael Jenkin and Patrick Dymond+**Supervisors:** Michael Jenkin and Patrick Dymond
  
 **Project:** How should a group of autonomous agents moving within multiple locations choose and maintain a leader to coordinate and control them? Utilizing the concept of an infection algorithm — a process much like the spread of a disease in which agents infect each other with information — it is possible to develop a probabilistic approach to this kind of leader election problem. Solutions to this type of problem finds wide application in distributed computing, and in particular distributed computing of autonomous agents and sensors which must compute information about control structures with limited information about the presence/absence of potential leaders in the environment. **Project:** How should a group of autonomous agents moving within multiple locations choose and maintain a leader to coordinate and control them? Utilizing the concept of an infection algorithm — a process much like the spread of a disease in which agents infect each other with information — it is possible to develop a probabilistic approach to this kind of leader election problem. Solutions to this type of problem finds wide application in distributed computing, and in particular distributed computing of autonomous agents and sensors which must compute information about control structures with limited information about the presence/absence of potential leaders in the environment.
Line 43: Line 121:
 ====== Asynchronicity in infection algorithms ====== ====== Asynchronicity in infection algorithms ======
  
-**Supervisors:** Professors Michael Jenkin and Patrick Dymond+**Supervisors:** Michael Jenkin and Patrick Dymond
  
 **Project:** How does changing the model of synchronization changing run time bounds on infection algorithms? **Project:** How does changing the model of synchronization changing run time bounds on infection algorithms?
Line 53: Line 131:
 ====== Simultaneous localization and mapping (SLAM) aided by a single unique directional landmark ====== ====== Simultaneous localization and mapping (SLAM) aided by a single unique directional landmark ======
  
-**Supervisors:** Professors Michael Jenkin and Patrick Dymond+**Supervisors:** Michael Jenkin and Patrick Dymond
  
 **Project:** How can a simple SLAM algorithm be improved if it is known a priori that there exists in the environment a single unique landmark that provides both position and orientation information? **Project:** How can a simple SLAM algorithm be improved if it is known a priori that there exists in the environment a single unique landmark that provides both position and orientation information?
Line 62: Line 140:
  
  
 +====== Immersive Virtual Worlds ======
 +
 +
 +**Supervisor:** Robert Allison
 +
 +We have a new and unique fully immersive virtual environment at York. The student would develop interactive 3D virtual worlds to study self motion perception and human computer interaction in a virtual world. In particular, working with a senior graduate student or postdoctoral fellow, the successful applicant would model 3D environments, render them in a virtual reality display and develop/implement interaction methods to control and interact with the simulation. Artistic background or skill would be an asset but is not required.
 +
 +**Required Background:** General EECS408x prerequisites, good programming skills, previous work with computer graphics would be helpful
 +
 +
 +====== Virtual Walking Devices ======
 +
 +**Supervisor:** Robert Allison
 +
 +Simulating effective walking in an immersive virtual environment is challenging. Working with a senior graduate student, the successful applicant would help to develop a circular treadmill interface to support virtual walking metaphors.
 +
 +**Required Background:** General EECS408x prerequisites, good programming and mechanical skills
 +
 +====== Adapting a 3D Printer for Paste Extrusion ======
 +
 +**Supervisor:** James Smith
 +
 +3D printers are an enabling technology for engineering design. However most low- to medium-end printers can only extrude plastics through a hot-end extrusion system. A local company has developed a nozzle and pump system for pastes that can be integrated with existing printers. A student group is sought to design a mounting bracket for an existing TAZ 4 printer that can be used to augment its ABS extruder with a Discov3ry paste extruder. The bracket is to be printed with the TAZ and the design is to be released publicly to the open-source community. Sample prints, calibration routines and possible modifications to the printer's software may be required. Experience with programming and hardware are important prerequisites.
 +
 +**Required Background:** General CSE408x prerequisites
 +
 +====== Peer-to-Peer agent based applications in smart power grids ======
 +
 +**Supervisor:** Hany Farag
 +
 +Multi-agent systems have been mentioned recently as a potential technology for several operational control objectives in smart power grids. The multi-agents technology allows the rapid and detailed creation of a system model and creates a robust framework for distributed control. The distributed control structure consists of components called control agents. These control agents try, through communication and negotiation with other control agents, to: 1) determine the current state of the system and/or subsystems and 2) make decisions (set their local actuators or communicate with other agents) in such a way that their own objectives are met as closely as possible and any constraints are satisfied.
 +
 +This project aims to implement formulated distributed constraint optimization (DCOP) in a multi-agent platform for two objectives in smart grids: 1) voltage regulation and 2) electricity market,. There are several Java-based open source platforms for peer-to-peer agent based applications e.g. (JADE, Jadex, Jason,..etc). With the help of the supervisor, the student will choose the platform that suits the required applications. Also, the student will implement the formulated DCOP in the suitable multi-agent platform to test its effectiveness and robustness. Toward that end, an interface between the multi-agent platform in Java environment and the power grid simulator in MATLAB environment is required to transfer the measurements from MATLAB to the multi-agent platform and then transfer the actions from the multi-agent platform to MATLAB in real-time.
 +
 +The student should be a strong Java and MATLAB programmer. He should have prior knowledge about multi-agent platforms such as JADE. The work involves reading and understanding the formulated DCOP in smart grids and working with the supervisor and master/PhD student(s) to implement the developed algorithms and to measure the performance of the developed algorithm(s) in the multi-agent platform.
 +
 +**Required Background:** General CSE408x prerequisites
 +
 +
 +====== Clustering High-Dimensional Data Sets ======
 +
 +**Supervisor:** Suprakash Datta
 +
 +Clustering is a basic technique for analyzing data sets. Clustering is the process of grouping data points in a way that points within a group are more similar to each other than points in other clusters. Many clustering algorithms have been developed over the years. However no single algorithm works well for all data sets. Further, most clustering algorithms have running times of the order of n^2 or n^3, so that they are not feasible for data sets with hundreds of thousands of points. In this project we will design good clustering algorithms for large real data sets. In particular we are interested in Biological data sets.
 +
 +Our data sets will include those obtained from Flow Cytometry data. Flow Cytometry is a common technique in many areas of Biology, particularly Immunology. Typical usage involves testing a blood sample for 25 attributes on a per-cell basis, and thus typical data sets are arrays of 500,000 points in a 25 dimensional space. The aim is to identify clusters that correspond to a biologist's notion of a cell “population”. In addition to the size of the data, the factors that make this problem difficult are heterogeneity of population sizes and densities and overlapping populations. With the help of collaborators we proposed an accurate algorithm called SWIFT (Cytometry A. 2014 May;85(5):408-33) that successfully finds small cell populations of interest to Immunologists. This project attempts to design and implement algorithms that are faster than SWIFT but at least as accurate. The supervisor has collaborators in Immunology who are experts in interpreting and analyzing Flow Cytometry data. Their expertise will be used to design and validate effective clustering algorithms that can run on large data sets.
 +
 +No Biology knowledge is required. The student should be a strong programmer. Knowledge of C/C++ is desirable but not essential. The work involves reading and understanding existing algorithms and working with the supervisor to design and implement improved algorithms and to measure the performance of the proposed algorithm(s).
 +
 +For more information, please send email to datta@cse.yorku.ca.
 +
 +**Required Background:** General EECS408x prerequisites
 +
 +
 +====== Metaheuristic-based Optimization techniques ======
 +
 +**Supervisor:** Suprakash Datta
 +
 +Optimization is a crucial step in many computational problems. For computational problems that seem (or are known to be) intractable, metaheuristic-based techniques often work well in practice. These are typically randomized algorithms, often inspired by physical or biological systems. Examples of such algorithms include simulated annealing, genetic algorithms and ant colony optimization. In this project we will focus on particle swarm optimization (PSO), a technique inspired by the search for food by flocks of birds or schools of fish. Briefly, a set (or population) of candidate solutions (called particles) are maintained at all times by the algorithm. These particles move in the search-space using simple rules that make use of the best solutions found so far by the particle as well as by the swarm. Movement of particles result in new particles being generated. The process is repeated until some termination criteria are met and the best solution found is output by the algorithm. While there is no guarantee of optimality, PSO has been shown to produce good or very good solutions for many practical problems. Many variants of PSO's have been proposed. In this problem we will study the performance of some PSO variants on both artificial and real optimization problems.
 +
 +The student should be a strong programmer. A good grasp of algorithms and knowledge of C/C++ are desirable but not essential. The work involves reading and understanding existing algorithms and working with the supervisor to design and implement improved algorithms and to measure the performance of the proposed algorithm(s).
 +
 +**Required Background:** General CSE408x prerequisites
 +
 +
 +====== Genome-wide identification of plant micro RNAs ======
 +
 +**Supervisor:** Katalin Hudak
 +
 +The Hudak Lab in the Biology Department has an opening for a fourth-year Honours student to assist with a bioinformatics project. We study the pokeweed plant, Phytolacca americana, which displays broad-spectrum virus resistance. To evaluate pokeweed gene expression, we recently sequenced the plant’s mRNA and small RNA transcriptomes under jasmonic acid (JA) treatment. JA is a plant hormone that mediates defence against pathogens and insect herbivores. We are interested in learning how pokeweed gene expression is regulated by miRNAs during biotic stress. Please note: no previous knowledge of biology is required.
 +
 +For more information, please see: Hudak Lab website- http://hudak.lab.yorku.ca/
 +
 +RNA sequencing- http://www.illumina.com/applications/sequencing/rna.html
 +
 +miRNAs- http://en.wikipedia.org/wiki/MicroRNA
 +
 +Working with the support of a PhD student, your project will involve:
 +
 +  - Prediction of micro RNA (miRNA) targets on the basis of complementary sequence matches
 +  - Correlation of miRNA and mRNA expression changes to identify genes that are regulated by miRNAs
 +  - Conducting pathway analysis to determine which biological processes are controlled by miRNAs
 +  - Construction of a miRNA/target interaction network to visualize predictions This work will contribute to a scientific manuscript on miRNA-mediated gene regulation in pokeweed during response to JA.
 +
 +
 +**Requirements:** Pre-requisites as per EECS Calendar. Facility with script-writing/modification (in Perl or Python). Preference for students with knowledge of statistics and familiarity with R programming.
 +
 +
 +====== DDoS Attack using Google-bots ======
 +
 +
 +**Supervisor:** Natalija Vlajic
 +
 +Not long ago, botnets - networks of compromised computers - were seen as the most effective (if not the only) means of conducting Distributed Denial of Service (DDoS) attacks. However, with the growing popularity and prevalence of application-layer over other types of DDoS attacks, the DDoS execution landscape is becoming increasingly more diverse. An especially interesting new trend is the execution of application-layer DDoS attacks by means of skillfully manipulated Web-crawlers, such as Google-bots. The goal of this project is to design, implement and test a real-world framework consisting of the following: a) the attacker's web-accessible domain specially designed to attract Google-bots and then manipulate them into generating attack traffic towards the target/victim site; b) the victim's Web site set up in Amazon S3 cloud. In addition to the hands-on component, the project will also look into the statistical/numerical estimation of the framework's anticipated 'attack potential' relative to an actual (real-world) target/victim site.
 +
 +**Recommended Background**: EECS 3213 or EECS 3214, EECS 3482
 +
 +
 +====== Attentive Sensing for Better Two-Way Communication in Remote Learning Environments ======
 +
 +**Supervisor:** James Elder
 +
 +One of the challenges in remote learning is to allow students to communicate effectively with the lecturer. For example, when a student asks a question, communication will be more effective if the instructor has a zoomed view of the student’s face, so that s/he can interpret expressions etc. The goal of this project is to apply attentive sensing technology (www.elderlab.yorku.ca) to this problem. This technology is able to monitor a large environment such as a classroom and direct a high-resolution ‘attentive’ sensor to events of interest. In particular, working with a senior graduate student or postdoctoral fellow, the successful applicant will:
 +
 +Study the problem of detecting hand-raises in the preattentive sensor stream
 +Implement algorithms for detecting hand-raises based upon this investigation
 +Evaluate these algorithms in a real-classroom setting, using proprietary attentive sensing technology
 +
 +**Required Background:** General CSE408x prerequisites, good programming skills, good math skills, knowledge of C and MATLAB programming languages
 +
 +====== Attentive Sensing for Sport Video Recording Markets ======
 +
 +**Supervisor**: James Elder
 +
 +The goal of this project is to modify York University’s patented attentive sensor technology to the sport video recording market. Specific application domains under investigation include skiing, indoor BMX parks, and horse tracks. The general problem is to use attentive sensing technology (www.elderlab.yorku.ca) to visually detect and track multiple moving agents (e.g., skiers, riders, horses) and to select specific agents for active high-resolution smooth pursuit. The student will work with senior graduate students, postdoctoral fellows and research scientists to help modify the attentive sensing technology to operate in these domains. Specific tasks include: 1. Ground-truth available datasets 2. Evaluate current attentive algorithms on these datasets 3. Modify these algorithms to improve performance on these datasets.
 +
 +**Required Background:** Good programming skills; Good math skills; Knowledge of C and MATLAB programming languages
 +
 +====== JPF in a Jar ======
 +
 +**Supervisor:** Franck van Breugel
 +
 +JPF, which is short for Java PathFinder, is an open source tool that has been developed at NASA's Ames Research Center. The aim of JPF is to find bugs in Java code. Instead of using testing to find those bugs, JPF uses model checking. The facts that JPF is downloaded hundreds of times per month and that some of the key papers on JPF have been cited more than a thousand times reflect the popularity of JPF. In fact it is the most popular model checker for Java.
 +
 +A study done by Cambridge University in 2014 found that the global cost of debugging code has risen to $312 billion annually. Furthermore, on average software developers spend 50% of their programming time with finding and fixing bugs. As a consequence, advocating the use tools, such as JPF, may have significant impact.
 +
 +Installing JPF is far from trivial. The tool itself has been implemented in Java. Therefore, it should, in theory, be feasible to encapsulate JPF in a Java archive (jar) file. This would make it significantly simplifying the installation process of JPF and, therefore, make the tool more easily accessible to its potential users.
 +
 +The aim of this project is to attempt to put JPF in a jar. Since JPF relies on a number of configuration files, so-called Java properties files, incorporating these properly into the jar is one of the challenges. Setting JPF's classpath is another challenge. Since JPF changes almost on a daily basis, our modifications to JPF should ideally be limited to only a few classes, yet another challenge.
 +
 +In this project you may collaborate with graduate students of the DisCoVeri group (discoveri.eecs.yorku.ca) and computer scientists of NASA. For more information, feel free to send email to franck@cse.yorku.ca.
 +
 +**Required Background:** General CSE408x prerequisites 
 +
 +====== Model-based Design and Development of Embedded Systems with Code Generation Tools ======
 +
 +**Supervisor:** Jia Xu
 +
 +Model-based design with code generation tools can be used for simulation, rapid prototyping, and hardware-in-the-loop testing of embedded systems. This project explores model-based design and development of embedded systems on various hardware platforms with code generation tools. The selected student will develop and test embedded systems using model-based design and code generation tools such as MathWorks MATLAB /Simulink Coder.
 +
 +**Required Background:** At least a B+ in Embedded Systems (EECS 3215), MATLAB, C programming skills, solid experience in using a microcontroller such as Arduino.
 +
 +====== C2000 Concerto Microcontrollers ======
 +
 +**Supervisor:** Jia Xu
 +
 +
 +The C2000 Concerto family of microcontrollers combines two cores on a single-chip with on-chip low latency interprocessor communication between the two cores: a C28x 32-bit control core for real-time control with faster/more loops and small sampling window; and an ARM 32-bit Cortex-M3 host core for communications and general purpose. The selected student will evaluate the capabilities of the C2000 Concerto family of microcontrollers through testing and investigating open source software for real-time control applications that runs on C2000 Concerto Microcontrollers.
 +
 +**Required Background:** At least a B+ in Embedded Systems (EECS3215), strong C programming skills, solid knowledge of microcontrollers
 +
 +====== Real-Time Bidding Platform ======
 +
 +
 +**Supervisor:** Jia Xu
 +
 +Description: Real-time bidding (RTB) is a new method of selling and buying online display advertising in real-time one ad impression at a time. Once a bid request has been sent out, all bids must be received within a strict deadline - generally under 100 milliseconds, including network latency. This project explores RTBkit, an open source SDK allowing developers to create customized real time ad bidding systems (for Media Buyers/Bidders).
 +
 +**Required Background:** At least a B+ in Operating System Fundamentals (EECS3221), strong Ubuntu/Linux, C++ programming, GCC, TCP/IP skills
 +
 +
 +====== Circuit and Board Design for a Pulsed Ground Penetrating Radar ======
 +
 +
 +**Supervisor:** Sebastian Magierowski
 +
 +The project requires the construction of components for a ground penetrating radar. The students would have to design microwave boards for the high-frequency components of this unit, on both the transmitter and the receiver. On the transmitter side the board would take a 5-MHz input clock, run it through a series of off-the-shelf amplifiers and then through a shaping circuit that would convert the input into an outgoing series of pulses (still at 5-MHz repetition rate) less than 400-ps in duration each. The bandwidth of the signal is roughly 2-8 GHz and hence requires very careful board layout. The receiver would be a time-shifted sampler, used to sample the returning pulses in progressive periods. This radar circuit is ultimately intended to be positioned on a rover doing ground analysis.
 +
 +**Required Background:** A background in undergraduate-level electronics is very important. Experience with board level implementations and knowledge of microstrip lines would be helpful, otherwise the basics would have to be picked up during the project.
 +
 +
 +
 +====== Tilt Target Selection on Touchscreen Phones ======
 +
 +
 +**Supervisor:** Scott MacKenzie
 +
 +Touchscreen mobile devices commonly use a built-in accelerometer to sense movement or tilting actions of the device. Tilt is commonly used the change the orientation of the display between portrait and landscape. Gaming is another common use for tilting actions. However, tilt may also be used for target selection, as a replacement for touch. This research project will evaluate tilt as an input primitive for target selection on touchscreen mobile devices.
 +
 +Readings: MacKenzie, I. S., & Teather, R. J. (2012). FittsTilt: The application of Fitts’ law to tilt-based interaction. Proceedings of the Seventh Nordic Conference on Human-Computer Interaction – NordiCHI 2012, pp. 568-577. New York: ACM.
 +
 +**Required Background:** General 4080 prerequisites, EECS 3461, and (preferably) EECS 4441. Interest in user interfaces and human-computer interaction (HCI). Students can use their own Android phone for the project or one supplied by the course supervisor.
 +
 +====== Attentive Sensing for Better Two-Way Communication in Remote Learning Environments ======
 +
 +**Supervisor:** James Elder
 +
 +One of the challenges in remote learning is to allow students to communicate effectively with the lecturer. For example, when a student asks a question, communication will be more effective if the instructor has a zoomed view of the student’s face, so that s/he can interpret expressions etc. The goal of this project is to apply attentive sensing technology (www.elderlab.yorku.ca) to this problem. This technology is able to monitor a large environment such as a classroom and direct a high-resolution ‘attentive’ sensor to events of interest. In particular, working with a senior graduate student or postdoctoral fellow, the successful applicant will:
 +
 +Study the problem of detecting hand-raises in the preattentive sensor stream
 +Implement algorithms for detecting hand-raises based upon this investigation
 +Evaluate these algorithms in a real-classroom setting, using proprietary attentive sensing technology.
 +
 +**Required Background:** General CSE408x prerequisites, good programming skills, good math skills, knowledge of C and MATLAB programming languages
 +
 +====== Attentive Sensing for Sport Video Recording Markets ======
 +
 +
 +**Supervisor**: James Elder
 +
 +The goal of this project is to modify York University’s patented attentive sensor technology to the sport video recording market. Specific application domains under investigation include skiing, indoor BMX parks, and horse tracks. The general problem is to use attentive sensing technology (www.elderlab.yorku.ca) to visually detect and track multiple moving agents (e.g., skiers, riders, horses) and to select specific agents for active high-resolution smooth pursuit. The student will work with senior graduate students, postdoctoral fellows and research scientists to help modify the attentive sensing technology to operate in these domains. Specific tasks include: 1. Ground-truth available datasets 2. Evaluate current attentive algorithms on these datasets 3. Modify these algorithms to improve performance on these datasets.
 +
 +**Required Background:** Good programming skills; Good math skills; Knowledge of C and MATLAB programming languages.
 +
 +====== Continuation of a Path Diagram to Syntax Application ======
 +
 +
 +**Supervisor:** Jeff Edmonds
 +
 +
 +
 +Structural equation modeling (SEM) is a statistical technique that is becoming increasingly popular in the educational and behavioral sciences. SEM allows researchers to test the validity of hypothesized models involving complex relationships among multiple variables. Collected data is used to estimate the parameters of the equations and assessing the fit of the model.
 +
 +The software required is an application that allows researchers to define their hypothesized models visually and will output the correct syntax for the analytical software of their choosing.
 +
 +To date a promising functional application has been developed in JAVA by a Computer Science student as a 4080 project. The existing software allows the user to draw a path diagram and outputs code for the R package sem. There are a number of improvements to be made (refinements and additions to graphical user interface) and then the application needs to be extended to output syntax appropriate for additional software applications (openMX, MPlus and EQS). Though this project may not begin at “the first stages” of the software lifecycle, this scenario is likely common in the software development market. In addition, the student will be working with a primary “client” who is far less technically advanced, which is also reflective of real-world situations.
 +
 +**Required Background**: General EECS 408x prerequisites
 +
 +**Recommended Background:** Java software development
 +
 +
 +====== Enabling SaaS access to an experimental AI planner ======
 +
 +**Supervisor:** Sotirios Liaskos 
 +
 +This project involves enriching and integrating a set of fairly complex scripts, which are components of an Artificial Intelligence (AI) planner, and exporting them to the public in a Software-as-a-Service (SaaS) fashion.
 +
 +The components are various Unix executables and LISP programs that need to interact in complex ways. The components may be residing in different servers in different universities. Currently integration is performed manually, at the expense of usability. Thus, we aim at constructing a module that: (a) integrates involved components to deliver output in one call, (b) exports a unique web interface (preferably following WSDL/SOAP) to be easily accessed by custom front-end tools by anyone, anywhere, (c ) offers a simple front-end for human users.
 +
 +
 +**Required Background:** Good knowledge of Unix tools / Python, Perl or Awk. Comfort with algorithms and programming. Essential: 2031 – Software Tools. Desired: 3402 – Functional & Logic Programming, 3101 – Design and Analysis of Algorithms, 4302 – Compilers and Interpreters.
 +
 +
 +====== Predicting Angular Error in Rigid Registration ======
 +
 +
 +**Supervisor:** Burton Ma
 +
 +Registration is a fundamental step in image-based surgical navigation. Several (seemingly) different approaches for predicting distance errors in registration are known, but for some surgical procedures, the angular error in registration is more important. This project will validate an approach for predicting angular error in registration; the student will use a combination of simulated and actual registration data for testing purposes.
 +
 +====== Calibration of a Tracked Pointer ======
 +
 +**Supervisor:** Burton Ma
 +
 +Description: Tracked pointers are the most common tools used in surgical navigation systems. A typical pointer has a tracked target on one end and a sharp or ball tip on the other end. Finding the location of the tip relative to the target is a calibration problem. One solution to the calibration problem involves pivoting the pointer about the tip while tracking the target; if the tip is kept stationary, then the target moves on the surface of a sphere. Fitting the tracking data to the surface of a sphere yields the location of the tip as the sphere center. Unfortunately, the calibrated tip position obtained using such a spherical calibration has high variance. This project will investigate how much variance there is in the calibrated tip position, and methods for reducing the variance of the calibrated tip position.
 +
 +====== A privacy safeguard framework for sharing photos on Facebook ======
 +
 +**Supervisor:** Uyen Trang Nguyen
 +
 +One of the major privacy concerns in Online Social Networks is photo sharing. A user may post his/her friends’ photos without their consent. The friends have no control over the user’s Facebook activities, namely photo sharing. In this project, we design and implement a third-party Facebook application that allows people to protect their identities in photos uploaded by another user without their consent.
 +
 +**Required prerequisite background:** Proficiency in programming, especially in Java and Web application programming.
 +
 +**Desired prerequisite:** Knowledge of image processing, Facebook API, JavaScript Object Notation (JSON)
 +
 +====== Simulation for Forest Fire Detection ======
 +
 +**Supervisor:** Rob Allison
 +
 +Detection of forest fires is a challenging activity that requires considerable training. The objective of this project is to implement a virtual reality simulation to incorporate key aspects of this task and then to perform an evaluation with a small user study.
 +
 +
 +**Required Background:** General EECS408x prerequisites
 +
 +**Recommended Background:** EECS3431 or EECS4471 or equivalent
 +
 +====== Study of self-motion perception in microgravity ======
 +
 +
 +**Supervisor:** Rob Allison
 +
 +This is a computer graphics project to present visual motion stimuli to an observer. The software will experimentally control scene content, collect user responses and control the camera trajectory to simulate the desired self-motion profile.
 +
 +**Required Background:** General EECS408x prerequisites
 +
 +**Recommended Background:** EECS3431 or EECS4471 or equivalent
 +
 +====== Stereoscopic cinema calculator ======
 +
 +**Supervisor:** Rob Allison
 +
 +Directors of three-dimensional movies sometimes use 'stereo calculators' to compute the simulated depth of objects in the film show to the viewer in order to maximize the stereoscopic effects and maintain comfortable viewing. However current calculators have limited ability to visualize the results of the calculations. This project will combine stereo calculations with visualization software to assist the director in artistic and technical decisions.
 +
 +**Required Background:** General EECS408x prerequisites
 +
 +**Recommended Background:** EECS3431 or EECS4471 or equivalent
 +
 +====== Computer pointing devices and the speed-accuracy tradeoff ======
 +
 +**Supervisor:** Scott MacKenzie
 +
 +**Required Background:** General 4080 prerequisites, EECS3461, and (preferably) EECS4441
 +
 +**Recommended Background:** Interest in user interfaces and human-computer interaction (HCI). Understanding of experiment design. Experience in doing user studies.
 +
 +====== One key text entry ======
 +
 +
 +**Supervisor:** Scott MacKenzie
  
-An Open Source Structural Equation Modeling Graph Drawing Application+**Required Background:** General 4080 prerequisites, EECS3461, and (preferably) EECS4441
  
-StudentDoug Scheurich+Recommended BackgroundInterest in user interfaces and human-computer interaction (HCI). Understanding of experiment design. Experience in doing user studies.
  
-Supervisor: J. Edmonds+====== The Algorithmics Animation Workshop ======
  
-Description 
  
-Structural equation modeling (SEM) is a statistical technique that is becoming increasingly popular in the sciences. SEM allows researchers to test the validity of hypothesized models involving complex relationships among multiple variables. These models can include latent variables, which are not measured directly but are constructs inferred by observed variables. Structural equation models can be represented visually by graphs. To generate such graphs currently in R would require over 80 lines of code which has no reusability and has to be re written each time a new graph has to be developed or analyzed (R is a UNIX based command line only program, however it is a very powerful analytic research tool).+**Supervisor:** Andy Mirzaian
  
-Collected data is used to estimate the parameters of the equations and assessing the fit of the model. There are several SEM software options available to researchershowever all have serious limitations (Windows onlyUnix onlyexpensive licensing feestext based or command line onlyno GUI, etc).+The URL for Algorithmics Animation Workshop (AAW) is http://www.cs.yorku.ca/~aaw. The main purpose of AAW is to be a pedagogical tool by providing animation of important algorithms and data structures in computer scienceespecially those studied in courses CSE 31014101510161146111. This is an open ended project in the sense that more animations can be added to this site over time.
  
-We propose developing an application which will allow the user to load observed variables from a data file to create graphs, or allow using an intuitive graphical interface, and convert the graphs into a text based model specification file (ie generate the code required so the graph can be used in other programs such as R). This text file can then be used as input for the sem() function in R. The application will be implemented in Java, which can then be used with any OS. Later versions may include the ability to call R functions directly from within the application and provide options for more advanced structural equation modeling techniques.+**Required background:** General prerequisites
  
-Exploring the notion of Variability in Business Process Modeling (and its relationship with Goals)+**Recommended background:** EECS 3101
  
-Student: Dean Shaft 
  
-Supervisor: S. Liaskos and Y. Lesperance+====== Automated Reasoning System for Quantified Propositional Logic ======
  
-Description 
  
-Business Process Modeling (BPM) notations are an increasingly popular subject of investigation in the analysis and design of Information Systems. Such notations allow analysts to represent different ways by which actors of a domain can collaboratively perform tasks in order to meet certain business goals. The diagrammatic result allows understanding of the involved activities at various levels of abstraction each being useful for different stakeholders, such as business versus technical ones. It also provides a basis for further formalization and analysis of the modeled business process or its translation into implementation models such as service composition programs. Several BPM languages have been introduced, most prominent being the Business Process Modeling Notation (BPMN).+**Supervisor:** Zbigniew Stachniak
  
-Variability occurs in business processes, in that the same business process may need to either be reused in different context (e.g. a different organization) or adapt to changing requirements or environmental constraints. Thus, each variation of the business process is applicable to different situation affects specified customization criteria in different way. Such criteria may include high-level qualities or non-functional goals e.g. such as key performance indicators (KPIsor operational constraints that prescribe patterns which the business process must follow. To some extend BPMs offer constructs for modeling such variability. However, both the problems of modeling customization criteria and that of using them to derive business process variations that best satisfy them have not enjoyed significant attention in the literature.+Quantified Propositional Logics (QPL) plays an important role in a number of computer science disciplines from the theoretical computer science to knowledge representation and verification. There are also a number of open problems concerning this logicand formulated more than 70 years ago, that can be finally solved (or at least approached) using automated reasoning techniques. The first step in such investigations has to be the design and implementation of theorem prover, or automated reasoning system, for QPLSuch system should, in principle, be able to determine whether or not a given formula of QPL is a theorem (or tautology) in this logic.
  
-In this project we shall investigate ways of modeling and reasoning about business process variability. We will pick a BPMpossibly BPMN, and explore different ways by which variability can be expressed. Then we will look at criteria that define variant selection and how such can be represented as well. Through possible formalizations in specification frameworks that are used in AI such as Situation Calculus or planning definition languages, the problem of automatically selecting variants of interest in order to meet certain customization criteria shall be studied. In the end we are hoping to develop a concrete framework for representing and reasoning about business process variability in light of high-level goal-based customization criteria.+The theorem prover for QPL is to be designedimplemented, and fully tested.
  
-Mobile Software Development Platform ComparisonWindows Phone 7 and Android+BackgroundVarious variants of QPL have been formally formulated for the first time in the 1920s by a number of logicians and mathematicians. In modern computer science, QPL plays a significant role in theoretical computer science (proof complexity, satisfiability) as well as in verification and AI.
  
-StudentAhmad Hasan+**Required background:** General prerequisites
  
-SupervisorJ. Ostroff+**Recommended background:** Passion for programming and experimentation; Some knowledge of propositional and predicate logic
  
-Description+====== NABU Network Emulator ======
  
-Over the past decade the development and use of smartphone technologies has become increasingly sophisticated. The computational power of modern smartphones is growing to match the power of conventional desktop computers. More people and organizations are becoming increasingly dependent on their mobile devices being able to perform sophisticated computations. As the leaders in the technology industry move towards providing advanced products and development platforms, the environment of traditional software development is changing rapidly. Mobile applications that provide a variety of services involving cloud computing, GPS, games, and automation.+**Supervisor:** Zbigniew Stachniak
  
-The goal of this project is to explore and compare the software development platforms for popular mobile phone operating systems for the development of applications and games.+Have you ever considered writing your own emulator of an interesting system? There has been a substantial activity in building software emulators of historically significant computers, game consoles, and, recently, smart communication devices. As a result, there is at least one emulator of almost every significant system. This activity contributes, in the first place, to the preservation and dissemination of significant hardware and software technologies. It also allows for cost-effective development of contemporary software and hardware. The project's objective is to design and implement an emulator of the NABU Network – one of the earliest “proto-Internet” networks. The emulator is to be implemented in Java.
  
-Business applications and games have distinctive features in the context of mobile platforms. For regular applications, platform capabilities relating to cloud computing, GPS and everyday consumer applications have unique development cycle that differ from regular desktop applications. Mobile applications are usually lightweight and efficient tools for everyday administrative tasksUnder Windows Phone 7 such apps are usually built under the Microsoft Silverlight framework, and the the application must adhere to guidelines and best practices laid out in the Windows Phone 7 documentationThe Android platform provides no such single framework for developing these types of applications but all of the tools and functionalities are available to provide the same servicesagain this app will also follow the guidelines and best practices described in the official Android documentation.+Background : The NABU Network was designed and implemented by Canadian company NABU Manufacturing between 1981 and 1983The underlying idea behind the network was to link home personal computers to cable television networks which would supply a continuoushigh speed stream of computer programs and information (at the rate of 6.5 Mbits per second) to almost an unlimited number of usersCable television was a uniquely ideal technology for NABU to deliver software and data to home computers because of its high bandwidth and networking capabilities. After the official launch on Ottawa Cablevision in October of 1983, the NABU Network was introduced by Ottawa's Skyline Cablevision in 1984 and a year later in Sowa, Japan, via a collaboration between NABU and ASCII Corp. NABU Network subscribers could rent or buy a NABU PC and dedicated network adaptor, and use an ordinary television set as a display monitor. Once connected to the networka user could choose from various application programs and services in categories including entertainment, information and guides, education, and professional programs. Dedicated NABU magazines, newsletters, programming guides, and user groups provided subscribers with supplementary information and support. To learn more, visit here.
  
-The games developed in each platform are intended to serve as explorations into the graphics capabilities of both systems. Graphics environments and frameworks are another area in mobile devices that are becoming increasingly important. Rich graphics and animation capabilities are important for providing immersive user experiences and games are excellent environments to develop and test interactive graphics capabilities on mobile devices. The Windows Phone 7 game development framework uses and extension of Microsoft’s well established XNA framework. This provides libraries to develop and debug game and graphics engines and easily integrate multimedia content into mobile games. Android game applications depend on a to be determined open source game engine.+**Required background:** General prerequisites
  
-This project aims to compare the mobile platforms with respect to development languages, the use of object oriented software development principles and the utility of the tools. The applications and documentation developed through the course of this project should also provide a good source of information for computer science and engineering students who might want to develop software on mobile platforms. Using standard libraries and working with established frameworks and as well as open source frameworks to develop reliable, extendible and reusable code for mobile platforms would be an excellent experience for students to learn about new emerging technologies and the software engineering concepts that apply to them.+**Recommended background:** Java (including 2D graphics); Some knowledge of PC hardware architecture; Some knowledge of (any) assembler language is an asset.
projects.1502390705.txt.gz · Last modified: 2017/08/10 18:45 by jenkin