Search

Back
3 units (fi 6)(EITHER, 0-3S-0)
There is no available course description.
3 units (fi 6)(EITHER, 0-3S-0)
There is no available course description.
3 units (fi 6)(EITHER, 0-3S-0)
There is no available course description.
3 units (fi 6)(EITHER, 0-3S-0)
There is no available course description.
3 units (fi 6)(EITHER, 0-3S-0)
There is no available course description.
3 units (fi 6)(EITHER, 0-3S-0)
There is no available course description.
3 units (fi 6)(EITHER, 0-3S-0)

Prerequisite: consent of Department. Repeatable.

3 units (fi 6)(EITHER, 0-3S-0)

Requires payment of additional student instructional support fees. Refer to the Tuition and Fees page in the University Regulations section of the Calendar.

3 units (fi 6)(EITHER, 0-3S-0)

Requires payment of additional student instructional support fees. Refer to the Tuition and Fees page in the University Regulations section of the Calendar.

3 units (fi VAR)(EITHER, UNASSIGNED)
There is no available course description.
0.5 units (fi 2)(FIRST, 1 DAY)

Topics of interest to second year Chemical and Materials Engineering students, with special reference to industries in Alberta, including coverage of elements of ethics, equity, concepts of sustainable development and environmental stewardship, public and worker safety and health considerations including the context of the Alberta Occupational Health and Safety Act. Offered in a single day during the first week of September. Restricted to students registered in the Department of Chemical and Materials Engineering.

3 units (fi 8)(EITHER, 3-0-3)

Basic process principles; material and energy balances, transient processes, introduction to computer-aided balance calculations. Prerequisites: ENCMP 100, MATH 102 and CHEM 105. Corequisites: CH E 243 and MATH 209 or equivalent. Credit may not be obtained in this course if previous credit has been obtained for CH E 265.

1.5 units (fi 8)(EITHER, 3-0-3)

Basic process principles; material and energy balances, transient processes, introduction to computer-aided balance calculations. Prerequisites: ENCMP 100, MATH 102 and CHEM 105. Corequisites: CH E 243 and MATH 209 or equivalent. Credit may not be obtained in this course if previous credit has been obtained for CH E 265.

1.5 units (fi 8)(EITHER, 3-0-3)

Basic process principles; material and energy balances, transient processes, introduction to computer-aided balance calculations. Prerequisites: ENCMP 100, MATH 102 and CHEM 105. Corequisites: CH E 243 and MATH 209 or equivalent. Credit may not be obtained in this course if previous credit has been obtained for CH E 265.

3 units (fi 8)(FIRST, 3-0-3/2)

Unit operations employed to concentrate minerals including comminution, classification, gravity concentration, froth flotation, thickening, filtering; tailings disposal; marketing of minerals; economics. Credit may not be obtained in this course if previous credit has been obtained in MAT E 331. Prerequisite: STAT 235 or consent of Instructor.

3 units (fi 6)(EITH/SP/SU, 0-0-7)

Projects in Chemical and Materials Engineering. This course is open only to Chemical and Materials Engineering students with a GPA of 3.0 or greater during the previous two academic terms. Variable meeting times. Credit may not be obtained in this course if previous credit has been earned in CH E 458, 459, MAT E 468 or 469. Prerequisite: consent of the Department.

1.5 units (fi 6)(EITH/SP/SU, 0-0-7)

Projects in Chemical and Materials Engineering. This course is open only to Chemical and Materials Engineering students with a GPA of 3.0 or greater during the previous two academic terms. Variable meeting times. Credit may not be obtained in this course if previous credit has been earned in CH E 458, 459, MAT E 468 or 469.Prerequisite: consent of the Department.

1.5 units (fi 6)(EITH/SP/SU, 0-0-7)

Projects in Chemical and Materials Engineering. This course is open only to Chemical and Materials Engineering students with a GPA of 3.0 or greater during the previous two academic terms. Variable meeting times. Credit may not be obtained in this course if previous credit has been earned in CH E 458, 459, MAT E 468 or 469.Prerequisite: consent of the Department.

3 units (fi 6)(EITHER, 0-0-7)

Projects in Chemical and Materials Engineering. This course is open only to Chemical and Materials Engineering students with a GPA of 3.0 or greater during the previous two academic terms. Variable meeting times. Credit may not be obtained in this course if previous credit has been earned in CH E 458, 459, MAT E 468 or 469. Prerequisite: CME 458 and consent of the Department.

3 units (fi 8)(EITHER, 3-1S-0)

Physical and chemical preparation of ore feed. Roasting, briquetting, sintering and pelletizing. Leaching processes and chemicals, kinetics of leaching, ion exchange, activated carbon adsorption, solvent extraction and McCabe-Thiele Diagram. Metal recovery from solutions, electrowinning and electrorefining. Furnaces and fuels, refractories, slags and mattes. Reduction of metal compounds, smelting and converting, pyrometallurgical metal refining. Credit may not be obtained in this course if previous credits have been obtained in MAT E 430 and MAT E 332. Prerequisites: CME 265, MAT E 341, or consent of the Department.

1 unit (fi 3)(EITHER, 1-0-0)

Communication and oral presentations. Graded on a pass/fail basis. Prerequisite: 85 units completed or consent of instructor.

0.5 units (fi 3)(EITH/SP/SU, 1-0-0)

Oral presentations. Graded on a pass/fail basis. Prerequisite: 85 units completed or consent of Instructor. Credit may not be obtained in this course if previous credit has been obtained for CH E 481.

0.5 units (fi 3)(EITH/SP/SU, 1-0-0)

Oral presentations. Graded on a pass/fail basis. Prerequisite: 85 units completed or consent of Instructor. Credit may not be obtained in this course if previous credit has been obtained for CH E 481.

3 units (fi 8)(FIRST, 3-1S-0)

Polymerization, molecular weight distribution, molecular weight measurement techniques, isomerism and conformation, rubber elasticity, glass transition, amorphous and crystalline states, crystallization and melting, tensile property, polymer melts and rheology, polymer solutions and blends. May include a tour to a local polymer manufacturer. Prerequisites: STAT 235, CH E 312 and (CH E 343 or MAT E 301 or 340).

