Deep Learning for Robot Locomotion
We explore ways in which deep reinforcement learning can be used to help underactuated and unintuitive robots learn locomotion tasks, ranging from gait discovery to path planning.
We explore ways in which deep reinforcement learning can be used to help underactuated and unintuitive robots learn locomotion tasks, ranging from gait discovery to path planning.
We explore ways in which ideas and techniques from geometric mechanics can be applied to underactuated and dynamic robot systems with an eye toward locomotion.
We explore ways in which inherent symmetries in different systems can be used to improve or make reinforcement learning techniques more efficient.
Summer 2024, Spring 2024, Spring 2023, Spring 2022, Summer 2021, Fall 2020, Fall 2019, Fall 2018
Artificial intelligence (AI) is a broad, interdisciplinary, and fast-growing subfield of computer science concerned with the construction and deployment of intelligent agents. This course provides an overview of the methods and applications of AI, with a focus on algorithms and computation. Topics include search and planning problems and game-playing, sequential decision problems and reinforcement learning, probabilistic models and inference, and supervised and deep learning. Students will develop intuition and algorithmic thinking through written as well as programming problems in Python. By the end of the course, students will be able to build intelligent agents that can solve problems through search, make decisions and reason in the face of uncertainty, and learn simple models from data.
Spring 2024, Fall 2021, Spring 2021, Spring 2019
This course is an introduction to fundamental problems and algorithms in robotics from a computer scientist’s perspective. While robotics is inherently a broad and interdisciplinary field, we will primarily focus on ideas with roots in computer science, as well as the roles that a computer scientist would play in robotics research or engineering tasks. Topics include configuration spaces, kinematics, search and sampling-based planning, state estimation, localization and mapping, perception, and learning.
Fall 2023, Fall 2022, Spring 2019
The study of discrete mathematics provides an important foundation for basic theoretical principles in computer science. We first build a strong foundation in logic, formal proofs, and mathematical induction. We then examine the discrete structures of functions, relations, and graphs, which provide different ways of representing relationships, connections, and networks. Finally, we move onto numerical and computational aspects: number theory and modular arithmetic, counting and combinatorics, and discrete probability. Throughout the course, we will also see computer science applications and practice writing implementations in Python.
Spring 2023, Spring 2022, Fall 2021, Spring 2021, Spring 2020
This course is an introduction to linear algebra and its usage in computational applications. The study of linear equations, linear functions, and their representations pervades numerous fields of study. Students will learn and practice fundamental ideas of linear algebra and simultaneously be exposed to and work with real-world applications of these ideas. This course emphasizes a rigorous approach to mathematics, which will serve as a foundation for future courses like computer graphics, machine learning, and robotics. The learning and usage of Python and libraries such as NumPy is an essential component of the course, as is the development of basic skills of computational programming.
Spring 2013 - Spring 2018 (Carnegie Mellon)
Although I was never a formal instructor for this course, I initially was a graduate student TA and then worked closely with my advisor in subsequent semesters to implement an online curriculum for present offerings of the course.
Summer 2012 (UC Berkeley)
This was my first foray into teaching as a 5-time TA and instructor for a course in introductory circuits during my undergraduate years at Berkeley.