CSE - Computer Science and Engineering

CSE 3 Computing Technology in a Changing Society

Introduction to computer hardware, software, and networking, with an emphasis on how these technologies impact society. Students learn key technical concepts and terminology and learn to modify and create programming code through making webpages and simple games. Students also gain hands-on experience using emerging technological tools such as 3D printing, laser-cutting, or 3D modeling software in virtual reality headsets. Course covers the history of computing, the early days of the internet, hardware fundamentals, accessibility tools, professional programming practices, open-source software, intellectual property concerns, networking, digital privacy, and cybersecurity. Designed for students with only basic, user-level computer experience. (Formerly offered as Personal Computer Concepts: Software and Hardware.)

Credits

5

General Education Code

PE-T

CSE 5J Introduction to Programming in Java

Introduces programming in Java for students who have no prior programming experience. Students learn programming and documentation skills, as well as algorithmic problem-solving, and programming methodologies. Introduces computers, compilers, and editors. Students write small to medium-sized programs. This course and CSE 5C and CSE 5P cover similar concepts, but use different programming languages. Because CSE 5J followed by CSE 11 is a two-quarter alternative to the accelerated course CSE 12A and CSE 12L, engineering majors and students planning on continuing the programming sequence are encouraged to take CSE 5J rather than CSE 5C or CSE 5P. Students may not receive credit for CSE 5J taken concurrently or subsequently to CSE 12A, CSE 12B, or Computer Engineering 13. (Formerly CMPS 5J.)

Credits

5

General Education Code

MF

CSE 10 Introduction to Computer Science

An overview of the theory, foundations, and practice of computer science with emphasis on what computers can and cannot do, now and in the future. Topics include algorithms and data, correctness and efficiency of algorithms, hardware, programming languages, limitations of computation, applications, and social issues. No programming skills are required as a prerequisite. Major concepts and open problems in computer science are presented without reliance on sophisticated mathematical tools. Students cannot receive credit for this course after completing CSE 15. (Formerly CMPS 10.)

Credits

5

General Education Code

MF

CSE 12 Computer Systems and Assembly Language and Lab

Introduction to computer systems and assembly language and how computers compute in hardware and software. Topics include digital logic, number systems, data structures, compiling/assembly process, basics of the system software, and computer architecture. Course is 7 credits with integrated laboratories illustrating concepts covered in lecture. Note that CSE 12 assumes some programming experience. Students can show programming experience by taking one of the courses listed in the prerequisite list below or by taking the CSE python Test-out Exam: https://undergrad.soe.ucsc.edu/cse-20-testout-exam (Formerly CSE 12 and CSE 12L)

Credits

7

Requirements

Prerequisite(s): CSE 5J, or CSE 20, or CSE 30, or BME 160, or equivalent.

CSE 13S Computer Systems and C Programming

Focuses on C programming, command line, shell programming, editors, debuggers, source code control, and other tools. Examines basic computer systems, algorithm design, and development, data types, and program structures. Develops understanding of process model, compile-link-execute build cycle, language-machine interface, memory, and data representation. Students cannot receive credit for both CSE 13S and CSE 13E. Course is 7 credits with integrated laboratory.

Credits

7

Requirements

Prerequisite(s): CSE 12 or BME 160.

CSE 16 Applied Discrete Mathematics

Introduction to applications of discrete mathematical systems. Topics include sets, functions, relations, graphs, predicate calculus, mathematical proof methods (induction, contraposition, contradiction), counting methods (permutations, combinations), and recurrences. Examples are drawn from computer science and computer engineering. Knowledge of computer programming is useful before taking this course. Students who do not have prior programming experience are strongly recommended to take CSE 20 or CSE 30 before taking this course.

Credits

5

Requirements

Prerequisite(s): MATH 19A or MATH 19B or MATH 11B or AM 11B or AM 15B or ECON 11B.

General Education Code

MF

CSE 20 Beginning Programming in Python

Provides students with Python programming skills and the ability to design programs and read Python code. Topics include data types, control flow, methods and advanced functions, built-in data structures, and introduction to OOP. No prior programming experience is required. Students may not receive credit for CSE 20 after receiving credit for CSE 30. Students with prior programming experience (especially in Python) are encouraged to take CSE Testout Exam to be evaluated for their readiness to take CSE 30 directly: https://undergrad.soe.ucsc.edu/cse-20-testout-exam.

Credits

5

General Education Code

MF

CSE 30 Programming Abstractions: Python

Introduction to software development in Python focusing on structuring software in terms of objects endowed with primitive operations. Introduces concepts and techniques via a sequence of concrete case studies. Coursework consists of programming assignments and a final examination. Note that CSE 30 assumes some Python experience, students trained in a different language should self-study Python to prepare for CSE 30. See CSE Testout Exam for resources and further information.

Credits

7

Requirements

Prerequisite(s): CSE 20 or BME 160; and MATH 3 or MATH 11A or MATH 19A or AM 3 or AM 11A or ECON 11A, or a score of 400 or higher on the mathematics placement examination (MPE).

CSE 40 Machine Learning Basics: Data Analysis and Empirical Methods

Introduction to the basic mathematical concepts and programming abstractions required for modern machine learning, data science, and empirical science. The mathematical foundations include basic probability, linear algebra, and optimization. The programming abstractions include data manipulation and visualization. The principles of empirical analysis, evaluation, critique and reproducibility are emphasized. Mathematical and programming abstractions are grounded in empirical studies including data-driven evidential reasoning, predictive modeling, and causal analysis.

Credits

5

Requirements

Prerequisite(s): MATH 19B or MATH 20B, and CSE 30.

General Education Code

SR

CSE 80A Universal Access: Disability, Technology, and Society

Overview of human-centered technology and of its potential for increasing the quality of life and independence of disabled individuals. A substantial portion of the course is devoted to studying physical, psychological, and psychosocial aspects of disability. Topics include: diversity and integration, legislation, accessibility, and universal design. (Formerly Computer Engineering 80A.)

Credits

5

General Education Code

PE-T

CSE 80L Social Data Analytics and Visualization

Course examines: social data analytics--veracity, consistency, uncertainty, volume; statistical computation--misuse, bias, dispersion, correlation, regressions, differential scales, normal distributions, factor and cluster analysis, extrapolation, inference, simple programming; visual representations--communication, critique and design of infographics; applications--environment, energy, economics, education, empowerment. (Formerly Computer Science 80L.)

Credits

5

General Education Code

SR

CSE 80N Introduction to Networking and the Internet

Introduction to the evolution, technological basis, and services of the Internet, with descriptions of its underlying communications structure, routing algorithms, peer-to-peer hierarchy, reliability, and packet switching. Network security, mail, multimedia and data compression issues, HTML, and digital images. Students who have completed CSE 150 cannot receive credit for this course. (Formerly Computer Engineering 80N.)

Credits

5

General Education Code

PE-T

CSE 80S Social Networks

Introduction to social networks and game theory. Topics include the structure of social networks; the world wide web; the flow of information and behavior through networks; and the principles behind modern web search and search-ad placement. (Formerly Computer Science 17.)

Credits

5

Requirements

Prerequisite(s): MATH 3 or MATH 11A; or AM 3 or AM 6 or AM 11A or AM 15A; or ECON 11A; or score on math placement exam of 300 or higher.

General Education Code

SR

CSE 94 Group Tutorial

Provides a means for a small group of students to study a particular topic in consultation with a faculty sponsor. Students submit petition to sponsoring agency.

Credits

5

Repeatable for credit

Yes

CSE 94F Group Tutorial

Provides a means for a small group of students to study a particular topic in consultation with a faculty sponsor. Students submit petition to sponsoring agency.

Credits

2

Repeatable for credit

Yes

CSE 99 Tutorial

Students submit petition to sponsoring agency.

Credits

5

Repeatable for credit

Yes

CSE 99F Tutorial

Students submit petition to sponsoring agency.

Credits

2

Repeatable for credit

Yes

CSE 100 Logic Design

Boolean algebra, logic minimization, finite-state machine design, sequential circuits, common logic elements, programmable logic devices, and an introduction to system level design. The electrical behavior of circuits including three state outputs, propagation delay, logic levels, and fanout.

Credits

5

Requirements

Prerequisite(s): CSE 12; previous or concurrent enrollment in CSE 100L is required.

CSE 100L Logic Design Laboratory

Laboratory sequence illustrating topics covered in course 100. Two 2-hour laboratory sessions per week. Weekly laboratory assignments which require the use of the oscilloscopes, TTL circuits, computer-aided design and simulation tools, and programmable logic.

Credits

2

Requirements

Prerequisite(s): CSE 12; previous or concurrent enrollment in CSE 100 is required.

CSE 101 Introduction to Data Structures and Algorithms

Introduction to abstract data types and basics of algorithms. Linked lists, stacks, queues, hash tables, trees, heaps, and graphs will be covered. Students will also be taught how to derive big-Oh analysis of simple algorithms. All assignments will be in C/C++. (Formerly Computer Science 101 Algorithms and Abstract Data Types.)

Credits

5

Requirements

Prerequisite(s): CSE 12 or BME 160; CSE 13E or ECE 13 or CSE 13S; and CSE 16; and CSE 30; and MATH 11B or MATH 19B or MATH 20B or AM 11B.

CSE 101M Mathematical Thinking for Computer Science

Introduction to problem-solving and proof techniques for computer science: modeling CS problems using mathematical concepts; solving problems and inventing mathematical arguments; writing rigorous, understandable proofs using LaTeX. Applications in all CS areas with focus on analyzing algorithms, programs, and protocols.

Credits

5

Requirements

Prerequisite(s): CSE 101.

CSE 102 Introduction to Analysis of Algorithms

Methods for the systematic construction and mathematical analysis of algorithms. Order notation, the RAM model of computation, lower bounds, and recurrence relations are covered. The algorithm design techniques include divide-and-conquer, branch and bound, and dynamic programming. Applications to combinatorial, graph, string, and geometric algorithms. (Formerly Computer Science 102.)

Credits

5

Requirements

Prerequisite(s): CSE 101.

CSE 103 Computational Models

Various representations for regular languages, context-free grammars, normal forms, simple parsing, pumping lemmas, Turing machines, the Church-Turing thesis, intractable problems, the P-NP question. (Formerly CMPS 130.)

Credits

5

Requirements

Prerequisite(s): CSE 101.

CSE 104 Computability and Computational Complexity

Turing machines, general phase-structure grammars, the Chomsky hierarchy, recursive functions, diagonalization, the Halting problem, computability and unsolvability, computational complexity, time and space bounds, NP-completeness with emphasis on reductions between problems from various areas. (Formerly CMPS 132.)

Credits

5

Requirements

Prerequisite(s): CSE 103.

CSE 105 Modern Algorithmic Toolbox

Undergraduate course on the modern algorithmic toolbox, meant for undergraduate students with a strong mathematical background. Students need familiarity with discrete math, analysis of algorithms, basic analysis, probability theory, and graph theory. Class is aimed at students who want to learn more about the central ideas and algorithmic techniques that are used in modern data science applications. Class focuses on the theoretical underpinnings of these algorithms as well as their practical applications and implementation details.

Credits

5

Requirements

Prerequisite(s): CSE 102 or equivalent or instructor consent. Students need a solid background in analysis of algorithms, discrete math, probability theory, graph theory, and overall mathematical maturity.

CSE 106 Applied Graph Theory and Algorithms

Basic concepts and algorithms are reviewed including trees, Eulerian and Hamiltonian graphs, and graph transversal. Algorithms are explored to solve problems in connectivity, routing, matching, and embedding of graphs. Graph theory and algorithms are developed around applications in computer engineering. (Formerly Computer Engineering 177.)