Starting: 2025-09-01 CME 482 - Fundamentals of Polymers

3 units (fi 8)(EITHER, 3-1S-0)

Polymerization, molecular weight distribution, molecular weight measurement techniques, isomerism and conformation, rubber elasticity, glass transition, amorphous and crystalline states, crystallization and melting, tensile property, polymer melts and rheology, polymer solutions and blends. May include a tour to a local polymer manufacturer. Prerequisites: STAT 235, CH E 312 and (CH E 343 or MAT E 204) or consent of instructor.

1 unit (fi 3)(SECOND, 1-0-0)

Oral presentation of technical material. Graded on a pass/fail basis. Prerequisite: CME 481. Credit may not be obtained in this course if previous credit has been obtained for CH E 483.

3 units (fi 8)(EITH/SP/SU, 3-1S-0)

Treatment of selected chemical and materials engineering special topics of current interest to staff and students.

2 units (fi 2)(EITH/SP/SU, 2-0-0)

This course provides an introduction to research methods specific to engineering disciplines. Topics covered include the philosophy of science and engineering, the scientific method, hypothesis-based research, statistical analysis, literature search and review, developing a research plan, research presentation and reporting, and best practices in experimental, theoretical and computational research. Restricted to graduate students in the Faculty of Engineering. Students from departments other than Chemical and Materials Engineering require instructor approval to register.

3 units (fi 6)(EITHER, 3-0-0)

Multivariate statistics. Process systems engineering objectives: modeling, estimation, monitoring, control, optimization, and their relationship to data analytics. Feature extraction and dimension reduction, clustering, classification, regression. Nonlinear techniques and analysis of dynamic data. Applications of advanced data analytics in chemical process engineering.

3 units (fi 6)(EITH/SP/SU, 3-1S-0)

An advanced treatment of selected chemical and materials engineering topics of current interest to staff and students.

3 units (fi 6)(VAR, UNASSIGNED)

An engineering project for students registered in a Master of Engineering program

1.5 units (fi 6)(VAR, UNASSIGNED)

An engineering project for students registered in a Master of Engineering program.

1.5 units (fi 6)(VAR, UNASSIGNED)

An engineering project for students registered in a Master of Engineering program.

3 units (fi 6)(EITHER, 3-0-3)

An introduction to fundamental concepts in computation, including state, abstraction, generalization, and representation. Introduction to algorithms, logic, number systems, circuits, and other topics in elementary computing science. This course cannot be taken for credit if credit has been obtained in CMPUT 114, 174, 274, or SCI 100. See Note (1) above.

Starting: 2024-09-01 CMPUT 101 - Introduction to Computing

3 units (fi 6)(EITHER, 3-0-3)

An introduction to fundamental concepts in computation, including state, abstraction, generalization, and representation. Introduction to algorithms, logic, number systems, circuits, and other topics in elementary computing science. This course cannot be taken for credit if credit has been obtained in CMPUT 114, 174, 175, 274, 275, or SCI 100, or ENCMP 100. See Note (1) above.

3 units (fi 6)(EITHER, 3-0-3)

CMPUT 174 and 175 use a problem-driven approach to introduce the fundamental ideas of Computing Science. Emphasis is on the underlying process behind the solution, independent of programming language or style. Basic notions of state, control flow, data structures, recursion, modularization, and testing are introduced through solving simple problems in a variety of domains such as text analysis, map navigation, game search, simulation, and cryptography. Students learn to program by reading and modifying existing programs as well as writing new ones. No prior programming experience is necessary. Prerequisite: Math 30, 30-1, or 30- 2. See Note (1) above. Credit cannot be obtained for CMPUT 174 if credit has already been obtained for CMPUT 274 or 275, except with permission of the Department.

Starting: 2024-09-01 CMPUT 174 - Introduction to the Foundations of Computation I

3 units (fi 6)(EITHER, 3-0-3)

CMPUT 174 and 175 use a problem-driven approach to introduce the fundamental ideas of Computing Science. Emphasis is on the underlying process behind the solution, independent of programming language or style. Basic notions of state, control flow, data structures, recursion, modularization, and testing are introduced through solving simple problems in a variety of domains such as text analysis, map navigation, game search, simulation, and cryptography. Students learn to program by reading and modifying existing programs as well as writing new ones. No prior programming experience is necessary. Prerequisite: Math 30, 30-1, or 30-2. See Note (1) above. Credit cannot be obtained for CMPUT 174 if credit has already been obtained for CMPUT 274, 275, or ENCMP 100, except with permission of the Department.

3 units (fi 6)(EITHER, 3-0-3)

A continuation of CMPUT 174, revisiting topics of greater depth and complexity. More sophisticated notions such as objects, functional programming, and Abstract Data Types are explored. Various algorithms, including popular searching and sorting algorithms, are studied and compared in terms of time and space efficiency. Upon completion of this two course sequence, students from any discipline should be able to build programs to solve basic problems in their area, and will be prepared to take more advanced Computing Science courses. Prerequisite: CMPUT 174 or SCI 100. Credit cannot be obtained for CMPUT 175 if one already has credit for CMPUT 275, except with permission of the Department.

3 units (fi 6)(EITHER, 3-0-3)

Introduction to data acquisition, basic data manipulation (cleaning, outlier detection), analysis (regression, clustering, classification), basic statistics and machine learning tools, information visualization to communicate information from data. Prerequisite: Math 30-1. This course cannot be taken for credit if credit has been obtained in CMPUT 174, 195, or 274.

Starting: 2024-09-01 CMPUT 191 - Introduction to Data Science

3 units (fi 6)(EITHER, 3-0-3)

Introduction to data acquisition, basic data manipulation (cleaning, outlier detection), analysis (regression, clustering, classification), basic statistics and machine learning tools, information visualization to communicate information from data. Prerequisite: Math 30-1. This course cannot be taken for credit if credit has been obtained in CMPUT 174, 175, 195, 274, 275, or ENCMP 100.

3 units (fi 6)(EITHER, 3-0-3)

