# Courses

**COMS E3999 Fieldwork. ***1 point*.

Prerequisites: Obtained internship and approval from faculty advisor.

May be repeated for credit, but no more than 3 total points may be used toward the 128-credit degree requirement. Only for SEAS computer science undergraduate students who include relevant off-campus work experience as part of their approved program of study. Final report and letter of evaluation required. May not be used as a technical or non-technical elective. May not be taken for pass/fail credit or audited.

Summer 2018: COMS E3999 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 3999 | 001/26780 | |
1 | 0 |

**COMS E6111 Advanced Database Systems. ***3 points*.

Lect: 2.

Prerequisites: (COMS W4111) and knowledge of Java or instructor's permission.

Continuation of *COMS W4111*, covers latest trends in both database research and industry: information retrieval, web search, data mining, data warehousing, OLAP, decision support, multimedia databases, and XML and databases. Programming projects required.

Fall 2017: COMS E6111 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 6111 | 001/25149 | T 4:10pm - 6:00pm 1127 Seeley W. Mudd Building |
Luis Gravano | 3 | 76/85 |

**COMS E6113 Topics in Database Systems. ***3 points*.

Lect: 2.**Not offered during 2017-18 academic year.**

Prerequisites: (COMS W4111)

Concentration on some database paradigm, such as deductive, heterogeneous, or object-oriented, and/or some database issue, such as data modeling, distribution, query processing, semantics, or transaction management. A substantial project is typically required. May be repeated for credit with instructor's permission.

**COMS E6117 Topics in Programming Languages and Translators. ***3 points*.

Lect: 2.

Prerequisites: (COMS W4115) or instructor's permission.

Concentration on the design and implementation of programming languages, and tools focused on advanced applications in new areas in software verification, distributed systems, programming in the large, and web computing. A substantial project is typically required. May be repeated for credit.

**COMS E6118 Operating systems, II. ***3 points*.

Lect: 2.**Not offered during 2017-18 academic year.**

Prerequisites: (COMS W4118) *COMS W4118*.

Corequisites: *COMS W4119*.

Continuation of *COMS W4118*, with emphasis on distributed operating systems. Topics include interfaces to network protocols, distributed run-time binding, advanced virtual memory issues, advanced means of interprocess communication, file system design, design for extensibility, security in a distributed environment. Investigation is deeper and more hands-on than in *COMS W4118*. A programming project is required.

**COMS E6121 Reliable Software. ***3 points*.

**Not offered during 2017-18 academic year.**

Prerequisites: (COMS W4118) or (COMS W4115) or (COMS W4117) or at least one of *COMS W4118* Operating Systems I, *COMS W4115* Programming Languages and Translators, or *COMS W4117* Compilers and Interpreters; or significant software development experiences.

Topics include: automated debugging, automated software repair, Concurrent software reliability, software error detection, and more.

Spring 2018: COMS E6121 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 6121 | 001/15919 | T 10:10am - 12:00pm 620 Schapiro Cepser |
Junfeng Yang | 3 | 6/15 |

**COMS E6123 Programming Environments and Software Tools (PEST). ***3 points*.

Lect: 2.

Prerequisites: (COMS W4156) or *COMS W4156*, or equivalent.

Software methodologies and technologies concerned with development and operation of today's software systems. Reliability, security, systems management and societal issues. Emerging software architectures such as enterprise and grid computing. Term paper and programming project. Seminar focus changes frequently to remain timely.

**COMS E6125 Web-enhanced Information Management (WHIM). ***3 points*.

Lect: 2.

Prerequisites: at least one COMS W41xx or COMS E61xx course and/or COMS W4444, or the instructor's permission. Strongly recommended: COMS W4111.

History of hypertext, markup languages, groupware and the web. Evolving web protocols, formats and computation paradigms such as HTTP, XML and Web Services. Novel application domains enabled by the web and societal issues. Term paper and programming project. Seminar focus changes frequently to remain timely.

**COMS E6156 Topics in Software Engineering. ***3 points*.

Topics in Software engineering arranged as the need and availability arises. Topics are usually offered on a one-time basis. Since the content of this course changes, it may be repeated for credit with advisor approval. Consult the department for section assignment.

Spring 2018: COMS E6156 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 6156 | 001/61486 | T Th 1:10pm - 2:25pm 545 Seeley W. Mudd Building |
Gail Kaiser | 3 | 15/60 |

**COMS E6160 Topics in Computer Graphics. ***3 points*.

Lect: 2.

Prerequisites: (COMS W4160) or instructor's permission.

An advanced graduate course, involving study of an advanced research topic in Computer Graphics. Content varies between offerings, and the course may be repeated for credit. Recent offerings have included appearance models in graphics, and high quality real-time rendering.

**COMS E6174 Interaction Design: A Perceptual Approach. ***3 points*.

Lect: 3.**Not offered during 2017-18 academic year.**

Prerequisites: (COMS W4170) or instructor's permission.

Design methodology for special-purpose user interfaces. Emphasis on how psychology and perception inform good design. Interviewing and task modeling, participatory design, and low-fidelity prototyping. Applications of brain research, graphic design and art to develop custom user interfaces components, screen layouts, and interaction techniques for application-specific systems.

**COMS E6176 User Interfaces for Mobile and Wearable Computing. ***3 points*.

Lect: 2.**Not offered during 2017-18 academic year.**

Prerequisites: (COMS W4170) or instructor's permission.

Introduction to research on user interfaces for mobile and wearable computing through lectures, invited talks, student-led discussions of important papers, and programming projects. Designing and authoring for mobility and wearability. Ubiquitous/pervasive computing. Collaboration with other users. Display, interaction, and communication technologies. Sensors for tracking position, orientation, motion, environmental context, and personal context. Applications and social consequences.

**COMS E6181 Advanced Internet Services. ***3 points*.

Lect: 2.

In-depth survey of protocols and algorithms needed to transport multimedia information across the Internet, including audio and video encoding, multicast, quality-of-service, voice-over-IP, streaming media and peer-to-peer multimedia systems. Includes a semester-long programming project.

**COMS E6183 Advanced Topics in Network Security. ***3 points*.

Lect: 3.

Prerequisites: (COMS W4180) and (CSEE W4119) and and COMS W4261 recommended.

Review the fundamental aspects of security, including authentication, authorization, access control, confidentiality, privacy, integrity, and availability. Review security techniques and tools, and their applications in various problem areas. Study the state of the art in research. A programming project is required.

**COMS E6184 Seminar on Anonymity and Privacy. ***3 points*.

Lect: 3.

Prerequisites: (COMS W4261) or (COMS W4180) or (CSEE W4119) or instructor's permission.

This course will cover the following topics: Legal and social framework for privacy. Data mining and databases. Anonymous commerce and Internet usage. Traffic analysis. Policy and national security considerations. Classes are seminars with students presenting papers and discussing them. Seminar focus changes frequently to remain timely.

**COMS E6185 Intrusion and Anomaly Detection Systems. ***3 points*.

Lect: 3.

Prerequisites: (COMS W4180)

Corequisites: COMS W4180

The state of threats against computers, and networked systems. An overview of computer security solutions and why they fail. Provides a detailedtreatment for Network and Host-based Intrusion Detection and Intrusion Prevention systems. Considerable depth is provided on anomaly detection systems to detect new attacks. Covers issues and problems in email (spam, and viruses) and insider attacks (masquerading and impersonation).

Spring 2018: COMS E6185 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 6185 | 001/94266 | F 10:10am - 12:00pm 1127 Seeley W. Mudd Building |
JOEL LAURENCE ROSENBLATT | 3 | 8/40 |

**COMS E6204 Topics in Graph Theory. ***3 points*.

Lect: 2.**Not offered during 2017-18 academic year.**

Prerequisites: (COMS W4203) or instructor's permission.

Content varies from year to year. This course may be repeated for credit. Concentration on some aspect of graph theory, such as topological graph theory, algebraic graph theory, enumerative graph theory, graphical optimization problems, or matroids.

**COMS E6206 Topics in Combinatorial Theory. ***3 points*.

Lect: 2.

Prerequisites: (COMS W4203) or (COMS W4205) or instructor's permission.

Concentration on some aspect of combinatorial theory. Content varies form year to year. This course may be repeated for credit.

**COMS E6232 Analysis of Algorithms, II. ***3 points*.

Lect: 2.

Prerequisites: (CSOR W4231) *CSOR W4231*.

Continuation of *CSOR W4231*.

**COMS E6253 Advanced Topics in Computational Learning Theory. ***3 points*.

Lect: 3.**Not offered during 2017-18 academic year.**

Prerequisites: (CSOR W4231) or (COMS W4252) or equivalent, COMS W4236 helpful but not required.

In-depth study of inherent abilities and limitations of computationally efficient learning algorithms. Algorithms for learning rich Boolean function classes in online, Probably Approximately Correct, and exact learning models. Connections with computational complexity theory emphasized. Substantial course project or term paper required.

**COMS E6261 Advanced Cryptography. ***3 points*.

Lect: 3.

Prerequisites: (COMS W4261) *COMS W4261*.

A study of advanced cryptographic research topics such as: secure computation, zero knowledge, privacy, anonymity, cryptographic protocols. Concentration on theoretical foundations, rigorous approach, and provable security. Contents varies between offerings. May be repeated for credit.

Spring 2018: COMS E6261 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 6261 | 001/28649 | M 6:10pm - 8:00pm 602 Northwest Corner |
Allison Bishop | 3 | 17/30 |

**COMS E6291 Theoretical Topics in Computer Science. ***3 points*.

Lect: 3.**Not offered during 2017-18 academic year.**

Prerequisites: Instructor's permission.

Concentration on some theoretical aspect of computer science. Content varies from year to year. May be repeated for credit.