Credits

5

Requirements

Prerequisite(s): CSE 101.

CSE 107 Probability and Statistics for Engineers

Introduction to fundamental tools of stochastic analysis. Probability, conditional probability; Bayes Theorem; random variables and transforms; independence; Bernnoulli trials. Statistics, inference from limited data; outcomes of repeated experiments; applications to design; assessment of relative frequency and probability; law of large numbers; precision of measurements. Elements of stochastic processes, Poisson processes; Markov chains. Students cannot receive credit for this course and Applied Mathematics and Statistics 131. (Formerly Computer Engineering 107.)

Credits

5

Requirements

Prerequisite(s): CSE 16; and AM 30 or MATH 22 or MATH 23A.

General Education Code

SR

CSE 108 Algorithmic Foundations of Cryptography

Focuses on some of the foundational aspects of modern cryptography, namely, private and public key cryptography, digital signatures, pseudorandom generators and functions, message authentication codes, hash functions, and random oracles. Course also connects the formal concepts with some real-world applications, like RA, SSL, and bitcoin, exposing students to general concepts of probability theory, number theory, and rigorous proofs. (Formerly Computer Science 118.)

Credits

5

Requirements

Prerequisite(s): CSE 101. Enrollment restricted to computer engineering and computer science majors.

CSE 110A Fundamentals of Compiler Design I

An introduction to the basic techniques used in compiler design. Topics include compiler structure, symbol tables, regular expressions and languages, finite automata, lexical analysis, context-free languages, LL(1), recursive descent, LALR(1), and LR(1) parsing; and attribute grammars as a model of syntax-directed translation. Students use compiler building tools to construct a working compiler. (Formerly Computer Science 104A.)

Credits

5

Requirements

Prerequisite(s): CSE 12 and CSE 101.

CSE 110B Fundamentals of Compiler Design II

Advanced study of compiler implementation. Topics include compiler structure back end, run-time environments, storage management, garbage collection, register allocation, code generation, basic blocks, control flow, data flow, local and global optimization, interpretation, and machine-code generation. Students may not receive credit for this course and CSE 211. Taught in conjunction with CSE 211. (Formerly Computer Science 104B.)

Credits

5

Requirements

Prerequisite(s): CSE 110A.

CSE 111 Advanced Programming

An introduction to object-oriented techniques of software development including data abstraction, inheritance, polymorphism, and object-oriented design. Extensive practice using a computer to solve problems, including construction of graphical user interfaces and a multithreaded client/server applications.

Credits

5

Requirements

Prerequisite(s): CSE 15 and CSE 15L; or CSE 13S and CMPM 35; or CSE 13E and CMPM 35; or ECE 13 and CMPM 35; or CSE 101.

CSE 112 Comparative Programming Languages

Covers several programming languages and compares styles, philosophy, and design principles. Principles underlying declarative, functional, and object-oriented programming styles are studied. Students write programs emphasizing each of these techniques. (Formerly Computer Science 112.)

Credits

5

Requirements

Prerequisite(s): CSE 101.

CSE 113 Parallel and Concurrent Programming

Introduction to parallel and concurrent programming. Topics include: types of parallel computers and programming platforms; design, implementation, and optimization of programs for parallel and multicore processors; basic and advanced programming techniques; performance analysis and load balancing; and selected parallel algorithms.

Credits

5

Requirements

Prerequisite(s): CSE 12 and CSE 101. CSE 120 recommended.

CSE 114A Foundations of Programming Languages

Problem solving emphasizing recursion, data abstraction, and higher-order functions. Introduction to types and type checking, modular programming, and reasoning about program correctness. (Formerly CSE 116, Introduction to Functional Programming.)

Credits

5

Requirements

Prerequisite(s): CSE 101.

CSE 114B Functional Programming

An in-depth study of the functional style of programming and functional abstraction, including the study of applicative functors and monads, and monadic parsers. (Formerly CSE 114.)

Credits

5

Requirements

Prerequisite(s): CSE 114A. Enrollment is restricted to junior and senior computer science majors.

CSE 115A Introduction to Software Engineering

Emphasizes the characteristics of well-engineered software systems. Topics include requirements analysis and specification, design, programming, verification and validation, maintenance, and project management. Practical and research methods are studied. Imparts an understanding of the steps used to effectively develop computer software. (Formerly Computer Science 115.)

Credits

5

Requirements

Prerequisite(s): satisfaction of the Entry Level Writing and Composition requirements and CSE 101 and CSE 130.

CSE 115B Software Design Project

Students in teams specify, design, construct, test, and document a complete software system in a specialized application domain. Class time is spent in technical discussions and ongoing design reviews. A formal presentation and demonstration of each project is required. An organizational meeting will be held during the preceding quarter. Projects may be drawn from industry and campus research groups. (Formerly Computer Science 116.)

Credits

5

Requirements

Prerequisite(s): CSE 115A.

General Education Code

PR-E

CSE 115C Software Design Project II

Continuation of CSE 116. Students work in teams to develop, test, document, and deploy a substantial software project. Teams give a formal presentation and demonstration of each project. (Formerly Computer Science 117.)

Credits

5

Requirements

Prerequisite(s): CSE 115B.

CSE 115D Software Design Project - Accelerated

Accelerated version of CSE 115B and CSE 115C. Students work in teams to develop, test, document and deploy a substantial software project. Each team gives a formal presentation and demonstration of their project. Students cannot receive credit for both CSE 115D and any part of the 115B-115C sequence.

Credits

5

Requirements

Prerequisite(s): CSE 115A.

General Education Code

PR-E

CSE 117 Open Source Programming

Teaches the principles of open source software development. By participating in diverse projects, students experience the process of developing software in a distributed, community-centric environment. Students learn about the tools, processes, and soft skills that are essential in this context.

Credits

5

Requirements

Prerequisite(s): CSE 101; and CSE 102 or CSE 111 or CSE 115A. Enrollment restricted to School of Engineering majors.

CSE 118 Mobile Applications

Introduces the tools and techniques required to develop the sophisticated interactive mobile applications we use daily on our Android and iOS devices. Native (specific to Android or iOS devices) and cross-platform (designed to work on both Android and iOS) development is undertaken with deployment to device emulators and, optionally, personal devices. Ownership of an Android or iOS device is not required and confers no advantage. (Formerly CMPS 121.)

Credits

5

Requirements

Prerequisite(s): CSE 101. Enrollment is restricted to juniors and seniors.

CSE 119 Software for Society

Provides experience with applying computing to social issues. Case studies on multiple issues. For example: privacy, copyright, voting, education, poverty, energy, activism. Team project in which students develop software to address a pre-identified need of a global or local non-profit. (Formerly Computer Science 119.)

Credits

5

Requirements

Prerequisite(s): CSE 101.

General Education Code

PE-T

CSE 120 Computer Architecture

Introduction to computer architecture including examples of current approaches and the effect of technology and software. Computer performance evaluation, basic combinatorial and sequential digital components, different instruction set architectures with a focus on the MIPS ISA and RISC paradigm. Evolution of CPU microarchitecture from single-cycle to multi-cycle pipelines, with overview of super-scalar, multiple-issue and VLIW. Memory system, cache, virtual memory and relationship between memory and performance. Evolution of PC system architecture. May include advanced topics, such as parallel processing, MIMD, and SIMD.

Credits

5

Requirements

Prerequisite(s): CSE 12; and CSE 13E, or CSE 13S, or ECE 13, or CSE 15 and CSE 15L. CSE 16 recommended.

CSE 121 Embedded System Design

The design and use of microprocessor-based embedded systems. Covers microprocessor and microcontroller architecture, programming techniques, bus and memory organization, DMA, timing issues, interrupts, peripheral devices, serial and parallel communication, and interfacing to analog and digital systems. (Formerly Microprocessor System Design, and formerly offered as two courses, CMPE 121 and CMPE 121L.)

Credits

7

Requirements

Prerequisite(s): CSE 12, CSE 100, CSE 100L; and CSE 13E or CSE 13S or ECE 13 or CSE 15 and CSE 15L; and ECE 101, ECE 101L, PHYS 5C and PHYS 5N.

CSE 122 Introduction to VLSI Digital System Design

Introduces very large scale integrated (VLSI) custom integrated circuits. Topics include: semiconductor manufacturing, logic families, field-effect transistors (FETs), interconnect models, simulation, and circuits. Introduces the design flow from logic design to layout with a focus on high performance and low power. Students cannot receive credit for this course and CSE 222A. (Formerly Computer Engineering 122.)

Credits

5

Requirements

Prerequisite(s): CSE 100, CSE 100L, ECE 101, and ECE 101L.

CSE 123A Engineering Design Project I

First of a two-course sequence that is the culmination of the engineering program. Students apply knowledge and skills gained in elective track to complete a major design project. Students complete research, specification, planning, and procurement for a substantial project. Includes technical discussions, design reviews, and formal presentations; engineering design cycle, engineering teams, and professional practices. Formal technical specification of the approved project is presented to faculty.

Credits

5

Requirements

Prerequisite(s): CSE 121; previous or concurrent enrollment in CSE 185E.

General Education Code

PR-E

CSE 123B Engineering Design Project II

Second of two-course sequence in engineering system design. Students fully implement and test system designed and specified in CSE 123A. Formal written report, oral presentation, and demonstration of successful project to review panel of engineering faculty required.

Credits

7

Requirements

Prerequisite(s): CSE 123A, and CSE 185E or CSE 185S.

CSE 125 Logic Design with Verilog

Verilog digital logic design with emphasis on ASIC and FPGA design. Students design and verify large-scale systems. Assignments and project use the Verilog Hardware Description Language with emphasis on verification and high-frequency ASIC/FPGA targets. May be taught in conjunction with CSE 225. Students cannot receive credit for both courses.

Credits

7

Requirements

Prerequisite(s): CSE 100 and CSE 100L and CSE 120.

CSE 129A Capstone Project I

First of a three-course sequence in which students apply knowledge and skills gained in elective track to complete a major design project. In this first course, students complete the specification and planning for a substantial project. Topics covered: engineering design cycle, engineering teams, and professional practices. (Formerly Computer Engineering 129A.)

Credits

2

Requirements

Prerequisite(s): previous or concurrent enrollment in courses CSE 121 and CSE 121L. Enrollment is restricted to bioengineering, biomolecular engineering and bioinformatics, computer engineering, and robotics engineering majors.

CSE 129B Capstone Project II

Second of a three-course sequence in which students apply knowledge and skills gained in elective track to complete a major design project. In this second course, students complete the research and procurement for a substantial project and a preliminary implementation. Prerequisite(s): CSE 121, CSE 121L, and CSE 129A. Previous or concurrent enrollment in CSE 185. Enrollment by permission of instructor.

Credits

5

General Education Code

PR-E

CSE 129C Capstone Project III

Third of a three-course sequence in which students apply knowledge and skills gained in elective track to complete a major design project. In this third course, students work in teams to complete the project specified and advanced in the first two courses. A formal written report, oral presentation, and demonstration of the successful project to a review panel of engineering faculty is required. Prerequisite(s): CSE 129B and CSE 185. Enrollment by permission of instructor.

Credits

5

CSE 130 Principles of Computer Systems Design

Covers the principles governing computer-systems design and complexity; familiarity with memory, storage, and networking; concurrency and synchronization; layering (abstraction and modularity); naming; client-server and virtualized system models; and performance. Requires significant programming projects demonstrating mastery of these concepts.

Credits

5

Requirements

