Computer Science Program
From Undergraduate Engineering Handbook
2015-16 Computer Science Program Requirements
- UG Director: Mehran Sahami, Gates 180, firstname.lastname@example.org
- Student Services Meredith Hutchin, 160 Gates, email@example.com
- Dept Chair: Alex Aiken, firstname.lastname@example.org
Looking at technology today, it is hard to believe that the first computers were developed only seventy years ago. Computers are everywhere, and much of modern engineering involves the application of computer technology. The undergraduate major in computer science offers a broad and rigorous training for students interested in the science of computing. The track structure of the CS program also allows you to pursue the area(s) of CS you find most interesting while giving you a solid overall foundation in the field.
Many students obtaining a BS in CS will go on to work in industry or do graduate work in a branch of CS such as artificial intelligence, robotics, software design, graphics, theory, or hardware design. But CS is not just for future computer scientists. There is an increasing demand for people trained in CS and some other field. If you are interested in working as a manager of a high-tech company, a BS in CS along with an MBA is a great combination. If you want to work on court cases involving software piracy, you will be well served by a BS in CS combined with a JD. Similar opportunities exist for those who combine a BS in CS with an MD or other graduate degree.
The minimum major in computer science consists of 96 units, including 26 units of math, 11 units of science, 13 units of engineering fundamentals, one course in TIS (Technology in Society), and 43 units of core depth. After learning essential programming techniques in CS106 (via the CS106A/B/X courses) and the mathematical foundations of computer science in CS103, the computer science major offers coursework in areas such as artificial intelligence, biocomputation, computer engineering, graphics, human-computer interaction, information, systems, and theory.
The Computer Science Department also participates in two interdisciplinary majors: Mathematical and Computational Sciences, and Symbolic Systems.
Joint Majors in CS + one of 10 Humanities majors: Joint majors follow the full CS requirements but can drop two CS depth electives. Read the notes for each track's Depth requirements for
specific details. For further detail on the Joint Majors and how to declare go to Explore Degrees, CS Joint Majors.
Undergraduate Research Opportunities
In addition to the honors program in CS (see the link to Honors on the home page of this site), there are many opportunities for undergraduates to get involved in research. Here is a partial list:
CURIS (Undergraduate Research in Computer Science)
Each summer undergraduates work with CS faculty through the summer research college. Interested students apply for positions during the winter quarter, and CURIS decisions are then made and offers sent out before spring quarter begins. These positions are fully-funded and provide invaluable experience in cutting-edge research. All CS students are notified via email of CURIS opportunities and the application process.
Research Seminars and Talks
At various times throughout the year the CS department hosts talks and presentations on various research and technology topics. In addition to these one-time events, there are regularly scheduled seminars that are open to undergraduates. Many of these seminars are available as 1 unit, 500-level courses, but enrollment is not required for attendance.
For Students Interested in Pursuing a Research-Oriented Undergraduate Program:
Freshman and Sophomore Year
Students interested in pursuing research should plan to finish the majority of the CS core (CS 103, 106, 107, 109, 110, and 161) by the end of the sophomore year. If you already have an idea of the area in CS you'd like to pursue, you may find these course suggestions useful:
If you’re considering…
- Possible AI courses: make sure to take CS 109 freshman/sophomore year
- Possible graphics courses: make sure to take Math 51 and/or Math 104 freshman/sophomore year
- Possible theory courses: make sure to take CS 109, CS 154, or CS 161 freshman/sophomore year
Students doing summer research through CURIS should expect to take a course or two spring quarter to prepare them for their research project.
During the junior year students considering research can take one of the following sequences, depending upon your field of interest:
- Artificial Intelligence: Autumn: CS 221, Winter: Any 22X, Spring: Coursework suggested by CURIS advisor
- Databases: Autumn: CS 145, Winter: CS 245, Spring: Coursework suggested by CURIS advisor
- Graphics: Autumn: CS 148, Winter: CS 248, Spring: Coursework suggested by CURIS advisor
- Human-Computer Interaction: Autumn: CS 147, Winter: CS 247, Spring: Coursework suggested by CURIS advisor
- Systems: Autumn: CS 144, Winter: CS 140, Spring: Coursework suggested by CURIS advisor
- Theory: Autumn: CS 157 & 161, Winter: CS 259, Spring: Coursework suggested by CURIS advisor
Students doing summer research through CURIS should expect to take a course or two spring quarter to prepare them for their research project.
At the end of the junior year students who qualify are encouraged to apply for the CS honors program (see the Computer Science ‘honors’ section in Chapter 6). Students who are accepted spend the senior year exploring a research topic in depth and writing an honors thesis.
Note: The above are meant to be taken only as suggestions. If you have questions, contact the CS course advisor at email@example.com.
(26 units minimum; see program sheet footnotes for options and restrictions)
- MATH 41 & 42. Calculus, 10 units, Aut-Wtr (or MATH 19, 20, 21 or AP credit) -- Freshman year
- CS 103. Mathematical Foundations of Computing, 5 units, Aut-Wtr-- Freshman year
- CS 109. Introduction to Probability for Computer Scientists, 5 units, Wtr-Spr -- Sophomore year
- Mathematics electives, two required, 6 units minimum -- see footnotes on program sheets
(11 units minimum)
- PHYSICS 41 (or 21 or 61). Mechanics, 4 units, Wtr -- Freshman year
- PHYSICS 43 (or 23 or 63). Electricity and Magnetism, 4 units, Spr -- Freshman year
- Science Elective (see footnotes on program sheets for options and restrictions)
(13 units minimum)
- ENGR 40 or ENGR 40A or ENGR 40M. Introductory Electronics or Making Stuff: What is EE, 3-5 units ( if one of these courses is taken for fewer than 5 units, students are required to complete 2 additional units of of ENGR Fundamentals or CS depth)-- Sophomore year
- CS 106B or CS 106X. Programming Abstractions or Accelerated version. 5 units -- Freshman or Sophomore year
- Fundamentals Elective (see list of approved courses in Fig. 3-4; may not be 106A, B or X or second 40-series course)
Technology in Society
(One course, 3-5 units) See list of approved courses in Figure 3-3.
Writing in the Major
One course: Choose from CS 181W, 191W, 194W, 210B, or 294W
(14 units) See Program Sheet footnotes for crucial details about Core & Depth course and unit requirements
CS 107 or 107E. Computer Organization and Systems, 5 units, AWS or WS-- Sophomore year
CS 110. Principles of Computer Systems, 5 units, AWS So/Jr
CS 161. Design and Analysis of Algorithms, 5 units, AS So/Jr
CS 191, 191W, 194, 194H, 194W, 210B, 294, or 294W (see Note 8 below) 3 units, Sr
Choose one of the following tracks: minimum of 7 courses (25 units minimum required)
- Artificial Intelligence Track
a) CS 221
b) Any two of: CS 223A, 224M, 224N, 228, 229, 131 or 231A
c) One additional course from category (b) or the following: CS 124, 205A, 222, 224S, 224U, 224W, 225A 225B, 227B, 213A (if not taken for Track Requirement B) 231B, 231M, 231N, 262, 276, 277, 279, 327A, 329 (with advisor approval), 331A, 371, 374, 379 (with advisor approval); EE 263, 376A; ENGR 205, 209A; MS&E 251, 351; Stat 315A, 315B
d) Track Electives: At least three additional courses selected from (b), (c), the general CS electives list6, or the following: CS 238, 275, 278, CS 334A or EE 364A; EE 364B; ECON 286; MS&E 252, 352, 355; PHIL152; PSYCH 202, 204A, 204B; STATS 200, 202, 205. (Joint Majors take one additional course, not three.)
See Biocomputation Track program sheet; Mathematics, Science, and Engineering Fundamentals requirements are non-standard
- Computer Engineering Track
a) EE 108A, 180
b) Any two of: EE 101A, 101B, 102A, 102B. (Joint Majors take one course, not two.)
c) Satisfy the requirements of one of the following concentrations:
1. Digital Systems concentration:
CS 140 or 143; EE 109, 271
Any two of: CS140 or 143 (if not counted above), 144, 149, 240E, 244; EE 273, 282. (Joint Majors take one course, not two.)
2. Robotics and Mechatronics concentration:
CS 205A, 223A; ME 210, ENGR 105
Any one of: CS 225A, 225B, 231A, 277; ENGR 205, 207A, 207B. (Joint Majors do not need to take one of these courses.)
3. Networking concentration:
CS 140, 144
Any three of: CS 240, 240E, 241, 244, 244B, 244E, 249A, 249B; EE 179, 276. (Joint Majors take two courses, not three.)
- Graphics Track
a) CS 148, 248
b) Any one of: CS 205A (strongly recommended); CME 104 (prereq of CME 102), 108; Math 52, 113
c) Any two of: CS 178, 205B, 131A or 231A, 233, 268, 348A, 348B, 348V,448
d) Track Electives: At least two additional courses selected from (b), (c), the general CS electives list (see Note 9 below), or the following: ARTSTUDI 160, 170, 179; CME 302, 306; EE 262, 264, 278, 368; ME 101; PSYCH 30, 221. (Joint Majors waive these two electives.)
- Human-Computer Interaction Track
a) CS 147, 247
b) Any one of: CS 247, 377, 448B, 210A. Any three of: CS 142, 148, 194H, 210A, 376, 377 ‘Topics in HCI’ courses of three or more units, 448B; ME216M
c) Any one of: PSYCH 30, 45, 50, 55, 70, 75, 131, 154, 252; ME 101, 116, or any MS&E 18*At least two additional courses selected from (b), the general CS electives list6, or the following: ArtStudio 160, 162, 163, 164, 165, 168, 264, 266, 267; COMM 121, 124/224, 140/240, 166, 169/269, 172/272, 182, 324; EDUC 191X, 281X, 239X, 338X, 342; HUMBIO 82A; MS&E 125, 185, 331; ME 101, 115A, 203, 210, 216A; MUSIC 220A, 220B, 220C, 250A; Psych 30, 45, 55, 70, 75, 110, 131, 154, 252, 254; SYMSYS 145/245; STATS 203; any class of three or more units at hci.stanford.edu under the 'courses' link; any d.school class of three or more units. (Joint Majors waive these two courses.)
Example HCI Depth course plans:
Design Thinking: CS 147, 247, 448B, 142, 194H, ME 101, 115A
Front-End Development: CS 147, 247, 142, 448B, 194H, 148, 221
User Experience: CS 147, 247, 194H, 210A, 376, COMM 121, MS&E 125
Product Management: CS 147, 247, 194H, 210A, 142, COMM 169, 140
Digital Art: CS 147, 247, 148, 448B, 142, ARTSTUDI 160, 168
Research Frontiers: CS 147, 247, 376, 448B, ME 216M, COMM 124, 166, PSYCH 252
- Information Track
a) CS 124, 145
b) Two courses, which must be from different areas below:
i. Information-based AI applications: CS 224N, 224S, 229, 229A, 233
ii. Database and Information Systems: CS 140, 142, 245, 246, 341, 345, 346, 347
iii. Information Systems in Biology: CS262, 270, 274
iv. Information Systems on the Web: CS 224W, 276, 364B
c) At least three additional courses selected from (b) or the general CS electives list (see Note below). (Joint Majors take one course, not three)
- Systems Track
a) CS 140
b) One of: CS 143 or EE 180
c) Two additional courses from category (b) or the following: CS 144, 145, 149, 155, 240, 242, 243, 244, 245; EE 271, 282
d) Track Electives: At least three additional courses selected from (c), the general CS electives list (see Note below), or the following: CS 240E, 241,244C, 244E, 315A, 315B, 341, 343, 344 (3 or more units, any suffix), 344E, 345, 346, 347, 349 (with advisor approval), 448; EE 382C, 384A, 384B, 384C, 384S, 384X (Joint Majors take one course, not three)
- Theory Track
a) CS 154
b) Any one of: CS 167, 168, 255, 258, 261, 264, 265, 268, 361A, 361B
c) Two additional courses from category (b) or the following: CS 143, 155, 157 or Phil 151, 205A, 228, 233, 242, 254, 259 (with advisor approval), 262, 263, 266, 354, 355, 357, 358, 359 (with advisor approval), 364A, 364B, 369 (with advisor approval), 374; MS&E 310
d) Track Electives: At least three additional courses selected from (b), (c), the general CS electives list (see Note below), or the following: CME 302, 305; Phil 152 (Joint Majors take one course, not three)
- Unspecialized Track
a) CS 154
b) Any one of: CS 140, 143
c) One additional course from (b) or the following: CS 144, 155, 242, 244; EE 180
d) Any one of: CS 221, 223A, 228, 229, 231A
e) Any one of: CS 145, 147, 148, 248, 262
f) At least two courses from the general CS electives list (see Note below) (Joint Majors waive these two courses)
- Individually Designed Track: Students may propose an individually designed track. Proposals should include a minimum of seven courses, at least four of which must be CS courses numbered 100 or above
1. MATH 19, 20 and 21 or AP Calculus may be used instead of MATH 41 and 42, as long as at least 26 math units are taken.
2. The Mathematics electives list consists of: Math 51, 104, 108, 109, 110, 113; CS 157, 205A; PHIL 151; CME 100, 102, 104. Completion of Math 52 and 53 will (together) count as one Math elective. Restrictions: CS 157 and PHIL 151 may not be used in combination to satisfy the Math electives requirement. Students who have taken both Math 51 and 52 may not count CME 100 as an elective.
3. Any course of 3 or more units from the School of Engineering list of “Courses Approved for the Science Requirement” (Figure 3-2); PSYCH 30; PSYCH 55, or AP Chemistry credit may also be used. Either of the physics sequences 61/63 or 21/23 may be substituted for 41/43 as long as at least 11 science units are taken.
4. Students who complete ENGR 40A, or take 40M for fewer than 5 units, are required to complete one-two additional units of Engineering Fundamentals, or one-two additional units of Depth
5. CS 191 and 191W independent study projects require faculty sponsorship and must be approved, in advance, by the advisor, faculty sponsor, and the CS senior project advisor (Patrick Young). A form bearing these signatures, along with a brief description of the project, should be filed with the department representative in Gates 193 the quarter before work on the project is begun.
6. General CS Electives: CS 108, 124, 131, 140, 142, 143, 144, 145, 147, 148, 149, 154, 155, 157 or Phil 151, 164, 166, 167, 168, 190, 205A, 205B, 210A, 221, 223A, 224M, 224N, 224S, 224U, 224W, 225A, 225B, 227B, 228, 228T, 229, 229A, 229T, 231A, 231B, 231M, 231N, 232, 233, 240, 240H, 242, 243, 244, 244B, 245, 246, 247, 248, 249A, 249B, 251, 254, 255, 261, 262, 263, 264, 265, 266, 267, 270, 271, 272, 173 or 273A, 274, 276, 277, 279, 348B; CME 108; EE 180, 282, 364A.
7. Of the category (b) options for the Graphics track, CS 205A is strongly recommended as a preferred choice. Note that students taking CME 104 are also required to take its prerequisite course CME 102.
For instructions on declaring CS, go the the Declaring page on the CS site.