This course introduces data science to students with prior computing experience. It covers the basics of data acquisition, manipulation, transformation, and cleaning, as well as data analysis (e.g., regression, clustering, classification) and visualization. Students learn principles and techniques of efficient data-driven communication and decision-making in various domains using industry-standard tools. Credit cannot be obtained for both CMPUT 191 and CMPUT 195. Prerequisite: CMPUT 174 or 274, or consent of the instructor.

Starting: 2024-09-01 CMPUT 195 - Introduction to Principles and Techniques of Data Science

3 units (fi 6)(EITHER, 3-0-3)

This course introduces data science to students with prior computing experience. It covers the basics of data acquisition, manipulation, transformation, and cleaning, as well as data analysis (e.g., regression, clustering, classification) and visualization. Students learn principles and techniques of efficient data-driven communication and decision-making in various domains using industry-standard tools. Credit cannot be obtained for both CMPUT 191 and CMPUT 195. Prerequisite: CMPUT 174 or 274.

3 units (fi 6)(EITHER, 3-0-3)

This course focuses on ethics issues in Artificial Intelligence (AI) and Data Science (DS). The main themes are privacy, fairness/bias, and explainability in DS. The objectives are to learn how to identify and measure these aspects in outputs of algorithms, and how to build algorithms that correct for these issues. The course will follow a case-studies based approach, where we will examine these aspects by considering real-world case studies for each of these ethics issues. The concepts will be introduced through a humanities perspective by using case studies with an emphasis on a technical treatment including implementation work. Prerequisite: one of CMPUT 191 or CMPUT 195, or one of CMPUT 174 or CMPUT 274 and one of STAT 141, STAT 151, STAT 235, STAT 265, SCI 151, MATH 181, or CMPUT 267, or consent of the instructor.

Starting: 2024-09-01 CMPUT 200 - Ethics of Data Science and Artificial Intelligence

3 units (fi 6)(EITHER, 3-0-3)

This course focuses on ethics issues in Artificial Intelligence (AI) and Data Science (DS). The main themes are privacy, fairness/bias, and explainability in DS. The objectives are to learn how to identify and measure these aspects in outputs of algorithms, and how to build algorithms that correct for these issues. The course will follow a case-studies based approach, where we will examine these aspects by considering real-world case studies for each of these ethics issues. The concepts will be introduced through a humanities perspective by using case studies with an emphasis on a technical treatment including implementation work. Prerequisite: one of CMPUT 191 or 195, or one of CMPUT 174 or 274 and one of STAT 151, 161, 181, 235, 265, SCI 151, MATH 181, or CMPUT 267.

3 units (fi 6)(EITHER, 3-0-3)

Introduction to the principles, methods, tools, and practices of the professional programmer. The lectures focus on the fundamental principles of software engineering based on abstract data types and their implementations. The laboratories offer an intensive apprenticeship to the aspiring software developer. Students use C and software development tools of the Unix environment. Prerequisite: CMPUT 175. Credit cannot be obtained for CMPUT 201 if credit has been obtained for CMPUT 275, except with permission of the Department.

3 units (fi 6)(EITHER, 3-1S-0)

The first of two courses on algorithm design and analysis, with emphasis on fundamentals of searching, sorting, and graph algorithms. Examples include divide and conquer, dynamic programming, greedy methods, backtracking, and local search methods, together with analysis techniques to estimate program efficiency. Prerequisites: CMPUT 175 or 275 and CMPUT 272; one of MATH 100, 113, 114, 117, 134, 144, 154, or SCI 100.

Starting: 2024-09-01 CMPUT 204 - Algorithms I

3 units (fi 6)(EITHER, 3-1S-0)

The first of two courses on algorithm design and analysis, with emphasis on fundamentals of searching, sorting, and graph algorithms. Examples include divide and conquer, dynamic programming, greedy methods, backtracking, and local search methods, together with analysis techniques to estimate program efficiency. Prerequisites: CMPUT 175 or 275, and CMPUT 272; and one of MATH 100, 114, 117, 134, 144, or 154.

Starting: 2024-09-01 CMPUT 204 - Algorithms I

3 units (fi 6)(EITHER, 3-1S-0)

The first of two courses on algorithm design and analysis, with emphasis on fundamentals of searching, sorting, and graph algorithms. Examples include divide and conquer, dynamic programming, greedy methods, backtracking, and local search methods, together with analysis techniques to estimate program efficiency. Prerequisites: CMPUT 175 or 275, and CMPUT 272; and one of MATH 100, 114, 117, 134, 144, or 154.

3 units (fi 6)(EITHER, 3-0-3)

An introduction to basic digital image processing theory, and the tools that make advanced image manipulation possible for ordinary users. Image processing is important in many applications: editing and processing photographs, special effects for movies, drawing animated characters starting with photographs, analyzing and enhancing remote imagery, and detecting suspects from surveillance cameras. Image processing concepts are introduced using tools like Photoshop and GIMP. Exposure to simple image processing programming with Java and MATLAB. This course is preparation for more advanced courses in the Digital Media area. Prerequisites: Any introductory-level Computing Science course, plus knowledge of introductory-level MATH and STAT; or consent of the instructor or SCI 100. Open to students in the Faculty of Arts, Engineering and Sciences; others require consent of the instructor.

Starting: 2024-09-01 CMPUT 206 - Introduction to Digital Image Processing

3 units (fi 6)(EITHER, 3-0-3)

An introduction to basic digital image processing theory, and the tools that make advanced image manipulation possible for ordinary users. Image processing is important in many applications: editing and processing photographs, special effects for movies, drawing animated characters starting with photographs, analyzing and enhancing remote imagery, and detecting suspects from surveillance cameras. Image processing building blocks and fundamental algorithms of image processing operations are introduced using Python libraries. Prerequisites: one of CMPUT 101, 174, or 274; one of MATH 100, 114, 117, 134, 144, or 154; and one of STAT 151, 161, 181, 235, 265, SCI 151, or MATH 181.

3 units (fi 6)(EITHER, 3-0-3)

