Please note:
To view the current Academic Calendar go to www.sfu.ca/students/calendar.html
Computing Science Dual Degree
Students in this graduate dual degree program (GDDP), jointly developed by ¶¡ÏãÔ°AV and Zhejiang University (ZJU), China, will acquire two graduate degrees. Graduates will receive a master of science (MSc) degree from ¶¡ÏãÔ°AV, and a master of software engineering (MSE) degree from Zhejiang University. Students will study and conduct research at both universities.
The language of instruction at ¶¡ÏãÔ°AV is English, while at Zhejiang University, it is either English and/or Chinese.
¶¡ÏãÔ°AV Requirements
Students must be admitted to one university, and then apply and be admitted to the other university.
To qualify for admission, students must satisfy the usual admission requirements as specified by each university. At ¶¡ÏãÔ°AV the admission requirements are stated in Graduate General Regulations 1.3 in the ¶¡ÏãÔ°AV Calendar. The university the student is first admitted to will be referred to as the student's 'home' university. Students whose home university is ¶¡ÏãÔ°AV are called ¶¡ÏãÔ°AV students while those whose home university is Zhejiang are called ZJU students.
Once admitted to the home university, the student may then apply for admission to the graduate dual degree program normally within 12 months of the date of admission to the home university graduate program. The program application requires the support and involvement of the student's supervisor at the home university. The graduate program committee at the home university decides whether to recommend the student for admission to the GDDP. A recommended individual's application will then be forwarded to the other partner university. Applicants must meet the admission requirements of that partner university.
Program Requirements
This program consists of course work at both ¶¡ÏãÔ°AV and ZJU, a one term co-op practicum or research/industry project at either ¶¡ÏãÔ°AV or ZJU, and two extended essays (one at each university). ¶¡ÏãÔ°AV students complete a minimum of 23 course units from both institutions. ZJU students complete a minimum of 24 course units from both institutions. All students complete at least 15 units of course, practicum/project and extended essay at ¶¡ÏãÔ°AV.
All students complete one of
The objective of this course is to expose students to basic techniques in algorithm design and analysis. Topics will include greedy algorithms, dynamic programming, advanced data structures, network flows, randomized algorithms. Students with credit for CMPT 706 may not take this course for further credit.
Section | Instructor | Day/Time | Location |
---|---|---|---|
Jan 6 – Apr 9, 2020: Mon, Wed, Fri, 2:30–3:20 p.m.
|
Burnaby |
This course provides a broad view of theoretical computing science with an emphasis on complexity theory. Topics will include a review of formal models of computation, language classes, and basic complexity theory; design and analysis of efficient algorithms; survey of structural complexity including complexity hierarchies, NP-completeness, and oracles; approximation techniques for discrete problems. Equivalent Courses: CMPT810.
2122001-2 Elements of the Theory of Computation (ZJU course)
and four courses from Table 1
To fulfil the program's breadth requirements, all students complete at least one course from each of the four course groupings in Table 1 below. ¶¡ÏãÔ°AV students at Zhejiang University also complete the China Survey course. ZJU students complete an additional three units of social science courses as specified by Zhejiang University.
and a co-op, or internship, or research/industry project at ¶¡ÏãÔ°AV or ZJU
This course is the first term of work experience in the School of Computing Science Co-operative Education Program for graduate students. Units of this course do not count towards computing science breadth requirements. Graded on a satisfactory/unsatisfactory basis. Prerequisite: 12 units of CMPT coursework at the 700-level or higher with a CGPA of at least 3.0.
Section | Instructor | Day/Time | Location |
---|---|---|---|
TBD | |||
TBD |
An internship in industry or a research environment for graduate research students. A final report will be submitted and graded by the student's supervisor. Units of this course do not count towards computing science breadth requirements. Graded on a satisfactory/unsatisfactory basis. Prerequisite: 12 units of CMPT course work with an ¶¡ÏãÔ°AV CGPA of at least 3.0. Approval of supervisor and a GPC representative is required prior to applying for, or accepting an internship.
Section | Instructor | Day/Time | Location |
---|---|---|---|
Jan 6 – Apr 9, 2020: Mon, Tue, Wed, Thu, Fri, 7:00 a.m.–7:20 p.m.
|
|
and two extended essays (one at each university)
Students will complete an extended essay required by the ¶¡ÏãÔ°AV-ZU graduate dual degree master program. The extended essay will normally be a report on a research/industry project or a survey on a specific topic in information technology. The topic and the scope of each essay will be determined in consultation with the supervisory committee. Graded on a satisfactory/unsatisfactory basis.
Section | Instructor | Day/Time | Location |
---|---|---|---|
TBD |
NOTE: A ¶¡ÏãÔ°AV course and a Zhejiang University course are deemed similar if the two courses overlap substantially. Students with credit for one of two similar courses may not complete the other course for further credit. ¶¡ÏãÔ°AV's graduate program breadth committee and the corresponding Zhejiang University committee will decide on the list of similar courses.
Table 1
Group I: Algorithms and Theory Credits
Courses at ¶¡ÏãÔ°AV
Deep connections between logic and computation have been evident since early work in both areas. More recently, logic-based methods have led to important progress in diverse areas of computing science. This course will provide a foundation in logic and computability suitable for students who wish to understand the application of logic in various areas of CS, or as preparation for more advanced study in logic or theoretical CS.
Section | Instructor | Day/Time | Location |
---|---|---|---|
Evgenia Ternovska |
Jan 6 – Apr 9, 2020: Mon, Wed, Fri, 12:30–1:20 p.m.
|
Burnaby |
The objective of this course is to expose students to basic techniques in algorithm design and analysis. Topics will include greedy algorithms, dynamic programming, advanced data structures, network flows, randomized algorithms. Students with credit for CMPT 706 may not take this course for further credit.
Section | Instructor | Day/Time | Location |
---|---|---|---|
Jan 6 – Apr 9, 2020: Mon, Wed, Fri, 2:30–3:20 p.m.
|
Burnaby |
This course provides a broad view of theoretical computing science with an emphasis on complexity theory. Topics will include a review of formal models of computation, language classes, and basic complexity theory; design and analysis of efficient algorithms; survey of structural complexity including complexity hierarchies, NP-completeness, and oracles; approximation techniques for discrete problems. Equivalent Courses: CMPT810.
Fundamental algorithmic techniques used to solve computational problems encountered in molecular biology. This area is usually referred to as Bioinformatics or Computational Biology. Students who have taken CMPT 881 (Bioinformatics) in 2007 or earlier may not take CMPT 711 for further credit.
Discrete optimization of nondeterministic polynomial time (NP) hard problems, design and analysis of approximation and randomized algorithms, and the applications of theoretical analysis to the study of heuristics will be covered in this course.
This course covers recent developments in discrete, combinatorial, and algorithmic geometry. Emphasis is placed on both developing general geometric techniques and solving specific problems. Open problems and applications will be discussed.
Algorithm design often stresses universal approaches for general problem instances. If the instances possess a special structure, more efficient algorithms are possible. This course will examine graphs and networks with special structure, such as chordal, interval, and permutation graphs, which allows the development of efficient algorithms for hard computational problems.
This course will cover a variety of optimization models, that naturally arise in the area of management science and operations research, which can be formulated as mathematical programming problems. Equivalent Courses: CMPT860.
Courses at Zhejiang University
2122001-2 Elements of the Theory of Computation
2122019-2 Advanced Formal Method
2124028-2 Pervasive Computing
Group II: Systems
Courses at ¶¡ÏãÔ°AV
This course examines fundamental principles of software engineering and state-of-the-art techniques for improving the quality of software designs. With an emphasis on methodological aspects and mathematical foundations, the specification, design and test of concurrent and reactive systems is addressed in depth. Students learn how to use formal techniques as a practical tool for the analysis and validation of key system properties in early design stages. Applications focus on high level design of distributed and embedded systems.
Principles involved in designing modern parallel and distributed software systems. The course focuses on covering key concepts like concurrency, synchronization, consistency models and fault tolerance. Involves multiple programming projects and reading articles on recent trends in parallel and distributed computing.
Investigates the design and operation of wide-area computer networks, especially the Internet and the TCP/IP protocol suite. This course studies performance modeling, security and quality of service; wireless connectivity and multimedia networking; network services, including recent topics and trends in these areas.
The goal of formal verification is to prove correctness or to find mistakes in software and other systems. This course introduces, at an accessible level, a formal framework for symbolic model checking, one of the most important verification methods. The techniques are illustrated with examples of verification of reactive systems and communication protocols. Students learn to work with a model checking tool such as NuSMV.
This course investigates the design, classification, modelling, analysis, and efficient use of communication networks such as telephone networks, interconnection networks in parallel processing systems, and special-purpose networks. Equivalent Courses: CMPT881.
Courses at Zhejiang University
2122002-2 Advanced Operating System
2122003-2 Advanced Computer Architecture
2124012-2 Grid Computing and Distributed Systems
2124045-2 Network and Information Security
2124059-2 Multi-core Computing
2124070-2 Parallel Computer Architecture and Programming
5121009-2 Fundamental of Financial Information System
5141010-3 Embedded System Design
5141061-2 System Analysis and Design
5141069-2 Embedded Operating Systems
5143078-2 Object-Oriented System Analysis and Design
Group III: Applications
Courses at ¶¡ÏãÔ°AV
Fundamental concepts in robotics and related fields, including computational methods for solving decision making and algorithms for robots to understand their environment. Topics include modeling and simulation of robotic systems, optimization, optimal control, robotic safety, reinforcement learning, and robotic perception. Applications of the material include unmanned aerial vehicles and self-driving cars.
Knowledge representation is the area of Artificial Intelligence concerned with how knowledge can be represented symbolically and manipulated by reasoning programs. This course addresses problems dealing with the design of languages for representing knowledge, the formal interpretation of these languages and the design of computational mechanisms for making inferences. Since much of Artificial Intelligence requires the specification of a large body of domain-specific knowledge, this area lies at the core of AI. Prerequisite: CMPT 310/710 recommended. Cross-listed course with CMPT 411.
Machine Learning is the study of computer algorithms that improve automatically through experience. Provides students who conduct research in machine learning, or use it in their research, with a grounding in both the theoretical justification for, and practical application of, machine learning algorithms. Covers techniques in supervised and unsupervised learning, the graphical model formalism, and algorithms for combining models. Students who have taken CMPT 882 (Machine Learning) in 2007 or earlier may not take CMPT 726 for further credit.
Section | Instructor | Day/Time | Location |
---|---|---|---|
Mo Chen |
Jan 6 – Apr 9, 2020: Mon, 3:30–4:20 p.m.
Jan 6 – Apr 9, 2020: Wed, 3:30–5:20 p.m. |
Burnaby Burnaby |
Statistical foundation for machine learning algorithms, emphasizing bias-variance tradeoff. Students will learn principles for choosing effective methods and tailoring them to fit a given learning problem. Potential topics include probabilistic graphical models, maximum likelihood estimation, latent variables and the EM algorithm, convex optimization, and variational and sampling-based methods.
Section | Instructor | Day/Time | Location |
---|---|---|---|
Maxwell Libbrecht |
Jan 6 – Apr 9, 2020: Tue, 11:30 a.m.–12:20 p.m.
Jan 6 – Apr 9, 2020: Thu, 9:30–11:20 a.m. |
Burnaby Burnaby |
Introduction to advanced database system concepts, including query processing, transaction processing, distributed and heterogeneous databases, object-oriented and object-relational databases, data mining and data warehousing, spatial and multimedia systems and Internet information systems.
The student will learn basic concepts and techniques of data mining. Unlike data management required in traditional database applications, data analysis aims to extract useful patterns, trends and knowledge from raw data for decision support. Such information are implicit in the data and must be mined to be useful.
Selected topics in computer vision including cameras, edge detection, feature matching, optical flow, alignment, epipolar geometry, stereo, structure-from-motion, recognition, segmentation, detection, and deep learning.
Section | Instructor | Day/Time | Location |
---|---|---|---|
Yasutaka Furukawa |
Jan 6 – Apr 9, 2020: Tue, 9:30–10:20 a.m.
Jan 6 – Apr 9, 2020: Thu, 9:30–11:20 a.m. |
Burnaby Burnaby |
Selected topics in biomedical imaging. Computer visions, medical data and image representation, file formats, segmentation, registration, classification, anatomical shape modeling, machine and deep learning tools and methods.
Advanced topics in geometric modelling and processing for computer graphics, such as Bezier and B-spline techniques, subdivision curves and surfaces, solid modelling, implicit representation, surface reconstruction, multi-resolution modelling, digital geometry processing (e.g., mesh smoothing, compression, and parameterization), point-based representation, and procedural modelling. Prerequisite: CMPT 361, MACM 316. Students with credit for CMPT 464 or equivalent may not take this course for further credit.
Section | Instructor | Day/Time | Location |
---|---|---|---|
Richard Zhang |
Jan 6 – Apr 9, 2020: Mon, 10:30 a.m.–12:20 p.m.
Jan 6 – Apr 9, 2020: Wed, 10:30–11:20 a.m. |
Burnaby Burnaby |
Selected topics in computer animation and simulation, including 3D character animation and control, facial animation, simulation of natural phenomena (i.e. fluids, crowd simulation, and deformation of pliant materials).
Advanced topics in the field of scientific and information visualization are presented. Topics may include: an introduction to visualization (importance, basic approaches and existing tools), abstract visualization concepts, human perception, visualization methodology, 2D and 3D display and interaction and their use in medical, scientific, and business applications. Prerequisite: CMPT 316, 461 or equivalent (by permission of instructor). Students with credit for CMPT 878 or 775 may not take this course for further credit.
This seminar course covers current research in the field of multimedia computing. Topics include multimedia data representation, compression, retrieval, network communications and multimedia systems. Computing science graduate student or permission of instructor. Equivalent Courses: CMPT880.
A seminar based on the artificial intelligence approach to vision. Computational vision has the goal of discovering the algorithms and heuristics which allow a two dimensional array of light intensities to be interpreted as a three dimensional scene. By reading and discussing research papers - starting with the original work on the analysis of line drawings, and ending with the most recent work in the field - participants begin to develop a general overview of computational vision, and an understanding of the current research problems.
This course surveys current research in formal aspects of knowledge representation. Topics covered in the course will centre on various features and characteristics of encodings of knowledge, including incomplete knowledge, non monotonic reasoning, inexact and imprecise reasoning, meta-reasoning, etc. Suggested preparation: a course in formal logic and a previous course in artificial intelligence.
In this course, theoretical and applied issues related to the development of natural language processing systems and specific applications are examined. Investigations into parsing issues, different computational linguistic formalisms, natural language syntax, semantics, and discourse related phenomena will be considered and an actual natural language processor will be developed.
Section | Instructor | Day/Time | Location |
---|---|---|---|
Angel Chang |
Jan 6 – Apr 9, 2020: Tue, Thu, 3:30–4:50 p.m.
|
Burnaby |
Intelligent systems are knowledge-based computer programs which emulate the reasoning abilities of human experts. This introductory course will analyze the underlying artificial intelligence methodology and survey advances in rule-based systems, constraint solving, incremental reasoning, intelligent backtracking and heuristic local search methods. We will look specifically at research applications in intelligent scheduling, configuration and planning. The course is intended for graduate students with a reasonable background in symbolic programming.
Section | Instructor | Day/Time | Location |
---|---|---|---|
Hang Ma |
Jan 6 – Apr 9, 2020: Tue, 11:30 a.m.–1:20 p.m.
Jan 6 – Apr 9, 2020: Thu, 11:30 a.m.–12:20 p.m. |
Burnaby Burnaby |
Examination of recent literature and problems in bioinformatics. Within the CIHR graduate bioinformatics training program, this course will be offered alternatively as the problem-based learning course and the advanced graduate seminar in bioinformatics (both concurrent with MBB 829). Prerequisite: Permission of the instructor.
An advanced course on database systems which focuses on data mining and data warehousing, including their principles, designs, implementations, and applications. It may cover some additional topics on advanced database system concepts, including deductive and object-oriented database systems, spatial and multimedia databases, and database-oriented Web technology.
Examines current research topics in computer graphics, human computer interaction (including audio), computer vision and visualization.
Section | Instructor | Day/Time | Location |
---|---|---|---|
Parmit Kaur Chilana |
Jan 6 – Apr 9, 2020: Tue, 11:30 a.m.–1:20 p.m.
Jan 6 – Apr 9, 2020: Thu, 11:30 a.m.–12:20 p.m. |
Burnaby Burnaby |
Courses at Zhejiang University
2122020-4 Computer Graphics
2122021-2 Introduction to Computer Vision
2122023-2 Introduction to Artificial Intelligence
2124003-2 Computer Security
2124014-2 Advanced Software Engineering
2124017-2 The Fundamental Principles of Non-Photorealistic Computer Graphics
2124044-2 Webservice Technology
2124057-2 High End Computing and Its Applications
2124060-2 Multimedia Computing
2124061-2 Network Multimedia Search Engine
2124062-2 Solid Modeling
2124063-2 Biologic Intelligence and Algorithm
2124064-2 Introduction to Machine Learning
2124065-2 Advanced Artificial Intelligence
2124066-2 Visualization in Scientific Computing
2124067-2 Speech and Language, Processing and Understanding
2124068-2 Image Processing and Modeling
2124076-2 Services Computing
5141005-2 Advanced Object-oriented Development Techniques
5141039-2 Advanced IoT Application
5141062-2 Advanced Data Base Technology
5141066-3 Big Data Storage and Processing
5143068-2 3D Animation and HCI
5143081-3 Key Technologies for Game Development
5143088-2 Stream Data Processing and Analyzing
Group IV: Other
Courses at ¶¡ÏãÔ°AV
This course investigates the design, classification, modelling, analysis, and efficient use of communication networks such as telephone networks, interconnection networks in parallel processing systems, and special-purpose networks. Equivalent Courses: CMPT881.
Courses at Zhejiang University
0711026-2 Bioinformatics Topics
5109001-2 Development of Professional Competency and Entrepreneurial Education
5121001-2 Software Project Management
5141060-2 Project Practice
5143016-3 Quality Assurance of Software and Testing Technology
Program Length
Students are expected to complete the program requirements in three years.
Other Information
Supervisory Committee
Each student will be supervised by a supervisory committee consisting of a senior supervisor from either university and at least one faculty member from the other university. Each student is required to have an annual progress evaluation by the supervisory committee. Meetings of the supervisory committee are normally once per year and may involve the use of new media.
Program Withdrawal
A student may withdraw from the GDDP program by transferring to the MSc program at either the home or partner university at any time. The full academic record at both universities may be considered to determine standing at the home university.
Extended Essays
Extended essay completed at ¶¡ÏãÔ°AV is examined by two readers and is not required to be submitted to the library upon completion.
Tuition Fees
When a student is resident at ¶¡ÏãÔ°AV, the student pays per-unit tuition fees to ¶¡ÏãÔ°AV. When a student is resident at Zhejiang University, the student pays tuition fees to Zhejiang University.
Academic Requirements within the Graduate General Regulations
All graduate students must satisfy the academic requirements that are specified in the Graduate General Regulations, as well as the specific requirements for the program in which they are enrolled.