NOTE: This listing represents our current plan for the semester in question. Course offerings and class times are occasionally subject to change for reasons beyond our control.
Course: CSE 003-110
Course Title: Intro to Programming, Part A
Credit Hours: 2
Primary Instructor: Chen, Brian
Enrollment Capacity: 60
Meeting Desc: Class FLEX
Days: MW
Time: 0920-1035
Part of Term: First Half Term
Long Text: Introduction to programming fundamentals & problem-solving using the Java language. Covers the first half of CSE 007 concepts, including data types, control flow, introduction to methods, arrays and a breadth of computing. No prior programming experience is needed. Cannot be taken by students who have completed CSE 007.
Course: CSE 003-111
Course Title: Intro to Programming, Part A
Credit Hours: 2
Primary Instructor: Chen, Brian
Enrollment Capacity: 5
Meeting Desc: Class FLEX
Time: TBD
Part of Term: First Half Term
Special Approval: Department or Instructor
Long Text: Introduction to programming fundamentals & problem-solving using the Java language. Covers the first half of CSE 007 concepts, including data types, control flow, introduction to methods, arrays and a breadth of computing. No prior programming experience is needed. Cannot be taken by students who have completed CSE 007.
Course: CSE 003-112
Course Title: Intro to Programming, Part A
Primary Instructor: Sturdivant, Elroy
Enrollment Capacity: 16
Recitation Days: F
Recitation Time: 1335-1425
Part of Term: First Half Term
Long Text: Introduction to programming fundamentals & problem-solving using the Java language. Covers the first half of CSE 007 concepts, including data types, control flow, introduction to methods, arrays and a breadth of computing. No prior programming experience is needed. Cannot be taken by students who have completed CSE 007.
Course: CSE 003-113
Course Title: Intro to Programming, Part A
Primary Instructor: Sturdivant, Elroy
Enrollment Capacity: 16
Recitation Days: W
Recitation Time: 1335-1425
Part of Term: First Half Term
Long Text: Introduction to programming fundamentals & problem-solving using the Java language. Covers the first half of CSE 007 concepts, including data types, control flow, introduction to methods, arrays and a breadth of computing. No prior programming experience is needed. Cannot be taken by students who have completed CSE 007.
Course: CSE 003-114
Course Title: Intro to Programming, Part A
Primary Instructor: Sturdivant, Elroy
Enrollment Capacity: 17
Recitation Days: F
Recitation Time: 0920-1010
Part of Term: First Half Term
Long Text: Introduction to programming fundamentals & problem-solving using the Java language. Covers the first half of CSE 007 concepts, including data types, control flow, introduction to methods, arrays and a breadth of computing. No prior programming experience is needed. Cannot be taken by students who have completed CSE 007.
Course: CSE 003-115
Course Title: Intro to Programming, Part A
Primary Instructor: Sturdivant, Elroy
Enrollment Capacity: 16
Recitation Days: F
Recitation Time: 1045-1135
Part of Term: First Half Term
Long Text: Introduction to programming fundamentals & problem-solving using the Java language. Covers the first half of CSE 007 concepts, including data types, control flow, introduction to methods, arrays and a breadth of computing. No prior programming experience is needed. Cannot be taken by students who have completed CSE 007.
Course: CSE 004-110
Course Title: Intro to Programming, Part B
Credit Hours: 2
Primary Instructor: Chen, Brian
Enrollment Capacity: 60
Meeting Desc: Class FLEX
Days: MW
Time: 0920-1035
Part of Term: Second Half Term
Long Text: Introduction to problem-solving and object-oriented programming (OOP) using the Java language. Covers the second half of CSE 007 concepts, including methods, arrays (including searching & sorting), basics of OOP including data encapsulation, inheritance and polymorphism and a breadth of computing. Cannot be taken by students who have completed CSE 007. Prerequisites: CSE 003
Course: CSE 004-111
Course Title: Intro to Programming, Part B
Credit Hours: 2
Primary Instructor: Chen, Brian
Enrollment Capacity: 5
Meeting Desc: Class FLEX
Time: TBD
Part of Term: Second Half Term
Special Approval: Department or Instructor
Long Text: Introduction to problem-solving and object-oriented programming (OOP) using the Java language. Covers the second half of CSE 007 concepts, including methods, arrays (including searching & sorting), basics of OOP including data encapsulation, inheritance and polymorphism and a breadth of computing. Cannot be taken by students who have completed CSE 007. Prerequisites: CSE 003
Course: CSE 004-112
Course Title: Intro to Programming, Part B
Primary Instructor: Sturdivant, Elroy
Enrollment Capacity: 16
Recitation Days: F
Recitation Time: 1335-1425
Part of Term: Second Half Term
Long Text: Introduction to problem-solving and object-oriented programming (OOP) using the Java language. Covers the second half of CSE 007 concepts, including methods, arrays (including searching & sorting), basics of OOP including data encapsulation, inheritance and polymorphism and a breadth of computing. Cannot be taken by students who have completed CSE 007. Prerequisites: CSE 003
Course: CSE 004-113
Course Title: Intro to Programming, Part B
Primary Instructor: Sturdivant, Elroy
Enrollment Capacity: 16
Recitation Days: W
Recitation Time: 1335-1425
Part of Term: Second Half Term
Long Text: Introduction to problem-solving and object-oriented programming (OOP) using the Java language. Covers the second half of CSE 007 concepts, including methods, arrays (including searching & sorting), basics of OOP including data encapsulation, inheritance and polymorphism and a breadth of computing. Cannot be taken by students who have completed CSE 007. Prerequisites: CSE 003
Course: CSE 004-114
Course Title: Intro to Programming, Part B
Primary Instructor: Sturdivant, Elroy
Enrollment Capacity: 17
Recitation Days: F
Recitation Time: 0920-1010
Part of Term: Second Half Term
Long Text: Introduction to problem-solving and object-oriented programming (OOP) using the Java language. Covers the second half of CSE 007 concepts, including methods, arrays (including searching & sorting), basics of OOP including data encapsulation, inheritance and polymorphism and a breadth of computing. Cannot be taken by students who have completed CSE 007. Prerequisites: CSE 003
Course: CSE 004-115
Course Title: Intro to Programming, Part B
Primary Instructor: Sturdivant, Elroy
Enrollment Capacity: 16
Recitation Days: F
Recitation Time: 1045-1135
Part of Term: Second Half Term
Long Text: Introduction to problem-solving and object-oriented programming (OOP) using the Java language. Covers the second half of CSE 007 concepts, including methods, arrays (including searching & sorting), basics of OOP including data encapsulation, inheritance and polymorphism and a breadth of computing. Cannot be taken by students who have completed CSE 007. Prerequisites: CSE 003
Course: CSE 007-110
Course Title: Introduction to Programming
Credit Hours: 4
Primary Instructor: Chen, Brian
Enrollment Capacity: 170
Meeting Desc: Class FLEX
Days: MW
Time: 0920-1035
Part of Term: Full Term
Long Text: Introduction to problem-solving and object-oriented programming (OOP) using the Java language. Covers data types, control flow, methods, arrays (including searching & sorting), basics of OOP including data encapsulation, inheritance and polymorphism and a breadth of computing. If credit is given for CSE 007 then no credit will be given for CSE 003 nor CSE 004.
Course: CSE 007-111
Course Title: Introduction to Programming
Credit Hours: 4
Primary Instructor: Chen, Brian
Enrollment Capacity: 20
Meeting Desc: Class FLEX
Time: TBD
Part of Term: Full Term
Special Approval: Department or Instructor
Long Text: Introduction to problem-solving and object-oriented programming (OOP) using the Java language. Covers data types, control flow, methods, arrays (including searching & sorting), basics of OOP including data encapsulation, inheritance and polymorphism and a breadth of computing. If credit is given for CSE 007 then no credit will be given for CSE 003 nor CSE 004.
Course: CSE 007-112
Course Title: Introduction to Programming
Primary Instructor: Sturdivant, Elroy
Enrollment Capacity: 45
Recitation Days: F
Recitation Time: 1335-1425
Part of Term: Full Term
Long Text: Introduction to problem-solving and object-oriented programming (OOP) using the Java language. Covers data types, control flow, methods, arrays (including searching & sorting), basics of OOP including data encapsulation, inheritance and polymorphism and a breadth of computing. If credit is given for CSE 007 then no credit will be given for CSE 003 nor CSE 004.
Course: CSE 007-113
Course Title: Introduction to Programming
Primary Instructor: Sturdivant, Elroy
Enrollment Capacity: 45
Recitation Days: W
Recitation Time: 1335-1425
Part of Term: Full Term
Long Text: Introduction to problem-solving and object-oriented programming (OOP) using the Java language. Covers data types, control flow, methods, arrays (including searching & sorting), basics of OOP including data encapsulation, inheritance and polymorphism and a breadth of computing. If credit is given for CSE 007 then no credit will be given for CSE 003 nor CSE 004.
Course: CSE 007-114
Course Title: Introduction to Programming
Primary Instructor: Sturdivant, Elroy
Enrollment Capacity: 50
Recitation Days: F
Recitation Time: 0920-1010
Part of Term: Full Term
Long Text: Introduction to problem-solving and object-oriented programming (OOP) using the Java language. Covers data types, control flow, methods, arrays (including searching & sorting), basics of OOP including data encapsulation, inheritance and polymorphism and a breadth of computing. If credit is given for CSE 007 then no credit will be given for CSE 003 nor CSE 004.
Course: CSE 007-115
Course Title: Introduction to Programming
Primary Instructor: Sturdivant, Elroy
Enrollment Capacity: 50
Recitation Days: F
Recitation Time: 1045-1135
Part of Term: Full Term
Long Text: Introduction to problem-solving and object-oriented programming (OOP) using the Java language. Covers data types, control flow, methods, arrays (including searching & sorting), basics of OOP including data encapsulation, inheritance and polymorphism and a breadth of computing. If credit is given for CSE 007 then no credit will be given for CSE 003 nor CSE 004.
Course: CSE 012-010
Course Title: Intro to Python
Credit Hours: 3
Primary Instructor: Staff, Teaching
Enrollment Capacity: 45
Meeting Desc: Class On-Campus Only
Days: MW
Time: 1915-2030
Part of Term: Full Term
Long Text: Fundamental concepts of computing and "computational thinking": problem analysis, abstraction, algorithms, digital representation of information, and networks. Concepts of software development using the Python language. This course will not be considered as a CSE technical elective for CS majors.
Course: CSE 012-011
Course Title: Intro to Python
Credit Hours: 3
Primary Instructor: Staff, Teaching
Enrollment Capacity: 40
Meeting Desc: Class On-Campus Only
Days: MW
Time: 0755-0910
Part of Term: Full Term
Long Text: Fundamental concepts of computing and "computational thinking": problem analysis, abstraction, algorithms, digital representation of information, and networks. Concepts of software development using the Python language. This course will not be considered as a CSE technical elective for CS majors.
Course: CSE 017-110
Course Title: Programming & Data Structures
Credit Hours: 3
Primary Instructor: Oudghiri, Houria
Enrollment Capacity: 150
Meeting Desc: Class FLEX
Days: MW
Time: 0920-1010
Part of Term: Full Term
Long Text: Design and implementation of algorithms and data structures using Java. Assumes that students have prior experience using conditional statements, loops, arrays, and object-oriented programming in Java. Algorithmic techniques such as recursion, algorithm analysis, and sorting. Design and implementation of data structures such as lists, queues, stacks, trees, and hash tables. Prerequisites: CSE 004 or CSE 007
Course: CSE 017-111
Course Title: Programming & Data Structures
Credit Hours: 3
Primary Instructor: Oudghiri, Houria
Enrollment Capacity: 10
Meeting Desc: Class FLEX
Time: TBD
Part of Term: Full Term
Special Approval: Department or Instructor
Long Text: Design and implementation of algorithms and data structures using Java. Assumes that students have prior experience using conditional statements, loops, arrays, and object-oriented programming in Java. Algorithmic techniques such as recursion, algorithm analysis, and sorting. Design and implementation of data structures such as lists, queues, stacks, trees, and hash tables. Prerequisites: CSE 004 or CSE 007
Course: CSE 017-112
Course Title: Programming & Data Structures
Primary Instructor: Tan, Jialiang
Enrollment Capacity: 40
Recitation Days: W
Recitation Time: 1500-1615
Part of Term: Full Term
Long Text: Design and implementation of algorithms and data structures using Java. Assumes that students have prior experience using conditional statements, loops, arrays, and object-oriented programming in Java. Algorithmic techniques such as recursion, algorithm analysis, and sorting. Design and implementation of data structures such as lists, queues, stacks, trees, and hash tables. Prerequisites: CSE 004 or CSE 007
Course: CSE 017-113
Course Title: Programming & Data Structures
Primary Instructor: Oudghiri, Houria
Enrollment Capacity: 40
Recitation Days: R
Recitation Time: 1045-1200
Part of Term: Full Term
Long Text: Design and implementation of algorithms and data structures using Java. Assumes that students have prior experience using conditional statements, loops, arrays, and object-oriented programming in Java. Algorithmic techniques such as recursion, algorithm analysis, and sorting. Design and implementation of data structures such as lists, queues, stacks, trees, and hash tables. Prerequisites: CSE 004 or CSE 007
Course: CSE 017-114
Course Title: Programming & Data Structures
Primary Instructor: Tan, Jialiang
Enrollment Capacity: 40
Recitation Days: R
Recitation Time: 1335-1450
Part of Term: Full Term
Long Text: Design and implementation of algorithms and data structures using Java. Assumes that students have prior experience using conditional statements, loops, arrays, and object-oriented programming in Java. Algorithmic techniques such as recursion, algorithm analysis, and sorting. Design and implementation of data structures such as lists, queues, stacks, trees, and hash tables. Prerequisites: CSE 004 or CSE 007
Course: CSE 017-115
Course Title: Programming & Data Structures
Primary Instructor: Tan, Jialiang
Enrollment Capacity: 40
Recitation Days: R
Recitation Time: 1500-1615
Part of Term: Full Term
Long Text: Design and implementation of algorithms and data structures using Java. Assumes that students have prior experience using conditional statements, loops, arrays, and object-oriented programming in Java. Algorithmic techniques such as recursion, algorithm analysis, and sorting. Design and implementation of data structures such as lists, queues, stacks, trees, and hash tables. Prerequisites: CSE 004 or CSE 007
Course: CSE 090-010
Course Title: Big Questions Seminar
Credit Hours: 3
Primary Instructor: Sommer, Ariel
Enrollment Capacity: 18
Meeting Desc: Class On-Campus Only
Days: TR
Time: 1500-1615
Part of Term: Full Term
Long Text: In the past few years, quantum computing has advanced rapidly, with quantum computers beginning to perform tasks that lie beyond the reach of classical supercomputers. Future applications of quantum computing cover a wide range of areas, including molecular simulation, financial modeling, and breaking cryptographic codes. How might quantum computing impact science, business, and international relations in the next few decades? In this seminar, students will study the basics of quantum information and computation, run quantum algorithms on quantum computers, and investigate the applications and potential impacts of quantum computing. No prior knowledge of quantum mechanics is required.
Course: CSE 098-010
Course Title: Success in CS
Credit Hours: 1
Primary Instructor: Erle, Mark
Enrollment Capacity: 35
Meeting Desc: Class On-Campus Only
Days: F
Time: 1045-1200
Part of Term: Full Term
Long Text: Intended for students likely to major or minor in a computer-related discipline. Provides a solid foundation in computing principles and systems, introduces software engineering tools and strategies, teaches effective learning habits, and positions students to succeed in navigating the challenges of a rigorous academic program.
Course: CSE 109-110
Course Title: Systems Software
Credit Hours: 4
Primary Instructor: Pearl, Kallie
Enrollment Capacity: 55
Meeting Desc: Class On-Campus Only
Days: MW
Time: 1335-1450
Part of Term: Full Term
Long Text: Design and implementation of modular programs interacting with the operating system through system calls and programming interfaces using the C programming language. Topics covered include data representation and storage, data and bit manipulation, memory management, stages of compilation, file I/O, interprocess communication, network programming, programmatic testing, interactive debugging, and error handling. Good programming practices, including security, and practical methods for implementing medium-scale programs are also emphasized. Prerequisites: CSE 017
Course: CSE 109-110
Course Title: Systems Software
Credit Hours: 4
Primary Instructor: Pearl, Kallie
Enrollment Capacity: 55
Meeting Desc: Common Hour Exam
Days: W
Time: 1625-1740
Part of Term: Full Term
Long Text: Design and implementation of modular programs interacting with the operating system through system calls and programming interfaces using the C programming language. Topics covered include data representation and storage, data and bit manipulation, memory management, stages of compilation, file I/O, interprocess communication, network programming, programmatic testing, interactive debugging, and error handling. Good programming practices, including security, and practical methods for implementing medium-scale programs are also emphasized. Prerequisites: CSE 017
Course: CSE 109-110
Course Title: Systems Software
Credit Hours: 4
Primary Instructor: Pearl, Kallie
Enrollment Capacity: 55
Meeting Desc: Common Hour Exam
Days: W
Time: 1625-1740
Part of Term: Full Term
Long Text: Design and implementation of modular programs interacting with the operating system through system calls and programming interfaces using the C programming language. Topics covered include data representation and storage, data and bit manipulation, memory management, stages of compilation, file I/O, interprocess communication, network programming, programmatic testing, interactive debugging, and error handling. Good programming practices, including security, and practical methods for implementing medium-scale programs are also emphasized. Prerequisites: CSE 017
Course: CSE 109-111
Course Title: Systems Software
Credit Hours: 4
Primary Instructor: Li, Mushu
Enrollment Capacity: 55
Meeting Desc: Class On-Campus Only
Days: TR
Time: 1045-1200
Part of Term: Full Term
Long Text: Design and implementation of modular programs interacting with the operating system through system calls and programming interfaces using the C programming language. Topics covered include data representation and storage, data and bit manipulation, memory management, stages of compilation, file I/O, interprocess communication, network programming, programmatic testing, interactive debugging, and error handling. Good programming practices, including security, and practical methods for implementing medium-scale programs are also emphasized. Prerequisites: CSE 017
Course: CSE 109-111
Course Title: Systems Software
Credit Hours: 4
Primary Instructor: Li, Mushu
Enrollment Capacity: 55
Meeting Desc: Common Hour Exam
Days: W
Time: 1625-1740
Part of Term: Full Term
Long Text: Design and implementation of modular programs interacting with the operating system through system calls and programming interfaces using the C programming language. Topics covered include data representation and storage, data and bit manipulation, memory management, stages of compilation, file I/O, interprocess communication, network programming, programmatic testing, interactive debugging, and error handling. Good programming practices, including security, and practical methods for implementing medium-scale programs are also emphasized. Prerequisites: CSE 017
Course: CSE 109-111
Course Title: Systems Software
Credit Hours: 4
Primary Instructor: Li, Mushu
Enrollment Capacity: 55
Meeting Desc: Common Hour Exam
Days: W
Time: 1625-1740
Part of Term: Full Term
Long Text: Design and implementation of modular programs interacting with the operating system through system calls and programming interfaces using the C programming language. Topics covered include data representation and storage, data and bit manipulation, memory management, stages of compilation, file I/O, interprocess communication, network programming, programmatic testing, interactive debugging, and error handling. Good programming practices, including security, and practical methods for implementing medium-scale programs are also emphasized. Prerequisites: CSE 017
Course: CSE 109-113
Course Title: Systems Software
Primary Instructor: Pearl, Kallie
Enrollment Capacity: 55
Recitation Days: R
Recitation Time: 1335-1450
Part of Term: Full Term
Long Text: Design and implementation of modular programs interacting with the operating system through system calls and programming interfaces using the C programming language. Topics covered include data representation and storage, data and bit manipulation, memory management, stages of compilation, file I/O, interprocess communication, network programming, programmatic testing, interactive debugging, and error handling. Good programming practices, including security, and practical methods for implementing medium-scale programs are also emphasized. Prerequisites: CSE 017
Course: CSE 109-114
Course Title: Systems Software
Primary Instructor: Li, Mushu
Enrollment Capacity: 55
Recitation Days: F
Recitation Time: 1045-1200
Part of Term: Full Term
Long Text: Design and implementation of modular programs interacting with the operating system through system calls and programming interfaces using the C programming language. Topics covered include data representation and storage, data and bit manipulation, memory management, stages of compilation, file I/O, interprocess communication, network programming, programmatic testing, interactive debugging, and error handling. Good programming practices, including security, and practical methods for implementing medium-scale programs are also emphasized. Prerequisites: CSE 017
Course: CSE 140-110
Course Title: Found Discrete Struct & Algor
Credit Hours: 3
Primary Instructor: Yang, Yu
Enrollment Capacity: 60
Meeting Desc: Class On-Campus Only
Days: TR
Time: 1045-1200
Part of Term: Full Term
Long Text: Basic representations used in algorithms: propositional and predicate logic, set operations and functions, relations and their representations, matrices and their representations, graphs and their representations, trees and their representations. Basic formalizations for proving algorithm correctness: logical consequences, induction, structural induction. Basic formalizations for algorithm analysis: counting, pigeonhole principle, permutations. Credit will not be given for both CSE 140 and MATH 261. Prerequisites: (MATH 021 or MATH 031 or MATH 051 or MATH 076) and CSE 017 Can be taken Concurrently: CSE 017
Course: CSE 140-110
Course Title: Found Discrete Struct & Algor
Credit Hours: 3
Primary Instructor: Yang, Yu
Enrollment Capacity: 60
Meeting Desc: Common Hour Exam
Days: T
Time: 1625-1740
Part of Term: Full Term
Long Text: Basic representations used in algorithms: propositional and predicate logic, set operations and functions, relations and their representations, matrices and their representations, graphs and their representations, trees and their representations. Basic formalizations for proving algorithm correctness: logical consequences, induction, structural induction. Basic formalizations for algorithm analysis: counting, pigeonhole principle, permutations. Credit will not be given for both CSE 140 and MATH 261. Prerequisites: (MATH 021 or MATH 031 or MATH 051 or MATH 076) and CSE 017 Can be taken Concurrently: CSE 017
Course: CSE 140-110
Course Title: Found Discrete Struct & Algor
Credit Hours: 3
Primary Instructor: Yang, Yu
Enrollment Capacity: 60
Meeting Desc: Common Hour Exam
Days: M
Time: 1625-1740
Part of Term: Full Term
Long Text: Basic representations used in algorithms: propositional and predicate logic, set operations and functions, relations and their representations, matrices and their representations, graphs and their representations, trees and their representations. Basic formalizations for proving algorithm correctness: logical consequences, induction, structural induction. Basic formalizations for algorithm analysis: counting, pigeonhole principle, permutations. Credit will not be given for both CSE 140 and MATH 261. Prerequisites: (MATH 021 or MATH 031 or MATH 051 or MATH 076) and CSE 017 Can be taken Concurrently: CSE 017
Course: CSE 140-111
Course Title: Found Discrete Struct & Algor
Credit Hours: 3
Primary Instructor: Yari, Masoud
Enrollment Capacity: 60
Meeting Desc: Class On-Campus Only
Days: TR
Time: 1500-1615
Part of Term: Full Term
Long Text: Basic representations used in algorithms: propositional and predicate logic, set operations and functions, relations and their representations, matrices and their representations, graphs and their representations, trees and their representations. Basic formalizations for proving algorithm correctness: logical consequences, induction, structural induction. Basic formalizations for algorithm analysis: counting, pigeonhole principle, permutations. Credit will not be given for both CSE 140 and MATH 261. Prerequisites: (MATH 021 or MATH 031 or MATH 051 or MATH 076) and CSE 017 Can be taken Concurrently: CSE 017
Course: CSE 140-111
Course Title: Found Discrete Struct & Algor
Credit Hours: 3
Primary Instructor: Yari, Masoud
Enrollment Capacity: 60
Meeting Desc: Common Hour Exam
Days: T
Time: 1625-1740
Part of Term: Full Term
Long Text: Basic representations used in algorithms: propositional and predicate logic, set operations and functions, relations and their representations, matrices and their representations, graphs and their representations, trees and their representations. Basic formalizations for proving algorithm correctness: logical consequences, induction, structural induction. Basic formalizations for algorithm analysis: counting, pigeonhole principle, permutations. Credit will not be given for both CSE 140 and MATH 261. Prerequisites: (MATH 021 or MATH 031 or MATH 051 or MATH 076) and CSE 017 Can be taken Concurrently: CSE 017
Course: CSE 140-111
Course Title: Found Discrete Struct & Algor
Credit Hours: 3
Primary Instructor: Yari, Masoud
Enrollment Capacity: 60
Meeting Desc: Common Hour Exam
Days: M
Time: 1625-1740
Part of Term: Full Term
Long Text: Basic representations used in algorithms: propositional and predicate logic, set operations and functions, relations and their representations, matrices and their representations, graphs and their representations, trees and their representations. Basic formalizations for proving algorithm correctness: logical consequences, induction, structural induction. Basic formalizations for algorithm analysis: counting, pigeonhole principle, permutations. Credit will not be given for both CSE 140 and MATH 261. Prerequisites: (MATH 021 or MATH 031 or MATH 051 or MATH 076) and CSE 017 Can be taken Concurrently: CSE 017
Course: CSE 140-112
Course Title: Found Discrete Struct & Algor
Primary Instructor: Yang, Yu
Enrollment Capacity: 60
Recitation Days: F
Recitation Time: 0920-1035
Part of Term: Full Term
Long Text: Basic representations used in algorithms: propositional and predicate logic, set operations and functions, relations and their representations, matrices and their representations, graphs and their representations, trees and their representations. Basic formalizations for proving algorithm correctness: logical consequences, induction, structural induction. Basic formalizations for algorithm analysis: counting, pigeonhole principle, permutations. Credit will not be given for both CSE 140 and MATH 261. Prerequisites: (MATH 021 or MATH 031 or MATH 051 or MATH 076) and CSE 017 Can be taken Concurrently: CSE 017
Course: CSE 140-113
Course Title: Found Discrete Struct & Algor
Primary Instructor: Yari, Masoud
Enrollment Capacity: 60
Recitation Days: F
Recitation Time: 1335-1450
Part of Term: Full Term
Long Text: Basic representations used in algorithms: propositional and predicate logic, set operations and functions, relations and their representations, matrices and their representations, graphs and their representations, trees and their representations. Basic formalizations for proving algorithm correctness: logical consequences, induction, structural induction. Basic formalizations for algorithm analysis: counting, pigeonhole principle, permutations. Credit will not be given for both CSE 140 and MATH 261. Prerequisites: (MATH 021 or MATH 031 or MATH 051 or MATH 076) and CSE 017 Can be taken Concurrently: CSE 017
Course: CSE 160-010
Course Title: Introduction to Data Science
Credit Hours: 3
Primary Instructor: Bharati, Aparna
Enrollment Capacity: 65
Meeting Desc: Class FLEX
Days: MW
Time: 1045-1135
Part of Term: Full Term
Long Text: Data Science is a fast-growing interdisciplinary field, focusing on the computational analysis of data to extract knowledge and insight. Collection, preparation, analysis, modeling, and visualization of data, covering both conceptual and practical issues. Examples from diverse fields and hands-on use of statistical and data manipulation software. Prerequisites: CSE 004 or CSE 007 or CSE 012 or BIS 335
Course: CSE 160-011
Course Title: Introduction to Data Science
Credit Hours: 3
Primary Instructor: Bharati, Aparna
Enrollment Capacity: 5
Meeting Desc: Class FLEX
Time: TBD
Part of Term: Full Term
Special Approval: Department or Instructor
Long Text: Data Science is a fast-growing interdisciplinary field, focusing on the computational analysis of data to extract knowledge and insight. Collection, preparation, analysis, modeling, and visualization of data, covering both conceptual and practical issues. Examples from diverse fields and hands-on use of statistical and data manipulation software. Prerequisites: CSE 004 or CSE 007 or CSE 012 or BIS 335
Course: CSE 160-060
Course Title: Introduction to Data Science
Primary Instructor: Bharati, Aparna
Enrollment Capacity: 35
Part of Term: Full Term
Long Text: Data Science is a fast-growing interdisciplinary field, focusing on the computational analysis of data to extract knowledge and insight. Collection, preparation, analysis, modeling, and visualization of data, covering both conceptual and practical issues. Examples from diverse fields and hands-on use of statistical and data manipulation software. Prerequisites: CSE 004 or CSE 007 or CSE 012 or BIS 335
Course: CSE 160-061
Course Title: Introduction to Data Science
Primary Instructor: Bharati, Aparna
Enrollment Capacity: 35
Part of Term: Full Term
Long Text: Data Science is a fast-growing interdisciplinary field, focusing on the computational analysis of data to extract knowledge and insight. Collection, preparation, analysis, modeling, and visualization of data, covering both conceptual and practical issues. Examples from diverse fields and hands-on use of statistical and data manipulation software. Prerequisites: CSE 004 or CSE 007 or CSE 012 or BIS 335
Course: CSE 202-110
Course Title: Comp Organization Architecture
Credit Hours: 3
Primary Instructor: Tan, Jialiang
Enrollment Capacity: 80
Meeting Desc: Class FLEX
Days: MW
Time: 1335-1450
Part of Term: Full Term
Long Text: Interaction between low-level computer architectural properties and high-level program behaviors: instruction set design; digital logic and assembly language; processor organization; the memory hierarchy; multicore and GPU architectures; and processor interrupt/exception models. Credit will not be given for both CSE 201 and CSE 202. Prerequisites: CSE 017
Course: CSE 202-111
Course Title: Comp Organization Architecture
Credit Hours: 3
Primary Instructor: Tan, Jialiang
Enrollment Capacity: 10
Meeting Desc: Class FLEX
Time: TBD
Part of Term: Full Term
Long Text: Interaction between low-level computer architectural properties and high-level program behaviors: instruction set design; digital logic and assembly language; processor organization; the memory hierarchy; multicore and GPU architectures; and processor interrupt/exception models. Credit will not be given for both CSE 201 and CSE 202. Prerequisites: CSE 017
Course: CSE 202-112
Course Title: Comp Organization Architecture
Primary Instructor: Tan, Jialiang
Enrollment Capacity: 45
Recitation Days: R
Recitation Time: 0920-1035
Part of Term: Full Term
Long Text: Interaction between low-level computer architectural properties and high-level program behaviors: instruction set design; digital logic and assembly language; processor organization; the memory hierarchy; multicore and GPU architectures; and processor interrupt/exception models. Credit will not be given for both CSE 201 and CSE 202. Prerequisites: CSE 017
Course: CSE 202-113
Course Title: Comp Organization Architecture
Primary Instructor: Tan, Jialiang
Enrollment Capacity: 45
Recitation Days: R
Recitation Time: 1045-1200
Part of Term: Full Term
Long Text: Interaction between low-level computer architectural properties and high-level program behaviors: instruction set design; digital logic and assembly language; processor organization; the memory hierarchy; multicore and GPU architectures; and processor interrupt/exception models. Credit will not be given for both CSE 201 and CSE 202. Prerequisites: CSE 017
Course: CSE 216-110
Course Title: Software Engineering
Credit Hours: 3
Primary Instructor: Sturdivant, Elroy
Enrollment Capacity: 120
Meeting Desc: Class FLEX
Days: MW
Time: 1500-1550
Part of Term: Full Term
Long Text: The software lifecycle; lifecycle models; software planning; testing; specification methods; maintenance. Emphasis on team work and large-scale software systems, including oral presentations and written reports. Prerequisites: CSE 017
Course: CSE 216-111
Course Title: Software Engineering
Credit Hours: 3
Primary Instructor: Sturdivant, Elroy
Enrollment Capacity: 5
Meeting Desc: Class FLEX
Time: TBD
Part of Term: Full Term
Special Approval: Department or Instructor
Long Text: The software lifecycle; lifecycle models; software planning; testing; specification methods; maintenance. Emphasis on team work and large-scale software systems, including oral presentations and written reports. Prerequisites: CSE 017
Course: CSE 216-112
Course Title: Software Engineering
Primary Instructor: Sturdivant, Elroy
Enrollment Capacity: 60
Recitation Days: M
Recitation Time: 1915-2155
Part of Term: Full Term
Long Text: The software lifecycle; lifecycle models; software planning; testing; specification methods; maintenance. Emphasis on team work and large-scale software systems, including oral presentations and written reports. Prerequisites: CSE 017
Course: CSE 216-113
Course Title: Software Engineering
Primary Instructor: Sturdivant, Elroy
Enrollment Capacity: 65
Recitation Days: T
Recitation Time: 1915-2155
Part of Term: Full Term
Long Text: The software lifecycle; lifecycle models; software planning; testing; specification methods; maintenance. Emphasis on team work and large-scale software systems, including oral presentations and written reports. Prerequisites: CSE 017
Course: CSE 217-010
Course Title: Computer Science Projects
Credit Hours: 3
Primary Instructor: Erle, Mark
Enrollment Capacity: 20
Meeting Desc: Class On-Campus Only
Days: TR
Time: 1500-1615
Part of Term: Full Term
Long Text: Project-based learning through independent or small-group projects related to computer systems and/or applications. Students will progress through the software development lifecycle, including high-level design, functional and non-functional requirements, implementation, testing, and maintenance. One large group meeting per week, where students serve as consultants to each other as they present their progress. Prerequisites: CSE 216
Course: CSE 241-110
Course Title: Data Base Systems & Apps
Credit Hours: 3
Primary Instructor: Palmieri, Roberto
Enrollment Capacity: 115
Meeting Desc: Class On-Campus Only
Days: TR
Time: 1335-1450
Part of Term: Full Term
Long Text: Design of large databases: Integration of databases and applications using SQL and JDBC; transaction processing; performance tuning; data mining and data warehouses. Not available to students who have credit for CSE 341 or ISE 224. Prerequisites: CSE 017
Course: CSE 241-111
Course Title: Data Base Systems & Apps
Primary Instructor: Palmieri, Roberto
Enrollment Capacity: 57
Recitation Days: F
Recitation Time: 1335-1450
Part of Term: Full Term
Long Text: Design of large databases: Integration of databases and applications using SQL and JDBC; transaction processing; performance tuning; data mining and data warehouses. Not available to students who have credit for CSE 341 or ISE 224. Prerequisites: CSE 017
Course: CSE 241-112
Course Title: Data Base Systems & Apps
Primary Instructor: Palmieri, Roberto
Enrollment Capacity: 58
Recitation Days: F
Recitation Time: 1500-1615
Part of Term: Full Term
Long Text: Design of large databases: Integration of databases and applications using SQL and JDBC; transaction processing; performance tuning; data mining and data warehouses. Not available to students who have credit for CSE 341 or ISE 224. Prerequisites: CSE 017
Course: CSE 242-010
Course Title: Blockchain Algs. and Systems
Credit Hours: 3
Primary Instructor: Korth, Hank
Enrollment Capacity: 25
Meeting Desc: Class On-Campus Only
Days: MW
Time: 1045-1200
Part of Term: Full Term
Long Text: Blockchain system concepts, data structures, and algorithms. Cryptographic algorithms for blockchain security. Distributed consensus algorithms for decentralized control in both a public and permissioned blockchain setting. Smart contracts. Cross-chain transactions. Blockchain databases and enterprise blockchains. Prerequisites: CSE 109 or CSE 241 or CSE 341 Can be taken Concurrently: CSE 109
Course: CSE 252-010
Course Title: Computing Ethics
Credit Hours: 3
Primary Instructor: Pearl, Kallie
Enrollment Capacity: 35
Meeting Desc: Class On-Campus Only
Days: MW
Time: 1045-1200
Part of Term: Full Term
Long Text: An interactive exploration that provides students with concepts and frameworks to reason about ethical and social issues related with computing. Topics may include: privacy, corporate responsibility, the changing nature of work, language technologies, professional ethics, autonomous systems, online political communication, fairness and bias, environmental impacts, legal regulation, political economy, and other relevant technologies, concepts, issues.
Course: CSE 252-011
Course Title: Computing Ethics
Credit Hours: 3
Primary Instructor: Staff, Teaching
Enrollment Capacity: 35
Meeting Desc: Class On-Campus Only
Days: TR
Time: 1045-1200
Part of Term: Full Term
Long Text: An interactive exploration that provides students with concepts and frameworks to reason about ethical and social issues related with computing. Topics may include: privacy, corporate responsibility, the changing nature of work, language technologies, professional ethics, autonomous systems, online political communication, fairness and bias, environmental impacts, legal regulation, political economy, and other relevant technologies, concepts, issues.
Course: CSE 252-012
Course Title: Computing Ethics
Credit Hours: 3
Primary Instructor: Staff, Teaching
Enrollment Capacity: 35
Meeting Desc: Class On-Campus Only
Days: TR
Time: 1210-1325
Part of Term: Full Term
Long Text: An interactive exploration that provides students with concepts and frameworks to reason about ethical and social issues related with computing. Topics may include: privacy, corporate responsibility, the changing nature of work, language technologies, professional ethics, autonomous systems, online political communication, fairness and bias, environmental impacts, legal regulation, political economy, and other relevant technologies, concepts, issues.
Course: CSE 262-110
Course Title: Programming Languages
Credit Hours: 3
Primary Instructor: Spear, Michael
Enrollment Capacity: 90
Meeting Desc: Class On-Campus Only
Days: MW
Time: 1045-1200
Part of Term: Full Term
Long Text: Use, structure and implementation of several programming languages. Prerequisites: CSE 017
Course: CSE 264-010
Course Title: Web Systems Programming
Credit Hours: 3
Primary Instructor: Onimus, Matthew
Enrollment Capacity: 75
Meeting Desc: Class On-Campus Only
Days: MW
Time: 1500-1615
Part of Term: Full Term
Long Text: Practical experience in designing and implementing modern Web applications. Concepts, tools, and techniques, including: HTTP, HTML, CSS, DOM, JavaScript, Ajax, PHP, graphic design principles, mobile web development. Not available to students who have credit for IE 275. Prerequisites: CSE 017
Course: CSE 265-010
Course Title: System & Network Admin
Credit Hours: 3
Primary Instructor: Creswell, Christopher
Enrollment Capacity: 30
Meeting Desc: Class On-Campus Only
Days: TR
Time: 1210-1325
Part of Term: Full Term
Long Text: Overview of systems and network administration in a networked UNIX-like environment. System installation, configuration, administration, and maintenance; security principles; ethics; network, host, and user management; standard services such as electronic mail, DNS, and WWW; file systems; backups and disaster recovery planning; troubleshooting and support services; automation, scripting; infrastructure planning. Prerequisites: CSE 017
Course: CSE 265-060
Course Title: System & Network Admin
Primary Instructor: Creswell, Christopher
Enrollment Capacity: 30
Part of Term: Full Term
Long Text: Overview of systems and network administration in a networked UNIX-like environment. System installation, configuration, administration, and maintenance; security principles; ethics; network, host, and user management; standard services such as electronic mail, DNS, and WWW; file systems; backups and disaster recovery planning; troubleshooting and support services; automation, scripting; infrastructure planning. Prerequisites: CSE 017
Course: CSE 271-010
Course Title: Prog. in Linux & Windows
Credit Hours: 3
Primary Instructor: Erle, Mark
Enrollment Capacity: 35
Meeting Desc: Class On-Campus Only
Days: TR
Time: 0920-1035
Part of Term: Full Term
Long Text: Students learn Linux and Windows operating system fundamentals, including features, history, organization, process management, and file systems. Tools commonly available with these operating systems, such as those for program development, text processing, scheduling jobs, and communications, are also explored. Emphasis is placed on learning the BASh and PowerShell scripting languages, and students should expect to work on a variety of small programming assignments. Prerequisites: CSE 017
Course: CSE 281-010
Course Title: Capstone Project II
Credit Hours: 3
Primary Instructor: Witmer, George
Enrollment Capacity: 90
Meeting Desc: Class On-Campus Only
Days: TR
Time: 1500-1615
Part of Term: Full Term
Long Text: Second of a two semester capstone course sequence that involves the design, implementation, and evaluation of a computer science software project; conducted by small student teams working from project definition to final documentation; each student team has a CSE faculty member serving as its advisor; The second semester emphasis is on project implementation, verification & validation, and documentation requirements. It culminates in a public presentation and live demonstration to external judges as well as CSE faculty and students. Prerequisites: CSE 280
Course: CSE 300-010
Course Title: Apprentice Teaching
Credit Hours: 1 to 4
Primary Instructor: Staff, Teaching
Enrollment Capacity: 5
Meeting Desc: Arranged by studnt w/ instruct
Time: TBD
Part of Term: Full Term
Special Approval: DE
Long Text: Practical teaching experience under supervision of an experienced instructor. Students learn fundamentals of teaching, including course and lecture planning, instructional delivery, classroom environment and management, and assessment. Students will benefit from significant hands-on experience in the lectures, recitations, and office hours. Department approval is required.
Course: CSE 303-010
Course Title: Operating System Design
Credit Hours: 3
Primary Instructor: Oudghiri, Houria
Enrollment Capacity: 135
Meeting Desc: Class On-Campus Only
Days: MW
Time: 1335-1450
Part of Term: Full Term
Long Text: Process and thread programming models, management, and scheduling. Resource sharing and deadlocks. Memory management, including virtual memory and page replacement strategies. I/O issues in the operating system. File system implementation. Multiprocessing. Computer security as it impacts the operating system. Prerequisites: ECE 201 or (CSE 201 or CSE 202) and CSE 109
Course: CSE 318-010
Course Title: Intro To Theory Of Computation
Credit Hours: 3
Primary Instructor: Femister, James
Enrollment Capacity: 32
Meeting Desc: Class On-Campus Only
Days: TR
Time: 1210-1325
Part of Term: Full Term
Long Text: Provides a deep understanding of computation, its capabilities and its limitations. The course uses discrete formal methods to (1) formulate precise definitions of three kinds of finite-state machines (finite automata, pushdown automata, and Turing machines); (2) prove properties of these machines by studying their expressiveness (i.e., the kinds of problems that can be solved with these machines), and (3) study computational problems that cannot be solved with algorithms. Prerequisites: CSE 140
Course: CSE 320-010
Course Title: Biomedical Image Computing
Credit Hours: 3
Primary Instructor: He, Lifang
Enrollment Capacity: 25
Meeting Desc: Class On-Campus Only
Days: TR
Time: 1405-1520
Part of Term: Full Term
Long Text: Biomedical image modalities, image computing techniques, and imaging informatics systems. Understanding, using, and developing algorithms and software to analyze biomedical image data and extract useful quantitative information: Biomedical image modalities and formats; image processing and analysis; geometric and statistical modeling; image informatics systems in biomedicine. Credit will not be given for both CSE 320 and CSE 420. Prerequisites: (MATH 205 or MATH 043) and CSE 017
Course: CSE 326-010
Course Title: Machine Learning
Credit Hours: 3
Primary Instructor: Sun, Lichao
Enrollment Capacity: 50
Meeting Desc: Class On-Campus Only
Days: TR
Time: 0920-1035
Part of Term: Full Term
Long Text: Bayesian decision theory and the design of parametric and nonparametric classification and regression: linear, quadratic, nearest-neighbors, neural nets. Boosting, bagging. Credit will not be given for both CSE 326 and CSE 426. Prerequisites: CSE 017 and (MATH 205 or MATH 043) and (MATH 231 or ISE 121 or ECO 045)
Course: CSE 337-010
Course Title: Reinforcement Learning
Credit Hours: 3
Primary Instructor: Saldana, David
Enrollment Capacity: 30
Meeting Desc: Class On-Campus Only
Days: F
Time: 0950-1230
Part of Term: Full Term
Long Text: Algorithms for automated learning from interactions with the environment to optimize long-term performance. Markov decision processes, dynamic programming, temporal-difference learning, Monte Carlo reinforcement learning methods. Credit will not be given for both CSE 337 and CSE 437. Prerequisites: (MATH 231, ECO 045) and CSE 109
Course: CSE 340-110
Course Title: Design&Analysis Of Algorithms
Credit Hours: 3
Primary Instructor: Yari, Masoud
Enrollment Capacity: 60
Meeting Desc: Class On-Campus Only
Days: TR
Time: 1335-1450
Part of Term: Full Term
Long Text: Algorithms for searching, sorting, manipulating graphs and trees, finding shortest paths and minimum spanning trees, scheduling tasks, etc.: proofs of their correctness and analysis of their asymptotic runtime and memory demands. Designing algorithms: recursion, divide-and-conquer, greediness, dynamic programming. Limits on algorithm efficiency using elementary NP-completeness theory. Prerequisites: (MATH 021 or MATH 031 or MATH 076) and CSE 140 and CSE 017
Course: CSE 340-111
Course Title: Design&Analysis Of Algorithms
Credit Hours: 3
Primary Instructor: Sun, Lichao
Enrollment Capacity: 60
Meeting Desc: Class On-Campus Only
Days: TR
Time: 1045-1200
Part of Term: Full Term
Long Text: Algorithms for searching, sorting, manipulating graphs and trees, finding shortest paths and minimum spanning trees, scheduling tasks, etc.: proofs of their correctness and analysis of their asymptotic runtime and memory demands. Designing algorithms: recursion, divide-and-conquer, greediness, dynamic programming. Limits on algorithm efficiency using elementary NP-completeness theory. Prerequisites: (MATH 021 or MATH 031 or MATH 076) and CSE 140 and CSE 017
Course: CSE 342-010
Course Title: Fund Of Internetworking
Credit Hours: 3
Primary Instructor: Sollog, Munroe
Enrollment Capacity: 35
Meeting Desc: Class On-Campus Only
Days: MW
Time: 1210-1325
Part of Term: Full Term
Long Text: Architecture and protocols of computer networks. Protocol layers; network topology; data-communication principles, including circuit switching, packet switching and error control techniques; sliding window protocols, protocol analysis and verification; routing and flow control; local and wide area networks; network interconnection; client-server interaction; emerging networking trends and technologies; topics in security and privacy. Prerequisites: CSE 109
Course: CSE 348-010
Course Title: Ai Game Programming
Credit Hours: 3
Primary Instructor: Urban, Stephen
Enrollment Capacity: 32
Meeting Desc: Class On-Campus Only
Days: TR
Time: 1335-1450
Part of Term: Full Term
Long Text: Contemporary computer games: techniques for implementing the program controlling the computer component; using Artificial Intelligence in contemporary computer games to enhance the gaming experience: pathfinding and navigation systems; group movement and tactics; adaptive games, game genres, machine scripting language for game designers, and player modeling. Credit will not be given for both CSE 348 and CSE 448. Prerequisites: CSE 327 or CSE 109
Course: CSE 349-010
Course Title: Big Data Analytics
Credit Hours: 3
Primary Instructor: Lopresti, Daniel
Enrollment Capacity: 30
Meeting Desc: Class FLEX
Days: MW
Time: 1405-1520
Part of Term: Full Term
Special Approval: Department or Instructor
Long Text: Provides working knowledge of large-scale data analysis using open source frameworks such as Apache Spark and Waikato Environment for Knowledge Analysis (Weka). Includes patterns employed in big data analytics, including classification, collaborative filtering, recommender systems, natural language processing, simulation, deep learning, and anomaly detection. Project-oriented software course; students should have substantial programming experience in one or more high-level languages. Past experience in data mining and/or machine learning expected. Credit will not be given for both 349 and 449. Prerequisites: CSE 109 and (CSE 326 or CSE 347) Department Permission is required.
Course: CSE 349-011
Course Title: Big Data Analytics
Credit Hours: 3
Primary Instructor: Lopresti, Daniel
Enrollment Capacity: 30
Meeting Desc: Class FLEX
Days: MW
Time: 1405-1520
Part of Term: Full Term
Special Approval: Department or Instructor
Long Text: Provides working knowledge of large-scale data analysis using open source frameworks such as Apache Spark and Waikato Environment for Knowledge Analysis (Weka). Includes patterns employed in big data analytics, including classification, collaborative filtering, recommender systems, natural language processing, simulation, deep learning, and anomaly detection. Project-oriented software course; students should have substantial programming experience in one or more high-level languages. Past experience in data mining and/or machine learning expected. Credit will not be given for both 349 and 449. Prerequisites: CSE 109 and (CSE 326 or CSE 347) Department Permission is required.
Course: CSE 367-010
Course Title: Blockchain Projects
Credit Hours: 3
Primary Instructor: Korth, Hank
Enrollment Capacity: 12
Meeting Desc: Class On-Campus Only
Days: F
Time: 1045-1200
Part of Term: Full Term
Special Approval: Department or Instructor
Long Text: Independent or small-group unique projects related to blockchain systems and/or applications. While pursuing their own project, students serve as consultants to the other teams via a once-weekly class meeting in which each team presents updates on status, progress, and open problems, and one student gives a longer prepared presentation on current research or development results in the blockchain field. Each project team has its own separate second weekly meeting with the instructor for a more in-depth project review and discussion. Repeat Status: Course may be repeated. Prerequisites: CSE 242
Course: CSE 371-010
Course Title: Principles of Mobile Computing
Credit Hours: 3
Primary Instructor: Chuah, Mooi Choo
Enrollment Capacity: 19
Meeting Desc: Class On-Campus Only
Days: MW
Time: 0920-1035
Part of Term: Full Term
Long Text: Fundamental concepts and technology underlying mobile computing. Current research in these areas. Examples drawn from a variety of application domains such as health monitoring, energy management, commerce, and travel. Issues of system efficiency will be studied, including efficient handling of large data such as images and effective use of cloud storage. Recent research papers will be discussed. Credit will not be given for both CSE371 and CSE471. Prerequisites: (CSE 109 and (CSE 202 or ECE 201)
Course: CSE 375-010
Course Title: Prin & Prac In Parallel Comp
Credit Hours: 3
Primary Instructor: Hassan, Ahmed
Enrollment Capacity: 30
Meeting Desc: Class On-Campus Only
Days: MW
Time: 1500-1615
Part of Term: Full Term
Long Text: Parallel computer architectures, parallel languages, parallelizing compilers and operating systems. Design, implementation, and analysis of parallel algorithms for scientific and data-intensive computing. Credit is not given for both CSE 375 and CSE 475. Prerequisites: (ECE 201 or CSE 201) or CSE 303 or CSE 202 Can be taken Concurrently: ECE 201, CSE 201, CSE 303, CSE 202
Course: CSE 398-012
Course Title: Scientific Machine Learning
Credit Hours: 3
Primary Instructor: Rahnemoonfar, Maryam
Enrollment Capacity: 30
Meeting Desc: Class On-Campus Only
Days: TR
Time: 1405-1520
Part of Term: Full Term
Long Text: Scientific Machine Learning is a seminar course focused on solving scientific problems using advanced machine learning algorithms. It explores techniques such as physics-informed neural networks (PINNs), neural operators, digital twins, and foundation models like VLMs for scientific discovery. Prerequisites: CSE 330/430 Deep Learning, CSE 398/498 Deep and Generative Models or CSE 426 Fundamentals of Machine Learning
Course: CSE 398-046
Course Title: Knowledge Representation
Credit Hours: 3
Primary Instructor: Heflin, Jeff
Enrollment Capacity: 30
Meeting Desc: Class On-Campus Only
Days: TR
Time: 1115-1230
Part of Term: Full Term
Long Text: Knowledge representation and reasoning (KR&R) is the subfield of artificial intelligence (AI) that concerns how to represent general information about the world, and how to determine the consequences of this information. One known weakness of deep learning models is lack of explainability; generally, knowledge representation models do not suffer from this problem. In this class we will explore the fundamentals of KR&R by examining many different formalisms and automated reasoning procedures. We will then use this basis to discuss the role of KR&R in modern systems: Why are many technology companies investing in knowledge graphs? When should knowledge representation be preferred to machine learning? Can knowledge representation be combined with machine learning when we have some degree of background knowledge regarding our problem? Can machine learning be used to make automated reasoning more efficient? Students will leave this class with a broader perspective of AI. Prerequisite: CSE 327
Course: CSE 398-062
Course Title: Theory of Social Computing
Credit Hours: 3
Primary Instructor: DiFranzo, Dominic
Enrollment Capacity: 30
Meeting Desc: Class On-Campus Only
Days: TR
Time: 0950-1105
Part of Term: Full Term
Long Text: The class is an introduction to the purpose and use of theory in social computing research. It will also act as a survey of many of the theoretical foundations of social computing possibly including but not limited to Feminist and Critical theory, Social Capital, Social Identity Perspective, Social Identity Theory, Uses and Gratifications Theory, Social Learning Theory, Priming,and others. Prerequisite is CSE 252.
Course: CSE 406-010
Course Title: Research Methods
Credit Hours: 3
Primary Instructor: Lopresti, Daniel
Enrollment Capacity: 19
Meeting Desc: Arranged by studnt w/ instruct
Days: MW
Time: TBD
Part of Term: Full Term
Long Text: Technical writing, reading the literature critically, analyzing and presenting data, conducting research, making effective presentations, and understanding social and ethical responsibilities. Topics drawn from probability and statistics, use of scripting languages, and conducting large-scale experiments. Must have first-year status in either the CS or CompE Ph. D. program.
Course: CSE 411-010
Course Title: Adv Programming Techniques
Credit Hours: 3
Primary Instructor: Montella, Corey
Enrollment Capacity: 35
Meeting Desc: Class On-Campus Only
Days: MW
Time: 1115-1230
Part of Term: Full Term
Long Text: Deeper study of programming and software engineering techniques. The majority of assignments involve programming in contemporary programming languages. Topics include memory management, GUI design, testing, refactoring, and writing secure code.
Course: CSE 412-010
Course Title: Intro to Python
Credit Hours: 3
Primary Instructor: Staff, Teaching
Enrollment Capacity: 10
Meeting Desc: Class On-Campus Only
Days: MW
Time: 1915-2030
Part of Term: Full Term
Long Text: Fundamental concepts of computing and "computational thinking": problem analysis, abstraction, algorithms, digital representation of information, and networks. Concepts of software development using the Python language. This course cannot be used toward a computer science undergraduate or graduate degree.
Course: CSE 418-010
Course Title: Theory of Computation
Credit Hours: 3
Primary Instructor: Femister, James
Enrollment Capacity: 10
Meeting Desc: Class On-Campus Only
Days: TR
Time: 1210-1325
Part of Term: Full Term
Long Text: Finite automata. Pushdown automata. Relationship to definition and parsing of formal grammars. Credit may be given for only one of the following: CSE318 and CSE409 and CSE418.
Course: CSE 420-010
Course Title: Biomedical Image Computing
Credit Hours: 3
Primary Instructor: He, Lifang
Enrollment Capacity: 25
Meeting Desc: Class On-Campus Only
Days: TR
Time: 1405-1520
Part of Term: Full Term
Long Text: Biomedical image modalities, image computing techniques, and imaging informatics systems. Understanding, using, and developing algorithms and software to analyze biomedical image data and extract useful quantitative information: Biomedical image modalities and formats; image processing and analysis; geometric and statistical modeling; image informatics systems in biomedicine. This course, a graduate version of BIOE 320, requires additional advanced assignments. Credit will not be given for both BIOE 320 and BIOE 420. Prerequisites: MATH 205 and CSE 109
Course: CSE 426-010
Course Title: Machine Learning
Credit Hours: 3
Primary Instructor: Sun, Lichao
Enrollment Capacity: 50
Meeting Desc: Class On-Campus Only
Days: TR
Time: 0920-1035
Part of Term: Full Term
Long Text: Bayesian decision theory and the design of parametric and nonparametric classification and regression: linear, quadratic, nearest-neighbors, neural nets. Boosting, bagging. This course, a version of CSE 326 for graduate students requires advanced assignments. Credit will not be given for both CSE 326 and CSE 426.
Course: CSE 437-010
Course Title: Reinfrcmntlearn&Markovdecision
Credit Hours: 3
Primary Instructor: Saldana, David
Enrollment Capacity: 15
Meeting Desc: Class On-Campus Only
Days: F
Time: 0950-1230
Part of Term: Full Term
Long Text: Formal model based on Markov decision processes for automated learning from interactions with stochastic, incompletely known environments. Markov decision processes, dynamic programming, temporal-difference learning, Monte Carlo reinforcement learning methods. Credit will not be given for both CSE 337 and CSE 437. Must have graduate standing in Computer Science or have consent of instructor.
Course: CSE 442-010
Course Title: Adv. Blockchain Systems&Theory
Credit Hours: 3
Primary Instructor: Korth, Hank
Enrollment Capacity: 1
Meeting Desc: Class On-Campus Only
Days: MW
Time: 1045-1200
Part of Term: Full Term
Special Approval: IN
Long Text: Formal foundations of blockchain systems: cryptography, consensus, zero-knowledge proofs, transaction processing both on-chain and cross-chain, validation, and governance. Algorithms and data structures for blockchain systems. Programming paradigms for smart contracts. Current research in blockchain drawing from the cryptography, database, operating system, and parallel computing research communities. Prerequisites: CSE 241 or CSE 341 or CSE 303 or CSE 403 or CSE 375 or CSE 475
Course: CSE 449-010
Course Title: Big Data Analytics
Credit Hours: 3
Primary Instructor: Lopresti, Daniel
Enrollment Capacity: 30
Meeting Desc: Class FLEX
Days: MW
Time: 1405-1520
Part of Term: Full Term
Special Approval: Department or Instructor
Long Text: Provides working knowledge of large-scale data analysis using open source frameworks such as Apache Spark and Waikato Environment for Knowledge Analysis (Weka). Includes patterns employed in big data analytics, including classification, collaborative filtering, recommender systems, natural language processing, simulation, deep learning, and anomaly detection. Project-oriented software course; students should have substantial programming experience in one or more high-level languages. Past experience in data mining and/or machine learning expected. Credit will not be given for both 349 and 449. Prerequisites: CSE 109 and (CSE 326 or CSE 347)
Course: CSE 449-011
Course Title: Big Data Analytics
Credit Hours: 3
Primary Instructor: Lopresti, Daniel
Enrollment Capacity: 30
Meeting Desc: Class FLEX
Days: MW
Time: 1405-1520
Part of Term: Full Term
Special Approval: Department or Instructor
Long Text: Provides working knowledge of large-scale data analysis using open source frameworks such as Apache Spark and Waikato Environment for Knowledge Analysis (Weka). Includes patterns employed in big data analytics, including classification, collaborative filtering, recommender systems, natural language processing, simulation, deep learning, and anomaly detection. Project-oriented software course; students should have substantial programming experience in one or more high-level languages. Past experience in data mining and/or machine learning expected. Credit will not be given for both 349 and 449. Prerequisites: CSE 109 and (CSE 326 or CSE 347)
Course: CSE 467-010
Course Title: Blockchain Projects
Credit Hours: 3
Primary Instructor: Korth, Hank
Enrollment Capacity: 12
Meeting Desc: Class On-Campus Only
Days: F
Time: 1045-1200
Part of Term: Full Term
Special Approval: Department or Instructor
Long Text: Independent or small-group graduate-level unique projects related to blockchain-systems and/or applications. While pursuing their own project, students serve as consultants to the other teams via a once-weekly class meeting in which each team presents updates on status, progress, and open problems, and one student gives a longer prepared presentation on current research or development results in the blockchain field. Each project team has its own separate second weekly meeting with the instructor for a more in-depth project review and discussion. Repeat Status: Course may be repeated.
Course: CSE 471-010
Course Title: Principles of Mobile Computing
Credit Hours: 3
Primary Instructor: Chuah, Mooi Choo
Enrollment Capacity: 19
Meeting Desc: Class On-Campus Only
Days: MW
Time: 0920-1035
Part of Term: Full Term
Long Text: Course topics include fundamental concepts and technology underlying mobile computing and current research in these areas. Examples drawn from a variety of application domains such as health monitoring, energy management, commerce, and travel. Issues of system efficiency will be studied, including efficient handling of large data such as images and effective use of cloud storage. Recent research papers will be discussed. The graduate version of CSE 371 requires additional effort. Credit will not be given for both CSE371 and CSE471. Prerequisites: CSE 109 and CSE 202 or CSE 303
Course: CSE 475-010
Course Title: Prin/Prac Parallel Computing
Credit Hours: 3
Primary Instructor: Hassan, Ahmed
Enrollment Capacity: 10
Meeting Desc: Class On-Campus Only
Days: MW
Time: 1500-1615
Part of Term: Full Term
Long Text: Parallel computer architectures, parallel languages, parallelizing compilers and operating systems. Design, implementation, and analysis of parallel algorithms for scientific and data-intensive computing. This is a graduate version of CSE 375. As such, it will require additional assignments. Credit is not given for both CSE 375 and CSE 475.
Course: CSE 498-012
Course Title: Scientific Machine Learning
Credit Hours: 3
Primary Instructor: Rahnemoonfar, Maryam
Enrollment Capacity: 30
Meeting Desc: Class On-Campus Only
Days: TR
Time: 1405-1520
Part of Term: Full Term
Long Text: Scientific Machine Learning is a seminar course focused on solving scientific problems using advanced machine learning algorithms. It explores techniques such as physics-informed neural networks (PINNs), neural operators, digital twins, and foundation models like VLMs for scientific discovery. Prereqs: CSE 330/430 Deep Learning, CSE 398/498 Deep and Generative Models or CSE 426 Fundamentals of Machine Learning
Course: CSE 498-046
Course Title: Knowledge Representation
Credit Hours: 3
Primary Instructor: Heflin, Jeff
Enrollment Capacity: 30
Meeting Desc: Class On-Campus Only
Days: TR
Time: 1115-1230
Part of Term: Full Term
Long Text: Knowledge representation and reasoning (KR&R) is the subfield of artificial intelligence (AI) that concerns how to represent general information about the world, and how to determine the consequences of this information. One known weakness of deep learning models is lack of explainability; generally, knowledge representation models do not suffer from this problem. In this class we will explore the fundamentals of KR&R by examining many different formalisms and automated reasoning procedures. We will then use this basis to discuss the role of KR&R in modern systems: Why are many technology companies investing in knowledge graphs? When should knowledge representation be preferred to machine learning? Can knowledge representation be combined with machine learning when we have some degree of background knowledge regarding our problem? Can machine learning be used to make automated reasoning more efficient? Students will leave this class with a broader perspective of AI and a set of new tools that they can apply to their research. Students will not be given credit for both CSE 398-046 and CSE 498-046.
Course: CSE 498-062
Course Title: Theory of Social Computing
Credit Hours: 3
Primary Instructor: DiFranzo, Dominic
Enrollment Capacity: 30
Meeting Desc: Class On-Campus Only
Days: TR
Time: 0950-1105
Part of Term: Full Term
Long Text: The class is an introduction to the purpose and use of theory in social computing research. It will also act as a survey of many of the theoretical foundations of social computing possibly including but not limited to Feminist and Critical theory, Social Capital, Social Identity Perspective, Social Identity Theory, Uses and Gratifications Theory, Social Learning Theory, Priming,and others.