An historical introduction to cryptography intended for a general audience. The development of codes and code-breaking from military espionage in ancient Greece to deciphering hieroglyphics via the Rosetta stone to modern computer ciphers. Includes frequency analysis, one-time-pad security, and public key cryptography. Prerequisite: Any 100-level course.

3 units (fi 6)(EITHER, 3-0-3)

Number representation, computer architecture and organization, instruction-set architecture, assembly-level programming, procedures, stack frames, memory access through pointers, exception handling, computer arithmetic, floating-point representation, datapath, control logic, pipelining, memory hierarchy, virtual memory. Prerequisite: CMPUT 201 or 275. Credit may be obtained in only one of CMPUT 229, E E 380 or ECE 212.

3 units (fi 6)(EITHER, 3-0-3)

An interdisciplinary course for students in Science, Arts, and other faculties. The focus is on games as interactive entertainment, their role in society, and how they are made. Teams composed of students with diverse backgrounds (e.g. English, Art and Design, and Computing Science) follow the entire creative process: from concept, through pitch, to delivery, of a short narrative-based game using a commercial game engine. To achieve the required mix of backgrounds and experience, students must apply to be considered for this course. See the Department web site for the online form. Prerequisite: Second-year standing.

3 units (fi 6)(EITHER, 3-0-3)

The purpose of this course is for students to gain a breadth of understanding of the AI approaches employed in digital games. This involves learning basic topics covered in other AI courses as they apply to digital games and more specialized game AI topics. Assignments will involve programming Game AI algorithms across a variety of areas including pathfinding, decision making, and data science. Prerequisite: CMPUT 174 or 274.

3 units (fi 6)(EITHER, 3-0-3)

Introduction to artificial intelligence focusing on techniques for building intelligent software systems and agents. Topics include search and problem-solving techniques, knowledge representation and reasoning, reasoning and acting under uncertainty, machine learning and neural networks. Prerequisites: one of STAT 141, 151, 235, or 265, or SCI 151. Corequisites: CMPUT 204 or 275. Credit cannot be obtained for CMPUT 261 if credit has already been obtained for CMPUT 366, except with permission of the Department.

Starting: 2024-09-01 CMPUT 261 - Introduction to Artificial Intelligence

3 units (fi 6)(EITHER, 3-0-3)

Introduction to artificial intelligence focusing on techniques for building intelligent software systems and agents. Topics include search and problem-solving techniques, knowledge representation and reasoning, reasoning and acting under uncertainty, machine learning and neural networks. Prerequisites: one of STAT 151, 161, 181, 235, 265, SCI 151, or MATH 181. Corequisites: CMPUT 204 or 275. Credit cannot be obtained for CMPUT 261 if credit has already been obtained for CMPUT 366, except with permission of the Department.

3 units (fi 6)(EITHER, 3-0-0)

This course introduces the fundamental statistical, mathematical, and computational concepts in analyzing data. The goal for this introductory course is to provide a solid foundation in the mathematics of machine learning, in preparation for more advanced machine learning concepts. The course focuses on univariate models, to simplify some of the mathematics and emphasize some of the underlying concepts in machine learning, including: how should one think about data, how can data be summarized, how models can be estimated from data, what sound estimation principles look like, how generalization is achieved, and how to evaluate the performance of learned models. Prerequisites: CMPUT 174 or 274; one of MATH 100, 114, 117, 134, 144, or 154. Corequisites: CMPUT 175 or 275; CMPUT 272; MATH 125 or 127; one of STAT 141, 151, 235, or 265, or SCI 151.

Starting: 2024-09-01 CMPUT 267 - Machine Learning I

3 units (fi 6)(EITHER, 3-0-0)

This course introduces the fundamental statistical, mathematical, and computational concepts in analyzing data. The goal for this introductory course is to provide a solid foundation in the mathematics of machine learning, in preparation for more advanced machine learning concepts. The course focuses on univariate models, to simplify some of the mathematics and emphasize some of the underlying concepts in machine learning, including: how should one think about data, how can data be summarized, how models can be estimated from data, what sound estimation principles look like, how generalization is achieved, and how to evaluate the performance of learned models. Prerequisites: CMPUT 174 or 274; one of MATH 100, 114, 117, 134, 144, or 154. Corequisites: CMPUT 175 or 275; CMPUT 272; MATH 102, 125 or 127; one of STAT 151, 161, 181, 235, 265, SCI 151, or MATH 181.

3 units (fi 6)(EITHER, 3-3S-0)

An introduction to the tools of set theory, logic, and induction, and their use in the practice of reasoning about algorithms and programs. Basic set theory; the notion of a function; counting; propositional and predicate logic and their proof systems; inductive definitions and proofs by induction; program specification and correctness. Prerequisites: CMPUT 101, 174, 175, 274, or SCI 100.

Starting: 2024-09-01 CMPUT 272 - Formal Systems and Logic in Computing Science

3 units (fi 6)(EITHER, 3-3S-0)

An introduction to the tools of set theory, logic, and induction, and their use in the practice of reasoning about algorithms and programs. Basic set theory; the notion of a function; counting; propositional and predicate logic and their proof systems; inductive definitions and proofs by induction; program specification and correctness. Prerequisites: CMPUT 101, 174, 175, 274, SCI 100, or ENCMP 100.

Starting: 2024-09-01 CMPUT 272 - Formal Systems and Logic in Computing Science

3 units (fi 6)(EITHER, 3-3S-0)

An introduction to the tools of set theory, logic, and induction, and their use in the practice of reasoning about algorithms and programs. Basic set theory; the notion of a function; counting; propositional and predicate logic and their proof systems; inductive definitions and proofs by induction; program specification and correctness. Prerequisites: CMPUT 101, 174, 175, 274, SCI 100, or ENCMP 100.

3 units (fi 6)(EITHER, 0-6L-0)

This is part 1 of a 2 sequence intensive problem-based introduction to Computing Science. In part 1, the key concepts of procedural programming, basic algorithm design and analysis (lists, queues, trees, sorting, searching) are learned by solving a series of problems using Python. Development is done using the Linux operating system. Prerequisites: Math 30 or 31. Note: this course is taught in studio-style, where lectures and labs are blended into 3 hour sessions, twice a week. Enrollment is limited by the capacity of the combined lecture/lab facilities. Credit cannot be obtained for CMPUT 274 if one already has credit for any of CMPUT 174, 175, or 201, except with permission of the Department.

