Computer Science CPSC
Instruction offered by members of the Department of Computer Science in the Faculty of Science
Department Head - K. Barker
Note: Computer Science students should also see courses listed under Software Engineering.
Note: In several cases, credit is not allowed for Computer Science courses and various courses offered by the Faculty of Engineering. Students who have successfully completed Engineering courses should contact the Department of Computer Science for additional information.
Computer Science 001 E(6 hours)
Introduction to Unix
An introduction to the Unix operating system, including the text editor "emacs," its programming modes and macros; shell usage (including "sh" and "tcsh"); and some advanced Unix commands.
Note: This course is highly recommended as preparation for Computer Science 215 or 231.
NOT INCLUDED IN GPA
Computer Science 002 Q(12 hours)
Advanced Unix
Unix signals, processes, and file system; interprocess communication; advanced shell programming; program profiling.
Prerequisites: Computer Science 233 or 235.
Note: This course is highly recommended as preparation for Computer Science 265 or 355.
NOT INCLUDED IN GPA
Computer Science 031 E(6 hours)
Mathematics Review for Computer Science 413
A review of topics in calculus and discrete mathematics that have applications in the analysis of computer algorithms.
Prerequisites: Mathematics 249, 251 or 261, and 271.
Note: This course is highly recommended as preparation for Computer Science 413.
NOT INCLUDED IN GPA
Junior Courses
Computer Science 203 H(3-2T-1)
Introduction to Computers
Computer system fundamentals, personal computer applications software, and computer communications both on campus and using the internet. Students will use personal computers to complete assignments in word processing, spreadsheet analysis, database management and other applications.
Note: This course is not available for credit for Computer Science majors.
Computer Science 215 H(3-2T-1)
Introduction to Programming
Introduction to algorithm design and implementation using a structured programming language. Discussion of, and practice with, elementary programming techniques with emphasis on good style.
Note: Credit for both Computer Science 215 and either 231 or 235 will not be allowed.
Note: See the statements at the beginning of the Computer Science entry.
Note: This course is not available for credit for Computer Science majors.
Note: This course does not assume prior programming background.
Computer Science 231 H(3-2T-1)
Introduction to Computer Science I
Problem solving and programming in a structured language. Data representation, program control, basic file handling, the use of simple data structures and their implementation. Pointers. Recursion.
Note: Credit for both Computer Science 231 and either 215 or 235 will not be allowed.
Note: See the statements at the beginning of the Computer Science entry.
Note: Computer Science 001 is strongly recommended.
Note: This course does not require prior programming background but does assume a mathematical/science inclination.
Computer Science 233 H(3-2T-1)
Introduction to Computer Science II
Continuation of Introduction to Computer Science I. The implementation of abstract data structures using objects, with emphasis on modularity and software design.
Prerequisites: Computer Science 231.
Note: Credit for both Computer Science 233 and either 235 or 497 (Electrical Engineering 497) will not be allowed.
Note: See the statements at the beginning of the Computer Science entry.
Computer Science 235 H(3-2T-2)
Inquiry-based Introduction to Computer Science
Problem solving. Algorithms and (object-oriented) programming. Control structures. Pre/Postconditions. Simple data structures. Recursion. Pointers. Abstract data types. Inheritance. Polymorphism. Modularity. Software Design. Project-based assignments.
Prerequisites: Consent of the Department.
Note: Credit for both Computer Science 235 and any of 215, 231 or 233 will not be allowed.
Note: See the statements at the beginning of the Computer Science entry.
Note: Computer Science 001 is strongly recommended.
Note: This course does not require prior programming background but does assume a strong mathematical/science inclination.
Note: Limited to highly qualified students.
Computer Science 265 H(3-2T-1)
Computer Architecture and Low-Level Programming
Organization and operation of the functional units in a stored program computer, internal data representation and programming at the architectural level establishing the link between high level language programming and machine operation.
Prerequisites: Computer Science 231 or 235.
Note: Credit for both Computer Science 265 and 355 will not be allowed.
Note: See the statements at the beginning of the Computer Science entry.
Senior Courses
Computer Science 313 H(3-2T)
Introduction to Computability
An introduction to abstract models of sequential computation, including finite automata, regular expressions, context-free grammars, and Turing machines. Formal languages, including regular, context-free, and recursive languages, methods for classifying languages according to these types, and relationships among these classes.
Prerequisites: Mathematics 271, one of Philosophy 279 or 377, and one of Computer Science 233 or 235.
Computer Science 325 H(3-2T-1)
Hardware/ Software Interface
Boolean algebra. Combinational circuits. Sequential logic. Computer organization. Data exchange. Interrupts and asynchronous programming. Real time programming. DMA. I/O Ports. Software implementation of protocols.
Prerequisites: One of Computer Science 265 or 355 and one of Philosophy 279 or 377.
Note: Credit for both Computer Science 325 and either 321 or 455 will not be allowed.
Note: See the statements at the beginning of the Computer Science entry.
Computer Science 331 H(3-2T-1)
Information Structures I
Algorithms: searching, sorting, graph navigation. Data structures: arrays, lists, stacks, queues, graphs, trees, hash tables; time and space efficiency of associated algorithms.
Prerequisites: One of Computer Science 233 or 235 or Computer Engineering 339.
Note: Mathematics 271 is recommended highly as preparation for Computer Science 331; students in Computer Engineering or Software Engineering programs should take Mathematics 271 and Computer Science 331 concurrently.
Computer Science 333 H(3-2T-1)
Foundations of Software Engineering
Inquiry-based introduction to software development problems and to the processes and methods used to address them. Software life cycle models. Software process improvement. Goals and methods for requirements analysis and specification, software design, implementation, integration and testing of software.
Prerequisites: Computer Science 331 and consent of the Department.
Note: Credit for both Computer Science 333 and Software Engineering 311 will not be allowed.
Note: Only open to students who have been admitted to Computer Science.
Note: Limited to highly qualified students.
Computer Science 335 H(3-2T-1)
Information Structures II
A continuation of Computer Science 331. Collision resolution in hash tables, search algorithms, advanced tree structures, strings. Advanced algorithmic tools for storing and manipulating information.
Prerequisites: Computer Science 331.
Computer Science 349 H(3-2T-1)
(formerly Computer Science 449)
Programming Paradigms
Examination of the basic principles of the major programming language paradigms. Focus on declarative paradigms as functional and logic programming. Data types, control expressions, loops, types of references, lazy evaluation, different interpretation principles, information hiding.
Prerequisites: Computer Science 331 and one of Philosophy 279 or 377.
Note: The prerequisite of Philosophy 279 or 377 is waived for Engineering students in the Software Engineering program.
Computer Science 401 H(3-2T)
Computer Structure I
Technology of memories, processors and peripherals. Architecture of computer systems. Discussion and comparison of several modern machines.
Prerequisites: Computer Science 325 or both 321 and 455.
Computer Science 409 H(3-0)
(formerly Computer Science 509)
History of Computation
The history of computation from the earliest times to the modern era.
Prerequisites: Computer Science 313.
Computer Science 411 H(3-2T)
Compiler Construction I
Introduction to compilers, interpreters, and the tools for parsing and translation. Lexical analysis, context free grammars and software tools for their recognition. Attribute grammars and their applications in translation and compiling.
Prerequisites: Computer Science 331.
Note: Computer Science 313 is strongly recommended.
Computer Science 413 H(3-2T)
Design and Analysis of Algorithms I
Techniques for the analysis of algorithms, including counting, summation, recurrences, and asymptotic relations; techniques for the design of efficient algorithms, including greedy methods, divide and conquer, and dynamic programming; examples of their application; an introduction to tractable and intractable problems.
Prerequisites: Computer Science 313, 331, and one of Mathematics 249, 251 or 261.
Note: Mathematics 253 is highly recommended but not mandatory. Computer Science 031 is also recommended.
Computer Science 417 H(3-2T-1)
Foundations of Functional Programming
Theoretical foundations of functional programming: the lambda-calculus, beta-reduction, confluence, and reduction strategies. Programming syntax: solving recursive equations with the Y-combinator, let and letrec, types, datatypes, and patterns. Programming in a functional language: recursion patterns, useful combinators, maps, and folds, for datatypes. Example applications: recursive descent parsing, unification, combinatorial algorithms, theorem proving.
Prerequisites: Computer Science 313 and one of 349 or 449.
Computer Science 421 H(3-3T)
Digital Systems Design
State machine design. Use of LSI circuits including PLAs; ROM and RAM design. Simulation and testing of digital circuits.
Prerequisites: One of Computer Science 321 or 325.
Computer Science 433 H(3-2T)
(formerly Computer Science 533)
Artificial Intelligence
An examination of the objectives, key techniques and achievements of work on artificial intelligence in Computer Science.
Prerequisites: Computer Science 313 and one of 349 or 449.
Computer Science 441 H(3-2T)
Computer Communications
Principles and practice in modern telecommunications, computer communications and networks. Layered communication protocols and current physical, data link, network and internet protocol layers. Circuit switching, packet switching, and an introduction to broadband multimedia networking.
Prerequisites: Computer Science 331 and one of 325, 455 or Computer Engineering 369.
Computer Science 453 H(3-2T-1)
Introduction to Computer Graphics
Introduction to computer graphics. Principles of raster image generation. Example of a graphics API. Graphics primitives. Coordinate systems, affine transformations and viewing of graphical objects. Introduction to rendering including shading models and ray tracing. Introduction to modelling including polygon meshes, subdivision, and parametric curves and surfaces.
Prerequisites: Computer Science 331, Mathematics 221 and one of Mathematics 253 or Applied Mathematics 219.
Note: Credit for both Computer Science 453 and either 407 or Electrical Engineering 555 will not be allowed.
Computer Science 455 H(3-2T-1)
The Software/Hardware Interface
Low and intermediate level support software necessary to access I/O devices and interfaces, to manage information and to provide a software interface between a single-user microcomputer environment and its hardware. Emphasis on I/O, interrupt handling, file systems and systems programming concepts. An introduction to process interaction.
Prerequisites: Computer Science 331 and 355.
Note: Credit for both Computer Science 325 and 455 will not be allowed.
Note: This course will be offered for the last time in the academic year 2005/2006.
Computer Science 457 H(3-2T-1)
Principles of Operating Systems
An introduction to operating systems principles. Performance measurement; concurrent programs; the management of information, memory and processor resources.
Prerequisites: Computer Science 331 and one of 325 or 455 .
Note: Computer Science 325/455 is waived as a prerequisite for students concurrently enrolled in Computer Engineering 415.
Computer Science 461 H(3-2T-1)
Information Structures III
File architecture and manipulation techniques for various file types. Physical characteristics of current mass storage devices. Advanced data structures and algorithms for implementing various sequential and hierarchical file structures. File organization and design for various applications, file systems and other storage management techniques including web site design.
Prerequisites: Computer Science 331 and one of 265 or 355.
Computer Science 471 H(3-2T-1)
Data Base Management Systems
Conceptual, internal and external data bases. Relational data base systems and SQL. The normal forms, data base design, and the entity-relationship approach.
Prerequisites: Computer Science 331.
Computer Science 481 H(3-2T)
Human-Computer Interaction I
Fundamental theory and practice of the design, implementation, and evaluation of human-computer interfaces. Topics include: principles of design; methods for evaluating interfaces with or without user involvement; techniques for prototyping and implementing graphical user interfaces.
Prerequisites: Computer Science 333 or Software Engineering 311.
Computer Science 491 H(3-2T)
Techniques for Numerical Computation
Elementary techniques for the numerical solution of mathematical problems on a computer, including methods for solving linear and non-linear equations, numerical integration, and interpolation.
Prerequisites: Computer Science 331, and Mathematics 251 or 261.
Note: Not open to students with credit in Applied Mathematics 491 or 493.
Computer Science 501 H(3-2T)
Advanced Programming Techniques
Theory and application of advanced programming methods and tools. Recent issues as well as those of an enduring nature will be discussed. Topics may include the Fourier transform; wavelets; functional programming; genetic algorithms, simulated annealing and neural networks; parallel and distributed programming; images and graphical user interface programming.
Corequisites: Computer Science 457.
Computer Science 502 F(1-5)
Honours Thesis
A substantial research project under the guidance of a faculty member. A report must be written and presented on completion of the course.
Prerequisites: Consent of the Department.
Note: Not open to students with credit in Computer Science 503.
Note: This course is normally only available to students enrolled in the honours program or to students with an equivalent standing.
Computer Science 503 H(1-5)
Project
A research project conducted under the guidance of a faculty member. A report must be presented on completion of the course.
Prerequisites: Consent of the Department
Note: Not open to students with credit in Computer Science 502.
Computer Science 510 F(3-2T)
Compiler Construction II
Theory and implementation of assemblers, compilers, and interpreters. Projects will include the writing of substantial segments of such programs.
Prerequisites: Computer Science 313, 411 and one of 265 or 355.
Note: Includes a research, writing and presentation component.
Computer Science 511 H(3-1T)
Introduction to Complexity Theory
Time and space complexity; the classes P, LOGSPACE, PSPACE and their nondeterministic counterparts; containments and separations between complexity classes; intractability and the theory of NP-completeness; complexity theories for probabilistic algorithms and for parallel algorithms.
Prerequisites: Computer Science 413.
Computer Science 513 H(3-1T)
Computability
Computable functions; decidable and undecidable problems; Church's thesis and recursive functions.
Prerequisites: Computer Science 313.
Computer Science 517 H(3-2T)
Design and Analysis of Algorithms II
Advanced techniques for the design and analysis of deterministic and probabilistic algorithms; techniques for deriving lower bounds on the complexity of problems.
Prerequisites: Computer Science 413.
Computer Science 518 H(3-2T)
Introduction to Computer Algebra
Fundamental problems, classical and modern algorithms, and algorithm design and analysis techniques of use in computer algebra. Integer and polynomial arithmetic. Additional problems in computer algebra, possibly including problems in computational linear algebra, factorization, and concerning systems of polynomial equations will be considered as time permits.
Prerequisites: Computer Science 413 and Mathematics 221.
Note: Computer Science 491 and Pure Mathematics 431 are recommended as preparation for this course.
Computer Science 519 H(3-1T)
Introduction to Quantum Computation
Quantum information, quantum algorithms including Shor's quantum factoring algorithm and Grover's quantum searching technique, quantum error correcting codes, quantum cryptography, nonlocality and quantum communication complexity, and quantum computational complexity.
Prerequisites: Computer Science 413 and Mathematics 311.
Computer Science 523 H(3-2T)
Computer Structure II
Continuation of Computer Science 401.
Prerequisites: Computer Science 401.
Computer Science 525 H(3-2)
Embedded Systems
Advanced techniques for the design of modern embedded systems. Modelling and characterization of embedded computer systems; real-time operating system issues; methods to evaluate design tradeoffs between alternative technologies. Hardware and software components integration.
Prerequisites: Computer Science 421 and Computer Engineering 491.
Computer Science 531 H(3-2T)
Systems Modelling and Simulation
An introduction to the modelling and simulation of stochastic systems; programming language issues; model and tool design; input data modelling; simulation experiments; and the interpretation of simulation results.
Prerequisites: Computer Science 457.
Computer Science 535 H(3-2T)
Introduction to Image Analysis and Computer Vision
Standard methods used in the analysis of digital images. Image acquisition and display: visual perception; digital representation. Sampling and enhancement. Feature extraction and classification methods. Object recognition.
Prerequisites: One of Mathematics 311, 331, 353, Applied Mathematics 307, 311, or Pure Mathematics 331, or consent of the Department.
Computer Science 550 F(2-1T-3)
Systems Administration
Topics and practices in systems administration and management. Required and optional administration duties and responsibilities. Moral and ethical conundrums, and legal responsibilities, in systems operation. Configuration and installation of operating systems and network and systems services.
Prerequisites: Computer Science 457 and consent of the Department.
Computer Science 557 H(3-1T)
Applied Cryptography and Network Security
Primitives for applied cryptographic applications, including hash functions, pseudorandom number generation, public-key infrastructures; systems and protocols for providing security services including secure email, internet protocol security, and web security; threats to network and computer security and countermeasures including intrusion detection, virus countermeasures, access control and firewalls.
Prerequisites: Pure Mathematics 329 or 321.
Corequisites: Computer Science 441.
Computer Science 559 H(3-2T)
Introduction to Distributed Systems
Essential issues in modern distributed systems. Network topologies, communication schemes and distributed system structures. Distributed file systems and distributed coordination problems. Open systems architectures and dejure/default standard methodologies will be discussed, and reliability and system performance issues will also be introduced.
Prerequisites: Computer Science 457.
Computer Science 561 H(3-2T)
Introduction to Distributed Algorithms
Basic problems in distributed systems such as symmetry breaking, consensus, resource allocation, and synchronization. The impact of system characteristics, such as models of communication, timing and failure, and of solution requirements, such as correctness and complexity criteria and algorithmic constraints, on the computability and complexity of these problems. Techniques for solving problems under different models will be emphasized.
Prerequisites: Computer Science 413.
Computer Science 565 H(3-1T)
Emergent Computing
An insight into a new mindset for programming as an emergent and evolutionary process of "breeding," rather than constructing. Programs can evolve to perform specific tasks in a bottom-up fashion rather than being manually coded. Topics will include: decentralized agent-based programming, massive parallelism and interaction, evolution, swarm intelligence.
Prerequisites: Computer Science 433 or 533.
Note: Offered in even-odd dated academic years.
Computer Science 567 H(3-1T)
Foundations of Multi-Agent Systems
Modelling of agents and properties of multi-agent systems. Communication issues, including interaction and coordination concepts, forming and maintaining organizations, and competitive agent environments. Example systems; the implementation of a multi-agent system will be performed as the assignment.
Prerequisites: Computer Science 457 and one of 433 or 533.
Note: Offered in odd-even dated academic years.
Computer Science 571 H(3-2T)
Design and Implementation of Database Systems
Implementation and design of modern database systems including query modification/optimization, recovery, concurrency, integrity, and distribution.
Prerequisites: Computer Science 461 and 471.
Computer Science 581 H(3-2)
Human-Computer Interaction II
Interaction Design. Advanced topics and applications in human computer interaction, with emphasis on developing skills for designing highly interactive human-computer interfaces.
Prerequisites: Computer Science 481 and consent of the Department.
Computer Science 585 H(3-2)
Games Programming
Standard techniques for the implementation of computer games. Standard multimedia programming environments and high performance multimedia. Special purpose rendering engines. Interactive control and feedback; modelling.
Prerequisites: Computer Science 453 and consent of the Department.
Computer Science 587 H(3-2T)
Fundamentals of Computer Animation
Principles of traditional animation, key framing, parametric and track animation, free form deformation, inverse kinematics, dynamics, spring mass systems, particle systems, numerical integration, Lagrangian constraints, space time constraints, collisions, human animation, behavioural animation, metamorphosis, implicit animation techniques, animating liquids, gases and cloth, motion capture.
Prerequisites: Computer Science 453.
Computer Science 589 H(3-2T)
Modelling for Computer Graphics
Parametric Modelling. B-splines and NURBS. Subdivision schemes. Surface subdivision. Multiresolution. Wavelets. Implicit modelling. Blends. Polygonization. Blobtree. Precise contact modelling. Solid modelling. CSG. Procedural modelling. Special topics, e.g. Differential geometry. Graph based modelling. Topology.
Prerequisites: Computer Science 453.
Computer Science 591 H(3-2T)
Rendering
Physical foundations of illuminations techniques. Color. Radiometry and photometry. Reflection models. The rendering equation. Ray tracing. Monte Carlo techniques. Sampling and antialiasing. Texturing. Radiosity. Photon tracing. Volume rendering. Image-based rendering. Real-time shading.
Prerequisites: Computer Science 453.
Computer Science 594 F(1-5)
Software Engineering Project
A software engineering project conducted under the guidance of a faculty member.
Prerequisites: Consent of the Department.
Note: Includes a research, writing and presentation component.
Computer Science 599 H(3-0)
Special Topics in Computer Science
New areas in Computer Science. This course will be offered only as required. Before registration consult the Head of the Department of Computer Science for topics offered.
Prerequisites: Consent of the Department.
MAY BE REPEATED FOR CREDIT
Graduate Courses
Note: Registration in all courses requires the approval of the Department of Computer Science. Computer Science students should also see courses listed under Software Engineering.
Computer Science 601 H(3-0)
Special Topics in Computer Science
A study of problems of particular interest to graduate students in Computer Science.
MAY BE REPEATED FOR CREDIT
Computer Science 605 H(3-0)
(Medical Science 605)
Information Storage and Processing in Biological Systems
Examination of complex biological systems; concepts and fundamentals of biological solutions to information storage and processing; modelling and computer simulation of biological systems; information storage in biological molecules; genetic networks; hierarchical organization of biological information processing in signal transduction, development, evolution, and ecology; biological control systems.
Computer Science 607 H(3-0)
Biological Computation
Examination and modelling of biological networks; focus on the latest developments in biological computing and their theoretical backgrounds, such as: DNA computing; genomic algorithms; artificial chemistries; complex adaptive systems, chaos and fractals; immune system computing; gene regulatory networks; swarm intelligence systems.
Computer Science 609 H(3-0)
Foundations of Multi-Agent Systems
Modelling of agents and properties of multi-agent systems. Communication issues, including interaction and coordination concepts, forming and maintaining organizations, and competitive agent environments. Example systems; the implementation of a multi-agent system will be performed as the assignment.
Note: Lectures may run concurrently with Computer Science 567.
Computer Science 611 H(3-0)
Complexity Theory
Deterministic and non-deterministic time and space complexity; complexity classes and hierarchies; NP-complete problems and intractable problems; axiomatic complexity theory.
Note: Lectures may run concurrently with Computer Science 511.
Note: Computer Science 413 is recommended as preparation for this course.
Computer Science 613 H(3-0)
Program Specification, Proof and Transformation
Program proving techniques; approaches to partial and total correctness. Operational abstraction and data abstraction. Mechanical transformation of programs. Machine assisted proof.
Note: Computer Science 515 is recommended as preparation for this course.
Computer Science 617 H(3-0)
Category Theory for Computer Science
Introduction to category theory with applications in computer science. Functors, natural transformations, adjoints and monads, initial and final algebras. Introduction to 2-categories and fibrations.
Note: Computer Science 513 or 515 is recommended as preparation for this course.
Computer Science 619 H(3-0)
Quantum Computation
Quantum information, quantum algorithms including Shor's quantum factoring algorithm and Grover's quantum searching technique, quantum error correcting codes, quantum cryptography, nonlocality and quantum communication complexity, and quantum computational complexity.
Note: Lectures may run concurrently with Computer Science 519.
Computer Science 635 H(3-0)
Image Analysis and Computer Vision
Standard methods used in the analysis of digital images. Image acquisition and display: visual perception; digital representation. Sampling and enhancement. Feature extraction and classification methods. Object recognition.
Note: Lectures may run concurrently with Computer Science 535.
Computer Science 641 H(3-0)
Performance Issues in High Speed Networks
An overview of current research in high speed networks. Topics covered will include the current Internet, the future Internet, wireless networks, optical networks, Asynchronous Transfer Mode (ATM), TCP/IP, network traffic measurement, Web server performance, and mobile computing. Emphasis will be placed on network performance issues for next-generation Internet protocols and applications.
Computer Science 653 H(3-0)
Computational Geometry
Geometric searching, hull proximity and intersection data structures and algorithms and their complexity.
Note: Computer Science 415 or 517 is recommended as preparation for this course.
Computer Science 657 H(3-0)
Modelling And Visualization of Plants
Modelling, simulation and visualization of plants for computer graphics and biological purposes. Modelling of plants as an example of interdisciplinary research including computer science, biology, mathematics and physics. L-systems as a formal basis for model construction. Modelling languages. Information flow in plants. Symmetry, self-similarity and allometry of plants. Descriptive models of plant architecture. Models integrating plant structure and function. Simulation of plant development. Case studies: competition for space, phyllotaxis, tropisms, and biomechanical considerations. Reaction-diffusion models of morphogensis. Genotype-to-phenotype mapping. Modelling of plant ecosystems. Rendering and visualization of the models. A survey of applications and research directions.
Note: Computer Science 453 or 553 is recommended as preparation for computer science students taking this course.
Computer Science 661 H(3-0)
Algorithms for Distributed Computation
Basic problems in distributed systems such as symmetry breaking, consensus, resource allocation, and synchronization. The impact of system characteristics, such as models of communication, timing and failure, and of solution requirements, such as correctness and complexity criteria and algorithmic constraints, on the computability and complexity of these problems. Techniques for solving problems under different models will be emphasized.
Note: Lectures may run concurrently with Computer Science 561.
Note: Computer Science 413 is recommended as preparation for this course.
Computer Science 663 H(3-0)
Design and Analysis of Parallel Algorithms
Models of parallel computation; measures of efficiency for parallel algorithms. Efficient parallel algorithms for the classical computational problems: selection, merging, sorting, and expression evaluation. Emphasis is on common techniques and recurrent subproblems. Inherently sequential problems; P-completeness.
Note: Computer Science 413 is recommended as preparation for this course.
Computer Science 667 H(3-0)
Computer Algebra
Fundamental problems, classical and modern algorithms, and algorithm design and analysis techniques of use in computer algebra. Integer and polynomial arithmetic. Additional problems in computer algebra, possibly including problems in computational linear algebra, factorization, and concerning systems of polynomial equations will be considered as time permits.
Note: Lectures may run concurrently with Computer Science 518.
Note: Computer Science 413, 491 and Pure Mathematics 431 are recommended as preparation for this course.
Computer Science 669 H(3-0)
(Pure Mathematics 669)
Cryptography
An introduction to the fundamentals of cryptographic systems, with emphasis on attaining well-defined notions of security. Public-key cryptosystems; examples, semantic security. One-way and trapdoor functions; hard-core predicates of functions; applications to the design of cryptosystems.
Prerequisites: Consent of the Department.
Note: Computer Science 413 and Mathematics 321 are recommended as preparation for this course.
Computer Science 673 H(3-0)
Distributed Database Systems
Introduction to distributed database systems. Topics covered include: architecture, data design, query processing, transaction management, multidatabases, object-oriented databases and advanced system issues.
Computer Science 675 H(3-0)
Datawarehouse Systems
Design, development and deployment of datawarehouses. Schemas, models, data organization, OLAP, tuning, data mining and architectural models may be discussed.
Computer Science 681 H(3-0)
Research Methods in Human-Computer Interaction
Application of the theory and methodology of human-machine studies to real systems; theory and practice.
Note: Computer Science 481 is recommended as preparation for this course.
Computer Science 683 H(3-0)
Information Visualization
The theory and development of interactive visual representations of abstract data for the purpose of amplifying cognition. Topics covered can include representational issues, perceptual issues, visual literacy, spatial abstraction, and interaction issues.
Computer Science 687 H(3-0)
Computer Animation
Principles of traditional animation, key framing, parametric and track animation, free form deformation, inverse kinematics, dynamics, spring mass systems, particle systems, numerical integration, Lagrangian constraints, space time constraints, collisions, human animation, behavioural animation, metamorphosis, implicit animation techniques, animating liquids, gases and cloth, motion capture.
Note: Lectures may run concurrently with Computer Science 587.
Computer Science 689 H(3-0)
Modelling for Computer Graphics
Parametric Modelling. B-splines and NURBS. Subdivision schemes. Surface subdivision. Multiresolution. Wavelets. Implicit modelling. Blends. Polygonization. Blobtree. Precise contact modelling. Solid modelling. CSG. Procedural modelling. Special topics, e.g. Differential geometry. Graph based modelling. Topology.
Note: Lectures may run concurrently with Computer Science 589.
Computer Science 691 H(3-0)
Rendering
Physical foundations of illuminations techniques. Color. Radiometry and photometry. Reflection models. The rendering equation. Ray tracing. Monte Carlo techniques. Sampling and antialiasing. Texturing. Radiosity. Photon tracing. Volume rendering. Image-based rendering. Real-time shading.
Note: Lectures may run concurrently with Computer Science 591.
Computer Science 695 H(3-0)
Geometric Algorithms in Geographical Information Systems and Applied Sciences
Examination of advanced geometric algorithms for representation, analysis, and visualization of Geographical Information Systems. Data structures such as progressive mesh, ROAM, multidimensional Delauney triangulization, quadtree and space partitioning. Basic techniques such as incremental, divide and conquer, sweep-plane, and dimension reduction. Algorithms for surface simplification, culling, quality measurement and error reduction. Applications in computer modelling, graphics, motion planning, visualization, and other areas.
Computer Science 699 H(3-0)
Research Methodology in Computer Science
An introduction to and survey of research areas and methods in Computer Science. Professional skills in computer science research such as reviewing, critical evaluation, and the preparation of research proposals.
Note: This course meets for one and one-half hours per week during the Fall and Winter Sessions.
NOT INCLUDED IN GPA
Computer Science 701 H(3-0)
Research Topics in Computer Science
In depth course on a focused current research topic in Computer Science. Involves a significant research component and requires substantial background knowledge.
MAY BE REPEATED FOR CREDIT
Computer Science 767 H(3-0)
Advanced Topics in Multiagent Systems
An in-depth study of a selected subfield of multiagent systems including state-of-the-art research. This is a project-driven course.
Prerequisites: Computer Science 567 or 609.
Computer Science 771 H(3-0)
Current Trends in Database Technology
Advanced topics chosen from Bioinformatics, Data mining, Mobile Databases, Spatial Databases and Web Databases. There is a large project component.
Computer Science 781 H(3-0)
Advanced Topics in Human-Computer Interaction
The topics covered will change year by year depending on current advances in human computer interaction.
Prerequisites: Computer Science 481.
Note: Computer Science 581 or 681 or equivalent is highly recommended before taking this course.
Computer Science 785 H(3-0)
Implicit Modelling
A detailed look at modelling using implicit and iso-surface techniques taking an in depth review of the literature. Algebraic methods will be followed by skeletal models, field function design, modelling techniques, rendering and texture mapping. Polygonisation algorithms, ray tracing implicits, techniques for animation, meta-morphosis, precise contact modelling, deformation and warping. Algorithms and data structures and implementation details will be presented. Students will be expected to make a new contribution in their project and term paper.