**COMS E6731 Humanoid Robots. ***3 points*.

Lect: 2.

Prerequisites: A course in at least one of the following: AI, robotics, computer graphics, or computer vision

Seminar on Humanoid Robots. Analysis of existing hardware and software platforms. Programming of multi-degree-of-freedom robots. Understanding sensor feedback in perceive-act-sense control paradigms. Task-level planning and reasoning. Final project includes implementing a humanoid robot task on either a simulated or physical robot.

Spring 2018: COMS E6731 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 6731 | 001/24624 | T 4:10pm - 6:00pm 233 Seeley W. Mudd Building |
Peter Allen | 3 | 37/40 |

**COMS E6732 Computational Imaging. ***3 points*.

Lect: 3.

Prerequisites: (COMS W4731) or *COMS W4731* or the instructor's permission.

Computational imaging uses a combination of novel imaging optics and a computational module to produce new forms of visual information. Survey of the state of art in computational imaging. Review of recent papers on: omni directional and panoramic imaging, catadioptric imaging, high dynamic range imaging, mosaicing and superresolution. Classes are seminars with the instructor, guest speakers, and students presenting papers and discussing them.

**COMS E6733 3D photography. ***3 points*.

Lect: 2.**Not offered during 2017-18 academic year.**

Prerequisites: Experience with at least one of the following topics: computer graphics, computer vision, pixel processing, robotics or computer aided design, or the instructor's permission. Programming proficiency in C, C++ or JAVA.

Programming proficiency in C, C++ or JAVA. 3D Photography - the process of automatically creating 3D, texture-mapped models of objects in detail. Applications include robotics, medicine, graphics, virtual reality, entertainment and digital movies etc. Topics include 3D data acquisition devices, 3D modeling systems and algorithms to acquire, create, augment, manipulate, render, animate and physically build such models.

**COMS E6734 Computational Photography. ***3 points*.

Lect: 3.

Prerequisites: (COMS W4160) and (COMS W4731) or a working knowledge of photography is recommended.

Students should have knowledge in any of three core areas: computer vision, computer graphics, or photography. Computational techniques are used to produce a new level of images and visual representations. Topics include: HDR imaging, feature matching using RANSAC, image mosaics, image-based rendering, motion magnification, camera lens arrays, programmable lighting, face detection, single and multi-view geometry, and more.

**COMS E6735 Visual Databases. ***3 points*.

Lect: 3.**Not offered during 2017-18 academic year.**

Prerequisites: (COMS W3134) and (COMS W3136) or (COMS W3137) or *COMS W3134* or *COMS W3137* required. *COMS W4731* and *COMS W4735* helpful but not required. Contact instructor if uncertain.

The analysis and retrieval of large collections of image and video data, with emphasis on visual semantics, human psychology, and user interfaces. Low-level processing: features and similarity measures; shot detection; key frame selection; machine learning methods for classification. Middle-level processing: organizational rules for videos, including unedited (home, educational), semi-edited (sports, talk shows), edited (news, drama); human memory limits; progressive refinement; visualization techniques; incorporation of audio and text. High-level processing: extraction of thematic structures; ontologies, semantic filters, and learning; personalization of summaries and interfaces; detection of pacing and emotions. Examples and demonstrations from commercial and research systems throughout. Substantial course project or term paper required.

**COMS E6737 Biometrics. ***3 points*.

Lect: 3.

Prerequisites: a background at the sophomore level in computer science, engineering, or like discipline.

In this course we will explore the latest advances in biometrics as well as the machine learning techniques behind them. Students will learn how these technologies work and how they are sometimes defeated. Grading will be based on homework assignments and a final project. There will be no midterm or final exam. This course shares lectures with COMS W4737. Students taking COMS E6737 are required to complete additional homework problems and undertake a more rigorous final project. Students will only be allowed to earn credit for COMS W4737 or COMS E6737 and not both.

**COMS E6900 Tutorial in Computer Science. ***1-3 points*.

Prerequisites: Instructor's permission.

A reading course in an advanced topic for a small number of students, under faculty supervision.

**COMS E6901 Projects in Computer Science. ***1-12 points*.

Prerequisites: Instructor's permission.

Software or hardware projects in computer science. Before registering, the student must submit a written proposal to the instructor for review. The proposal should give a brief outline of the project, estimated schedule of completion, and computer resources needed. Oral and written reports are required. May be taken over more than one semester, in which case the grade will be deferred until all 12 points have been completed. No more than 12 points of *COMS E6901* may be taken. Consult the department for section assignment.

**COMS E6902 Thesis. ***1-9 points*.

Available to M.S. and CSE candidates. An independent investigation of an appropriate problem in computer science carried out under the supervision of a faculty member. A formal written report is essential and an oral presentation may also be required. May be taken over more than one semester, in which case the grade will be deferred until all 9 points have been completed. No more than 9 points of *COMS E6902* may be taken. Consult the department for section assignment.

**COMS E6910 Fieldwork. ***1 point*.

Prerequisites: Obtained internship and approval from faculty adviser.

Only for M.S. in the Computer Science Department who need relevant work experience as part of their program of study. Final report required. This course may not be taken for pass/fail credit or audited.

**COMS E6915 Technical writing for computer scientists and engineers. ***3 points*.

Prerequisites: Available to M.S. and Ph.D candidates in CS/CE.

Topics to help CS/CE graduate students’ communication skills. Emphasis on writing, presenting clear, concise proposals, journal articles, conference papers, theses, and technical presentations. May be repeated for credit. Credit may not be used to satisfy degree requirements.

Fall 2017: COMS E6915 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 6915 | 001/22205 | M W 12:10pm - 2:00pm 620 Schapiro Cepser |
Janet Kayfetz | 3 | 15/15 |

Spring 2018: COMS E6915 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |

COMS 6915 | 001/71884 | M W 1:10pm - 3:40pm 620 Schapiro Cepser |
Janet Kayfetz | 3 | 11/15 |

**COMS E6998 Topics in Computer Science. ***3 points*.

Prerequisites: Instructor's permission.

Selected topics in computer science. Content varies from year to year. May be repeated for credit.

Fall 2017: COMS E6998 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 6998 | 002/20942 | T 4:10pm - 6:40pm 415 Schapiro Cepser |
Omri Weinstein | 3 | 19/30 |

COMS 6998 | 003/27311 | W 2:10pm - 4:00pm 6lw4 Schapiro Cepser |
Peter Belhumeur | 3 | 24/25 |

COMS 6998 | 004/29673 | M W 10:10am - 11:25am 602 Northwest Corner |
Daniel Hsu | 3 | 17/30 |

COMS 6998 | 005/75947 | M W 4:10pm - 5:25pm 415 Schapiro Cepser |
Alexandr Andoni | 3 | 22/42 |

COMS 6998 | 006/78279 | W 4:10pm - 6:40pm 404 International Affairs Bldg |
Alex Slivkins, Alekh Agarwal | 3 | 49/60 |

COMS 6998 | 007/75886 | Th 7:00pm - 9:30pm 545 Seeley W. Mudd Building |
Homayoon Beigi | 3 | 26/60 |

COMS 6998 | 008/68933 | Th 4:10pm - 6:40pm 327 Seeley W. Mudd Building |
Michael Sikorski | 3 | 21/35 |

COMS 6998 | 009/27725 | T 4:10pm - 6:00pm 405 International Affairs Bldg |
Steven Bellovin | 3 | 8/9 |

COMS 6998 | 010/81299 | F 4:10pm - 6:00pm 303 Hamilton Hall |
Kenneth Church | 3 | 12/40 |

COMS 6998 | 012/11348 | F 10:10am - 12:40pm 313 Fayerweather |
Alp Kucukelbir | 3 | 31/75 |

COMS 6998 | 013/82194 | Th 8:10pm - 10:00pm 702 Hamilton Hall |
Tristan Boutros | 3 | 46/80 |

COMS 6998 | 014/97599 | T 2:10pm - 4:00pm 405 International Affairs Bldg |
Donald Ferguson | 3 | 53/50 |

COMS 6998 | 015/12550 | W 1:10pm - 3:40pm 414 Pupin Laboratories |
Daniel Rubenstein | 3 | 11/25 |

COMS 6998 | 016/76049 | T 7:00pm - 9:30pm 603 Hamilton Hall |
Patrick Houlihan | 3 | 42/54 |

COMS 6998 | 017/62298 | F 1:10pm - 3:40pm 313 Fayerweather |
David Shilane | 3 | 35/78 |

Spring 2018: COMS E6998 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |

COMS 6998 | 001/64858 | T 4:10pm - 6:00pm 825 Seeley W. Mudd Building |
Augustin Chaintreau | 3 | 29/50 |

COMS 6998 | 002/14274 | M 10:10am - 12:40pm 313 Fayerweather |
Tony Jebara | 3 | 63/70 |

COMS 6998 | 003/76136 | M 12:10pm - 2:00pm 467 Ext Schermerhorn Hall |
Roxana Geambasu | 3 | 12/35 |

COMS 6998 | 004/60841 | F 10:10am - 12:40pm 109 Hartley Hall |
Martha Kim | 3 | 13/20 |

COMS 6998 | 005/18116 | W 4:10pm - 6:00pm 227 Seeley W. Mudd Building |
Eugene Wu | 3 | 10/40 |

COMS 6998 | 006/29861 | Th 8:10pm - 10:00pm 517 Hamilton Hall |
Tristan Boutros | 3 | 76/80 |

COMS 6998 | 007/61574 | Th 6:10pm - 8:00pm 227 Seeley W. Mudd Building |
Xiaofu He | 3 | 28/45 |

COMS 6998 | 008/75750 | F 12:10pm - 2:00pm 413 Kent Hall |
Lior Horesh, John Smolin | 3 | 31/60 |