3 units (fi 6)(EITHER, 0-6L-0)

This is part 2 of a 2 sequence intensive introduction to Computing Science. Part 2 expands to add object-oriented programming, with C++, and more complex algorithms and data structures such as shortest paths in graphs; divide and conquer and dynamic programming; client-server style computing; and recursion. Prerequisite: CMPUT 274. Note: this course is taught in studio-style, where lectures and labs are blended into 3 hour sessions, twice a week. Enrollment is limited by the capacity of the combined lecture/lab facilities. Credit cannot be obtained for CMPUT 275 if one already has credit for any of CMPUT 174, 175, or 201, except with permission of the Department.

3 units (fi 6)(EITHER, 3-0-1.5)

Basic concepts in computer data organization and information processing; entity-relationship model; relational model; SQL and other relational query languages; storage architecture; physical organization of data; access methods for relational data. Programming experience (e.g., Python) is required for the course project. Prerequisites: CMPUT 175 or 274, and 272. Corequisite: one of CMPUT 201 or 275.

3 units (fi 6)(VAR, VARIABLE)

This topics course is designed for new course offerings that may be offered in a given term. Prerequisites are determined by the instructor in the course outline. See Note (3) above.

1.5 units (fi 6)(VAR, VARIABLE)

This topics course is designed for new course offerings that may be offered in a given term. Prerequisites are determined by the instructor in the course outline. See Note (3) above.

1.5 units (fi 6)(VAR, VARIABLE)

This topics course is designed for new course offerings that may be offered in a given term. Prerequisites are determined by the instructor in the course outline. See Note (3) above.

3 units (fi 6)(VAR, VARIABLE)

This topics course is designed for new course offerings that may be offered in a given term. Prerequisites are determined by the instructor in the course outline. See Note (3) above.

1.5 units (fi 6)(VAR, VARIABLE)

This topics course is designed for new course offerings that may be offered in a given term. Prerequisites are determined by the instructor in the course outline. See Note (3) above.

1.5 units (fi 6)(VAR, VARIABLE)

This topics course is designed for new course offerings that may be offered in a given term. Prerequisites are determined by the instructor in the course outline. See Note (3) above.

3 units (fi 6)(VAR, VARIABLE)

This topics course is designed for new course offerings that may be offered in a given term. Prerequisites are determined by the instructor in the course outline. See Note (3) above.

1.5 units (fi 6)(VAR, VARIABLE)

This topics course is designed for new course offerings that may be offered in a given term. Prerequisites are determined by the instructor in the course outline. See Note (3) above.

1.5 units (fi 6)(VAR, VARIABLE)

This topics course is designed for new course offerings that may be offered in a given term. Prerequisites are determined by the instructor in the course outline. See Note (3) above.

3 units (fi 6)(VAR, VARIABLE)

This topics course is designed for a one on one individual study course between a student and an instructor. Prerequisites are determined by the instructor in the course outline. See Note (3) above.

1.5 units (fi 6)(VAR, VARIABLE)

This topics course is designed for a one on one individual study course between a student and an instructor. Prerequisites are determined by the instructor in the course outline. See Note (3) above.

1.5 units (fi 6)(VAR, VARIABLE)

This topics course is designed for a one on one individual study course between a student and an instructor. Prerequisites are determined by the instructor in the course outline. See Note (3) above.

3 units (fi 6)(EITHER, 3-1S-0)

Social, ethical, professional, economic, and legal issues in the development and deployment of computer technology in society. Prerequisites: Any introductory-level Computing Science course or SCI 100, and any 200-level course.

3 units (fi 6)(EITHER, 3-0-3)

Object-oriented design and analysis, with interactive applications as the primary example. Topics include: software process; revision control; Unified Modeling Language (UML); requirements; software architecture, design patterns, frameworks, design guidelines; unit testing; refactoring; software tools. Prerequisite: CMPUT 201 or 275. This course may not be taken for credit if credit has been obtained in MIS 419 or BTM 419.

3 units (fi 6)(EITHER, 3-0-3)

A complementary course to introductory software engineering focused on a user-centered approach to software design. The main themes are how humans interact with physical and information environments, and how to design software with human's information needs and their cognitive capacities in mind. Topics include the user-centered design cycle, and evaluation methods for discovering usability problems in interface design. Prerequisite: CMPUT 301.

3 units (fi 6)(EITHER, 3-0-0)

This course is focused on algorithmic problems, where a solution involves properly understanding a written description, designing an efficient algorithm to solve the problem, and then correctly implementing the solution. Students will use previous knowledge in algorithms, data structures, and mathematical reasoning to solve problems in addition to learning new algorithms and data structures. Lectures are shared with CMPUT 403. Credit cannot be obtained for both CMPUT 303 and CMPUT 403. Prerequisites: One of CMPUT 201 or CMPUT 275, CMPUT 204.

Starting: 2024-09-01 CMPUT 303 - Algorithmics in Practice

3 units (fi 6)(EITHER, 3-0-0)

This course is focused on algorithmic problems, where a solution involves properly understanding a written description, designing an efficient algorithm to solve the problem, and then correctly implementing the solution. Students will use previous knowledge in algorithms, data structures, and mathematical reasoning to solve problems in addition to learning new algorithms and data structures. Lectures are shared with CMPUT 403. Credit cannot be obtained for both CMPUT 303 and CMPUT 403. Prerequisites: CMPUT 201 or 275, and 204.

3 units (fi 6)(EITHER, 3-1S-0)

The second course of a two-course sequence on algorithm design. Emphasis on principles of algorithm design. Categories of algorithms such as divide-and-conquer, greedy algorithms, dynamic programming; analysis of algorithms; limits of algorithm design; NP-completeness; heuristic algorithms. Prerequisites: CMPUT 204; one of STAT 141, 151, 235 or 265 or SCI 151; one of MATH 225, 227, 228; or consent of the instructor.

