Course Load
Note: CMU counts Units differently than most other schools. To convert to normal credits, divide by 3. So a 12 Unit course would be similar to a 4-credit course at another university.
Fall 2023:
15-281 Artificial Intelligence: Representation and Problem Solving (12 Units)
This course is about the theory and practice of Artificial Intelligence. We will study modern techniques for computers to represent task-relevant information and make intelligent (i.e., satisficing or optimal) decisions towards the achievement of goals. The search and problem-solving methods are applicable throughout a large range of industrial, civil, medical, financial, robotic, and information systems. We will investigate questions about AI systems such as: how to represent knowledge, how to effectively generate appropriate sequences of actions and how to search among alternatives to find optimal or near-optimal solutions. We will also explore how to deal with uncertainty in the world and how to learn from experience. We will cover the aggregation of conflicting preferences and computational game theory. Throughout the course, we will discuss topics such as AI and Ethics and introduce applications related to AI for Social Good. We expect that by the end of the course students will have a thorough understanding of the algorithmic foundations of AI, how probability and AI are closely interrelated, and how automated agents make decisions. We also expect students to acquire a strong appreciation of the big-picture aspects of developing fully autonomous intelligent agents.
15-210 Parallel and Sequential Data Structures and Algorithms (12 Units)
15-210 aims to teach methods for designing, analyzing, and programming sequential and parallel algorithms and data structures. The emphasis is on teaching fundamental concepts applicable across a wide variety of problem domains, and transferable across a reasonably broad set of programming languages and computer architectures. This course also includes a significant programming component in which students will program concrete examples from domains such as engineering, scientific computing, graphics, data mining, and information retrieval (web search). Unlike a traditional introduction to algorithms and data structures, this course puts an emphasis on parallel thinking — i.e., thinking about how algorithms can do multiple things at once instead of one at a time.
36-218 Probability Theory for Computer Scientists (9 Units)
This is a first course in probability theory, and no prior background in probability or statistics is assumed or required. Probability theory is at the core of statistics, machine learning, decision theory, and many other areas. Throughout the semester, we will develop the concepts and methods of probability and apply them to problems in statistics, statistical machine learning, and computer science, among others. Unlike most probability courses at this level, we will emphasize the foundations of a probability model in some detail. The reason is that once this is understood, all of the work we do later with random variables, random experiments, probabilities, and expectation will make more sense. We will explore the concepts of distributions and conditioning. We will work with mathematical models for random systems evolving in time or space, which are called stochastic processes. And we will develop statistical methods using probabilistic concepts.
15-387 Computational Perception (9 Units)
The perceptual capabilities of even the simplest biological organisms are far beyond what we can achieve with machines. Whether you look at sensitivity, robustness, adaptability and generalizability, perception in biology just works, and works in complex, ever changing environments, and can make inference on the most subtle sensory patterns. Is it the neural hardware? Does the brain use a fundamentally different algorithm? What can we learn from biological systems and human perception? In this course, we will study the biological and psychological data of biological perceptual systems, mostly the visual system, in depth, and then apply computational thinking to investigate the principles and mechanisms underlying natural perception. You will learn how to reason scientifically and computationally about problems and issues in perception, how to extract the essential computational properties of those abstract ideas, and finally how to convert these into explicit mathematical models and computational algorithms. The course is targeted to both neuroscience and psychology students who are interested in learning computational thinking, as well as computer science and engineering students who are interested in learning more about the neural and computational basis of perception. Prerequisites: First year college calculus, differential equations, linear algebra, basic probability theory and statistical inference, and programming experience are desirable.
85-211 Cognitive Psychology (9 Units)
Cognitive Psychology is the study of the mind; how we perceive the world, remember, reason, think, and learn. To study the mind, cognitive psychologists use methods including laboratory experiments, computational models, brain imaging, and studying the effects of brain damage. We will discuss all of these approaches during the course, learning about key theories and research findings that have emerged from the field of Cognitive Psychology.
03-125 Evolution (9 Units)
Evolutionary theory is the unifying principle of biology. A good comprehension of the concepts that underlie this theory is therefore important to properly appreciate and understand any biological process. This course is designed for students intending to continue studies in biology so that they may gain an understanding of the evolutionary framework in their more advanced courses, and also non-biology majors who want to extend their knowledge of biology at an introductory level. The lectures will include (i) an examination of the history and development of evolutionary theory, (ii) consideration of some of the facts that have established the theory, (iii) an introduction to the concepts of phylogenetics, (iv) discussion of the patterns and mechanism that lead to the diversity and origins of the groups of life, (v) an introduction to genetics and population genetic theory, and (vi) discussion of and how this applies to natural selection and speciation. The course will also include some more specialist topics, including evolution of development, sexual selection, evolutionary applications to medicine and conservation biology, and genome evolution. Assessment will be based on several in-class exams and quizzes, homework assignments, a written term paper, and a final exam.
17-603 Communications for Software Leaders I (3 Units, Master's Class)
Communication skills are fundamental to professionals in all fields, from architecture to software engineering to zoology, because they enable the exchange of ideas and the completion of organizational goals. The ability to identify an audience, to develop clear, persuasive presentations and written documents, and to handle the complex interactions that occur in the workplace make the difference between those who participate in an organization and those who lead it. This is the first course in a two-semester sequence designed to help you build and refine your skills so that you can communicate as a leader in your professional work. Through a combination of in-class exercises, case studies, projects, presentations, and written assignments, you will assess your current skill level and build upon it.
Fall 2023 Total Units: 63
Summer 2023:
15-150 Functional Programming (12 Units)
The purpose of this course is to introduce the theory and practice of functional programming (FP). The characteristic feature of FP is the emphasis on computation as evaluation. The traditional distinction between program and data characteristic of imperative programming (IP) is replaced by an emphasis on classifying expressions by types that specify their applicative behavior. Types include familiar (fixed and arbitrary precision) numeric types, tuples and records (structs), classified values (objects), inductive types such as trees, functions with specified inputs and outputs, and commands such as input and output. Well-typed expressions are evaluated to produce values, in a manner that is guaranteed to be type-safe. Because functional programs do not cause side-effects we can take advantage of simple mathematical principles in reasoning about applicative behavior and analyzing the runtime properties of programs.
Grade Received: A
15-213 Introduction to Computer Systems (12 Units)
The ICS course provides a programmer's view of how computer systems execute programs, store information, and communicate. It enables students to become more effective programmers, especially in dealing with issues of performance, portability and robustness. It also serves as a foundation for courses on compilers, networks, operating systems, and computer architecture, where a deeper understanding of systems-level issues is required. Topics covered include: machine-level code and its generation by optimizing compilers, performance evaluation and optimization, computer arithmetic, memory organization and management, networking technology and protocols, and supporting concurrent computation.
Grade Received: A
Summer 2023 Total Units: 24
Spring 2023:
15-251 Great Theoretical Ideas in Computer Science (12 Units)
This course is about the rigorous study of computation, which can be described as the process of manipulating information. Computation is a fundamental component of minds, civilizations, nature and the universe. Therefore, having the right language and tools to reason about computation is an important goal. This course teaches the mathematical underpinnings of computation and explores some of the central results and questions regarding the nature of computation.
Grade Received: A
21-241 Matrices and Linear Transformations (10 Units)
A first course in linear algebra intended for scientists, engineers, mathematicians and computer scientists. Students will be required to write some straightforward proofs. Topics to be covered: complex numbers, real and complex vectors and matrices, rowspace
and columnspace of a matrix, rank and nullity, solving linear systems by row reduction of a matrix, inverse matrices and determinants, change of basis, linear transformations, inner product of vectors, orthonormal bases and the Gram-Schmidt process, eigenvectors and eigenvalues, diagonalization of a matrix, symmetric and orthogonal matrices.
Grade Received: A
73-102 Principles of Microeconomics (9 Units)
The course is an introduction to microeconomic principles and how to think like an economist. Market and policy outcomes are largely a function of individual decisions. These questions typically take the form: how much and what combination of things should I buy? When do we want businesses to go bust? Should the government fund student tuition? Its my hope that youll also start to think about everyday questions from an economic lens: why were bicycles so hard to find this past summer? Is Uber surge pricing just a rip-off? Is illegal streaming bad for consumers? Throughout the semester, we will build a toolkit to allow us to understand how these decisions interact and explain market successes, market failures, and the role of government in the marketplace. Toward the end of the semester, well change a few underlying assumptions and address a variety of questions related to strategic interaction. Some of the topics we will begin to introduce include credible threats, commitment problems, and the strategic use of information.
Grade Received: B
80-100 Introduction to Philosophy (9 Units)
Even philosophers have a hard time explaining what exactly philosophy is. Instead of attempting a definition, one might instead list some of the questions philosophers try to answer. Like most other academic fields, philosophy has its own sub-disciplines, and each of these has its own questions it tries to answer. In this course, we will be looking at questions from several of these areas of philosophy, including: What is the mind? Do we have free will? What does the answer to that question mean for practices of reward and punishment? Is morality relative? What, if anything, is its connection to religion? How can I know the right thing to do? How can I know anything? This class isn't a historical introduction to philosophy, and we will be jumping around through history and subjects as we please, concerned only with interesting questions and good answers. As a whole, the course will strongly emphasize some of the basic skills of doing just about any kind of philosophy: how to recognize and understand arguments, how to evaluate them, and how to construct your own. As it turns out, these are skills you need to successfully navigate your way through just about any field of study and any career. This course will include a fair amount of writing, but you'll be getting lots of help from me, from your TA, and even from your peers.
Grade Received: B
66-122 Beyond Earth: Reaching into the Cosmos through Science, Science Fiction, and Language (9 Units)
The aim in the course is to foster in students a planetary perspective, to see Earth in its context of the cosmos and to see humans in their relation to real or possible forms of life in the universe. The obsession with outer space is found among scientists, business people and politicians, in deed and story, in film and even computer games. If we are to fully appreciate the potentials of space, we must also consider the search for intelligent life in its scientific and societal aspects, and investigate how we could adapt our systems of communication to reach species across distances that may be physically insurmountable. This interdisciplinary course will be taught by scholars from distinct cultural and linguistic backgrounds. Course materials will be taken from scientific literature, the history of science, and science fiction. We will explore scientific writing and reasoning, the space race between global powers, space travel and colonization, and the promise and pitfalls of interspecies and interspace communication. A planetary perspective, once achieved, can change the way one sees other inhabitants of this planet – as partners in survival in a universe which sets enormous odds against it, or as unwelcome intruders grasping for scant resources within this thin epidermis of soil, air, and water which surrounds Earth and makes our lives possible.
Grade Received: A
76-107 Writing about Data (4.5 Units)
Our lives are increasingly shaped by writing that involves numbers: newspapers routinely report the latest medical fads; politicians support their political agendas with both dubious and credible statistics; parents use data to decide where to buy a house and where to send their kids to school. This course (one of two minis students can choose to fulfill their FYW requirement) focuses upon interpreting and making arguments using mainly numerical data but also qualitative data. We will look at research in a range of disciplines including psychology, education, medicine, engineering, and the sciencesand note how writers select and analyze the data they collect. We will also examine what happens to this research when it is picked up by the popular media. Students will also practice collecting and analyzing their own data and reporting it to suit the needs of various stakeholders. There are two primary audiences for this section. Students in data-driven majors will find the section useful preparation for communicating in their disciplines. Students in other fields will learn how to critique and respond to the many ways that numbers shape our lives. This section presumes a basic ability to calculate averages, percentages, and ratios, but no advanced mathematical or statistical preparation. Instead, this section provides a fascinating look at how numbers and words intersect to create persuasive arguments in academic, professional, and popular contexts. Students will compare and analyze texts that make arguments with data, practice rhetorical strategies for synthesizing and representing data so that by the end of the class, students will apply these strategies to write an original data-driven research proposal.
Grade Received: A
76-106 Writing about Literature, Art and Culture (4.5 Units)
This mini course uses artistic, literary, and cultural texts (e.g., poetry, short story, lyrics, video clips) to introduce students to a variety of academic reading and writing practices that enable students to engage with texts and write about them with complexity and nuance. Within the course, we will discuss texts and evidence from multiple perspectives. We will examine how literary and cultural scholars write about texts (defined broadly), how they make claims, provide reasoning, and use textual support to argue for particular ways of seeing cultural objects. Throughout the semester, students will draw upon prior strategies and develop new ones for close reading and for critical analysis in order to produce their own thesis-driven arguments about why texts matter. We will consider and write about the extent to which these reading strategies are relevant for other kinds of reading and analysis by comparing texts from a variety of different disciplinary contexts.
Grade Received: B
Spring 2023 Total Units: 58
Fall 2022:
15-122 Principles of Imperative Computation (10 Units)
This course teaches imperative programming in a C-like language and methods for ensuring the correctness of imperative programs. It is intended for students who are familiar with elementary programming concepts such as variables, expressions, loops, arrays, and functions. Given these building blocks, students will learn the process and techniques needed to go from high-level descriptions of algorithms to correct imperative implementations, with specific applications to basic data structures and algorithms. Much of the course will be conducted in a subset of C amenable to verification, with a transition to full C near the end.
Grade Received: A
21-128 Math Concepts and Proofs (12 Units)
In this class we will learn how to provide complete explanations of why certain things are true. We will also determine how to detect false statements and provide conclusive evidence of their falsity.
We will begin with concrete objects like numbers, sets and functions and learn to prove things about them using elementary logic. After studying a proof technique known as induction, we will explore functions and use them to classify the size of infinite sets (yes, there are different sized infinite sets).
Next we will find out how to count the number of objects that can be obtained as the result of a certain process. For example, we can count the number of distinct poker hands which have three aces and two kings or the number of different three-topping pizzas that can be made if ten toppings are available. We then tackle elementary problems concerning integers, such as factorization, divisibility and their possible applications to cryptography.
Lastly, we will study some classic topics from Discrete Math. Elementary probability will be explored in order to ascertain, for example, just how likely are we to be dealt a poker hand containing three aces and two kings. We will see that probability is related to counting and will move on to study useful topics in counting known as the pigeonhole principle and inclusion/exclusion.
Grade Received: B
21-259 Calculus in Three Dimensions (9 Units)
In this course we will learn about differentiation and integration of functions of more than one variable, and tie these topics together with the study of vector calculus.
First we will spend some time with the basic elements that we'll need to understand: the geometry of three dimensions, lines and planes, functions of 2 (or more) variables, limits and continuity for these functions, and so on. Partial derivatives, which allows us to determine rates of change of a function with respect to each independent variable, will then be introduced. Other differentiation concepts will be studied as well, including the total derivative of a function, the gradient of a function, and the divergence and curl of a field. Various applications of derivatives will again be considered, and most importantly the optimization problems.
Integration will be introduced, and the various types of integrals will depend on the function and domain considered. Keep in mind that the integral is a tool, an extremely flexible and powerful tool to measure and analyze functions. We'll encounter double integrals, triple integrals, line integrals along curves, and surface integrals. Also, we'll integrate vector fields over both oriented curves and surfaces. Fortunately, we'll be able to reduce the calculation of these integrals to one-variable integrals.
Grade Received: A
85-102 Introduction to Psychology (9 Units)
How does the science of psychology help us understand the thoughts, feelings, and behaviors we see and experience in everyday life? What are the main disciplines within psychology? What are the different questions each discipline seeks to answer?
This course will serve as an introduction to the field of psychology and its many different areas and applications. You will learn about the central methods, findings, and unanswered questions of these areas, as well as how to interpret and critically evaluate research findings. The course, overall, will attempt to foster interest in psychology as well as scientific curiosity in an engaging, supportive, and intellectually stimulating environment.
Grade Received: A
36-200 Reasoning with Data (9 Units)
This course is an introduction to learning how to make statistical decisions and now to reason with data. The approach will emphasize the thinking-through of empirical problems from beginning to end and using statistical tools to look for evidence for/against explicit arguments/hypotheses. Types of data will include continuous and categorical variables, images, text, networks, and repeated measures over time. Applications will largely drawn from interdisciplinary case studies spanning the humanities, social sciences, and related fields. Methodological topics will include basic exploratory data analysis, elementary probability, significance tests, and empirical research methods. There will be once-weekly computer lab for additional hands-on practice using an interactive software platform that allows student-driven inquiry.
Grade Received: A
Fall 2022 Total Units: 49