COMS 6998 | 009/72781 | M 10:10am - 12:00pm 602 Northwest Corner |
Junfeng Yang | 3 | 13/30 |

COMS 6998 | 010/12268 | M 6:10pm - 8:00pm 310 Fayerweather |
Sambit Sahu | 3 | 93/96 |

COMS 6998 | 011/82597 | T 10:10am - 12:00pm 834 Seeley W. Mudd Building |
Jason Nieh | 3 | 7/40 |

COMS 6998 | 012/73149 | M W 4:10pm - 5:25pm 303 Hamilton Hall |
Smaranda Muresan | 3 | 34/42 |

**COMS E6999 Topics in Computer Science, II. ***3 points*.

**Not offered during 2017-18 academic year.**

Prerequisites: (COMS E6998)

Continuation of *COMS E6998*.

**COMS E9800 Directed Research in Computer Science. ***1-15 points*.

Prerequisites: Submission of an outline of the proposed research for approval by the faculty member who will supervise.

The department must approve the number of points. May be repeated for credit. This course is only for Eng.Sc.D. candidates.

**COMS E9910 Graduate Research I. ***1-6 points*.

Prerequisites: Submission of an outline of the proposed research for approval by the faculty member who will supervise.

The department must approve the number of credits. May be repeated for credit. This course is only for M.S. candidates holding GRA or TA appointments. Note: It is NOT required that a student take Graduate Research I prior to taking Graduate Research II. Consult the department for section assignment.

**COMS E9911 Graduate research II. ***1-15 points*.

Prerequisites: Submission of an outline of the proposed research for approval by the faculty member who will supervise.

The department must approve the number of points. May be repeated for credit. This course is only for M.S./Ph.D. and Ph.D. students. Note: It is NOT required that a student take Graduate Research, I prior to taking Graduate Research, II. Consult the department for section assignment.

**COMS W1001 Introduction to Information Science. ***3 points*.

Lect: 3.

Basic introduction to concepts and skills in Information Sciences: human-computer interfaces, representing information digitally, organizing and searching information on the World Wide Web, principles of algorithmic problem solving, introduction to database concepts, and introduction to programming in Python.

**COMS W1002 Computing in Context. ***4 points*.

CC/GS: Partial Fulfillment of Science Requirement

Introduction to elementary computing concepts and Python programming with domain-specific applications. Shared CS concepts and Python programming lectures with track-specific sections. Track themes will vary but may include computing for the social sciences, computing for economics and finance, digital humanities, and more. Intended for nonmajors. Students may only receive credit for one of ENGI E1006 and COMS W1002.

Fall 2017: COMS W1002 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 1002 | 001/19718 | T Th 2:40pm - 3:55pm 417 International Affairs Bldg |
Adam Cannon, Gregory Falco | 4 | 218/340 |

**COMS W1004 Introduction to Computer Science and Programming in Java. ***3 points*.

Lect: 3.

A general introduction to computer science for science and engineering students interested in majoring in computer science or engineering. Covers fundamental concepts of computer science, algorithmic problem-solving capabilities, and introductory Java programming skills. Assumes no prior programming background. Columbia University students may receive credit for only one of the following two courses: *1004* and *1005*.

Fall 2017: COMS W1004 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 1004 | 001/74467 | T Th 4:10pm - 5:25pm 417 International Affairs Bldg |
Adam Cannon | 3 | 286/400 |

Spring 2018: COMS W1004 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |

COMS 1004 | 001/12368 | T Th 2:40pm - 3:55pm 309 Havemeyer Hall |
Adam Cannon | 3 | 225/300 |

COMS 1004 | 002/64704 | T Th 4:10pm - 5:25pm 309 Havemeyer Hall |
Adam Cannon | 3 | 179/300 |

**COMS W1005 Introduction to Computer Science and Programming in MATLAB. ***3 points*.

CC/GS: Partial Fulfillment of Science Requirement

A general introduction to computer science concepts, algorithmic problem-solving capabilities, and programming skills in MATLAB. Assumes no prior programming background. Columbia University students may receive credit for only one of the following two courses: *W1004* and *W1005*.

Spring 2018: COMS W1005 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 1005 | 001/76034 | M W 7:10pm - 8:25pm 501 Schermerhorn Hall |
Timothy Paine | 3 | 22/120 |

**COMS W1007 Honors Introduction to Computer Science. ***3 points*.

Lect: 3.

Prerequisites: AP Computer Science with a grade of 4 or 5 or similar experience.

An honors-level introduction to computer science, intended primarily for students considering a major in computer science. Computer science as a science of abstraction. Creating models for reasoning about and solving problems. The basic elements of computers and computer programs. Implementing abstractions using data structures and algorithms. Taught in Java.

Fall 2017: COMS W1007 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 1007 | 001/73954 | T Th 1:10pm - 2:25pm 717 Hamilton Hall |
John Kender | 3 | 43/86 |

**COMS W1404 Emerging Scholars Program Seminar. ***1 point*.

Pass/Fail only.

Prerequisites: the instructor's permission.

Corequisites: COMS W1004,COMS W1007

Peer-led weekly seminar intended for first and second year undergraduates considering a major in Computer Science. Pass/fail only. May not be used towards satisfying the major or SEAS credit requirements.

Fall 2017: COMS W1404 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 1404 | 001/28157 | F 1:15pm - 2:30pm 502 Northwest Corner |
Adam Cannon | 1 | 10/12 |

COMS 1404 | 002/13785 | F 12:00pm - 1:15pm 502 Northwest Corner |
Adam Cannon | 1 | 6/12 |

COMS 1404 | 003/12284 | F 3:15pm - 4:30pm 502 Northwest Corner |
Adam Cannon | 1 | 9/12 |

COMS 1404 | 004/25539 | F 4:30pm - 5:45pm 502 Northwest Corner |
Adam Cannon | 1 | 7/12 |

Spring 2018: COMS W1404 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |

COMS 1404 | 001/23830 | |
Adam Cannon | 1 | 28/50 |

**COMS W3101 Programming Languages. ***1 point*.

Lect: 1.

Prerequisites: Fluency in at least one programming language.

Introduction to a programming language. Each section is devoted to a specific language. Intended only for those who are already fluent in at least one programming language. Sections may meet for one hour per week for the whole term, for three hours per week for the first third of the term, or for two hours per week for the first six weeks. May be repeated for credit if different languages are involved.

**COMS W3102 Development Technologies. ***1-2 points*.

Lect: 2. Lab: 0-2.

Prerequisites: Fluency in at least one programming language.

Introduction to software development tools and environments. Each section devoted to a specific tool or environment. One-point sections meet for two hours each week for half a semester, and two point sections include an additional two-hour lab.

**COMS W3134 Data Structures in Java. ***3 points*.

CC/GS: Partial Fulfillment of Science Requirement

Prerequisites: (COMS W1004) or *COMS W1004* or knowledge of Java.

Data types and structures: arrays, stacks, singly and doubly linked lists, queues, trees, sets, and graphs. Programming techniques for processing such structures: sorting and searching, hashing, garbage collection. Storage management. Rudiments of the analysis of algorithms. Taught in Java. Note: Due to significant overlap, students may receive credit for only one of the following three courses: *COMS W3134*, *COMS W3136*, *COMS W3137*.

Fall 2017: COMS W3134 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 3134 | 001/72834 | M W 5:40pm - 6:55pm 301 Pupin Laboratories |
Paul Blaer | 3 | 245/276 |

Spring 2018: COMS W3134 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |

COMS 3134 | 001/18062 | M W 1:10pm - 2:25pm 309 Havemeyer Hall |
Paul Blaer | 3 | 204/320 |

COMS 3134 | 002/65556 | M W 5:40pm - 6:55pm 417 International Affairs Bldg |
Paul Blaer | 3 | 125/398 |

**COMS W3136 Data Structures with C/C++. ***4 points*.

Prerequisites: (COMS W1004) and (COMS W1005) and (COMS W1007) or (ENGI E1006) *COMS W1004*, *W1005*, *W1007*, or *ENGI E1006*.

A second programming course intended for nonmajors with at least one semester of introductory programming experience. Basic elements of programming in C and C++, arraybased data structures, heaps, linked lists, C programming in UNIX environment, object-oriented programming in C++, trees, graphs, generic programming, hash tables. Due to significant overlap, students may only receive credit for either COMS W3134, W3136, or W3137.

Fall 2017: COMS W3136 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 3136 | 001/22037 | T Th 5:40pm - 6:55pm 833 Seeley W. Mudd Building |
Timothy Paine | 4 | 70/110 |

**COMS W3137 Honors Data Structures and Algorithms. ***4 points*.

Prerequisites: (COMS W1004) or (COMS W1007) *COMS W1004 or W1007*.

Corequisites: *COMS W3203*.

An honors introduction to data types and structures: arrays, stacks, singly and doubly linked lists, queues, trees, sets, and graphs. Programming techniques for processing such structures: sorting and searching, hashing, garbage collection. Storage management. Design and analysis of algorithms. Taught in Java. Note: Due to significant overlap, students may receive credit for only one of the following three courses: *COMS W3134*, *W3136*, or *W3137*.

Spring 2018: COMS W3137 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 3137 | 001/77075 | M W 1:10pm - 2:25pm 313 Fayerweather |
Daniel Bauer | 4 | 30/78 |

**COMS W3157 Advanced Programming. ***4 points*.

Lect: 4.

Prerequisites: COMS W3134 or equivalent.

C programming language and Unix systems programming. Also covers Git, Make, TCP/IP networking basics, C++ fundamentals.

Fall 2017: COMS W3157 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 3157 | 001/28865 | T Th 11:40am - 12:55pm 301 Pupin Laboratories |
Jae Lee | 4 | 181/274 |