Starting: 2024-09-01 CMPUT 304 - Algorithms II

3 units (fi 6)(EITHER, 3-1S-0)

The second course of a two-course sequence on algorithm design. Emphasis on principles of algorithm design. Categories of algorithms such as divide-and-conquer, greedy algorithms, dynamic programming; analysis of algorithms; limits of algorithm design; NP-completeness; heuristic algorithms. Prerequisites: CMPUT 204; one of STAT 151, 161, 181, 235, 265, SCI 151, or MATH 181; and one of MATH 225, 227, or 228.

Starting: 2024-09-01 CMPUT 304 - Algorithms II

3 units (fi 6)(EITHER, 3-1S-0)

The second course of a two-course sequence on algorithm design. Emphasis on principles of algorithm design. Categories of algorithms such as divide-and-conquer, greedy algorithms, dynamic programming; analysis of algorithms; limits of algorithm design; NP-completeness; heuristic algorithms. Prerequisites: CMPUT 204; one of STAT 151, 161, 181, 235, 265, SCI 151, or MATH 181; and one of MATH 225, 227, or 228.

3 units (fi 6)(EITHER, 3-0-3)

An introductory course on the theory and applications of computer based 3D modeling and animation. The course will cover a selection of topics from overview of tools supporting modeling and animation, automatically generating 3D models, and animation of skeleton based models through algorithms and software. Applications of 3D modeling and animation in games, virtual/augmented environments, movies, and emerging video transmission algorithms will be discussed. Prerequisites: one of CMPUT 206, 308, or 411; or consent of the instructor.

Starting: 2024-09-01 CMPUT 307 - 3D Modeling and Animation

3 units (fi 6)(EITHER, 3-0-3)

An introductory course on the theory and applications of computer based 3D modeling and animation. The course will cover a selection of topics from overview of tools supporting modeling and animation, automatically generating 3D models, and animation of skeleton based models through algorithms and software. Applications of 3D modeling and animation in games, virtual/augmented environments, movies, and emerging video transmission algorithms will be discussed. Prerequisites: CMPUT 206, or CMPUT 204 and one of MATH 225 or 227.

3 units (fi 6)(EITHER, 3-0-3)

An introductory course in video data processing, with implementations in programming languages, like Python, C and MATLAB, using libraries like OpenCV. Topics in this course may include video capture, video compression, tracking, video content understanding, real-time video conferencing and surveillance. Time permitting, advanced topics like video mining, 3D modeling, and motion capture-based video coding, video-based 3D scene understanding could be discussed. Prerequisites: CMPUT 201, 206, MATH 125 or 127, STAT 151 or 265, or consent of the instructor.

Starting: 2024-09-01 CMPUT 308 - Video Processing and Applications

3 units (fi 6)(EITHER, 3-0-3)

An introductory course in video data processing, with implementations in programming languages, like Python, C and MATLAB, using libraries like OpenCV. Topics in this course may include video capture, video compression, tracking, video content understanding, real-time video conferencing and surveillance. Time permitting, advanced topics like video mining, 3D modeling, and motion capture-based video coding, video-based 3D scene understanding could be discussed. Prerequisites: CMPUT 201 and 206; one of MATH 102, 125, or 127; and one of STAT 151, 161, 181, 235, 265, SCI 151, or MATH 181.

3 units (fi 6)(EITHER, 3-0-3)

Algorithms and software paradigms for robot programming; mathematical modeling of robot arms and rovers including kinematics, and an introduction to dynamics and control; sensors, motors and their modeling; basics of image processing and machine vision; vision-guided motion control. Prerequisite: CMPUT 275. Corequisite: CMPUT 340 or 418, or ECE 240. Students having CMPUT 174, 175, 201, 204 may seek consent of the instructor.

Starting: 2024-09-01 CMPUT 312 - Introduction to Robotics and Mechatronics

3 units (fi 6)(EITHER, 3-0-3)

Algorithms and software paradigms for robot programming; mathematical modeling of robot arms and rovers including kinematics, and an introduction to dynamics and control; sensors, motors and their modeling; basics of image processing and machine vision; vision-guided motion control. Prerequisite: CMPUT 275. Corequisite: CMPUT 340 or 418, or ECE 240. Students having CMPUT 174, 175, 201, 204 may seek permission from the Department.

3 units (fi 6)(EITHER, 3-0-3)

Introduction to computer communication networks; protocols for error and flow control; wired and wireless medium access protocols; routing and congestion control; internet architecture and protocols; multimedia transmission; recent advances in networking. Prerequisites: CMPUT 201 and 204 or 275; one of CMPUT 229, E E 380 or ECE 212; and STAT 252 or 266.

Starting: 2024-09-01 CMPUT 313 - Computer Networks

3 units (fi 6)(EITHER, 3-0-3)

Introduction to computer communication networks; protocols for error and flow control; wired and wireless medium access protocols; routing and congestion control; internet architecture and protocols; multimedia transmission; recent advances in networking. Prerequisites: CMPUT 201 and 204, or 275; one of CMPUT 229, E E 380, or ECE 212; and one of STAT 151, 161, 181, 235, 265, SCI 151, or MATH 181.

Starting: 2024-09-01 CMPUT 313 - Computer Networks

3 units (fi 6)(EITHER, 3-0-3)

Introduction to computer communication networks; protocols for error and flow control; wired and wireless medium access protocols; routing and congestion control; internet architecture and protocols; multimedia transmission; recent advances in networking. Prerequisites: CMPUT 201 and 204, or 275; one of CMPUT 229, E E 380, or ECE 212; and one of STAT 151, 161, 181, 235, 265, SCI 151, or MATH 181.

3 units (fi 6)(EITHER, 3-0-3)

A study of the theory, run-time structure, and implementation of selected non-procedural programming languages. Languages will be selected from the domains of functional, and logic-based languages. Prerequisites: CMPUT 201 and 204 or 275; one of CMPUT 229, E E 380 or ECE 212, and MATH 125.

Starting: 2024-09-01 CMPUT 325 - Non-Procedural Programming Languages

3 units (fi 6)(EITHER, 3-0-3)