Prerequisite(s): CSE 12; and CSE 101, or CSE 15 and CSE 15L; and knowledge of C programming language.

CSE 132 Computer Security

Introduction to computer security (including selected topics in network security). Access control. Security in programming languages. Basic cryptography. Security protocols. (Formerly CMPS 122.)

Credits

5

Requirements

Prerequisite(s): CSE 130 or CSE 131 or permission of instructor. Enrollment restricted to School of Engineering majors.

CSE 134 Embedded Operating Systems

Detailed exploration of the internal design of an embedded operating systems kernel. Covers kernel structure and organization, device drivers, I/O systems, file systems, memory management, and security. Students complete significant programming projects that extend or modify existing operating systems. (Formerly Computer Engineering 114.)

Credits

5

Requirements

Prerequisite(s): CSE 120 and CSE 130.

CSE 138 Distributed Systems

Covers topics in distributed computing including communication, naming, synchronization, consistency and replication, fault tolerance, and security. Examples drawn from peer-to-peer systems, online gaming, the World Wide Web; other systems also used to illustrate approaches to these topics. Students implement simple distributed systems over the course of the quarter. (Formerly CMPS 128, Distributed Systems: File Sharing, Online Gaming, and More.)

Credits

5

Requirements

Prerequisite(s): CSE 130 or CSE 131.

CSE 140 Artificial Intelligence

Introduction to the contemporary concepts and techniques of artificial intelligence, including any or all of: machine perception and inference, machine learning, optimization problems, computational methods and models of search, game playing and theorem proving. Emphasis may be on any formal method of perceiving, learning, reasoning, and problem solving which proves to be effective. This includes both symbolic and neural network approaches to artificial intelligence. Issues discussed include symbolic versus nonsymbolic methods, local versus global methods, hierarchical organization and control, and brain modeling versus engineering approaches. Lisp or Prolog may be introduced. Involves one major project or regular programming assignments. (Formerly CMPS 140.)

Credits

5

Requirements

Prerequisite(s): CSE 101.

CSE 142 Machine Learning

Introduction to machine learning algorithms and their applications. Topics include classification learning, density estimation and Bayesian learning regression, and online learning. Provides introduction to standard learning methods such as neural networks, decision trees, boosting, and nearest neighbor techniques.

Credits

5

Requirements

Prerequisite(s): CSE 40 or STAT 132; and CSE 101; and AM 30, or MATH 22, or MATH 23A; and STAT 131 or CSE 107.

CSE 143 Introduction to Natural Language Processing

Introduces the theory and practice of natural language processing (NLP)--the creation of computer programs that can understand, generate, and learn natural language. Introduces the three major subfields of NLP: syntax (the structure of a sentence); semantics (the explicit meaning of a single sentence); and pragmatics (the implicit meaning of a sentence when it is used in a specific discourse). Projects focus on the techniques useful for a particular application area, alternating in different years. Project application areas include information extraction, narrative understanding, sentiment analysis, dialogue systems, and question answering. (Formerly CMPS 143.)

Credits

5

Requirements

Prerequisite(s): CSE 101, and CSE 107 or STAT 131. Python competence equivalent to CSE 30 is highly recommended.

CSE 144 Applied Machine Learning: Deep Learning

Provides a practical and project-oriented introduction to deep learning techniques. Starts with a review of basic elements of machine learning: training and testing, loss function, gradient descent, linear regression, and logistic regression. Moves on to common deep learning models: feedforward networks, convolutional networks for image recognition, recurrent networks and LSTM for temporal and sequential data, attention models and transformers. Some practical concepts for deep learning, including how to find model parameters, how to train large scale models, techniques for regularization and avoid overfitting, are also covered. A very basic introduction to more complex techniques such as deep reinforcement learning, neural symbolic models and diffusion models is provided in week 9. Selected student teams present their course projects in the last week. (Formerly offered as Applied Machine Learning.)

Credits

5

Requirements

Prerequisite(s): CSE 40 or STAT 132; and CSE 101. Enrollment is restricted to juniors and seniors.

CSE 145 Introduction to Data Mining

Covers the techniques, algorithms, and applications of data mining, including data preprocessing, data exploration, classification, clustering, mining text, and sequential and social data. (Formerly TIM 145.)

Credits

5

Requirements

Prerequisite(s): CSE 15 and CSE 15L or CSE 30 or CSE 13S; and AM 30 or MATH 22 or MATH 23A; and STAT 5 or CSE 107 or STAT 131; and AM 10 or MATH 21; and CSE 16 or ECON 113. Enrollment restricted to juniors and seniors. Graduate students by permission of instructor.

CSE 146 Ethics and Algorithms

Provides an introduction to data-driven and algorithmic decision making, and ethical frameworks for evaluating automated systems. Emphasis on algorithmic literacy, critical analysis, and fundamental limitations of automated decision making. Covers concepts including predictive and causal modeling. Discusses bias, fairness, interpretability, privacy, and accountability. Finally, discusses notions of autonomy and algorithmic auditing.

Credits

5

Requirements

Prerequisite(s): CSE 101; and CSE 107 or STAT 131. CSE 142 and CSE 140 are recommended.

CSE 150 Introduction to Computer Networks

Addresses issues arising in organizing communications among autonomous computers. Network models and conceptual layers; Internet-working; characteristics of transmission media; switching techniques (packet switching, circuit switching, cell switching); medium access control (MAC) protocols and local area networks; error-control strategies and link-level protocols; routing algorithms for bridges and routers; congestion control mechanisms; transport protocols; application of concepts to practical wireless and wireline networks and standard protocol architectures. Lab component provides students with hands-on experience in computer networks. Students who have completed CSE 80N can take this course for credit.

Credits

7

Requirements

Prerequisite(s): CSE 16 and CSE 12; and CSE 30, or CSE 15 and CSE 15L.

CSE 151 Advanced Computer Networks

Provides an in-depth coverage of fundamental topics introduced in course 150 including routing, transport, and internetworking. Also introduces advanced concepts not covered in CSE 150 including wireless, application-layer services, security, etc. (Formerly Computer Engineering 151.)

Credits

5

Requirements

Prerequisite(s): CSE 150. Concurrent enrollment in CSE 151L is required.

CSE 151L Advanced Computer Networks Laboratory

Laboratory illustrating the concepts covered in CSE 151: provides students with hands-on experience in computer networks. (Formerly Computer Engineering 151L.)

Credits

2

Requirements

Prerequisite(s): CSE 150. Concurrent enrollment in CSE 151 is required.

CSE 152 Principles of Computer Communication

Course focuses on the design and analysis of protocols for computer communication. Topics include: the safety, liveliness, and performance of communication protocols for medium access control (MAC); link control; routing and switching; multicasting; and end-to-end transport. Students cannot receive credit for this course and CSE 250B.

Credits

5

Requirements

Prerequisite(s): CSE 107, CSE 150, and CSE 150L.

CSE 156 Network Programming

Methods and tools used for network programming. Topics include: operating system (OS) support for network protocols; inter-process communication (IPC) facilities, such as pipes, sockets, and remote procedure call (RPC); design of client and server sides of network applications; network security; and programming projects. (Formerly Computer Engineering 156.)

Credits

5

Requirements

,Prerequisites: CSE 150 and CSE 101. Concurrent enrollment in course CSE 156L is required.

CSE 156L Network Programming Laboratory

Laboratory sequence illustrating concepts taught in CSE 156. Students learn use of network programming tools and methods via programming exercises. (Formerly Computer Engineering 156L.)

Credits

2

Requirements

Prerequisites: CSE 150 and CSE 101. Concurrent enrollment in CSE 156 is required.

CSE 157 Internet of Things

Introduces the key concepts and techniques in the design of Internet of Things (IoT). Topics include dominant architectures and protocols for IoT, wireless infrastructure for IoT, hardware and software development methodologies, embedded software design for IoT, cloud software for IoT, and network and system security. Students work in teams on a project to design, prototype, and test a complete IoT system.

Credits

7

Requirements

Prerequisite(s): CSE 121 and CSE 150.

CSE 160 Introduction to Computer Graphics

Introduces techniques of modeling, transformation, and rendering for computer-generated imagery. Topics: 2D/3D primitives, projections, matrix composition, and shading algorithms. Programming assignments and major project required. Students cannot receive credit for both this course and CSE 260 in quarters when they are offered concurrently. Mastery of materials in the prerequisite courses will be verified with a quiz or assignment during the first two weeks of the course. Lab component will help with gaining additional competence with a number of important software development tools, graphics libraries, and graphical user interfaces. Topics include OpenGL, WebGL, rubberbanding, picking, sliders, buttons, dialog, event handling, double buffering, lighting, shading, materials, and textures. The topic list may be updated to reflect technological changes. (Formerly Computer Science 160.)

Credits

7

Requirements

Prerequisite(s): CSE 101 and MATH 21 or AM 10.

CSE 161 Introduction to Data Visualization

Concepts and methods for data analysis, information and scientific visualization, and effective communication of technical data. Topics include: mathematical foundations; scalar, vector, and tensor field visualization; multivariate visualization; and tree and graph visualizations. Applications are drawn from social-network analysis; environmental and space science; and medical imaging. Evaluation based on examinations, programming exercises, and a project. (Formerly CMPS 161.)

Credits

5

Requirements

Prerequisite(s): CSE 160 or equivalent. Concurrent enrollment in CSE 161L is required.

CSE 161L Data Visualization Laboratory

Complements CSE 161. Students gain additional competence with a number of important software development tools and techniques. Included are Paraview, Visualization Toolkit (VTK), and Insight Toolkit (ITK). Students get hands-on experience with designing transfer functions, isosurfacing, direct volume rendering, vector-field visualization techniques, as well as methods for dealing with non-spatial data. (Formerly CMPS 161L.)

Credits

2

Requirements

Concurrent enrollment in CSE 161 is required.

CSE 162 Advanced Computer Graphics and Animation