COMS 3157 | 002/20796 | T Th 4:10pm - 5:25pm 501 Schermerhorn Hall |
Jae Lee | 4 | 119/180 |

Spring 2018: COMS W3157 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |

COMS 3157 | 001/23295 | T Th 4:10pm - 5:25pm 301 Pupin Laboratories |
Jae Lee | 4 | 234/250 |

**COMS W3203 Discrete Mathematics: Introduction to Combinatorics and Graph Theory. ***3 points*.

Lect: 3.

Prerequisites: Any introductory course in computer programming.

Logic and formal proofs, sequences and summation, mathematical induction, binomial coefficients, elements of finite probability, recurrence relations, equivalence relations and partial orderings, and topics in graph theory (including isomorphism, traversability, planarity, and colorings).

Fall 2017: COMS W3203 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 3203 | 001/62348 | T Th 10:10am - 11:25am 209 Havemeyer Hall |
Ansaf Salleb-Aouissi | 3 | 103/100 |

COMS 3203 | 002/20951 | T Th 11:40am - 12:55pm 209 Havemeyer Hall |
Ansaf Salleb-Aouissi | 3 | 102/100 |

COMS 3203 | 003/69273 | M W 8:40am - 9:55am 203 Mathematics Building |
Antonio Moretti | 3 | 53/100 |

Spring 2018: COMS W3203 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |

COMS 3203 | 001/14562 | T Th 11:40am - 12:55pm 417 International Affairs Bldg |
Ansaf Salleb-Aouissi | 3 | 190/200 |

**COMS W3210 Scientific Computation. ***3 points*.

CC/GS: Partial Fulfillment of Science Requirement

Prerequisites: two terms of calculus.

Introduction to computation on digital computers. Design and analysis of numerical algorithms. Numerical solution of equations, integration, recurrences, chaos, differential equations. Introduction to Monte Carlo methods. Properties of floating point arithmetic. Applications to weather prediction, computational finance, computational science, and computational engineering.

**COMS W3251 Computational Linear Algebra. ***3 points*.

CC/GS: Partial Fulfillment of Science Requirement

Prerequisites: two terms of calculus.

Computational linear algebra, solution of linear systems, sparse linear systems, least squares, eigenvalue problems, and numerical solution of other multivariate problems as time permits.

**COMS W3261 Computer Science Theory. ***3 points*.

CC/GS: Partial Fulfillment of Science Requirement

Prerequisites: (COMS W3203) *COMS W3203*.

Corequisites: *COMS W3134*, *W3136*, or *W3137*.

Regular languages: deterministic and non-deterministic finite automata, regular expressions. Context-free languages: context-free grammars, push-down automata. Turing machines, the Chomsky hierarchy, and the Church-Turing thesis. Introduction to Complexity Theory and NP-Completeness.

Fall 2017: COMS W3261 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 3261 | 001/22794 | M W 1:10pm - 2:25pm 428 Pupin Laboratories |
Alfred Aho | 3 | 104/147 |

COMS 3261 | 002/78449 | T Th 11:40am - 12:55pm 516 Hamilton Hall |
Nakul Verma | 3 | 45/54 |

Spring 2018: COMS W3261 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |

COMS 3261 | 001/60678 | M W 10:10am - 11:25am 207 Mathematics Building |
Tal Malkin | 3 | 140/152 |

COMS 3261 | 002/66946 | M W 8:40am - 9:55am 207 Mathematics Building |
Tal Malkin | 3 | 99/152 |

**COMS W3410 Computers and Society. ***3 points*.

Lect: 3.

Broader impact of computers. Social networks and privacy. Employment, intellectual property, and the media. Science and engineering ethics. Suitable for nonmajors.

Spring 2018: COMS W3410 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 3410 | 001/17789 | M W 2:40pm - 3:55pm 310 Fayerweather |
Steven Bellovin | 3 | 84/96 |

**COMS W3902 Undergraduate Thesis. ***1-6 points*.

Prerequisites: Agreement by a faculty member to serve as thesis adviser.

An independent theoretical or experimental investigation by an undergraduate major of an appropriate problem in computer science carried out under the supervision of a faculty member. A formal written report is mandatory and an oral presentation may also be required. May be taken over more than one term, in which case the grade is deferred until all 6 points have been completed. Consult the department for section assignment.

**COMS W3995 Special Topics in Computer Science. ***3 points*.

Lect: 3.

Prerequisites: the instructor's permission.

Consult the department for section assignment. Special topics arranged as the need and availability arise. Topics are usually offered on a one-time basis. Since the content of this course changes each time it is offered, it may be repeated for credit.

Spring 2018: COMS W3995 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 3995 | 001/18628 | M W 10:10am - 11:25am 467 Ext Schermerhorn Hall |
Alan DeChant | 3 | 35/30 |

**COMS W3998 Undergraduate Projects in Computer Science. ***1-3 points*.

Prerequisites: Approval by a faculty member who agrees to supervise the work.

Independent project involving laboratory work, computer programming, analytical investigation, or engineering design. May be repeated for credit, but not for a total of more than 3 points of degree credit. Consult the department for section assignment.

**COMS W4111 Introduction to Databases. ***3 points*.

Lect: 3.

Prerequisites: (COMS W3134) or (COMS W3136) or (COMS W3137) and fluency in Java; or the instructor's permission.

The fundamentals of database design and application development using databases: entity-relationship modeling, logical design of relational databases, relational data definition and manipulation languages, SQL, XML, query processing, physical database tuning, transaction processing, security. Programming projects are required.

Fall 2017: COMS W4111 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 4111 | 001/15421 | W 4:10pm - 6:40pm 1127 Seeley W. Mudd Building |
Alexandros Biliris | 3 | 71/80 |

COMS 4111 | 002/85942 | M 8:40am - 11:10am 602 Hamilton Hall |
Alexandros Biliris | 3 | 78/80 |

COMS 4111 | 003/93700 | T Th 8:40am - 9:55am 207 Mathematics Building |
Donald Ferguson | 3 | 138/152 |

Spring 2018: COMS W4111 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |

COMS 4111 | 001/11617 | T Th 2:40pm - 3:55pm 501 Northwest Corner |
Luis Gravano | 3 | 154/164 |

COMS 4111 | 002/76608 | T Th 10:10am - 11:25am 209 Havemeyer Hall |
Donald Ferguson | 3 | 107/110 |

COMS 4111 | 003/75893 | W 4:10pm - 6:40pm 1127 Seeley W. Mudd Building |
Alexandros Biliris | 3 | 79/80 |

**COMS W4112 Database System Implementation. ***3 points*.

Lect: 2.5.

Prerequisites: (COMS W4111) and fluency in Java or C++. CSEE W3827 is recommended.

The principles and practice of building large-scale database management systems. Storage methods and indexing, query processing and optimization, materialized views, transaction processing and recovery, object-relational databases, parallel and distributed databases, performance considerations. Programming projects are required.

Spring 2018: COMS W4112 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 4112 | 001/23279 | M W 1:10pm - 2:25pm 833 Seeley W. Mudd Building |
Kenneth Ross | 3 | 39/75 |

**COMS W4113 Fundamentals of Large-Scale Distributed Systems. ***3 points*.

Prerequisites: (COMS W3134) and (COMS W3136) or (COMS W3137) and (COMS W3157) or (COMS W4118) or (CSEE W4119) or *COMS W3134*, *W3136*, or *W3137*. *COMS W3157* or good working knowledge of C and C++. *COMS W4118* or *CSEE W4119*.

Design and implementation of large-scale distributed and cloud systems. Teaches abstractions, design and implementation techniques that enable the building of fast, scalable, fault-tolerant distributed systems. Topics include distributed communication models (e.g., sockets, remote procedure calls, distributed shared memory), distributed synchronization (clock synchronization, logical clocks, distributed mutex), distributed file systems, replication, consistency models, fault tolerance, distributed transactions, agreement and commitment, Paxos-based consensus, MapReduce infrastructures, scalable distributed databases. Combines concepts and algorithms with descriptions of real-world implementations at Google, Facebook, Yahoo, Microsoft, LinkedIn, etc.

Fall 2017: COMS W4113 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 4113 | 001/75588 | M W 1:10pm - 2:25pm 602 Hamilton Hall |
Roxana Geambasu | 3 | 73/86 |

**COMS W4115 Programming Languages and Translators. ***3 points*.

Lect: 3.

Prerequisites: (COMS W3134) and (COMS W3136) or (COMS W3137) or (COMS W3261) and (CSEE W3827) or equivalent, or the instructor's permission.

Modern programming languages and compiler design. Imperative, object-oriented, declarative, functional, and scripting languages. Language syntax, control structures, data types, procedures and parameters, binding, scope, run-time organization, and exception handling. Implementation of language translation tools including compilers and interpreters. Lexical, syntactic and semantic analysis; code generation; introduction to code optimization. Teams implement a language and its compiler.

Fall 2017: COMS W4115 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 4115 | 001/16828 | M W 4:10pm - 5:25pm 501 Northwest Corner |
Stephen Edwards | 3 | 124/164 |

COMS 4115 | H01/93148 | |
Stephen Edwards | 3 | 4/50 |

Spring 2018: COMS W4115 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |

COMS 4115 | 001/76626 | M W 2:40pm - 3:55pm 833 Seeley W. Mudd Building |
Stephen Edwards, Richard Townsend | 3 | 116/120 |

**COMS W4117 Compilers and Interpreters. ***3 points*.

Lect: 3.**Not offered during 2017-18 academic year.**

Prerequisites: (COMS W4115) or instructor's permission.

Continuation of *COMS W4115*, with broader and deeper investigation into the design and implementation of contemporary language translators, be they compilers or interpreters. Topics include parsing, semantic analysis, code generation and optimization, run-time environments, and compiler-compilers. A programming project is required.

