Computer Science

College of Science and Engineering
Dean: 

Department of Computer Science
TH 906
415-338-1008
E-mail: cs@sfsu.edu
Chair: Jozo J. Dujmovic

Undergraduate Advisers: Douglas, Hodges, Kroll, Murphy, Wong
Graduate Coordinator: B. Levine

Faculty

Professors—Douglas, Dujmovic, Eisman, Levine, Murphy, Wong

Associate Professors—Hodges, Hsu, Kroll

Adjunct Professor—Brandstatter, Ignjatovic

Lecturers—Rankovich-Dujmovic, Mash, Osborne, Tomasevich

Programs

B.S. in Computer Science
Minor in Computer Science
M.S. in Computer Science


Program Scope

The primary mission of the Computer Science Department is to prepare students for employment as computer specialists in the software development and computer manufacturing industries and for continued study toward advanced degrees. The department offers a broad curriculum covering the major areas of the computing discipline. Students are exposed to the fundamentals of computing architecture and computing theory, and focus their studies on the areas of software and system development. Faculty work directly with students to develop in them the skills and knowledge of computing professionals.

Department faculty are committed to teaching excellence. They remain current in the rapidly changing field of computing technology through continued research, direct consultation with local industries, and seminar programs that bring top researchers to campus to speak on current developments in the field. Programs such as the Industry Research Associate Program provide opportunities for graduate students to complement their academic learning with real world experience.

The department has an additional commitment to sharing its knowledge and skills with the rest of the university community, with local schools, and with community based organizations of the Bay Area.

The B.S. program stresses a basic foundation in mathematics and physics, and a thorough study of the fundamentals of the discipline--software development, computer architecture, operating systems, programming languages, algorithms, and the theoretical foundations of computer science. A wide variety of elective courses such as database systems, artificial intelligence, computer architecture and graphics, allow students to emphasize study in selected areas. Ethical and social issues of computing are discussed throughout the curriculum.

Computing Facilities

Central Facilities:
  1. A network of Unix servers supported by SFSU Computing Services
  2. A SUN server (libra) supported by SFSU Computing Services and used for Computer Science classes
  3. Microcomputer labs in SFSU library; several other microcomputer labs are located around campus
Departmental Facilities:
  1. Advanced CS laboratory (UNIX worstation)
  2. SUN microsystem lab (Java workstation)
  3. Experimental computer science lab (PC)

Internet access is provided at all the above facilities.

Career Alternatives

BACHELOR OF SCIENCE IN COMPUTER SCIENCE

Students intending to enter this program at the freshman level should complete two years of algebra and one semester of trigonometry in high school. One year each of high school geometry and physics is very desirable as well as basic knowledge of computer organization and programming.

All lower division courses (course numbers below 300) included among the degree requirements are available at many community colleges in California; students intending to enter the program upon transferring to San Francisco State University from a community college should take as many of those courses there as possible.

Students should plan their program of study in the major with the help of a departmental adviser in order that the correct sequence of courses be taken and a proper set of electives be chosen. It is also suggested that students consult with an adviser before selecting courses to meet General Education requirements.

Students are encouraged to participate in the Computer Science Cooperative Education Program at SFSU. Under this program, they may obtain industrial employment related to their academic studies. This combination of on-the-job training and academic experience can greatly enhance the value of an undergraduate degree in computer science.

An Endowed Scholarship Fund, established in the memory of Jules H. Strauss, offers an annual award to a computer science major who shows scholarly accomplishment and demonstrates a financial need. The Chevron Corporation Achievement Award and the BMC Software Award are given each semester to a junior or senior who has exhibited exceptional achievement.

Students are advised that except for the laboratory courses, CSC 212 and CSC 311, CR/NC grades are not acceptable in courses to be counted for the computer science major program.

Online course descriptions are available.