Covers concepts and methods for modeling and rendering static and dynamic scenes Topics include: mathematical foundations (e.g., splines and numerical integration; global illumination models; texture mapping; morphing; physically based animation; behavioral animations; and procedural animations. Evaluation based on examinations, programming exercises, and a project. (Formerly CMPS 162.)

Credits

5

Requirements

Prerequisite(s): CSE 160 or equivalent. Concurrent enrollment in CSE 162L is required.

CSE 162L Advanced Computer Graphics and Animation Laboratory

Complements CSE 162. Students gain additional competence in a hands-on computational laboratory setting. Representative examples include topics, such as interactive curve and surface design; shaders for advanced effects; crowd and behavioral animation; experiments with particle systems; facial animation; and motion and planning. (Formerly CMPS 162L.)

Credits

2

Requirements

Prerequisite(s): concurrent enrollment in CSE 162 is required.

CSE 163 Data Programming for Visualization

Presents the basics of open-source programming tools to perform data analysis and create interactive visualizations and maps for the web, data integrity and scraping, statistical computation, simple and novel visualizations, and geomapping. The examples are drawn from social science, public policy, and data journalism. (Formerly CMPS 165.)

Credits

5

Requirements

Prerequisite(s): CSE 101.

CSE 164 Computer Vision

Introduces both the basic computer vision concepts and the advanced deep learning methods for computer vision. Topics include fundamentals of image formation, camera imaging geometry, early-/mid-/high-level vision, basics of machine learning and convolutional neural networks for vision.

Credits

5

Requirements

Prerequisite(s): CSE 144.

CSE 165 Human-Computer Interaction

Theory and hands-on practice to understand what makes user interfaces usable and accessible to diverse individuals. Covers human senses and memory and their design implications, requirement solicitation, user-centered design and prototyping techniques, and expert and user evaluations. Interdisciplinary course for social science and engineering majors. Students cannot receive credit for this course and CSE 265 or DANM 231. (Formerly Computer Engineering 131.)

Credits

5

Requirements

Prerequisite(s): CSE 15.

CSE 167 Mobile Sensing and Interaction

Provides hands-on knowledge and experience with modern mobile computing platforms for sensing and interactions tasks. Students learn how to create usable applications on a sensor-laden, mobile computing platform with adequate level of user interface.

Credits

5

Requirements

Prerequisite(s): CSE 13S; or CSE 13E or ECE 13; or CSE 15 and CSE 15L; and PHYS 5A or PHYS 6A; and AM 10 or MATH 21.

CSE 168 Introduction to Augmented Reality and Virtual Reality

Covers the concepts and methods needed to develop augmented reality (AR) and virtual reality (VR) applications. Topics include 3D modeling, graphics rendering, image compositing, occlusion handling, sensors, computer vision and image analysis, toolkits for AR, different display options, dynamics, interaction, and navigation. Prerequisite(s): CSE 160 and CSE 160L. Some knowledge of mobile platforms (e.g., CSE 118 or CSE 167) is helpful, but not required. Enrollment is by instructor permission. Enrollment is restricted to juniors and seniors. (Formerly CMPS 168.)

Credits

7

CSE 180 Database Systems I

Introduction to the concepts, approaches, tools, and methodology of database design. Covers the entity-relationship model, the relational model, relational algebra, relational calculus, commercial languages (such as SQL and QBE), functional dependencies, normal forms, and design theory. Other topics may include knowledge-bases, constraint databases, and alternative database models. Students that have taken and passed CSE 182 may not take CSE 180 for credit. (Formerly CMPS 180.)

Credits

5

Requirements

Prerequisite(s): CSE 101.

CSE 181 Database Systems II

Introduction to the architecture and implementation of database systems. Topics covered include data storage, tree and hash indexes, storage management, query evaluation and optimization, transaction management, concurrency control, recovery, and XML data management.

Credits

5

Requirements

Prerequisite(s): CSE 180 and CSE 130.

CSE 182 Introduction to Database Management Systems

Concepts, approaches, tools, and methodology of database design. Topics include the entity-relationship model; the relational data model; normal forms; commercial languages such as SQL (SQL constraints, SQL triggers, and update languages); query-by-example (QBE); XML data model, and XML query language (XQuery); as well as relational database-management support for XML and object-relational features in database-management systems. Involves a database -application development project. Students that have taken and passed CSE 180 cannot receive credit for CSE 182.

Credits

5

Requirements

Prerequisite(s): CSE 16 or BME 160; CSE 15 and CSE 15L or CSE 13E or CSE 13S or ECE 13. Course intended for non-majors; computer science majors should enroll in CSE 180.

CSE 183 Web Applications

The World-Wide Web is one of the main mechanisms by which computer applications are delivered to users. This course introduces the design of Web applications. Students learn the main technologies involved, and build web applications as part of homework assignments and group class projects. Students cannot receive credit for this course and CSE 186.

Credits

5

Requirements

Prerequisite(s): CSE 15 and CSE 15L, or CMPM 35, or CSE 101.

General Education Code

PR-E

CSE 184 Data Wrangling and Web Scraping

Python basics; data extraction from CSV, JSON, XML, Excel, PDF, encoded text files; data cleaning, finding duplicates, missing data, fuzzy matching; data exploration, joining, aggregating, separating, correlation, clustering; web scraping, APIs, scraping data from social media, open data network. (Formerly CMPS 184.)

Credits

5

Requirements

Prerequisite(s): CSE 101.

CSE 185E Technical Writing for Computer Science and Engineering

Writing by engineers and computer scientists to technical audiences. Writing exercises include: cover letter and resume for job application, tutorial writing, grant proposal, document specification, literature review, and a final technical report. Two oral presentations are also required, an in-class presentation and a poster presentation. Students also receive instruction in the use of UC library and journal database resources, and in the writing of a statement of purpose for graduate school application. Also offered as CSE 185S. (Formerly Computer Engineering 185, Technical Writing for Computer Engineers.)

Credits

5

Cross Listed Courses

Prerequisite(s): CSE 101, one additional upper-division CSE course, and satisfaction of the Entry Level Writing and Composition requirements. Enrollment is restricted to computer science majors, or by permission of the instructor.

Cross Listed Courses

CSE 185S

Requirements

Prerequisite(s): satisfaction of Entry Level Writing and Composition requirements; and CSE 12 or CSE 15 or CSE 30 or BME 160 or by permission of the instructor. Enrollment is restricted to computer engineering, bioengineering, bioinformatics, biomolecular engineering and bioinformatics, or network and digital technology majors.

CSE 186 Full Stack Web Development I

Examines current uses of the World Wide Web for delivery of the sophisticated interactive applications used daily. Web applications offer several advantages over traditional, locally installable binaries including heterogeneous deployment, instantaneous access, continuous updates, and the possibility of collaboration at scale. These full stack web applications are typically more complex than their traditional counterparts, requiring the seamless integrating of numerous related technologies if end users are to have a productive experience and the system is to remain robust, performant, and secure. Students cannot receive credit for this course and CSE 183.

Credits

5

Requirements

Prerequisite(s): CSE 15 and CSE 15L, or CSE 30, or CSE 101. Enrollment is restricted to juniors and seniors majoring in computer engineering, computer science, and computer game design.

CSE 187 Full Stack Web Development II

Continues the examination of current uses of the World Wide Web for delivery of the sophisticated interactive applications we use daily. Advanced development techniques are examined with continued emphasis on automated testing. A sizable team project is undertaken to introduce topics including, but not limited to, automated build pipelines, penetration testing, API versioning, and deployment at scale.

Credits

5

Requirements

Prerequisite(s): CSE 186. Enrollment is restricted to juniors and seniors.

General Education Code

PR-E

CSE 191 Computer Science and Technology Seminar

Weekly talks by industry experts, university researchers, field practitioners, and video presentations provide an in-depth exposure to a specific or a broad area of computer science and technology. Topics include emerging ideas, opportunities, challenges, and future of the industry. (Formerly CMPS 191.)

Credits

2

Repeatable for credit

Yes

CSE 192 Supervised Student Teaching/Tutoring

Students hold tutoring hours, run a lab, or lead discussion section in conjunction with a regularly offered course and under close supervision by the course's instructor. Weekly meetings with a regular faculty member to discuss teaching techniques, pedagogy, sensitivity to students' needs, maintaining a comfortable learning environment, and strategies for handling difficult situations. Students submit a report on their teaching experience. Enrollment by permission of instructor and restricted to sophomores, juniors, and seniors. (Formerly CMPS 192.)

Credits

5

CSE 192F Supervised Student Teaching/Tutoring

Students hold tutoring hours, run a lab, or lead discussion section in conjunction with a regularly offered course and under close supervision by the course's instructor. Weekly meetings with a regular faculty member to discuss teaching techniques, pedagogy, sensitivity to students' needs, maintaining a comfortable learning environment, and strategies for handling difficult situations. Students submit a report on their teaching experience. Enrollment by permission of instructor and restricted to sophomores, juniors, and seniors. (Formerly CMPS 192F.)

Credits

2

CSE 193 Field Study

Provides for individual programs of study with specific academic objectives carried out under the direction of a faculty member of the Computer Engineering Department and a willing sponsor at the field site using resources not normally available on campus. Credit is based on the presentation of evidence of achieving the objectives by submitting a written and oral presentation. May not be repeated for credit. Students submit petition to sponsoring agency.

Credits

5

CSE 193F Field Study

Provides for individual programs of study with specific academic objectives carried out under the direction of a faculty member of the Computer Engineering Department and a willing sponsor at the field site using resources not normally available on campus. Credit is based on the presentation of evidence of achieving the objectives by submitting a written and oral presentation. May not be repeated for credit. Students submit petition to sponsoring agency.

Credits

2

CSE 194 Group Tutorial

A program of independent study arranged between a group of students and a faculty member. Students submit petition to sponsoring agency.

Credits

5

Repeatable for credit

Yes

CSE 194F Group Tutorial

A program of independent study arranged between a group of students and a faculty member. Students submit petition to sponsoring agency.

Credits

2

Repeatable for credit

Yes

CSE 195 Senior Thesis Research

Students submit petition to sponsoring agency. Prerequisite(s): satisfaction of the Entry Level Writing and Composition requirements. Computer Engineering majors, CSE 123A or CSE 129A.

Credits

5

CSE 195F Senior Thesis Research

Students submit petition to sponsoring agency. Consent of instructor required. Prerequisite: CSE 123A.

Credits

2

CSE 198 Individual Study or Research

Students submit petition to sponsoring agency.

Credits

5

Repeatable for credit

Yes

CSE 198F Individual Study or Research

Students submit petition to sponsoring agency.

Credits

2

Repeatable for credit

Yes

CSE 199 Tutorial

For fourth-year students majoring in computer engineering. Students submit petition to sponsoring agency.

Credits

5

Repeatable for credit

Yes

CSE 199F Tutorial

For fourth-year students majoring in computer engineering. Students submit petition to sponsoring agency.

Credits

2

Repeatable for credit

Yes

CSE 200 Research and Teaching in Computer Science and Engineering

Basic teaching techniques for teaching assistants, including responsibilities and rights of teaching assistants, resource materials, computer security, leading discussion or lab sessions, presentation techniques, maintaining class records, electronic handling of homework, and grading. The course examines research and professional training, including use of the library and online databases, technical typesetting, writing journal and conference papers, publishing in computer science and computer engineering, giving talks in seminars and conferences, and ethical issues in science and engineering. Required for all teaching assistants. Formerly CMPS 200 and CMPE 200.)

Credits

3

Requirements

Enrollment is restricted to graduate students.

CSE 201 Analysis of Algorithms

Rigorous analysis of the time and space requirements of important algorithms, including worst case, average case, and amortized analysis. Techniques include order-notation, recurrence relations, information-theoretic lower bounds, adversary arguments. Analysis of the key data structures: trees, hash tables, balanced tree schemes, priority queues, Fibonacci and binomial heaps. Algorithmic paradigms such as divide and conquer, dynamic programming, union-find with path compression, augmenting paths. Selected advanced algorithms. Introduction to NP-completeness. (Formerly Computer Science 201.)

Credits

5

Requirements

Enrollment is restricted to graduate students; undergraduate students may enroll in this course if they have completed CSE 102 or CSE 106 and have the consent of the instructor.

CSE 202 Combinatorial Algorithms

Fundamental combinatorial algorithms, graph algorithms, flow problems, matching problems, linear programming, integer programming, NP-completeness, approximation algorithms for optimization problems. (Formerly Computer Science 211.)

Credits

5

Requirements

Prerequisite(s): CSE 201.

CSE 203 Randomized Algorithms

Course on randomized algorithms, meant for graduate students with a good mathematical background. Students need familiarity with discrete math, analysis of algorithms, basic analysis, probability theory, and graph theory.

Credits

5

Requirements

Prerequisite(s): CSE 201. Students need a solid background in analysis of algorithms, discrete math, probability theory, graph theory, and overall mathematical maturity. Enrollment is restricted to graduate students. Undergraduates with a good understanding of the material in CSE 101, CSE 102, and CSE 103, and real analysis can enroll with permission of the instructor.

CSE 204 Computational Models and Complexity