**COMS W4118 Operating Systems I. ***3 points*.

Lect: 3.

Prerequisites: (CSEE W3827) and knowledge of C and programming tools as covered in COMS W3136, W3157, or W3101, or the instructor's permission.

Design and implementation of operating systems. Topics include process management, process synchronization and interprocess communication, memory management, virtual memory, interrupt handling, processor scheduling, device management, I/O, and file systems. Case study of the UNIX operating system. A programming project is required.

Fall 2017: COMS W4118 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 4118 | 001/61957 | T Th 1:10pm - 2:25pm 833 Seeley W. Mudd Building |
Jason Nieh | 3 | 82/120 |

Spring 2018: COMS W4118 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |

COMS 4118 | 001/18633 | T Th 11:40am - 12:55pm 501 Northwest Corner |
Jae Lee | 3 | 73/164 |

**COMS W4121 Computer Systems for Data Science. ***3 points*.

Prerequisites: background in Computer System Organization and good working knowledge of C/C++

Corequisites: CSOR W4246,STAT GU4203

An introduction to computer architecture and distributed systems with an emphasis on warehouse scale computing systems. Topics will include fundamental tradeoffs in computer systems, hardware and software techniques for exploiting instruction-level parallelism, data-level parallelism and task level parallelism, scheduling, caching, prefetching, network and memory architecture, latency and throughput optimizations, specialization, and an introduction to programming data center computers.

Spring 2018: COMS W4121 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 4121 | 001/87147 | T 7:00pm - 9:30pm 309 Havemeyer Hall |
Sambit Sahu, Roxana Geambasu, Eugene Wu | 3 | 158/175 |

**COMS W4130 Principles and Practice of Parallel Programming. ***3 points*.

CC/GS: Partial Fulfillment of Science Requirement

Prerequisites: (COMS W3134) and (COMS W3136) or (COMS W3137) or experience in Java, basic understanding of analysis of algorithms. *COMS W3134*, *W3136*, or *W3137* (or equivalent).

Principles of parallel software design. Topics include task and data decomposition, load-balancing, reasoning about correctness, determinacy, safety, and deadlock-freedom. Application of techniques through semester-long design project implementing performant, parallel application in a modern parallel programming language.

**COMS W4156 Advanced Software Engineering. ***3 points*.

Lect: 3.

Prerequisites: (COMS W3157) or equivalent.

Software lifecycle from the viewpoint of designing and implementing N-tier applications (typically utilizing web browser, web server, application server, database). Major emphasis on quality assurance (code inspection, unit and integration testing, security and stress testing). Centers on a student-designed team project that leverages component services (e.g., transactions, resource pooling, publish/subscribe) for an interactive multi-user application such as a simple game.

Fall 2017: COMS W4156 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 4156 | 001/15547 | T Th 10:10am - 11:25am 1127 Seeley W. Mudd Building |
Gail Kaiser | 3 | 88/85 |

Spring 2018: COMS W4156 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |

COMS 4156 | 001/27550 | T Th 5:40pm - 6:55pm 313 Fayerweather |
Ewan Lowe | 3 | 76/78 |

**COMS W4160 Computer Graphics. ***3 points*.

Lect: 3.

Prerequisites: (COMS W3134) or (COMS W3136) or (COMS W3137) COMS W4156 is recommended. Strong programming background and some mathematical familiarity including linear algebra is required.

Introduction to computer graphics. Topics include 3D viewing and projections, geometric modeling using spline curves, graphics systems such as OpenGL, lighting and shading, and global illumination. Significant implementation is required: the final project involves writing an interactive 3D video game in OpenGL.

Fall 2017: COMS W4160 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 4160 | 001/83279 | Th 6:10pm - 8:00pm 503 Hamilton Hall |
Michael Reed | 3 | 32/50 |

Spring 2018: COMS W4160 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |

COMS 4160 | 001/60291 | T Th 11:40am - 12:55pm 413 International Affairs Bldg |
Changxi Zheng | 3 | 49/60 |

**COMS W4162 Advanced Computer Graphics. ***3 points*.

Lect: 3.

Prerequisites: (COMS W4160) or equivalent, or the instructor's permission.

A second course in computer graphics covering more advanced topics including image and signal processing, geometric modeling with meshes, advanced image synthesis including ray tracing and global illumination, and other topics as time permits. Emphasis will be placed both on implementation of systems and important mathematical and geometric concepts such as Fourier analysis, mesh algorithms and subdivision, and Monte Carlo sampling for rendering. Note: Course will be taught every two years.

**COMS W4167 Computer Animation. ***3 points*.

Lect: 3.

Prerequisites: Multivariable calculus, linear algebra, C++ programming proficiency. COMS W4156 recommended.

Theory and practice of physics-based animation algorithms, including animated clothing, hair, smoke, water, collisions, impact, and kitchen sinks. Topics covered: Integration of ordinary differential equations, formulation of physical models, treatment of discontinuities including collisions/contact, animation control, constrained Lagrangian Mechanics, friction/dissipation, continuum mechanics, finite elements, rigid bodies, thin shells, discretization of Navier-Stokes equations. General education requirement: quantitative and deductive reasoning (QUA).

Fall 2017: COMS W4167 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 4167 | 001/78448 | T Th 2:40pm - 3:55pm 703 Hamilton Hall |
Changxi Zheng | 3 | 18/60 |

**COMS W4170 User Interface Design. ***3 points*.

CC/GS: Partial Fulfillment of Science Requirement

Prerequisites: (COMS W3134) and (COMS W3136) or (COMS W3137) *COMS W3134*, *W3136*, or *W3137*.

Introduction to the theory and practice of computer user interface design, emphasizing the software design of graphical user interfaces. Topics include basic interaction devices and techniques, human factors, interaction styles, dialogue design, and software infrastructure. Design and programming projects are required.

Fall 2017: COMS W4170 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 4170 | 001/76984 | T Th 1:10pm - 2:25pm 413 Kent Hall |
Steven Feiner | 3 | 61/65 |

Spring 2018: COMS W4170 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |

COMS 4170 | 001/25649 | M W 4:10pm - 5:25pm 413 Kent Hall |
Lydia Chilton | 3 | 73/65 |

**COMS W4172 3D User Interfaces and Augmented Reality. ***3 points*.

CC/GS: Partial Fulfillment of Science Requirement

Prerequisites: (COMS W4160) or (COMS W4170) or *COMS W4160*, *COMS W4170*, or the instructor's permission.

Design, development, and evaluation of 3D user interfaces. Interaction techniques and metaphors, from desktop to immersive. Selection and manipulation. Travel and navigation. Symbolic, menu, gestural, and multimodal interaction. Dialogue design. 3D software support. 3D interaction devices and displays. Virtual and augmented reality. Tangible user interfaces. Review of relevant 3D math.

Spring 2018: COMS W4172 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 4172 | 001/24265 | T Th 1:10pm - 2:25pm 214 Pupin Laboratories |
Steven Feiner | 3 | 47/52 |

**COMS W4180 Network Security. ***3 points*.

Lect: 3.

Prerequisites: (COMS W3134) and (COMS W3136) or (COMS W3137) and (CSEE W4119) or instructor's permission.

Introduction to network security concepts and mechanisms. Foundations of network security and an in-depth review of commonly-used security mechanisms and techniques, security threats and network-based attacks, applications of cryptography, authentication, access control, intrusion detection and response, security protocols (IPsec, SSL, Kerberos), denial of service, viruses and worms, software vulnerabilities, web security, wireless security, and privacy.

Spring 2018: COMS W4180 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 4180 | 001/74216 | F 10:10am - 12:40pm 545 Seeley W. Mudd Building |
Debra Cook | 3 | 18/40 |

**COMS W4187 Security Architecture and Engineering. ***3 points*.

Lect: 3.

Prerequisites: (COMS W4118) and (COMS W4180) or CSEE W4119 recommended.

Secure programming. Cryptograhic engineering and key handling. Access controls. Tradeoffs in security design. Design for security.

Fall 2017: COMS W4187 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 4187 | 001/68791 | M W 2:40pm - 3:55pm 545 Seeley W. Mudd Building |
Suman Jana | 3 | 42/70 |

**COMS W4203 Graph Theory. ***3 points*.

Lect: 3.

Prerequisites: (COMS W3203)

General introduction to graph theory. Isomorphism testing, algebraic specification, symmetries, spanning trees, traversability, planarity, drawings on higher-order surfaces, colorings, extremal graphs, random graphs, graphical measurement, directed graphs, Burnside-Polya counting, voltage graph theory.

Spring 2018: COMS W4203 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 4203 | 001/63591 | T Th 2:40pm - 3:55pm 327 Seeley W. Mudd Building |
Timothy Sun | 3 | 32/39 |

**COMS W4205 Combinatorial Theory. ***3 points*.

Lect: 3.**Not offered during 2017-18 academic year.**

Prerequisites: (COMS W3203) and course in calculus.

Sequences and recursions, calculus of finite differences and sums, elementary number theory, permutation group structures, binomial coefficients, Stilling numbers, harmonic numbers, generating functions.

**COMS W4236 Introduction to Computational Complexity. ***3 points*.

Lect: 3.

Prerequisites: (COMS W3261)

Develops a quantitative theory of the computational difficulty of problems in terms of the resources (e.g. time, space) needed to solve them. Classification of problems into complexity classes, reductions, and completeness. Power and limitations of different modes of computation such as nondeterminism, randomization, interaction, and parallelism.

Spring 2018: COMS W4236 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 4236 | 001/28954 | T Th 1:10pm - 2:25pm 420 Pupin Laboratories |
Mihalis Yannakakis | 3 | 45/50 |

**COMS W4241 Numerical Algorithms and Complexity. ***3 points*.

