University of Wisconsin - Madison
2025 Spring (Expected)
- CS 577 - Introduction to Algorithms (Honor)
- CS 639 - Deep Learning for Computer Vision
- CS 520 - Introduction to Theory of Computing
- MATH 522 - Analysis II (Honor)
- ENGL 177 - AI: Reimagining Communication
Details of Selected Courses
MATH 240
An introduction to discrete mathematics. We covered topics such like proof techniques, recursion and structural induction, recurrences, functions and relations, graphs and trees, finite automata and regular expressions, and counting.Introduction to Discrete Mathematics
MATH 341
An introduction to linear algebra. This is one of the hardest linear algebra courses in UW-Madison. We talked about some properties of vector space, subspace, and field first. Then we covered the regular topics such as matrix calculation, eigenvalues, diagonalization, Gram-Schmidt Orthogonalization Process and Orthogonal Complements. Details can be seen in my github repo MATH341.Linear Algebra (Honor Section)
COMP SCI 300
My first formal Computer Science course in UW-Madison. This course talked about some basic objects and properties of Java like polymorphis. Also, it introduced some simple data structures like binary search tree, heap, etc. There were 10 programming assignments in total, all of them are strongly related with current topic. All of them should be completed with Java.Programming II
MUSIC 60
University string orchastra opened for all students in our university. I play cello in this orchastra. This course has rehearsals every week, and a concert at the end of semester.All-University String Orchestra
COMP SCI 252
An introduction to computer engineering. It introduced how computers compile programs, various electronic components, and how to write assembly language. There are programming assignments in LC-3 language.Introduction to Computer Engineering
COMP SCI 400
This is the third and final course in the series of Java programming course CS200/300/400. In this course we learnt some useful CS techniques, including usage of various Linux commands and git. Also, we learnt more algorithms including Kruskal, Dijkstra, and data structures like red-black tree.Programming III
MATH 521
Introduction to mathematics analysis. It covered several topics about analysis, including basic set theory, topology on metric spaces, formal definitions of derivative and integral, and some techniques about analyzing properties of sequence, series, and functions. We used baby rudin (Principles of Mathematical Analysis) as our textbooks, which is written by professor Rudin from our university!Analysis I (Honor Section)
MATH 541
This course introduced abstract algebra. Topics basic set theory, group theory (including group actions), ring theory, Euclidean Domain, Principle Ideal Domain, and congurence problems with Chinese Remainder Theorem are covered and all appear in the homework and exams. We mainly followed the lecture notes written by professor Chenxi Wu. I wrote several blogs about topics that are covered in this course.Modern Algebra (Honor Section)
MATH 551
In this course, we learnt point set topology, in the order of set theory, topology on metric spaces, then point set topology (general topology). I wrote several blogs about topics that are covered in this course.Elementary Topology (Honor Section)
MATH/CS 475
This course introduced various topics about combinatorics, including generating permutations and combinations, binomial coefficients, inclusion-exclusion principle, recurrence relations, generating functions, special counting sequences (First/Second Stirling number, Catalan number), and Polya Counting. It is interesting that these topics are also covered in International Collegiate Programming Contest. We used a textbook written by professor Brualdi, who also comes from our university.Introduction to Combinatorics
COMP SCI 540
As its name, this is an introduction to artificial intelligence. Indeed, this is one of the most popular upper level CS courses in UW-MAdison, probably because its name. As there are to many topics that are covered in this course, please refer to our course webpage if you are interested in the topics of this course. There are 10 programming assignments in this course. All of them (except the first one about writing essay) should be completed by python. While there are few prerequistes for this course, you need a solid understanding in basic probability theory and linear algebra to fully grasp this course.Introduction to Artificial Intelligence
COMP SCI 502
This is a course about CS education. We discuessed lots of topics about the problems in CS education, such as the usage of LLM, how to make students feel more belonging in CS courses, and what are the characteristics of a good peer mentor. We are also asked to watch how peer mentors/TAs work, and write reports and thoughts from the observation.Theory and Practice in Computer Science Education