Finite automata and regular expressions, universal models of computation, computability and unsolvability, relations between complexity classes, hierarchy theorems, reductions, complete problems for the major complexity classes (L, NL, P, NP, PSPACE). Other topics may include complexity of counting and enumeration problems, complexity of approximation, randomized complexity classes. (Formerly Computer Science 210.)

Credits

5

Requirements

Prerequisite(s): CSE 201.

CSE 205 Logic in Computer Science

The applications and uses of formal systems to computer science. Covers the syntax and semantics of propositional logic and first-order logic, normal forms, soundness and completeness theorems, Herbrand's theorem, unification and resolution, foundations of logic programming, automated theorem proving. Other topics may include deductive databases, database query languages, nonmonotonic reasoning. (Formerly Computer Science 217.)

Credits

5

Requirements

Enrollment is restricted to graduate students.

CSE 206C Foundations of Modern Cryptography

Focuses on foundational aspects of modern cryptography, namely, private and public key cryptography; digital signatures; pseudorandom generators and functions/permutations; message authentication codes; hash functions; and random oracles, certificates and public-key infrastructures. Also connects the formal concepts with real-world applications. Students are exposed to general concepts of probability theory, number theory, and rigorous proofs. Assumes background on proofs, discrete probability, and modular arithmetic as well as programming in C/C++ or Python. Prerequisite(s): CSE 201 is recommended. Enrollment is restricted to graduate students and requires instructor permission.

Credits

5

CSE 207 Graph Algorithms

Explores graph theory and algorithms for solving problems in engineering. A review of basic graph concepts and algorithms is followed by topics in network flow, partitioning, spectral analysis of graphs, graph isomorphism, and intractability. (Formerly Computer Engineering 277.)

Credits

5

Requirements

Prerequisite(s): CSE 101 and CSE 102; or CSE 106; or CSE 201; or equivalent. Enrollment is restricted to graduate students.

CSE 209A Modern Algorithmic Toolbox

Graduate course on the modern algorithmic toolbox, meant for graduate students with a good mathematical background. Students need familiarity with discrete math, analysis of algorithms, basic analysis, probability theory, and graph theory. Class is aimed at students who want to learn more about the central ideas and algorithmic techniques that are used in modern data science applications. Class focuses on the theoretical underpinnings of these algorithms as well as their practical applications and implementation details.

Credits

5

Requirements

Prerequisite(s): CSE 201 or equivalent or instructor consent. Students need a solid background in analysis of algorithms, discrete math, probability theory, graph theory, and overall mathematical maturity. Enrollment is restricted to graduate students.

CSE 210A Programming Languages

Covers current issues in programming languages. Language topics include object oriented, concurrent, functional, and logic programming, and other programmable applications such as symbolic manipulators and simulation. (Formerly Computer Science 203.)

Credits

5

Requirements

Enrollment is restricted to graduate students; undergraduate students may enroll for this course if they have completed CSE 112 and have the consent of the instructor.

CSE 210B Advanced Programming Languages

Covers issues in the design, implementation, analysis, and specification of programming languages. Topics include formal semantics (including operational, axiomatic, and denotational semantics), advanced type systems, program analysis (including abstract interpretation and model checking), specification, and verification. (Formerly Computer Science 253.)

Credits

5

Requirements

Prerequisite(s): CSE 210A or equivalent.

CSE 211 Compiler Design

Advanced study of compiler implementation. Topics include compiler structure back end, run-time environments, storage management, garbage collection, register allocation, code generation, basic blocks, control flow, data flow, local and global optimization, interpretation, machine code generation. Students may not receive credit for this course and CSE 110B. Taught in conjunction with CSE 110B. (Formerly Computer Science 204.)

Credits

5

Requirements

Enrollment is restricted to graduate students.

CSE 212A Software Engineering

Introduction to the general principles of software engineering. Covers current and classical topics from both practical and theoretical viewpoints. Topics include software evolution, project management, software inspections, design methods, requirements analysis and specification, software testing, maintenance, software implementation, human interfaces, and software engineering experimentation. (Formerly CMPS 276.)

Credits

5

Requirements

Enrollment is restricted to graduate students; undergraduates may enroll in this course if they have completed CSE 115A.

CSE 212B Software Reuse and Component-Based Software Engineering

Detailed study of interlocking business, organizational, and technical issues in large-scale software reuse and component-based software engineering. Topics include architecture, design for reuse, domain engineering, model-driven development, domain-specific kits, components, frameworks, software agents, generators, problem-oriented languages, library design, reuse tools, patterns, and aspects. Assumes prior exposure to software engineering topics. (Formerly Computer Science 279.)

Credits

5

Requirements

Prerequisite(s): CSE 212A or consent of instructor. Enrollment is restricted to graduate students.

CSE 214 Principles of Database Systems

Advanced course on principles of database systems. Main topics include overview of the relational data model and relational query languages; recursive queries, datalog, and fixed-points; query processing and optimization; database design, dependencies, normal forms, and the chase procedure. Additional topics may include information integration, complex objects, semistructured data, and XML. (Formerly Computer Science 277.)

Credits

5

Requirements

Prerequisite(s): CSE 201 or equivalent or consent of instructor. Enrollment is restricted to graduate students.

CSE 215 Design and Implementation of Database Systems

Advanced course in implementation techniques for database systems. For students who wish to do research in databases or to learn more about large-scale data processing. Topics include: indexing of complex data; techniques for high-volume concurrency control; query processing and optimization; database recovery; parallel database system architectures; database systems for streaming data; approximate query answering. Additional topics may include: self-managing database systems; advanced query optimization techniques; and query processing techniques for semi-structured data.

Credits

5

Requirements

Prerequisite(s): Enrollment is restricted to graduate students. Undergraduates that have taken CSE 181 may enroll. A basic knowledge of databases, similar to the content of CSE 180, is recommended.

CSE 216 Formal Methods

Mathematical techniques for analyzing systems to prove rigorous guarantees about their behavior. Fundamental algorithms for and advanced topics in modeling, specification, verification, correct-by-construction synthesis, and testing. Applications to hardware/software design, cybersecurity, robotics, machine learning. Course includes a final project.

Credits

5

Requirements

Prerequisite(s): CSE 103 or equivalent recommended, but not required. Enrollment is restricted to graduate students; undergraduates may enroll by permission of instructor.

CSE 220 Computer Architecture

Provides a thorough and fundamental treatment of the art of computer architecture. Topics include concepts of von Neumann architectures, methods of evaluating CPU performance, instruction-set design and examples, compiler issues, instruction pipelining, superscalar processors, methods for reduction of branch penalty, memory hierarchies, I/O systems, floating-point arithmetic, and current issues in parallel processing. (Formerly CMPE 202.)

Credits

5

Requirements

Enrollment is restricted to graduate students; undergraduates may enroll if they have completed CSE 120 and with consent of instructor. A basic knowledge of computer architecture, similar to the content of CSE 120, is recommended.

CSE 221 Advanced Microprocessor Design

Introduction to latest advances in computer architecture. Focuses on processor core design. Topics include simultaneous multithreading, thread level speculation, trace caches, novel out-of-order mechanisms, and energy-efficient processor core designs. Final project is modification/enhancement of an out-of-order processor on an FPGA development system. (Formerly Computer Engineering 221.)

Credits

5

Requirements

Prerequisite(s): CSE 220; and CSE 125, CSE 225, or equivalent Verilog experience. Concurrent enrollment in CSE 221L is required. Enrollment restricted to graduate students.

CSE 221L Advanced Microprocessor Design Laboratory

Laboratory sequence illustrating topics covered in course 221. (Formerly Computer Engineering 221L.)

Credits

3

Requirements

Prerequisite(s): CSE 220; and CSE 125, CSE 225, or equivalent Verilog experience. Concurrent enrollment in CSE 221 is required. Enrollment restricted to graduate students.

CSE 222A VLSI Digital System Design

Advanced Very Large Scale Integrated (VLSI) custom integrated circuits. Topics include: semiconductors; field-effect transistors (FETs); circuits; and interconnect simulation, along with advanced material on manufacturability, variability, short-channel devices, and non-volatile memories. Students cannot receive credit for this course and CSE 122. (Formerly Computer Engineering 222.)

Credits

5

Requirements

Prerequisite(s): CSE 122 or equivalent.

CSE 222B VLSI System-on-a-Chip Design

Design methodologies for Application Specific Integrated Circuits (ASICs). Topics include: behavioral specification; logic synthesis; standard-cell libraries; advanced timing analysis; and physical design automation tools. Familiarizes students with real-world tools during the design of a small system-on-a-chip project. Students are encouraged to fabricate and test their chips in an independent study. (Formerly Computer Engineering 223.)

Credits

5

Requirements

Prerequisite(s): CSE 222A or permission of instructor. Enrollment is restricted to graduate students.

CSE 225 Introduction to ASIC Systems Design

Verilog digital logic design with emphasis on ASIC and FPGA design. Students design and verify large-scale systems. Assignments and project use the Verilog Hardware Description Language with emphasis on verification and high-frequency ASIC/FPGA targets. Course may be taught in conjunction with CSE 125.

Credits

7

Requirements

Prerequisite(s): CSE 120 or CSE 220. Enrollment is restricted to graduate students; undergraduates may enroll with permission of instructor. Students with hardware background should consult instructor for permission to enroll.

CSE 226 Advanced Parallel Processing

Introduction to programming advanced parallel computer architecture. Topics may include: SIMD massively parallel processor arrays; streaming parallel coprocessors, such as graphics cards used for general-purpose processing (GPGPU); or other hybrid MIMD/SIMD architectures. Course has programming lab component, a project, and student presentation on related topics. (Formerly Computer Engineering 220.)

Credits

5

Requirements

Enrollment is restricted to graduate students; undergraduates may enroll with permission of instructor.

CSE 228A Agile Hardware Design

Agile Hardware Design techniques take the best of software engineering methods and apply them to improve hardware design productivity. Agile approaches not only reduce the time to solution, but they can also produce solutions which are better tailored for their target problems. In this synchronous in-person course, these techniques are covered while taking advantage of the Chisel hardware design language which brings the strengths of functional object-oriented programming to hardware design. Course consists of engaging lectures (intermixed coding demos and guest speakers) and progressive design assignments that culminate in a small project.

Credits

5

Requirements

Prerequisite(s): equivalent experience in at least two of the following three areas: logic design (Verilog/VHDL e.g. CSE 100/CSE 100L or CSE 125/CSE 125L), computer architecture (CSE 120/CSE 220), advanced programming (functional, object oriented, etc.). Enrollment is restricted to graduate students; open to advanced undergraduates with instructor consent.

CSE 229 Field-Programmable Gate Arrays Computer-Assisted Design

Design methods for Field-Programmable Gate Arrays (FGPAs), including algorithms for technology mapping, routability estimation, placement, and routing. The relationship between FPGA architectures and their computer-aided design tools. Course project involves the modification and analysis of an FPGA tool. (Formerly Computer Engineering 229.)

Credits

5

Requirements

Enrollment is restricted to graduate students or by consent of instructor. CSE 100, CSE 125, CSE 222A, CSE 225, or other digital design experience recommended.

CSE 231 Advanced Operating Systems

A detailed study of the issues involved in operating systems design and implementation. Readings cover current research topics and systems of historical significance. Topics include (but are not restricted to) process and memory management, protection, security, synchronization, performance evaluation, file systems, distributed systems. (Formerly Computer Science 221.)

Credits

5

Requirements

Enrollment is restricted to graduate students; undergraduates by interview only.

CSE 232 Distributed Systems