Lect: 3.

Prerequisites: Knowledge of a programming language. Some knowledge of scientific computation is desirable.

Modern theory and practice of computation on digital computers. Introduction to concepts of computational complexity. Design and analysis of numerical algorithms. Applications to computational finance, computational science, and computational engineering.

**COMS W4252 Introduction to Computational Learning Theory. ***3 points*.

CC/GS: Partial Fulfillment of Science Requirement

Prerequisites: (CSOR W4231) or (COMS W4236) or (COMS W3203) or (COMS W3261) and *CSOR W4231* or *COMS W4236* or *COMS W3203* and the instructor's permission, or *COMS W3261* and the instructor's permission.

Possibilities and limitations of performing learning by computational agents. Topics include computational models of learning, polynomial time learnability, learning from examples and learning from queries to oracles. Computational and statistical limitations of learning. Applications to Boolean functions, geometric functions, automata.

**COMS W4261 Introduction to Cryptography. ***3 points*.

Lect: 2.5.

Prerequisites: Comfort with basic discrete math and probability. Recommended: COMS W3261 or CSOR W4231.

An introduction to modern cryptography, focusing on the complexity-theoretic foundations of secure computation and communication in adversarial environments; a rigorous approach, based on precise definitions and provably secure protocols. Topics include private and public key encryption schemes, digital signatures, authentication, pseudorandom generators and functions, one-way functions, trapdoor functions, number theory and computational hardness, identification and zero knowledge protocols.

Fall 2017: COMS W4261 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 4261 | 001/11898 | M W 7:10pm - 8:25pm 209 Havemeyer Hall |
Allison Bishop | 3 | 71/110 |

**COMS W4281 Introduction to Quantum Computing. ***3 points*.

Lect: 3.

Prerequisites: Knowledge of linear algebra. Prior knowledge of quantum mechanics is not required although helpful.

Introduction to quantum computing. Shor's factoring algorithm, Grover's database search algorithm, the quantum summation algorithm. Relationship between classical and quantum computing. Potential power of quantum computers.

**COMS W4444 Programming and Problem Solving. ***3 points*.

CC/GS: Partial Fulfillment of Science Requirement

Prerequisites: (COMS W3134) and (COMS W3136) or (COMS W3137) and (CSEE W3827) *COMS W3134*, *W3136*, or *W3137* and *CSEE W3827*.

Hands-on introduction to solving open-ended computational problems. Emphasis on creativity, cooperation, and collaboration. Projects spanning a variety of areas within computer science, typically requiring the development of computer programs. Generalization of solutions to broader problems, and specialization of complex problems to make them manageable. Team-oriented projects, student presentations, and in-class participation required.

Fall 2017: COMS W4444 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 4444 | 001/60172 | M W 1:10pm - 2:25pm 703 Hamilton Hall |
Kenneth Ross | 3 | 20/30 |

**COMS W4460 Principles of Innovation and Entrepreneurship. ***3 points*.

CC/GS: Partial Fulfillment of Science Requirement

Prerequisites: (COMS W3134) and (COMS W3136) or (COMS W3137) or *COMS W3134*, *W3136*, or *W3137* (or equivalent), or the instructor's permission.

Team project centered course focused on principles of planning, creating, and growing a technology venture. Topics include: indentifying and analyzing opportunities created by technology paradigm shifts, designing innovative products, protecting intellectual property, engineering innovative business models.

Fall 2017: COMS W4460 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 4460 | 001/72803 | F 10:10am - 12:40pm 608 Schermerhorn Hall |
William Reinisch | 3 | 26/32 |

**COMS W4560 Introduction to Computer Applications in Health Care and Biomedicine. ***3 points*.

Lect: 3.

Prerequisites: Experience with computers and a passing familiarity with medicine and biology. Undergraduates in their senior or junior years may take this course only if they have adequate background in mathematics and receive the instructor's permission.

An overview of the field of biomedical informatics, combining perspectives from medicine, computer science and social science. Use of computers and information in health care and the biomedical sciences, covering specific applications and general methods, current issues, capabilities and limitations of biomedical informatics. Biomedical Informatics studies the organization of medical information, the effective management of information using computer technology, and the impact of such technology on medical research, education, and patient care. The field explores techniques for assessing current information practices, determining the information needs of health care providers and patients, developing interventions using computer technology, and evaluating the impact of those interventions.

**COMS W4701 Artificial Intelligence. ***3 points*.

CC/GS: Partial Fulfillment of Science Requirement

Prerequisites: (COMS W3134) or (COMS W3136) or (COMS W3137)

Provides a broad understanding of the basic techniques for building intelligent computer systems. Topics include state-space problem representations, problem reduction and and-or graphs, game playing and heuristic search, predicate calculus, and resolution theorem proving, AI systems and languages for knowledge representation, machine learning and concept formation and other topics such as natural language processing may be included as time permits.

Fall 2017: COMS W4701 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 4701 | 001/13442 | M W 10:10am - 11:25am 417 International Affairs Bldg |
Daniel Bauer | 3 | 236/250 |

Spring 2018: COMS W4701 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |

COMS 4701 | 001/26372 | T Th 10:10am - 11:25am 833 Seeley W. Mudd Building |
Ansaf Salleb-Aouissi | 3 | 112/120 |

**COMS W4705 Natural Language Processing. ***3 points*.

Lect: 3.

Prerequisites: (COMS W3134) and (COMS W3136) or (COMS W3137) or equivalent, or instructor's permission.

Computational approaches to natural language generation and understanding. Recommended preparation: some previous or concurrent exposure to AI or Machine Learning. Topics include information extraction, summarization, machine translation, dialogue systems, and emotional speech. Particular attention is given to robust techniques that can handle understanding and generation for the large amounts of text on the Web or in other large corpora. Programming exercises in several of these areas.

Fall 2017: COMS W4705 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 4705 | 001/72501 | T Th 2:40pm - 3:55pm 501 Northwest Corner |
Kathleen McKeown | 3 | 131/150 |

COMS 4705 | 002/22548 | T Th 11:40am - 12:55pm 1127 Seeley W. Mudd Building |
Michael Collins | 3 | 75/78 |

COMS 4705 | H01/13602 | |
Kathleen McKeown | 3 | 40/50 |

Spring 2018: COMS W4705 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |

COMS 4705 | 001/74833 | M W 4:10pm - 5:25pm Room TBA |
Michael Collins | 3 | 74/78 |

COMS 4705 | 002/68687 | M W 10:10am - 11:25am 209 Havemeyer Hall |
Daniel Bauer | 3 | 105/110 |

**COMS W4706 Spoken Language Processing. ***3 points*.

CC/GS: Partial Fulfillment of Science Requirement

Prerequisites: (COMS W3134) and (COMS W3136) or (COMS W3137) or *COMS W3134*, *W3136*, or *W3137*; or the instructor's permission.

Computational approaches to speech generation and understanding. Topics include speech recognition and understanding, speech analysis for computational linguistics research, and speech synthesis. Speech applications including dialogue systems, data mining, summarization, and translation. Exercises involve data analysis and building a small text-to-speech system.

**COMS W4725 Knowledge representation and reasoning. ***3 points*.

Lect: 3.**Not offered during 2017-18 academic year.**

Prerequisites: (COMS W4701)

General aspects of knowledge representation (KR). The two fundamental paradigms (semantic networks and frames) and illustrative systems. Topics include hybrid systems, time, action/plans, defaults, abduction, and case-based reasoning. Throughout the course particular attention is paid to design trade-offs between language expressiveness and reasoning complexity, and issues relating to the use of KR systems in larger applications.

**COMS W4731 Computer Vision. ***3 points*.

Lect: 3.

Prerequisites: Fundamentals of calculus, linear algebra, and C programming. Students without any of these prerequisites are advised to contact the instructor prior to taking the course.

Introductory course in computer vision. Topics include image formation and optics, image sensing, binary images, image processing and filtering, edge extraction and boundary detection, region growing and segmentation, pattern classification methods, brightness and reflectance, shape from shading and photometric stereo, texture, binocular stereo, optical flow and motion, 2D and 3D object representation, object recognition, vision systems and applications.

Fall 2017: COMS W4731 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 4731 | 001/19314 | M W 10:10am - 11:25am 329 Pupin Laboratories |
Shree Nayar | 3 | 90/100 |

**COMS W4733 Computational Aspects of Robotics. ***3 points*.

CC/GS: Partial Fulfillment of Science Requirement

Prerequisites: (COMS W3134) and (COMS W3136) or (COMS W3137) *COMS W3134*, *W3136*, or *W3137*.

Introduction to robotics from a computer science perspective. Topics include coordinate frames and kinematics, computer architectures for robotics, integration and use of sensors, world modeling systems, design and use of robotic programming languages, and applications of artificial intelligence for planning, assembly, and manipulation.

Fall 2017: COMS W4733 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 4733 | 001/18851 | T Th 11:40am - 12:55pm 313 Fayerweather |
Peter Allen | 3 | 71/75 |

**COMS W4735 Visual Interfaces to Computers. ***3 points*.

Lect: 3.

Prerequisites: (COMS W3134) and (COMS W3136) or (COMS W3137)

Visual input as data and for control of computer systems. Survey and analysis of architecture, algorithms, and underlying assumptions of commercial and research systems that recognize and interpret human gestures, analyze imagery such as fingerprint or iris patterns, generate natural language descriptions of medical or map imagery. Explores foundations in human psychophysics, cognitive science, and artificial intelligence.

Spring 2018: COMS W4735 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 4735 | 001/13203 | T Th 2:40pm - 3:55pm 1127 Seeley W. Mudd Building |
John Kender | 3 | 58/80 |

**COMS W4737 Biometrics. ***3 points*.

CC/GS: Partial Fulfillment of Science Requirement