A study of the theory, run-time structure, and implementation of selected non-procedural programming languages. Languages will be selected from the domains of functional, and logic-based languages. Prerequisites: CMPUT 201 and 204, or 275; one of CMPUT 229, E E 380, or ECE 212; and one of MATH 102, 125, or 127.

3 units (fi 6)(EITHER, 3-0-3)

Introduction to visual recognition to recognize objects and classify scenes or images automatically by a computer. Supervised and unsupervised machine learning principles and deep learning techniques will be utilized for visual recognition. Successful commercial systems based on visual recognition range from entertainment to serious scientific research: face detection and recognition on personal devices, social media. Prerequisites: CMPUT 115 or 175; one of MATH 100, 113, 114, 117, 134, 144, 154; MATH 125; STAT 141, 151 or 235.

Starting: 2024-09-01 CMPUT 328 - Visual Recognition

3 units (fi 6)(EITHER, 3-0-3)

Introduction to visual recognition to recognize objects and classify scenes or images automatically by a computer. Supervised and unsupervised machine learning principles and deep learning techniques will be utilized for visual recognition. Successful commercial systems based on visual recognition range from entertainment to serious scientific research: face detection and recognition on personal devices, social media. Prerequisites: CMPUT 175 or 275; one of MATH 100, 114, 117, 134, 144, or 154; one of MATH 102, 125, or 127; and one of STAT 151, 161, 181, 235, 265, SCI 151, or MATH 181.

3 units (fi 6)(EITHER, 3-0-3)

CMOS technology, digital circuits, combinational logic, sequential logic, memory technologies, programmable logic devices, control logic design, register transfer logic, CPU design, hardware description languages. Prerequisite: one of CMPUT 229, E E 380 or ECE 212. Credit may be obtained in only one of CMPUT 329, E E 280 or ECE 210.

3 units (fi 6)(EITHER, 3-0-0)

Cryptography is the science of secure communications. This course is an introduction to computational methods for encrypting and deciphering messages, with an emphasis on computer implementation. Prerequisites: CMPUT 201 or 275, and CMPUT 272.

3 units (fi 6)(EITHER, 3-0-3)

Introduction to the concepts and components involved in secure, networked, systems. The concepts of confidentiality, integrity, availability; shared and public key cryptography; authentication protocols; third-party authentication services; key agreement protocols; strong password protocols; digital signature schemes; non-repudiation; certificate authorities; random number generation; proof-of-work; network protocol and network services vulnerabilities; firewalls; malicious code; computer viruses and worms; intrusion detection. Prerequisite: CMPUT 201 or 275.

3 units (fi 6)(EITHER, 3-1S-3)

Computer arithmetic and errors. The study of computational methods for solving problems in linear algebra, non-linear equations, optimization, interpolation and approximation, and integration. This course will provide a basic foundation in numerical methods that supports further study in machine learning; computer graphics, vision and multimedia; robotics; and other topics in Science and Engineering. Prerequisites: CMPUT 204 or 275; MATH 125, 214; one of STAT 141, 151, 235 or 265 or SCI 151.

Starting: 2024-09-01 CMPUT 340 - Introduction to Numerical Methods

3 units (fi 6)(EITHER, 3-1S-3)

Computer arithmetic and errors. The study of computational methods for solving problems in linear algebra, non-linear equations, optimization, interpolation and approximation, and integration. This course will provide a basic foundation in numerical methods that supports further study in machine learning; computer graphics, vision and multimedia; robotics; and other topics in Science and Engineering. Prerequisites: CMPUT 204 or 275; MATH 214; one of MATH 102, 125, or 127; one of MATH 225 or 227; and one of STAT 151, 161, 181, 235, 265, SCI 151, or MATH 181.

3 units (fi 6)(EITHER, 3-0-3)

This course focuses on state-of-the-art AI and graphics programming for video games. Part 1 introduces C++, the language of choice for video game engines, emphasizing efficiency, safety, the Standard Template Library, and OpenGL. Part 2 on real time strategy deals with efficient pathfinding algorithms, planning, and scripting AI systems. Student projects give hands-on experience directly applicable to the video games industry. Prerequisites: CMPUT 201 or 275, and 204.

3 units (fi 6)(EITHER, 3-0-0)

An introduction to algorithms and theory behind computer programs that solve puzzles (mazes, peg solitaire, etc.) or play games (chess, Go, Hex, etc.). This course is intended for a general audience. Prerequisite: any 200-level Computing Science course.

3 units (fi 6)(EITHER, 3-0-0)

Introduction to information retrieval focusing on algorithms and data structures for organizing and searching through large collections of documents, and techniques for evaluating the quality of search results. Topics include boolean retrieval, keyword and phrase queries, ranking, index optimization, practical machine-learning algorithms for text, and optimizations used by Web search engines. Prerequisites: CMPUT 201 and CMPUT 204, or 275. One of MATH 102, 125, or 127 is strongly recommended.

3 units (fi 6)(EITHER, 3-0-0)

This course provides an introduction to reinforcement learning, which focuses on the study and design of learning agents that interact with a complex, uncertain world to achieve a goal. The course will cover multi- armed bandits, Markov decision processes, reinforcement learning, planning, and function approximation (online supervised learning). The course will take an information-processing approach to the study of intelligence and briefly touch on perspectives from psychology, neuroscience, and philosophy. The course will use the University of Alberta MOOC on Reinforcement Learning. Any student who understands the material in this course will understand the foundations of much of modern probabilistic artificial intelligence (AI) and be prepared to take more advanced courses, or to apply AI tools and ideas to real-world problems. Prerequisites: CMPUT 175 or 275; one of CMPUT 267, 466, or STAT 265; or consent of the instructor.

Starting: 2024-09-01 CMPUT 365 - Introduction to Reinforcement Learning

3 units (fi 6)(EITHER, 3-0-0)