Overview of research topics in distributed computer systems. Topics may include communication paradigms, process management, naming, synchronization and coordination, consistency and replication, fault tolerance, and security. Examples include distributed operating systems, distributed file and object systems, distributed document systems, and peer-to-peer systems. (Formerly Computer Science 232.)

Credits

5

Requirements

Enrollment is restricted to graduate students.

CSE 233 Advanced Computer Security

Overview of research topics in computer and network security. Topics may include cryptographic operations, security properties and policies, authentication and access control, attacks on computer systems and defenses against them, security in programming languages, and network protocols for security. (Formerly CMPS 223.)

Credits

5

Requirements

Enrollment is restricted to graduate students or consent of instructor.

CSE 234 Understanding Cryptography

Cryptography has become ubiquitous, from light bulbs to atomic weapons. This course provides both a comprehensive introduction to applied cryptography and an additional focus on the human issues caused by bad implementations, bad processes, and broken algorithms. Knowledge of C Programming, Linux, and Virtual machines is required. (Formerly Computer Engineering 236 and Computer Science 236.)

Credits

5

Requirements

Prerequisite(s): CSE 201. Enrollment is restricted to graduate students.

CSE 235 Cyber-Physical Systems Security

Cyber-physical systems now permeate our lives; they include autonomous vehicles, the Internet of things, and modern control of our critical infrastructure such as the power grid. Learning about the threats against these systems and the possible defenses is essential for computer security practitioners. In this course, students read and analyze the latest published research in this area, and work on projects to address new problems.

Credits

5

Requirements

Enrollment is restricted to graduate students.

CSE 237 Storage Systems

Topics include storage devices, storage architectures, local file systems, high-performance file systems, and next-generation storage devices and architectures; covers issues of performance, reliability, scalability, robustness, and security. (Formerly Computer Science 229.)

Credits

5

Requirements

Enrollment is restricted to graduate students.

CSE 240 Artificial Intelligence

Prepares students for doing research in artificial intelligence. Major topics covered are search and heuristics, knowledge representation, planning, deduction and inference, reinforcement learning, associative pattern retrieval, and adaptive search. Discussion includes current research issues in AI problem-solving methods. Individualized projects. (Formerly Computer Science 240.)

Credits

5

CSE 241 Knowledge Engineering

Introduction to the acquisition, representation, and application of knowledge in expert systems. Topics include production systems, backward and forward chaining, dependency-directed backtracking, reasoning with uncertainty, certainty factors, fuzzy systems, knowledge representation (rules, frames, and semantic nets), inference engines, and metaknowledge. Discussion includes current research issues in adaptive expert systems. Involves one major project. Undergraduates may enroll in this course if they have completed CSE 140. (Formerly Computer Science 241.)

Credits

5

CSE 242 Machine Learning

Introduction to machine learning algorithms. Covers learning models from fields of statistical decision theory and pattern recognition, artificial intelligence, and theoretical computer science. Topics include classification learning and the Probably Approximately Correct (PAC) learning framework, density estimation and Bayesian learning, EM, regression, and online learning. Provides an introduction to standard learning methods such as neural networks, decision trees, boosting, nearest neighbor, and support vector machines. Requirements include one major experimental learning project or theoretical paper. Students may not receive credit for both this course and CSE 142. (Formerly CMPS 242.)

Credits

5

Requirements

Enrollment is restricted to graduate students in the computer science and engineering, computer engineering and computer science master's programs; and students in the following doctoral programs: computer science and engineering, computer engineering, computer science, applied mathematics, applied mathematics and statistics, biomolecular engineering and bioinformatics, electrical and computer engineering, electrical engineering, statistical science, and technology information management. Others may enroll by permission of the instructor.

CSE 243 Data Mining

Covers the principles, algorithms, and applications of data mining, including mining sequential data, structured data, stream data, text data, spatiotemporal data, biomedical data, and other forms of complex data. Formerly TIM 245.)

Credits

5

Requirements

Enrollment is restricted to graduate students.

CSE 244A Foundations of Deep Learning

Provides foundations of deep learning algorithms and principles. Topics include neural networks, deep learning principles, deep learning architectures such as convolutional neural networks and recurrent neural networks, autoencoders, generative adversarial networks, and reinforcement learning. (CSE 244A and CSE 244B formerly offered as one course, CSE 244.)

Credits

5

Requirements

Prerequisite(s): CSE 201 and familiarity with basic machine learning concepts. Enrollment is restricted to computer science and engineering graduate students.

CSE 244B Machine Learning for Natural Language Processing

Introduction to machine learning models and algorithms for Natural Language Processing. Covers deep learning approaches and traditional machine learning models. Topics include an introduction to standard neural network learning methods such as feed-forward neural networks, recurrent neural networks, convolutional neural networks, and encoder-decoder models with applications to natural language processing problems such as utterance classification and sequence tagging. Requirements include a midterm, final, programming assignments, and a project. (CSE 244A and CSE 244B formerly offered as one course, CSE 244.)

Credits

5

Requirements

Prerequisite: CSE 244A.

CSE 245 Computational Models of Discourse and Dialogue

Focuses on classic and current theories and research topics in the computational modeling of discourse and dialogue, with applications to human-computer dialogue interactions; dialogue interaction in computer games and interactive story systems; and processing of human-to-human conversational and dialogue-like language such as e-mails. Topics vary depending on the current research of the instructor(s) and the interests of the students. Students read theoretical and technical papers from journals and conference proceedings and present class lectures. A research project is required.

Credits

5

Cross Listed Courses

LING 245, CMPM 245

Requirements

Enrollment is restricted to graduate students. Undergraduates may enroll with permission of instructor.

Repeatable for credit

Yes

CSE 246 Responsible Data Science

Graduate course covering basics of data science literacy and data science ethics. Topics include algorithmic discrimination, fairness, interpretability, privacy, and reproducibility. Key statistical topics such as generalization, causality, curse of dimensionality, and sampling bias are covered.

Credits

5

Requirements

Enrollment is restricted to graduate students.

CSE 247 Projects in Artificial Intelligence

Overview of artificial intelligence (AI) and machine learning (ML) and principles, implementation and deployment pipeline, and approaches in solving domain-related problems. Topics covered through direct instruction, invited guest speakers, reviews of state-of-art research papers, and a team project. Students are given an opportunity to work on a quarter-long AI/ML project to be counted toward their master's degree project requirements. Enrollment is by instructor consent. Prior experience in machine learning and deep learning is required. (Formerly AI: Problem Solving and Intelligent Search.)

Credits

5

CSE 248 Foundations of Data Science

Examines the mathematical and algorithmic foundations of data science including high dimensional data, probabilistic inequalities, dimensionality reduction, correlation detection, streaming algorithms, and clustering. (Formerly Computer Science 218.)

Credits

5

Requirements

Prerequisite(s): CSE 201. Enrollment is restricted to graduate students.

CSE 249 Large-Scale Web Analytics and Machine Learning

Provides a systematic methodology and corresponding set of methods and analytical tools in stochastic models; reinforcement learning; stochastic (neuro-)dynamic programming; Bayesian graphical models; inference; and social networks used for web analytics and machine learning to achieve business intelligence (BI) and support research and applications in computer science, computer engineering, and electrical engineering, applied mathematics and statistics, business, management, and economics. Includes exposure to Hadoop for large-scale computation. Students should have solid background in probability equivalent to statistics, stochastic, methods, calculus, (and preferably) stochastic processes and optimization, or mathematical maturity and exposure to business intelligence and algorithms. (Formerly TIM 251.)

Credits

5

Requirements

Prerequisite(s): CSE 107 or STAT 131 or permission of instructor. Enrollment is restricted to graduate students.

CSE 250A Computer Networks

Issues resulting from organizing communication among autonomous computers. Includes network models and switching techniques; medium access control protocols and local area networks; error control and retransmission strategies; routing algorithms and protocols; congestion control mechanisms and end-to-end protocols; application-level protocols; and application of concepts to wireless and wireline networks, with emphasis on the Internet. (Formerly Computer Engineering 252A.)

Credits

5

Requirements

Enrollment is restricted to graduate students.

CSE 250B Principles of Computer Communication

Focuses on the design and analysis of protocols for computer communication. Topics include: the safety, liveliness, and performance of communication protocols for medium access control (MAC); link control; routing and switching; multicasting; and end-to-end transport. Students cannot receive credit for this course and CSE 152. (Formerly CMPE 252B.)

Credits

5

Requirements

Prerequisite(s): CSE 250A. Enrollment is restricted to graduate students.

CSE 250C High Speed Computer Networks

Fiber-optic technology; fiber-optic link design; network protocol concepts; coding and error control; high-speed local area and metropolitan area networks; gigabit networks; error and congestion control; photonic networks; research topics. (Formerly Computer Engineering 254.)

Credits

5

Requirements

Prerequisite(s): CSE 250B.

CSE 253 Network Security

Fundamental mechanisms for network security and their application in widely deployed protocols. In-depth treatment of security mechanism at the data-link, network, and transport layers for both wired and wireless networks. Covers mechanisms for privacy and integrity, and methods for intrusion detection. (Formerly CMPE 253.)

Credits

5

Requirements

Prerequisite(s): CSE 250A and CSE 201. Enrollment restricted to graduate students.

CSE 257 Wireless and Mobile Networks

An interdisciplinary course on wireless communication and mobile computing. Covers the physical aspects of wireless communication but emphasizes higher protocol layers. Topics include cellular networks, packet radio and ad hoc networks, wireless transport protocols, security, and application-level issues. (Formerly Computer Engineering 257.)

Credits

5

Requirements

Prerequisite(s): CSE 250A or permission of instructor.

CSE 259 Sensor Networks

Focuses on the networking aspects of sensor networks: protocols at the various layers and how they answer the specific requirements posed by these networks (e.g., data driven, energy efficient, etc.) and their applications (monitoring, tracking, etc.). Explores how physical layer and hardware issues may influence protocol design. (Formerly Computer Engineering 259.)

Credits

5

Requirements

Prerequisite(s): CSE 250A. CSE 257 is recommended as a prerequisite.

CSE 260 Computer Graphics

Introduces current research and techniques of modeling, 2D/3D transformation, matrix composition, shading algorithms, and rendering to obtain computer-generated imagery. Programming assignments and major project required. Students cannot receive credit for both this course and CSE 160. (Formerly Computer Science 260.)

Credits

5

Requirements

Enrollment is restricted to graduate students; undergraduates by interview only.

CSE 261 Advanced Visualization

Covers advanced topics in visualization, e.g., tensor-field visualization, uncertainty visualization, information visualization. Topics vary with differing offerings of the course. Course includes lectures, exam, research paper reading/presentation, and projects. Final project is expected to be at a sufficiently advanced level for submission to a conference. Students work individually or in pairs. (Formerly Computer Science 261.)

Credits

5

Requirements

Enrollment is restricted to graduate students.

CSE 262 Computer Animation

An in-depth treatment of computer animation, including its origins in conventional animation, 2-D animation, inbetweening, motion control, morphing, graphical motion editors, animation languages, motion blur, simulation of articulated body motion, real-time animation, and special-purpose animation hardware. (Formerly Computer Science 262.)

Credits

5

Requirements

Enrollment is restricted to graduate students.

CSE 263 Data Driven Discovery and Visualization

Explores high-quality interdisciplinary research using socio-economic data and software available on the Internet, and data curation, computation, and visualization to strengthen scientific inquiry to bear on large-scale societal problems. Applications include inequality, poverty, water, energy, environment, health, education, and democracy. Enrollment restricted to graduate students. Enrollment by instructor consent. (Formerly Computer Science 263.)