Prerequisites: a background at the sophomore level in computer science, engineering, or like discipline.

In this course. we will explore the latest advances in biometrics as well as the machine learning techniques behind them. Students will learn how these technologies work and how they are sometimes defeated. Grading will be based on homework assignments and a final project. There will be no midterm or final exam. This course shares lectures with *COMS E6737*. Students taking *COMS E6737* are required to complete additional homework problems and undertake a more rigorous final project. Students will only be allowed to earn credit for *COMS W4737* or *COMS E6737* and not both.

**COMS W4771 Machine Learning. ***3 points*.

Lect: 3.

Prerequisites: Any introductory course in linear algebra and any introductory course in statistics are both required. Highly recommended: COMS W4701 or knowledge of Artificial Intelligence.

Topics from generative and discriminative machine learning including least squares methods, support vector machines, kernel methods, neural networks, Gaussian distributions, linear classification, linear regression, maximum likelihood, exponential family distributions, Bayesian networks, Bayesian inference, mixture models, the EM algorithm, graphical models and hidden Markov models. Algorithms implemented in MATLAB.

Fall 2017: COMS W4771 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 4771 | 001/76261 | M W 2:40pm - 3:55pm 428 Pupin Laboratories |
James McInerney | 3 | 88/130 |

COMS 4771 | 002/11548 | T Th 2:40pm - 3:55pm 207 Mathematics Building |
Nakul Verma | 3 | 132/152 |

COMS 4771 | H01/80532 | |
James McInerney | 3 | 34/50 |

Spring 2018: COMS W4771 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |

COMS 4771 | 001/21286 | M W 1:10pm - 2:25pm 501 Northwest Corner |
Nakul Verma | 3 | 121/130 |

COMS 4771 | 002/67785 | M W 2:40pm - 3:55pm 501 Northwest Corner |
Nakul Verma | 3 | 100/130 |

**COMS W4772 Advanced Machine Learning. ***3 points*.

Lect: 3.

Prerequisites: (COMS W4771) or instructor's permission; knowledge of linear algebra & introductory probability or statistics is required.

An exploration of advanced machine learning tools for perception and behavior learning. How can machines perceive, learn from, and classify human activity computationally? Topics include appearance-based models, principal and independent components analysis, dimensionality reduction, kernel methods, manifold learning, latent models, regression, classification, Bayesian methods, maximum entropy methods, real-time tracking, extended Kalman filters, time series prediction, hidden Markov models, factorial HMMS, input-output HMMs, Markov random fields, variational methods, dynamic Bayesian networks, and Gaussian/Dirichlet processes. Links to cognitive science.

**COMS W4776 Machine Learning for Data Science. ***3 points*.

Lect.: 3

Prerequisites: (STAT GU4001) or (COMS W3251) or (IEOR E4150) or equivalent.

Introduction to machine learning, emphasis on data science. Topics include least square methods, Gaussian distributions, linear classification, linear regression, maximum likelihood, exponential family distributions, Bayesian networks, Bayesian inference, mixture models, the EM algorithm, graphical models, hidden Markov models, support vector machines kernel methods. Emphasizes methods and problems relevant to big data. Students may not receive credit for both COMS W4771 and W4776.

**COMS W4901 Projects in Computer Science. ***1-3 points*.

Prerequisites: Approval by a faculty member who agrees to supervise the work.

A second-level independent project involving laboratory work, computer programming, analytical investigation, or engineering design. May be repeated for credit, but not for a total of more than 3 points of degree credit. Consult the department for section assignment.

**COMS W4995 Special topics in computer science, I. ***3 points*.

Lect: 3.

Prerequisites: Instructor's permission.

Special topics arranged as the need and availability arises. Topics are usually offered on a one-time basis. Since the content of this course changes each time it is offered, it may be repeated for credit. Consult the department for section assignment.

Fall 2017: COMS W4995 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

COMS 4995 | 001/72676 | T 4:10pm - 6:40pm 750 Schapiro Cepser |
Paul Blaer, Scott Handler | 3 | 26/30 |

COMS 4995 | 002/25518 | M W 7:10pm - 8:25pm 1024 Seeley W. Mudd Building |
Iddo Drori | 3 | 56/60 |

COMS 4995 | 003/17193 | M W 4:10pm - 5:25pm 503 Hamilton Hall |
Henning Schulzrinne | 3 | 28/54 |

COMS 4995 | 004/88536 | T Th 8:40am - 9:55am 310 Fayerweather |
Christos Papadimitriou | 3 | 20/70 |

COMS 4995 | 006/25283 | T 7:00pm - 9:30pm 516 Hamilton Hall |
Haiyuan Wang | 3 | 8/54 |

COMS 4995 | 007/67305 | Th 7:00pm - 9:30pm 633 Seeley W. Mudd Building |
Adam Kelleher | 3 | 31/70 |

COMS 4995 | 008/96248 | Th 7:00pm - 9:30pm 520 Mathematics Building |
Bryan Gibson | 3 | 30/49 |

COMS 4995 | H02/13000 | |
Iddo Drori | 3 | 34/50 |

Spring 2018: COMS W4995 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |

COMS 4995 | 001/65579 | F 10:10am - 12:00pm 227 Seeley W. Mudd Building |
Bjarne Stroustrup | 3 | 34/35 |

COMS 4995 | 002/28032 | T Th 7:10pm - 8:25pm 602 Hamilton Hall |
Iddo Drori | 3 | 61/80 |

COMS 4995 | 003/87282 | M W 1:10pm - 2:25pm 417 International Affairs Bldg |
Andreas Mueller | 3 | 133/150 |

COMS 4995 | 004/19694 | Th 7:00pm - 9:30pm 313 Fayerweather |
Adam Kelleher | 3 | 16/70 |

COMS 4995 | 005/10034 | T 4:10pm - 6:00pm 413 International Affairs Bldg |
Sameer Maskey, Steven Rennie | 3 | 53/60 |

COMS 4995 | 006/13053 | T Th 2:40pm - 3:55pm 603 Hamilton Hall |
Peter Belhumeur | 3 | 54/53 |

**COMS W4996 Special topics in computer science, II. ***3 points*.

Lect: 3.**Not offered during 2017-18 academic year.**

Prerequisites: Instructor's permission.

A continuation of COMS W4995 when the special topic extends over two terms.

**CSEE E6180 Modeling and Performance. ***3 points*.

Lect: 2.

Prerequisites: (COMS W4118) and (STAT GU4001) *COMS W4118* and *SIEO W4150*.

Introduction to queuing analysis and simulation techniques. Evaluation of time-sharing and multiprocessor systems. Topics include priority queuing, buffer storage, and disk access, interference and bus contention problems, and modeling of program behaviors.

**CSEE E6824 Parallel Computer Architecture. ***3 points*.

Lect: 2.

Prerequisites: (CSEE W4824)

Parallel computer principles, machine organization and design of parallel systems including parallelism detection methods, synchronization, data coherence and interconnection networks. Performance analysis and special purpose parallel machines.

**CSEE E6847 Distributed Embedded Systems. ***3 points*.

Lect: 2.**Not offered during 2017-18 academic year.**

Prerequisites: Any COMS W411X, CSEE W48XX or ELEN E43XX course, or the instructor's permission.

An interdisciplinary graduate-level seminar on the design of distributed embedded systems. System robustness in the presence of highly variable communication delays and heterogeneous component behaviors. The study of the enabling technologies (VLSI circuits, communication protocols, embedded processors, RTOSs), models of computation, and design methods. The analysis of modern domain-specific applications including on-chip micro-networks, multiprocessor systems, fault-tolerant architectures, and robust deployment of embedded software. Research challenges such as design complexity, reliability, scalability, safety, and security. The course requires substantial reading, class participation and a research project.

**CSEE E6861 Computer-Aided Design of Digital Systems. ***3 points*.

Lect: 2.