This course provides an introduction to reinforcement learning, which focuses on the study and design of learning agents that interact with a complex, uncertain world to achieve a goal. The course will cover multi- armed bandits, Markov decision processes, reinforcement learning, planning, and function approximation (online supervised learning). The course will take an information-processing approach to the study of intelligence and briefly touch on perspectives from psychology, neuroscience, and philosophy. The course will use the University of Alberta MOOC on Reinforcement Learning. Any student who understands the material in this course will understand the foundations of much of modern probabilistic artificial intelligence (AI) and be prepared to take more advanced courses, or to apply AI tools and ideas to real-world problems. Prerequisites: CMPUT 175 or 275; one of CMPUT 267, 466, or STAT 265.

3 units (fi 6)(EITHER, 3-0-3)

This course provides an introduction to search and planning in artificial intelligence. The course covers deterministic single-agent and multi-agent problems. Students will learn how to model real-world problems as state-space search problems and how to solve such problems. The course covers algorithms for solving deterministic shortest path problems with factored and non-factored states, combinatorial optimization problems, constraint satisfaction problems, and multi- agent problems. Prerequisites: CMPUT 204 or 275, and CMPUT 272.

3 units (fi 6)(EITHER, 3-0-0)

This course in machine learning focuses on higher-dimensional data and a broader class of nonlinear function approximation approaches. Topics include: optimization approaches (constrained optimization, hessians, matrix solutions), kernel machines, neural networks, dimensionality reduction, latent variables, feature selection, more advanced methods for assessing generalization (cross-validation, bootstrapping), introduction to non-iid data and missing data. Credit cannot be obtained for both CMPUT 367 and CMPUT 466. Prerequisites: CMPUT 204 and 267; one of MATH 115, 118, 136, 146, or 156.

3 units (fi 6)(EITHER, 3-0-3)

Introduction to the structure, components, and concepts behind modern general-purpose operating systems. Processes: process state transitions; operations on processes; interrupt processing; multiprocessor considerations; resource allocation; synchronization; critical sections and events; semaphores; deadlock: avoidance, detection, and recovery; memory management; virtual memory; paging and segmentation; page replacement strategies; working sets; demand paging; process scheduling; scheduling algorithms; file system functions; file organization; space allocation; virtual machines. Prerequisites: CMPUT 201 and 204, or 275; one of CMPUT 229, E E 380 or ECE 212.

3 units (fi 6)(EITHER, 3-0-3)

Graphics processing units (GPU) can be programmed like a coprocessor to solve non-graphics problems, including voice recognition, computational physics, convolutional neural networks, and machine learning. The many processing cores of a GPU support a high-degree of parallelism. Course topics include hardware architecture, algorithmic design, programming languages (e.g., CUDA, OpenCL), and principles of programming for GPUs for high performance. Prerequisites: CMPUT 201 or 275, and CMPUT 229.

Starting: 2024-09-01 CMPUT 382 - Introduction to GPU Programming

3 units (fi 6)(EITHER, 3-0-3)

Graphics processing units (GPU) can be programmed like a coprocessor to solve non-graphics problems, including voice recognition, computational physics, convolutional neural networks, and machine learning. The many processing cores of a GPU support a high-degree of parallelism. Course topics include hardware architecture, algorithmic design, programming languages (e.g., CUDA, OpenCL), and principles of programming for GPUs for high performance. Prerequisites: CMPUT 201 or 275, and one of CMPUT 229, E E 380, or ECE 212.

3 units (fi 6)(EITHER, 3-0-3)

This course covers the implementation of RDBMSs and some non- relational data models, along with their query languages. Topics: compilation, execution, and optimization of SQL queries; concurrent execution of transactions; indexing; advanced constructs in SQL; semi-structured data models and query languages; distributed and parallel databases; NoSQL and cloud-based database systems. Prerequisites: CMPUT 201 and 204, or 275; and CMPUT 291.

3 units (fi 6)(VAR, VARIABLE)

This topics course is designed for new course offerings that may be offered in a given term. Prerequisites are determined by the instructor in the course outline. See Note (3) above.

1.5 units (fi 6)(VAR, VARIABLE)

This topics course is designed for new course offerings that may be offered in a given term. Prerequisites are determined by the instructor in the course outline. See Note (3) above.

1.5 units (fi 6)(VAR, VARIABLE)

This topics course is designed for new course offerings that may be offered in a given term. Prerequisites are determined by the instructor in the course outline. See Note (3) above.

3 units (fi 6)(VAR, VARIABLE)

This topics course is designed for new course offerings that may be offered in a given term. Prerequisites are determined by the instructor in the course outline. See Note (3) above.

1.5 units (fi 6)(VAR, VARIABLE)

This topics course is designed for new course offerings that may be offered in a given term. Prerequisites are determined by the instructor in the course outline. See Note (3) above.

1.5 units (fi 6)(VAR, VARIABLE)

This topics course is designed for new course offerings that may be offered in a given term. Prerequisites are determined by the instructor in the course outline. See Note (3) above.

3 units (fi 6)(VAR, VARIABLE)

This topics course is designed for new course offerings that may be offered in a given term. Prerequisites are determined by the instructor in the course outline. See Note (3) above.

1.5 units (fi 6)(VAR, VARIABLE)

This topics course is designed for new course offerings that may be offered in a given term. Prerequisites are determined by the instructor in the course outline. See Note (3) above.

1.5 units (fi 6)(VAR, VARIABLE)

This topics course is designed for new course offerings that may be offered in a given term. Prerequisites are determined by the instructor in the course outline. See Note (3) above.

3 units (fi 6)(VAR, VARIABLE)

This topics course is designed for a one on one individual study course between a student and an instructor. Prerequisites are determined by the instructor in the course outline. See Note (3) above.

1.5 units (fi 6)(VAR, VARIABLE)

This topics course is designed for a one on one individual study course between a student and an instructor. Prerequisites are determined by the instructor in the course outline. See Note (3) above.

1.5 units (fi 6)(VAR, VARIABLE)

This topics course is designed for a one on one individual study course between a student and an instructor. Prerequisites are determined by the instructor in the course outline. See Note (3) above.

3 units (fi 6)(EITHER, 3-1S-3)

All phases of software development are reviewed from a process perspective. Best practices in software project and product development and management are introduced. Architectural and technological impacts on management. Group projects require specification and initial design or redesign of a software system. Prerequisite: CMPUT 301.