Credits

5

CSE 264 Computer Vision

Introduces general concepts in computer vision, with an emphasis on geometric 3D reconstruction. Topics include radiometry, photometry, projective geometry, geometric camera model, epipolar geometry, stereo depth reconstruction, corner and edge features, point descriptors and matching, and optical flow. (Formerly Computer Engineering 264.)

Credits

5

Requirements

Enrollment is restricted to graduate students. Undergraduate students who are interested in enrolling should meet with the instructor first.

CSE 265 Human-Computer Interaction

Theory and hands-on practice to understand what makes user interfaces usable and accessible to diverse individuals. Covers human senses and memory and their design implications, requirement solicitation, user-centered design and prototyping techniques, and expert and user evaluations. Individual research project. Interdisciplinary course for art, social science and engineering graduate students. Students cannot receive credit for this course and CSE 165.

Credits

5

Cross Listed Courses

DANM 231

Requirements

Enrollment is restricted to graduate students.

CSE 272 Information Retrieval

Course covers major topics of information retrieval including: characteristics and representation of text, several important retrieval and ranking models, content recommendation and classification; distributed or federated search, AI semantics and dialog for information access; human factors and interfaces; and evaluation, and domain-specific applications. A research project is required. (Formerly TIM 260.)

Credits

5

Requirements

Enrollment is restricted to graduate students. Undergraduates may enroll with permission of instructor.

CSE 276 Optimization Theory and Applications

A first graduate course in optimization with an emphasis on problems arising in management and engineering applications. Objectives are to become experts in problem formulation, comfortable with software for solving these problems, and familiar with analytical methods behind these solver technologies. (Formerly TIM 206.)

Credits

5

Requirements

Prerequisite(s): calculus and linear algebra. Enrollment is restricted to graduate students.

CSE 277 Random Process Models in Engineering

A first graduate course in stochastic process modeling and analysis with an emphasis on applications in technology management, information systems design, and engineering. (Formerly TIM 207.)

Credits

5

Requirements

Enrollment is restricted to graduate students. Prerequisite: CSE 107 or other undergraduate probability course recommended.

CSE 279 Data Mining and Business Analytics in Knowledge Services

Provides students with systematic methodology and analytical tools in data and text mining and business analytics. Also provides an integrated perspective and examines use of these methods in the field of knowledge services, such as online marketing, sponsored search, health care, financial services, recommender systems, etc. Includes training in the basic elements of stochastic optimization and other algorithmic approaches, such as stochastic dynamic programming, statistics, constrained optimization, and machine learning with exposure to software tools. These methods enable firms to achieve rapid, effective, and profitable optimization of knowledge-services management. (Formerly TIM 209.)

Credits

5

Requirements

Enrollment is restricted to graduate students. Students are expected to have undergraduate preparation in probability and statistics. Undergraduates may enroll with instructor approval.

CSE 280A Seminar in Computer Science and Engineering

Weekly seminar covering topics of current research in computer science. Enrollment by permission of instructor. (Formerly CMPS 280A, Seminar in Computer Science Research.)

Credits

2

Repeatable for credit

Yes

CSE 280D Seminar in Database Systems

Covers advanced research topics from the recent literature in database systems and related fields. Involves presentations from UCSC students and faculty, and guest talks from researchers in industry and other academic institutions. Enrollment by permission of instructor. (Formerly 280D.)

Credits

2

Repeatable for credit

Yes

CSE 280F Seminar on Software Engineering

Weekly seminar covering topics of current research in software engineering. (Formerly CMPS 280G.)

Credits

2

Requirements

Prerequisite(s): Enrollment is restricted to graduate students.

Repeatable for credit

Yes

CSE 280G VLSI/CAD Seminar

Weekly seminar on advanced topics in VLSI and computer-aided design (CAD). Students present and discuss modern issues in semiconductor design, fabrication, and CAD. Frequent guest speakers present pertinent results from industry and academia. (Formerly Computer Engineering 280G.)

Credits

2

Repeatable for credit

Yes

CSE 280H Seminar in Human Computation Systems

Covers advanced topics and current research in the general area of human computation. Material is drawn from several disciplines that involve or deal with human computation, including computer vision, human-computer interaction, databases, and machine learning. The course comprises presentations from faculty, enrolled students, and external visitors. (Formerly CMPS 280H.)

Credits

2

Requirements

Enrollment is restricted to graduate students.

Repeatable for credit

Yes

CSE 280I Seminar on Information Retrieval and Knowledge Management

Seminar series discussing advanced topics in information retrieval and knowledge management. Current research and literature are presented during each meeting. (Formerly 280I.)

Credits

2

Requirements

Enrollment is restricted to graduate students.

Repeatable for credit

Yes

CSE 280J Seminar on Computer Graphics

Weekly seminar covering topics of current research in computer graphics. Enrollment restricted to graduate students and by permission of instructor. (Formerly CMPS 280J.)

Credits

2

Repeatable for credit

Yes

CSE 280K Sales and Marketing for Technologists and Engineers

Perspective on the theory, plus examples, and tools useful to technologists and engineers for successfully guiding and supporting sales and marketing endeavors and, thereby, ensuring funding, staffing, product appeal, positive customer relationships, and marketplace success. (Formerly TIM 280M.)

Credits

2

CSE 280L Seminar on Logic in Computer Science

Covers advanced research topics from the recent literature in the uses of logic in computer science with particular emphasis on the applications of logic to the representation and the management of data. Involves presentations from UCSC students and faculty, and guest talks from researchers in other academic institutions or industrial research labs. Enrollment is by permission of the instructor and is restricted to graduate students. (Formerly CMPS 280L.)

Credits

2

Repeatable for credit

Yes

CSE 280M Seminar on Machine Learning

Weekly seminar covering topics of current interest in machine learning. Enrollment is by permission of the instructor. Enrollment is restricted to graduate students. (Formerly CMPS 280M.)

Credits

2

Repeatable for credit

Yes

CSE 280N Seminar on Networks

Weekly seminar series covering topics of current research in networks and networked systems. Current research work and literature in these areas are discussed. Prerequisite(s): permission of instructor. Enrollment is restricted to graduate students. (Formerly Computer Engineering 280N.)

Credits

2

Repeatable for credit

Yes

CSE 280O Seminar in Applied Programming Languages

Covers current research in language-based approaches to security, distributed systems, databases, and formal verification. Students read and present papers from academic journals and conferences.

Credits

2

Requirements

Enrollment is restricted to graduate students, or by permission of the instructor.

Repeatable for credit

Yes

CSE 280P Seminar on Parallel Processing

Weekly seminar series covering topics of current research in parallel systems, architectures, and algorithms. Current research work and literature in these areas are discussed. (Formerly Computer Engineering 280P.)

Credits

2

Requirements

Enrollment is restricted to graduate students.

Repeatable for credit

Yes

CSE 280S Seminar on Computer Systems

Weekly seminar series covering topics of current research in computer systems. Enrollment by permission of instructor. (Formerly CMPS 280S AND CMPE 280S.)

Credits

2

Repeatable for credit

Yes

CSE 280T Seminar on New Technologies

Weekly seminar series in which distinguished speakers from industry, universities, and government discuss current developments in networking and computer technology. The emphasis is on open research questions that may lead to collaborative work with faculty and graduate students. (Formerly Computer Engineering 280T.)

Credits

2

CSE 280V Seminar on Computer Vision

Weekly graduate-level seminar series discussing advanced topics in computer vision and image analysis. Current research and literature presented during each meeting. Enrollment is by permission of the instructor. Enrollment is restricted to graduate students. (Formerly Computer Engineering 280V.)

Credits

2

Repeatable for credit

Yes

CSE 280X Seminar in Distributed Systems

Covers advanced research topics from the recent literature in distributed systems and related fields. Involves presentations from UCSC students and faculty. Enrollment is restricted to graduate students and by permission of the instructor.

Credits

2

Repeatable for credit

Yes

CSE 280Z Seminar in Natural Language Processing and Dialogue

Covers advanced topics and current research in natural language processing. Focuses on student presentations and seminar participation. Enrollment is restricted to graduate students. Enrollment is by permission of the instructor. (Formerly CMPS 280Z.)

Credits

2

Repeatable for credit

Yes

CSE 285 Technical Writing for Engineering Graduates

Writing skills development for graduate engineers. Students produce a major writing project with many subtasks. Exercises includes fellowship application; mathematical and algorithmic description; use of tables and graphs; experiment description; and producing technical web sites, presentations, and posters. Enrollment is restricted to graduate students in biomolecular engineering, computer science and engineering, computer science, and electrical and computer engineering and by permission of the instructor. (Formerly CMPE 285.)

Credits

5

CSE 290A Topics in Algorithms and Complexity Theory: Probabilistic Algorithms and Average Case Analysis

Graduate seminar in algorithms and complexity theory on topics from recently published research journal articles and conference proceedings. Topics vary from year to year depending on the current research of the instructor(s) and interests of students. Students read technical papers from relevant journals and conference proceedings and present class lectures. Guest lectures may supplement the student presentations. A research project and/or paper may be required. (Formerly Computer Science 290A.)

Credits

5

Requirements

Enrollment is restricted to graduate students.

Repeatable for credit

Yes

CSE 290C Advanced Topics in Machine Learning

In-depth study of current research topics in machine learning. Topics vary from year to year but include multi-class learning with boosting and SUM algorithms, belief nets, independent component analysis, MCMC sampling, and advanced clustering methods. Students read and present research papers; theoretical homework in addition to a research project. (Formerly Computer Science 290C.)

Credits

5

Requirements

Prerequisite(s): CSE 242.

Repeatable for credit

Yes

CSE 290D Neural Computation

An introduction to the design and analysis of neural network algorithms. Concentrates on large artificial neural networks and their applications in pattern recognition, signal processing, and forecasting and control. Topics include Hopfield and Boltzmann machines, perceptions, multilayer feed forward nets, and multilayer recurrent networks. (Formerly Computer Science 290D.)

Credits

5

Requirements

Enrollment is restricted to graduate students.

Repeatable for credit

Yes

CSE 290E Object-Oriented Programming Methodology

Object-oriented programming methodology is the application of abstract-data types and polymorphism to coding solution. Topics geared to beginning thesis research in this field. (Formerly Computer Science 290E.)

Credits

5

Requirements

Prerequisite(s): CSE 201 and CSE 210A. Enrollment is restricted to graduate students.

Repeatable for credit

Yes

CSE 290F Applications of Combinatorics

Combinatorial mathematics, including summation methods, working with binomial coefficients, combinatorial sequences (Fibonacci, Stirling, Eulerian, Harmonic, Bernoulli numbers), generating functions and their uses, Bernoulli processes, and other topics in discrete probability. Oriented toward problem solving, applications mainly to computer science, but also physics. (Formerly Computer Science 290F.)

Credits

5

Requirements

Prerequisite(s): CSE 16 and AM 10. Enrollment is restricted to graduate students and upper-division undergraduates.

Repeatable for credit

Yes

CSE 290G Topics in Software Engineering

Research seminar on current topics in software engineering. Topics vary from year to year depending on the current research of the instructor(s) and interests of students. Students read technical papers from relevant journals and conference proceedings. Synthesis and understanding of materials is demonstrated by a required research project. (Formerly Computer Science 290G.)

Credits

5

Requirements

Prerequisite(s): CSE 212A recommended. Enrollment is restricted to graduate students; undergraduates may enroll with permission of instructor.

Repeatable for credit

Yes

CSE 290H Topics in Database Systems