Prerequisites: (CSEE W4823) and (COMS W3134) and (COMS W3136) and (COMS W3137) and (COMS W3157) or (i) one semester of advanced digital logic (*CSEE 4823* or equivalent, or the instructor's permission); and (ii) a basic course in data structures and algorithms (*COMS W3134*, *W3136*, *W3137*, *W3157*, or equivalent, and familiarity with programming.

Introduction to modern digital CAD synthesis and optimization techniques. Topics include: modern digital system design (high-level synthesis, register-transfer level modeling, algorithmic state machines, optimal scheduling algorithms, resource allocation and binding, retiming), controller synthesis and optimization, exact and heuristic two-level logic minimization, advanced multi-level logic optimization, optimal technology mapping to library cells (for delay, power and area minimization), advanced data structures (binary decision diagrams), SAT solvers and their applications, static timing analysis, and introduction to testability. Includes hands-on small design projects using and creating CAD tools.

**CSEE E6863 Formal verification of hardware and software systems. ***3 points*.

Lect: 2.

Prerequisites: (COMS W3134) and (COMS W3136) or (COMS W3137) and (COMS W3261)

Introduction to the theory and practice of formal methods for the design and analysis of correct (i.e. bug-free) concurrent and embedded hardware/software systems. Topics include temporal logics; model checking; deadlock and liveness issues; fairness; satisfiability (SAT) checkers; binary decision diagrams (BDDs); abstraction techniques; introduction to commercial formal verification tools. Industrial state-of-art, case studies and experiences: software analysis (C/C++/Java), hardware verification (RTL).

Fall 2017: CSEE E6863 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

CSEE 6863 | 001/87531 | W 6:10pm - 8:00pm 214 Pupin Laboratories |
Michael Theobald, Franjo Ivancic | 3 | 45/60 |

**CSEE E6868 Embedded scalable platforms. ***3 points*.

Lect: 2.

Prerequisites: (CSEE W4868) or CSEE W4868 or instructor permission.

Inter-disciplinary graduate-level seminar on design and programming of embedded scalable platforms. Content varies between offerings to cover timely relevant issues and latest advances in system-on-chip design, embedded software programming, and electronic design automation. Requires substantial reading of research papers, class participation, and semester-long project.

Spring 2018: CSEE E6868 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

CSEE 6868 | 001/28461 | Th 4:10pm - 6:00pm 834 Seeley W. Mudd Building |
Luca Carloni | 3 | 9/40 |

**CSEE W3827 Fundamentals of Computer Systems. ***3 points*.

Lect: 3.

Prerequisites: an introductory programming course.

Fundamentals of computer organization and digital logic. Boolean algebra, Karnaugh maps, basic gates and components, flipflops and latches, counters and state machines, basics of combinational and sequential digital design. Assembly language, instruction sets, ALU’s, single-cycle and multi-cycle processor design, introduction to pipelined processors, caches, and virtual memory.

Fall 2017: CSEE W3827 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

CSEE 3827 | 001/20794 | T Th 10:10am - 11:25am 501 Schermerhorn Hall |
Martha Kim | 3 | 196/215 |

Spring 2018: CSEE W3827 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |

CSEE 3827 | 001/72320 | T Th 10:10am - 11:25am 309 Havemeyer Hall |
Daniel Rubenstein | 3 | 206/320 |

**CSEE W4119 Computer Networks. ***3 points*.

Lect: 3.

Corequisites: IEOR E3658,IEOR E4150

Introduction to computer networks and the technical foundations of the Internet, including applications, protocols, local area networks, algorithms for routing and congestion control, security, elementary performance evaluation. Several written and programming assignments required.

Fall 2017: CSEE W4119 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

CSEE 4119 | 001/74094 | T Th 1:10pm - 2:25pm 301 Pupin Laboratories |
Ethan Katz-Bassett | 3 | 89/150 |

Spring 2018: CSEE W4119 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |

CSEE 4119 | 001/26750 | F 1:10pm - 3:40pm 501 Northwest Corner |
Henning Schulzrinne | 3 | 99/164 |

**CSEE W4140 Networking Laboratory. ***3 points*.

Lect: 3.

Prerequisites: (CSEE W4119) or equivalent.

In this course, students will learn how to put "principles into practice," in a hands-on-networking lab course. The course will cover the technologies and protocols of the Internet using equipment currently available to large internet service providers such as CISCO routers and end systems. A set of laboratory experiments will provide hands-on experience with engineering wide-area networks and will familiarize students with the Internet Protocol (IP), Address Resolution Protocol (ARP), Internet Control Message Protocol (ICMP), User Datagram Protocol (UDP) and Transmission Control Protocol (TCP), the Domain Name System (DNS), routing protocols (RIP, OSPF, BGP), network management protocols (SNMP, and application-level protocols (FTP, TELNET, SMTP).

Fall 2017: CSEE W4140 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

CSEE 4140 | 001/28029 | W 10:10am - 11:25am 337 Seeley W. Mudd Building |
Gil Zussman | 3 | 15/32 |

Spring 2018: CSEE W4140 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |

CSEE 4140 | 001/11241 | W 10:10am - 11:25am 603 Hamilton Hall |
Gil Zussman | 3 | 20/42 |

**CSEE W4823 Advanced Logic Design. ***3 points*.

Lect: 3.

Prerequisites: (CSEE W3827) or *CSEE W3827*, or a half semester introduction to digital logic, or the equivalent.

An introduction to modern digital system design. Advanced topics in digital logic: controller synthesis (Mealy and Moore machines); adders and multipliers; structured logic blocks (PLDs, PALs, ROMs); iterative circuits. Modern design methodology: register transfer level modelling (RTL); algorithmic state machines (ASMs); introduction to hardware description languages (VHDL or Verilog); system-level modelling and simulation; design examples.

Spring 2018: CSEE W4823 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

CSEE 4823 | 001/28452 | M W 11:40am - 12:55pm 428 Pupin Laboratories |
Mingoo Seok | 3 | 44/80 |

**CSEE W4824 Computer Architecture. ***3 points*.

Lect: 3.

Prerequisites: (CSEE W3827) or equivalent.

Focuses on advanced topics in computer architecture, illustrated by case studies from classic and modern processors. Fundamentals of quantitative analysis. Pipelining. Memory hierarchy design. Instruction-level and thread-level parallelism. Data-level parallelism and graphics processing units. Multiprocessors. Cache coherence. Interconnection networks. Multi-core processors and systems-on-chip. Platform architectures for embedded, mobile, and cloud computing.

Spring 2018: CSEE W4824 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

CSEE 4824 | 001/20248 | M W 4:10pm - 5:25pm 633 Seeley W. Mudd Building |
Simha Sethumadhavan | 3 | 38/60 |

**CSEE W4840 Embedded Systems. ***3 points*.

Lect: 3.

Prerequisites: (CSEE W4823) *CSEE W4823*.

Embedded system design and implementation combining hardware and software. I/O, interfacing, and peripherals. Weekly laboratory sessions and term project on design of a microprocessor-based embedded system including at least one custom peripheral. Knowledge of C programming and digital logic required.

**CSEE W4868 System-on-chip platforms. ***3 points*.

Prerequisites: (COMS W3157) and (CSEE W3827) COMS W3157 and CSEE W3827

Design and programming of System-on-Chip (SoC) platforms. Topics include: overview of technology and economic trends, methodologies and supporting CAD tools for system-level design, models of computation, the SystemC language, transaction-level modeling, software simulation and virtual platforms, hardware-software partitioning, high-level synthesis, system programming and device drivers, on-chip communication, memory organization, power management and optimization, integration of programmable processor cores and specialized accelerators. Case studies of modern SoC platforms for various classes of applications.

Fall 2017: CSEE W4868 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

CSEE 4868 | 001/23175 | T Th 11:40am - 12:55pm 717 Hamilton Hall |
Luca Carloni | 3 | 26/64 |

**CSEE W6600 From Data to Solutions. ***3 points*.

Lect: 3.**Not offered during 2017-18 academic year.**

Prerequisites: Ability to study research solutions and write a coherent weekly report in English that summarizes problems involving large-scale data sets and solutions based on data science methods and tools

Introduces students interested in data science and interdisciplinary research to a wide variety of problems in medical research, journalism, history, economics, business, English, psychology, and other areas which might benefit from computational approaches.

**COSA E9800 Data Science Doctoral Seminar. ***1 point*.

**Not offered during 2017-18 academic year.**

The Data Science Doctoral Seminar is a 1-credit course that meets weekly. The purpose is to expose the doctoral students to a breadth of ideas in data science across disciplinary domains. The syllabus combines guest lectures from academic data scientists in the greater NYC area and faculty at Columbia, along with a selection of related readings chosen by the guest lecturers. As part of this seminar, students will be expected to engage in active open discussion about the topics and readings covered in class, as well as discuss how such topics apply to their own respective research areas.

**CSOR E4010 Graph Theory: A Combinatorial View. ***3 points*.

Lect: 3.**Not offered during 2017-18 academic year.**

Prerequisites: Linear Algebra, or instructor's permission.

Graph Theory is an important part of the theoretical basis of operations research. A good understanding of the basic fundamentals of graph theory is necessary in order to apply the theory successfully in the future. This is an introductory course in graph theory with emphasis on its combinatorial aspects. It covers basic definitions, and some fundamental concepts in graph theory and its applications. Topics include trees and forests graph coloring, connectivity, matching theory and others. This course will provide a solid foundation for students in the IEOR department, on which further courses may build.

**CSOR W4231 Analysis of Algorithms I. ***3 points*.

Lect: 3.

Prerequisites: (COMS W3134) and (COMS W3136) or (COMS W3137) and (COMS W3203)

Introduction to the design and analysis of efficient algorithms. Topics include models of computation, efficient sorting and searching, algorithms for algebraic problems, graph algorithms, dynamic programming, probabilistic methods, approximation algorithms, and NP-completeness.

Fall 2017: CSOR W4231 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

CSOR 4231 | 001/27262 | T Th 11:40am - 12:55pm 833 Seeley W. Mudd Building |
Mihalis Yannakakis | 3 | 109/110 |

CSOR 4231 | 002/67835 | T Th 4:10pm - 5:25pm 207 Mathematics Building |
Clifford Stein | 3 | 143/150 |

CSOR 4231 | H01/13781 | |
Mihalis Yannakakis | 3 | 43/50 |

Spring 2018: CSOR W4231 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |

CSOR 4231 | 001/27733 | M W 4:10pm - 5:25pm 833 Seeley W. Mudd Building |
Alexandr Andoni | 3 | 90/120 |

CSOR 4231 | 002/26380 | T Th 4:10pm - 5:25pm 501 Northwest Corner |
Eleni Drinea | 3 | 89/164 |

**CBMF W4761 Computational Genomics. ***3 points*.

Lect: 3.

Prerequisites: Working knowledge of at least one programming language, and some background in probability and statistics.

Computational techniques for analyzing genomic data including DNA, RNA, protein and gene expression data. Basic concepts in molecular biology relevant to these analyses. Emphasis on techniques from artificial intelligence and machine learning. String-matching algorithms, dynamic programming, hidden Markov models, expectation-maximization, neural networks, clustering algorithms, support vector machines. Students with life sciences backgrounds who satisfy the prerequisites are encouraged to enroll.

Spring 2018: CBMF W4761 | |||||

Course Number | Section/Call Number | Times/Location | Instructor | Points | Enrollment |
---|---|---|---|---|---|

CBMF 4761 | 001/19098 | M W 4:10pm - 5:25pm 545 Seeley W. Mudd Building |
Itshack Pe'er | 3 | 35/70 |