Mathematics and Physics (22 units) Units
MATH 226-227 Calculus I-II (4 each) 8
MATH 250 Probability and Statistics with Computing 3
MATH 325 Linear Algebra 3
PHYS 220/222 General Physics with Calculus I (3/1) 4
PHYS 230/232 General Physics with Calculus II (3/1) 4
Core Computer Science Requirements (24 units)
CSC 210 Introduction to Computer Programming 3
CSC 212 Software Development Tools with UNIX 2
CSC 301 Fundamentals of Computer Science 3
CSC 310 Assembly Language Programming and Introduction to Computer Organization 3
CSC 311 Assembly Language Programming Laboratory 2
ENGR 356 Basic Computer Architecture 3
CSC 313 Data Structures 3
CSC 330 Discrete Mathematical Structures for Computer Science 3
CSC 413 Software Development 3
Advanced Computer Science Requirements (21 units)
CSC 415 Principles of Operating Systems 3
CSC 510 Analysis of Algorithms I 3
CSC 600 Programming Language Design 3
Senior Presentation. Each major is required to make an oral presentation on an area of computer science during his/her senior year. Guidelines for the presentation are available in the department office 0
Electives (see requirements below) 12
Total for major 67

Elective Requirements (four 3-unit courses)

Electives are selected from the nine subareas of computer science listed below. Electives must meet the following requirements.

  1. One of the electives must be either CSC 520, Theory of Computing, or CSC 656, Computer Organization. (CSC 520 and CSC 656 can be used to partially meet the depth and breadth requirements.)
  2. Depth Requirement: two of the electives must be chosen from the same subarea of the discipline.
  3. Breadth Requirement: electives must be chosen from three different subareas.

For example, the following four electives meet the requirements (subareas are shown in parentheses):

CSC 520 meets requirement 1.
CSC 620 and CSC 671 are both in the Artificial Intelligence subarea (depth requirement 2).
CSC 520, CSC 620, and CSC 675 are in three different subareas (breadth requirement 3).

NOTE: It is recommended that students planning to continue their study of computer science in graduate school take both CSC 656 and CSC 520.

The courses listed below constitute a partial list of suitable courses. Frequently, the department offers courses under the title of CSC 690, Undergraduate Seminar, which meet elective requirements. For example, new courses in computer music, multimedia, performance evaluation, and network administration have been offered. In addition, many students find that by their senior year they are prepared to undertake certain graduate courses in computer science. Any course substitutions must be approved by the major adviser.

Areas of Special Emphasis

Algorithms and Theory of Computing
CSC 520 Theory of Computing
CSC 610 Sorting and Searching
CSC 630 Computer Graphics Systems Design
CSC 635 Software Techniques for the Processing of Computer Music and Sound Data
CSC 671 Neural Networks
CSC 675 Introduction to Database Systems
MATH 400 Numerical Analysis I

Architecture
CSC 645 Computer Networks
CSC 656 Computer Organization

Artificial Intelligence
CSC 620 Natural Language Processing
CSC 665 Introduction to Artificial Intelligence
CSC 671 Neural Networks

Database
CSC 675 Introduction to Database Systems

Graphics
CSC 630 Computer Graphics Systems Design

Numerical and Symbolic Computing
MATH 400 Numerical Analysis I
CSC 635 Software Techniques for the Processing of Computer Music and Sound Data
CSC 671 Neural Networks

Operating Systems and Distributed Processing
CSC 645 Computer Networks
CSC 650 Secure Networked Systems
CSC 667 Internet Application Design and Development

Programming Languages
CSC 520 Theory of Computing
CSC 620 Natural Language Processing
CSC 640 Software Engineering
CSC 665 Introduction to Artificial Intelligence
CSC 668 Object Oriented Programming

Software Engineering
CSC 640 Software Engineering
CSC 667 Internet Application Design and Development
CSC 668 Object Oriented Programming

MINOR IN COMPUTER SCIENCE

Many university students want to acquire sufficient computer science background to enable them to use computers effectively in their major areas, or to provide an alternative source of income after graduation, but do not want to study computer science in the depth required for the B.S. degree. For such students, a minor consisting of the most central courses in the B.S. program, plus some electives, is ideal. Students are advised that except for the laboratory courses, CSC 212 and CSC 311, CR/NC grades are not acceptable in courses to be counted for the Computer Science Minor.