Focuses on current research topics in database systems. Different offerings cover different topics depending on current research of instructor(s) and the interests of students. Students read technical papers from journals and conference proceedings and present class lectures. A research project is required. (Formerly Computer Science 290H.)

Credits

5

Requirements

Prerequisite(s): CSE 180 (or equivalent) or CSE 214 or consent of instructor. Enrollment is restricted to graduate students.

Repeatable for credit

Yes

CSE 290J Advanced Topics in Computer Graphics and Visual Computing

A graduate seminar in computer graphics on topics from recently published research journal articles and conference proceedings. Topics vary from year to year depending on interests of students. Primary areas of interest are likely to be scientific visualization, modeling, rendering, scattered data techniques, wavelets, and color and vision models. Students read technical papers and present class lectures. Guest lecturers supplement the student presentations. A research project is required. (Formerly Computer Science 290B.)

Credits

5

Repeatable for credit

Yes

CSE 290K Advanced Topics in Natural Language Processing

Teaches participants about current methods and directions in active areas of Natural Language Processing research and applications. Students perform independent research and hone skills with state-of-the-art NLP tools and techniques.

Credits

5

Requirements

Enrollment is restricted to computer science and engineering, computer engineering, computer science, and technology management graduate students.

Repeatable for credit

Yes

CSE 290L Topics in Crowdsourcing and Collaboration

Explores the foundations of crowdsourcing and computer-mediated collaboration. Covers the algorithmic and statistical foundations of crowdsourcing, introducing and analyzing algorithms, and experimenting with concrete systems. Also, provides an introduction to computational systems for mediating user interaction and collaboration. (Formerly Computer Science 290L.)

Credits

5

Requirements

Enrollment is restricted to graduate students.

CSE 290M Topics in Parallel Computation

Investigates selected topics in applied parallel computation. Topics may include numerical methods, artificial intelligence and machine learning algorithms, graphics and image processing, systolic algorithms, and the interplay between hardware and algorithms. Students are encouraged to investigate and discuss the parallelization of their own research. (Formerly Computer Engineering 290M.)

Credits

5

Requirements

Enrollment is restricted to graduate students.

CSE 290N Topics in Computer Performance

Selected topics of current interest in the area of computer system performance. Subjects may include aspects of large systems, performability, computer networks, storage subsystems, and nontraditional approaches and are subject to periodic revision. (Formerly Computer Engineering 290N.)

Credits

5

Requirements

Enrollment is restricted to graduate students.

CSE 290O Algorithmic Foundations of Convex Optimization

Focuses on some of the foundational aspects of convex and its relationship to modern machine learning. Discusses positive results--how can you solve convex optimization problems--and negative ones with statements like This family of problems is too hard to be solved in reasonable time. Course is divided into three parts, each exploring a different aspect of convex optimization: 1) algorithmic frameworks; 2) Oracle complexities; 3) the power of randomness. Through this course students are exposed to general concepts of convex geometry, learning theory, and rigorous proofs. (formerly CMPS 290O.)

Credits

5

Requirements

Prerequisite(s): CSE 201 and CSE 242. Enrollment is restricted to computer engineering and computer science graduate students.

CSE 290P Data Privacy Via Machine Learning, and Back

Helps students achieve both expository knowledge and expertise in the field of data privacy. Focuses on fundamental techniques used in designing privacy-preserving, machine-learning systems in both academia and in the industry. Students are expected to read and understand recent research papers in the topic. (Formerly Computer Science 290P.)

Credits

5

Requirements

Prerequisite(s): CSE 201 and CSE 242 or equivalent. Enrollment is restricted to graduate students.

Repeatable for credit

Yes

CSE 290Q Topics in Programming Languages

Current research topics on computer programming languages. Topics vary year to year. Students read papers from current conferences and journals, and present class lectures. A research project is required. (Formerly Computer Science 290Q.)

Credits

5

Requirements

Prerequisite(s): CSE 210A. Enrollment is restricted to graduate students.

Repeatable for credit

Yes

CSE 290S Advanced Topics in Computer Systems

Focuses on current research topics in computer systems. Topics vary from year to year depending on the current research of the instructor(s) and the interests of the students. Students read technical papers from current journals and conference proceedings, and present class lectures. A research project is required. (Formerly Computer Science 290S.)

Credits

5

Requirements

Prerequisite(s): CSE 231 recommended. Enrollment is restricted to graduate students; qualified undergraduates may enroll with instructor's consent.

Repeatable for credit

Yes

CSE 290T Topics in Computing for Society

Current research topics on computer technology that is intentionally targeted to benefiting society. Topics vary year to year. Students read papers from current conferences and journals, and present class lectures. A research project is required. (Formerly Computer Science 290T.)

Credits

5

Requirements

Enrollment is restricted to graduate students.

Repeatable for credit

Yes

CSE 290X Cryptography and Computer Security

Research seminar on encryption and related technologies. Topics include theory of codes, random sequences and generators, public key cryptosystems, private key cyphers, key exchange protocols, quantum computing and cryptography. Major project required. Prerequisite: interview with instructor. (Formerly Computer Science 290X.)

Credits

5

Repeatable for credit

Yes

CSE 293 Advanced Topics in Computer Science & Engineering

A graduate seminar on a research topic in computer engineering which varies according to instructor. Possible topics include, but are not limited to, communication networks, data compression, special-purpose architectures, computer arithmetic, software reliability and reusability, systolic arrays. (Formerly Computer Engineering 293.)

Credits

5

CSE 296 Masters Project

Independent completion of a masters project under faculty supervision. Students submit petition to sponsoring agency.

Credits

2

Repeatable for credit

Yes

CSE 297A Individual Study or Research

Independent study or research under faculty supervision. Although this course may be repeated for credit, not every degree program will accept a repeated course towards degree requirements. Students submit petition to sponsoring agency.

Credits

5

Repeatable for credit

Yes

CSE 297B Individual Study or Research

Independent study or research under faculty supervision. Although this course may be repeated for credit, not every degree program will accept a repeated course towards degree requirements. Students submit petition to sponsoring agency.

Credits

10

Repeatable for credit

Yes

CSE 297C Individual Study or Research

Independent study or research under faculty supervision. Although this course may be repeated for credit, not every degree program will accept a repeated course towards degree requirements. Students submit petition to sponsoring agency.

Credits

15

Repeatable for credit

Yes

CSE 297F Independent Study or Research

Independent study or research under faculty supervision. Although this course may be repeated for credit, not every degree program will accept a repeated course toward degree requirements.

Credits

2

Repeatable for credit

Yes

CSE 299A Thesis Research

Thesis research conducted under faculty supervision. Although the course may be repeated for credit, not every degree program will accept a repeated course towards degree requirements. Students submit petition to sponsoring agency.

Credits

5

Repeatable for credit

Yes

CSE 299B Thesis Research

Thesis research conducted under faculty supervision. Although the course may be repeated for credit, not every degree program will accept a repeated course towards degree requirements. Students submit petition to sponsoring agency.

Credits

10

Repeatable for credit

Yes

CSE 299C Thesis Research

Thesis research conducted under faculty supervision. Although the course may be repeated for credit, not every degree program will accept a repeated course towards degree requirements. Students submit petition to sponsoring agency.

Credits

15

Repeatable for credit

Yes

CSE 299F Thesis Research

Independent study or research under faculty supervision. Enrollment is restricted to graduate students. Recommended for part-time students. Students submit petition to sponsoring agency.

Credits

2

Repeatable for credit

Yes

Cross-listed courses that are managed by another department are listed at the bottom.

Cross-listed Courses

CSE 185E Technical Writing for Computer Science and Engineering

Writing by engineers and computer scientists to technical audiences. Writing exercises include: cover letter and resume for job application, tutorial writing, grant proposal, document specification, literature review, and a final technical report. Two oral presentations are also required, an in-class presentation and a poster presentation. Students also receive instruction in the use of UC library and journal database resources, and in the writing of a statement of purpose for graduate school application. Also offered as CSE 185S. (Formerly Computer Engineering 185, Technical Writing for Computer Engineers.)

Credits

5

Cross Listed Courses

CSE 185S

Requirements

Prerequisite(s): satisfaction of Entry Level Writing and Composition requirements; and CSE 12 or CSE 15 or CSE 30 or BME 160 or by permission of the instructor. Enrollment is restricted to computer engineering, bioengineering, bioinformatics, biomolecular engineering and bioinformatics, or network and digital technology majors.

ECE 253 Introduction to Information Theory

An introduction to information theory including topics such as entropy, relative entropy, mutual information, asymptotic equipartition property, channel capacity, differential entropy, rate distortion theory, and universal source coding. (Formerly EE 253 and CMPS 250.)

Credits

5

Cross Listed Courses

CSE 208

Requirements

Enrollment is restricted to graduate students.

ECON 166B Game Theory and Applications II

Explores research frontiers in game theory, emphasizing applications in social science, biology, and engineering. Each interdisciplinary team develops a topic, and presents it to the class in oral and written reports and demonstrations. Students must have shown a strong performance in course 166A or equivalent. Students cannot receive credit for this course and ECON 272, CSE 209, or BIOE 274.

Credits

5

Cross Listed Courses

CSE 166B

Instructor

The Staff

Requirements

Prerequisite(s): ECON 166A or CSE 166A; satisfaction of the Entry Level Writing and Composition requirements. Enrollment is restricted to juniors and seniors.

ECON 272 Evolutionary Game Theory

Reviews static equilibrium concepts, games of incomplete information, and the traditional theory of dynamic games in discrete time. Develops recent evolutionary game models, including replicator and best reply dynamics, and applications to economics, computer science, and biology. Prerequisite(s): upper-division math courses in probability theory are strongly recommended. Cannot receive credit for this course and ECON 166B or CSE 166B.

Credits

5

Cross Listed Courses

BIOE 274, CSE 209

Instructor

The Staff

PHYS 150 Quantum Computing

Review of linear algebra. Includes basic concepts in quantum mechanics including quantum states, measurements, operators, entanglement, entanglement entropy, "no cloning" theorem, and density matrices; classical gates, reversible computing, and quantum gates; several quantum algorithms including Deutsch's algorithm, Simon's algorithm, Shor's algorithm, and the Grover algorithm; quantum error correction; and quantum key distribution and teleportation.

Credits

5

Cross Listed Courses

CSE 109

Instructor

Peter Young

Requirements

PHYS 116A or MATH 21 or AM 10. Enrollment is restricted to juniors and seniors.

Quarter offered

Spring

STAT 266A Data Visualization and Statistical Programming in R

Introduces students to data visualization and statistical programming techniques using the R language. Covers the basics of the language, descriptive statistics, visual analytics, and applied linear regression. Enrollment is by permission of the instructor. (Formerly Applied Math and Statistics 266A and Computer Science 266A.)

Credits

3

Cross Listed Courses

CSE 266A

STAT 266B Advanced Statistical Programming in R

Teaches students already familiar with the R language advanced tools such as interactive graphics, interfacing with low-level languages, package construction, debugging, profiling, and parallel computation. (Formerly Applied Math and Statistics 266B and Computer Science 266B.)

Credits

3

Cross Listed Courses

CSE 266B

Requirements

Prerequisite(s): STAT 266A or CSE 266A.

STAT 266C Introduction to Data Wrangling

Introduces students to concepts and tools associated with data collection, curation, manipulation, and cleaning including an introduction to relational databases and SQL, regular expressions, API usage, and web scraping using Python. (Formerly Applied Math and Statistics 266C and Computer Science 266C.)

Credits

3

Cross Listed Courses

CSE 266C

Requirements

Prerequisite(s): STAT 266A or CSE 266A.