Undergraduate classes, Fall 2007, Computer Science
Note: All courses taken towards the major or minor must be taken on a letter grade basis, not pass/fail.
|CS 110: Computer Science Fundamentals||Credits: 4||− Description||− Sections|
Content: The course will provide a basic understanding of the principles underlying computer systems and software. Topics include an overview of computer hardware, the design of algorithms and their role in problem solving, and programming in a high level language. Databases, networking and the world-wide web, and contemporary issues in information technology will also be discussed.
Particulars: Lectures will be supplemented by readings and some laboratory exercises; there will be several quizzes, a midterm, a final exam, and assignments. Computer-based assignments will account for approximately 25% of the grade but this is not primarily a programming course.
CS110 is intended for students who do not expect to take additional computing courses. Students interested in further course work should instead start in CS170.
|000||MSC: W301||TuTh 1:00pm - 2:15pm||Vaidy Sunderam|
|CS 155: Computer Science with Business Applications||Credits: 4||− Description||− Sections|
Content: This course covers tools and concepts of computer science that are most relevant to business (enterprise) computing and e-commerce, emphasizing the common 3-tier website model. Students will be introduced to basic programming principles, page layout and visual interface design, client/server computing, and simple techniques for accessing databases. Algorithmic and mathematical foundations of fundamental e-commerce techniques such as search engines, recommendation and reputation management systems, and online auctions will be studied. Teams of students will explore existing websites and design and implement extensions to a code framework. No background in computing is necessary but students with background are welcomed.
Particulars: Class meetings will be a mix of lectures and hands-on work in the Math/CS teaching lab using Microsoft Visual Basic .NET and related tools. Grades will be based on participation, presentations, project design and implementation, and a midterm and final exam.
This class has a lab on Mondays from 4-5 pm.
|001||MSC: W303||MWF 11:45am - 12:35pm||Phil Hutto|
|Lab||E308A||W 4:00pm - 5:00pm||Phil Hutto|
|CS 170: Introduction to Computer Science I||Credits: 4||− Description||− Sections|
Content: This course is an introduction to computer science for the student who expects to make serious use of the computer in course work or research. Topics include: fundamental computing concepts, general programming principles, the Unix Operating System, the X-window system, and the Java programming language. Emphasis will be on algorithm development with examples highlighting topics in data structures.
Particulars: No previous programming experience is required for this course. Students expecting to take more advanced Computer Science courses should start here.
The grade in this course will be based on programming assignments and examinations. Typically the programming assignments will count no more than 50%.
|000||MSC: W201||MWF 12:50pm - 1:40pm||Li Xiong|
|000L||E308A||M 4:00pm - 5:00pm||Li Xiong|
|001||MSC: W201||TuTh 1:00pm - 2:15pm||Shun Yan Cheung|
|001L||E308A||Th 4:00pm - 5:00pm||Shun Yan Cheung|
|CS 171: Introduction to Computer Science II||Credits: 4||− Description||− Sections|
Content: A continuation of CS170. Emphasis is on the use and implementation of data structures, introductory algorithm analysis, and object oriented design and programming with Java. The course will also introduce the basics of procedural programming with C.
|000||MSC: W301||MWF 11:45am - 12:35pm||Michelangelo Grigni|
|CS 190: Freshman Seminar: Robots||Credits: 4||− Description||− Sections|
Content: Computers are ubiquitous and take a variety of interesting forms such as robots, mobile phones, electronic music players, toys, and biomedical devices. This course provides an introduction to Computer Science by programming and exploring such embedded computer systems and robotics, culminating in a competition among student- designed robots. Although the course is self-contained, a strong interest in learning or experience in programming is helpful.
|000||MSC: W306||TuTh 11:30am - 12:45pm||Ojas Parekh|
|CS 224: Mathematical Foundations of Computer Science||Credits: 4||− Description||− Sections|
Content: This course introduces elementary mathematics necessary for the computer science curriculum. Topics include functions, boolean logic, quantifiers, automata, languages, asymptotic notation, and reasoning about programs.
Particulars: The grade is based on regular homeworks, one or two midterms, and a final exam.
Prerequisites: Math 112 (or 112s or 112Z). Corequisite: CS 170.
|000||MSC: W306||MWF 9:35am - 10:25am||Michelangelo Grigni|
|CS 255: Computer Organization and Architecture I||Credits: 4||− Description||− Sections|
Content: This is the first course in computer organization and architecture and is designed to introduce the student to computer organization, architecture. The hardware components of computer systems and their interconnections will be studied at a level suitable for assembly programming. The architecture of the M68000 and SPARC computers and their assembly languages will be covered in detail.
Particulars: Grades will be based on quizzes, homework, programming assignments, and tests.
Prerequisites: CS 171.
|000||MSC: W301||TuTh 10:00am - 11:15am||Shun Yan Cheung|
|CS 356: Programming Languages||Credits: 4||− Description||− Sections|
Content: (Same as CS 470). Design of programming languages, variables and bindings, control structures and dataflow, imperative programming, functional programming, object-oriented programming, logic programming. An understanding of the fundamental concepts in the design of computer languages, syntax, semantics, and pragmatics, comparative analysis of programming paradigms.
Particulars: Classroom lectures, supplemented by readings and discussions, programming projects.
Prerequisites: CS 171.
|000||MSC: W303||MWF 12:50pm - 1:40pm||Phil Hutto|
|CS 450: Systems Programming||Credits: 4||− Description||− Sections|
Content: (Same as CS 351). Systems programming topics will be illustrated by use of the Unix operating system. Topics include: file i/o, the tty driver, window systems, processes, shared memory, message passing, semaphores, signals, and interrupt handlers.
Programming examples and assignments will illustrate the system interface on actual computer hardware. All assignments will be in written in C. The department's computing lab will be used in the course to allow students to get hands-on experience with operating system and hardware topics that cannot effectively be pursued on a central timesharing computer.
Particulars: Grades will be based on the programming assignments as well as the midterm and final exams. This course may not be taken S/U.
Prerequisites: CS 171 and CS 255.
|000||MSC: W301||TuTh 11:30am - 12:45pm||Ken Mandelberg|
|CS 456: Compiler Construction||Credits: 4||− Description||− Sections|
Content: An introduction to the algorithms and data structures used to construct a high level language compiler. Topics include: formal language specification, lexical analysis, parsing, and code generation.
Particulars: A substantial portion of this course will involve a student project to construct a compiler for a simplified programming language. Working knowledge of C or C++ is highly recommended.
Prerequisites: CS 253, CS 255, and CS 424, or their equivalents.
|000||MSC: W301||MWF 2:00pm - 2:50pm||James Lu|
|CS 497R: Undergraduate Directed Study||Credits: 1 - 12||− Description||− Sections|