Program Requirements Units
CSC 210 Introduction to Computer Programming 3
CSC 212 Software Development Tools with UNIX 2
CSC 301 Fundamentals of Computer Science 3
CSC 310 Assembly Language Programming and Introduction to Computer Organization 3
CSC 311 Assembly Language Programming Laboratory 1
CSC 313 Data Structures 3
CSC 413 Software Development 3
One upper division computer related elective by approval of the minor adviser 3
Total for minor 22

MASTER OF SCIENCE IN COMPUTER SCIENCE

Admission to Program

Candidates for admission to the Computer Science M.S. program should have strong backgrounds in the mathematics which underlies all sciences, the fundamental programming techniques, and the basic concepts of computer architecture, as well as demonstrated potential for graduate study in computer science. The requisite academic background is normally evidenced by a 3.3 grade point average with no grades below a B in the following courses or their equivalents: CSC 330, 413; and ENGR 356. In addition, the student must have completed the following with no grades below a B: MATH 226, 227, 250, and 325. Candidates for admission must submit two or more letters of recommendation from individuals familiar with their previous academic work and/or potential for graduate study. Finally, candidates must submit their scores on the general GRE aptitude test, taken within three years prior to the date of application (institution code: 4684, department code: 0402). Letters of recommendation and test scores should be sent to the Graduate Admissions Officer, Department of Computer Science.

Candidates who satisfy most but not all requirements for admission may sometimes be admitted on condition that they achieve the requisite grade point average in the courses mentioned above in the minimum possible time. (These courses, however, may not be counted toward the M.S. degree requirements.)

Financial Assistance

Graduate Assistantships are frequently available for qualified master's students. These opportunities include assisting with management of departmental and university computer laboratories as well as lecturer positions for beginning undergraduate computer science courses. In addition, a new program, the Industrial Research Assistant Program, provides an opportunity for graduate students in Computer Science to obtain experience working in the local computing industry while attending the University.

Written English Proficiency Requirement

Level One: newly admitted students are required to take the Graduate Essay Test (GET, administered by the Testing Office) preferably before the first enrollment takes place, but no later than completion of the first nine units of course work toward the master's degree. If remedial work is necessary, the student shall be expected to complete courses in writing or other corrective work acceptable to the department. Level Two: the second level of proficiency in written English must be demonstrated before graduation. At this time, the student must demonstrate writing skills which exemplify scholarly style in computer science. This is generally demonstrated by the master's thesis or the research project. Students who do not write a thesis can satisfy this requirement by obtaining the approval of the graduate adviser based on a letter of support from a faculty member who has evaluated the student's English proficiency. The evaluation should be based on written assignments completed for graduate-level computer science course work.

The Master of Science in Computer Science consists of core courses covering advanced topics in software, hardware, and computer science theory with additional elective courses covering the breadth of the discipline. There are two options for the culminating experience for the degree: the Master's Thesis or the Applied Research Project.

A maximum of nine units of undergraduate courses (numbered below 700) may be applied to the graduate degree.

Online course descriptions are available.

Program Requirements Units
CSC 720 Advanced Operating Systems 3
CSC 810 Analysis of Algorithms II 3
CSC 856 Advanced Computer Architecture 3
Upper division or graduate electives selected on advisement from the areas listed below 18
One of the following: 3
CSC 895 Applied Research Project and
  Oral Project Presentation or
  CSC 898   Master's Thesis and
  Oral Defense of Thesis
Minimum total 30

Areas of Computer Science (graduate electives)

Architecture
Artificial Intelligence
Database Systems
Graphics
Multimedia
Networks
Operating Systems
Programming Languages
Software Engineering
Theory of Computation and Algorithms
Special Study or Research

Policy on Enrollment While Conducting Directed Research

Pursuant to Policy F89-165 adopted by the Academic Senate in 1989, the Computer Science Department has adopted the policy that all graduate students who are working with a research adviser (above and beyond general advising during office hours) and/or having his/her thesis or project reviewed, must enroll in at least one unit of CSC 895, 897, 898, or 899. Registered students will have priority for departmental computing resources.