Computer Science
(Bachelor of Science)
Students interested in Computer Science have several options, including an emphasis in Information Assurance and Security (aka, cybersecurity), a more traditional emphasis in Software Engineering, and a minor. The two Computer Science emphases offer an expanding array of theoretical and applied work that prepares students to enter the job market or pursue graduate studies. The minor in Computer Science offers lower-level basic skills and an upper-level flexible approach that can be used to augment many majors, from business to the design arts and humanities.
The field of computer science is undergoing great changes as technology advances and the need for computer software increases. Students entering this field must not see a bachelor’s degree in computer science as the culmination of study in the field. Rather, they must see it as the first step in a continuing education process that will last as long as they choose to stay in the field. The goal of the Computer Science major is to provide students with a strong foundation upon which they can continue to build as the field changes. Students can receive instruction in areas such as software design and project management, object-oriented programming, design of algorithms, operating systems, database management systems, neural networks, computer graphics, network programming, cybersecurity, and more.
Computer science courses are often mistaken for programming courses. In reality, they require much more than learning and mastering a programming language. The heart of software design is not the language, but the ability to define a problem, analyze various components, and project and evaluate potential solutions, all of which must be scalable and robust. This must also be done under the constraint that they are subject to limitations inherent in a given computer. Students must understand that in industry there must be more than just a working program. Good software must not only work but must be fully documented, clearly written, easily modifiable to meet changing and more extensive requirements, and engineered for stability, security, and correctness.
Equally important, the program provides a theoretical base for computer science and helps students understand there is more to computer science than software development. Students develop skills they can use upon graduation but they must be prepared to enter a field which is both diverse and rapidly changing and they must be able to adapt to new technologies. This requires a solid theoretical foundation with knowledge of how computers work and how they carry out tasks specified in applications software. It requires that students think beyond writing software and explore areas such as neural networks, computer graphics, algorithm analysis, or scientific applications. This knowledge is an important ingredient to professional development as it gives them the tools they need to analyze efficiency and evaluate various programming and data design options and to see the possible futures as computer science evolves. Simply providing them with skills necessary to enter the computing profession is not sufficient. Each student must be prepared to apply what he or she has learned in order to adapt to the inevitable changes that will occur. Each must also have the ability to learn new ideas and apply them.
Graduates of the Computer Science program are prepared to continue their education at the graduate level or to apply for entry-level positions in industry. Typical entry-level jobs are programmer or programmer/analyst positions.
All registered students have access to the University’s computing facilities. Student accounts allow students to access a wide variety of both PC-compatible and Macintosh computers, Linux and database servers (for select courses), various software developer environments, and of course the internet. Labs are open seven days per week and are staffed by consultants who provide assistance in using the facilities. Classrooms also have network connections which allow demonstrations of software and internet applications to be integrated with classroom lectures. There is also a Computer Science teaching lab with 25 workstations and display facilities that support Computer Science instruction.
Computer Science courses have a strict prerequisite structure. It is imperative that students learn what courses are prerequisites for others and when they are offered. Students are strongly encouraged to talk to an adviser very early in their college career.
Students seeking information on teacher certification should contact the Education Office.
The following is only an example of a four-year Computer Science degree program and is subject to change without notice. Students should consult a Computer Science program advisor to ensure that they have the most accurate and up-to-date information available about a particular four-year degree option.
Michael E Zorn; Professor; Ph.D., University of Wisconsin - Madison, chair*
Tanim Ahsan; Assistant Professor; Ph.D., Marquette University
Iftekhar Anam; Assistant Professor; Ph.D., University of Memphis
Ankur Chattopadyay; Assistant Professor; Ph.D., University of Colorado at Colorado Springs
Courses
COMP SCI 201. Introduction to Computing & Internet Technologies. 3 Credits.
Introduction to the history of computing, overview of computers, how they work, and relevant applications, especially to web site creation. Introduction to procedural programming using Microsoft Web Development tools part of the Microsoft Visual Studio.NET programming environment, the basics of HTML, CSS, and JavaScript.
Fall and Spring.
COMP SCI 221. Database Design & Management. 3 Credits.
This introductory course focuses on how databases and database systems work and how they are used in various data-driven applications. The course covers relational databases, SQL, different ways of designing databases, and management of databases. The course provides hands-on experience with exercises using SQL Server and Microsoft Access and includes group discussions. The course also introduces some advanced topics, including database security, data privacy, data analytics, and big data. Working knowledge of Microsoft Office suite and Windows is required for this course.
P: COMP SCI 201 or COMP SCI 256 with at least a C grade
Fall Only.
COMP SCI 231. Introduction to IT Operations. 3 Credits.
This course covers the basic knowledge and skills needed to plan, design, control and monitor Information Technology services and infrastructure. Topics include the fundamentals of asset management, service provisioning, and functional operations. This course serves as an introduction to careers in the IT field.
Fall Only.
COMP SCI 240. Discrete Mathematics. 4 Credits.
Study of topics in mathematics that do not depend upon the limit process, including: number systems, set theory, logic, counting techniques, matrix manipulation, recursion, mathematical induction, graph theory, recurrence relations, and finite state machines. Techniques, computations, and data representations to facilitate problem-solving by hand and by computer.
P: MATH 104 with at least a C grade or WPT-MFND score >465 and WPT-AALG score >525 and WPT-TAG score >525
Fall and Spring.
COMP SCI 256. Introduction to Software Design. 4 Credits.
Students will learn a language common to software design and be introduced to software design techniques. This includes the problem statement, solution design, program testing, implementation, debugging, and final documentation.
P: None
Fall and Spring.
COMP SCI 292. Introduction to Mobile Platforms and Apps. 3 Credits.
An introduction and survey to the world of mobile computing. Each student will design, develop and produce their own app. Topics covered will include areas such as models of mobile information, GPS services, social networking, casual gaming, networked games, business apps, and information gathering -- all from the perspective of mobile platforms.
P: COMP SCI 201 and COMP SCI 256 with at least a C grade in both.
Fall Only.
COMP SCI 299. Travel Course. 1-6 Credits.
Travel courses are conducted to various parts of the world and are led by one or more faculty members. May be repeated to different locations.
P: cons of instr & prior trip arr & financial deposit.
COMP SCI 316. Advanced Software Design. 4 Credits.
A continuation of COMP SCI 256, this course deals with larger projects, more complex problems, and group work. It introduces linear data structures and their implementations. It also develops the object oriented design paradigm to include inheritance and polymorphism.
P: COMP SCI 256 with at least a C grade
Fall and Spring.
COMP SCI 351. Data Structures. 4 Credits.
Concepts involved in storage, retrieval and processing data. Emphasis is on the design of software with complex data retrieval needs and on non-linear structures such as generalized lists, trees, and graphs.
P: COMP SCI 240 AND COMP SCI 316 with at least a C grade in both.
Spring.
COMP SCI 352. Computer Graphics and Animation. 3 Credits.
Basic techniques of computer graphics, such as point and line plotting, clipping and windowing using the OpenGL platform. Use of graphics hardware; construction of graphics packages. Basic animation techniques.
P: COMP SCI 240 with at least a C grade. REC: COMP SCI 371
Fall Odd.
COMP SCI 353. Computer Architecture and Organization. 3 Credits.
Data representation, assembly language, procedure call protocols, memory, cache, and bus organizations, comparison of processor architectures, I/O systems, logic circuits, Boolean algebra.
P: COMP SCI 240 and COMP SCI 256 with at least a C grade in both.
Fall Only.
COMP SCI 357. Theory of Programming Languages. 3 Credits.
Comparison of several common languages and discussion of advantages and disadvantages of compiling and interpreting. Discussion of language design and syntax, data types, variables, constants, binding and scope of a variable and data handling procedure.
P: COMP SCI 316 with at least a C grade.
Fall Only.
COMP SCI 358. Data Communication and Computer Networks. 3 Credits.
Transmission media, analog and digital signals, modulation, compression, error detection methods, security and encryption protocols, Ethernet standards, TCP/IP protocols, routing algorithms, Internet and steraming applications.
P: COMP SCI 256 with at least a C grade.
Spring.
COMP SCI 361. Information Assurance and Security. 3 Credits.
An exploration of the fundamentals of information assurance and security (IAS). The course will introduce the underlying concepts of IAS in context of today's society. It will explore the security & ethical issues in information and computing from the perspective of today's computing world. It will discuss the appropriate remedies and defense strategies in the wake of today's security threats and attacks. Class topics will focus on physical security, cyber security, network security and software security through lectures and hands on experiments. This course will be of interest to students, who wish to obtain an understanding of the basic principles and practices in IAS. It will cover the fundamental concepts in IAS necessary for understanding the threats to security as well as various defenses against those threats.
P: COMP SCI 256 with at least a C grade.
Fall Only.
COMP SCI 371. Advanced Object-Oriented Design. 4 Credits.
Advanced object oriented design techniques in C++, including: objects, classes, class design and class relationships, inheritance, and polymorphism. Additional coverage of C/C++ topics such as pointers and pointer arithmetic, C strings, dynamic memory management, memory leaks, exception handling and operator overloading.
P: COMP SCI 316 with at least a C grade.
Fall and Spring.
COMP SCI 372. Software Engineering. 3 Credits.
Design and programming techniques for large and complex data-driven projects, using C++. Design based on Design Patterns. Use of Software Engineering metrics and formal methodologies. Fundamentals of component-based software development and software deployment techniques.
P: COMP SCI 201 and COMP SCI 221 with at least a C grade for both. REC: COMP SCI 316
Spring.
COMP SCI 450. Theory of Algorithms. 3 Credits.
Design, analysis and comparison of algorithms; divide and conquer techniques, greedy method, dynamic programming and smart searching. Applications to optimization with constraints and decision problems. Theory of computability including examples of NP-complete problems such as the "traveling salesman" problem.
P: COMP SCI 240, COMP SCI 316, MATH 202 with at least a C grade in all three.
Spring.
COMP SCI 451. Database Systems and Big Data Processing. 3 Credits.
This course covers advanced relational database concepts, data warehousing, and distributed database management systems. It introduces students to unstructured data and NoSQL databases and discusses the basics of real-time storage and processing of massive datasets using Hadoop ecosystems. The course includes hands-on exercises with Hadoop ecosystem and SQL Server.
P: COMP SCI 221 with at least a C grade
Spring.
COMP SCI 452. Operating Systems Using Linux. 3 Credits.
Methods and philosophies behind management of computing resources, including: memory management, process management, scheduling, process signaling, process synchronization, mutual exclusion; interprocess communication, introduction to the Linux Operating System and environment, shell scripting, C programming, process management, and message passing.
P: COMP SCI 240 with at least a C grade. REC: COMP SCI 371
Spring.
COMP SCI 464. Artificial Intelligence. 3 Credits.
Study of the fundamental types of artificial intelligence, their principal applications, and implementation of simulations on a conventional computer. These include inference systems, expert systems, artificial neural networks, swarm intelligence, genetic programming, evolutionary computing and reinformcement learning.
P: COMP SCI 240 with at least a C grade. REC: COMP SCI 351 and MATH 202
Fall Only.
COMP SCI 474. Game Engines. 3 Credits.
This course provides students with an introduction to the theory and practice of video game programming. Students will participate in individual hands-on lab exercises, and also work together like a real game development team to design and build their own functional game using an existing game engine (e.g. Unity, Ogre).
P: COMP SCI 256 with at least a C grade.
Spring Odd.
COMP SCI 478. Honors in the Major. 3 Credits.
Honors in the Major is designed to recognize student excellence within interdisciplinary and disciplinary academic programs.
P: min 3.50 all cses req for major and min gpa 3.75 all UL cses req for major.
Fall and Spring.
COMP SCI 490. Capstone Essay in Computer Science. 3 Credits.
A project course in which a student does reading in computer science journals and produces a major research paper.
P: COMP SCI 358 and COMP SCI 361 with at least a C grade in both.
Fall Only.
COMP SCI 497. Internship. 1-12 Credits.
Supervised practical experience in an organization or activity appropriate to a student's career and educational interests. Internships are supervised by faculty members and require periodic student/faculty meetings. Course is repeatable for credit.
P: jr st.
Fall and Spring.
COMP SCI 498. Independent Study. 1-4 Credits.
Independent study is offered on an individual basis at the student's request and consists of a program of learning activities planned in consultation with a faculty member. A student wishing to study or conduct research in an area not represented in available scheduled courses should develop a preliminary proposal and seek the sponsorship of a faculty member. The student's advisor can direct him or her to instructors with appropriate interests. A written report or equivalent is required for evaluation, and a short title describing the program must be sent early in the semester to the registrar for entry on the student's transcript. Course is repeatable for credit.
P: fr or so st with cum gpa > or = 2.50; or jr or sr st with cum gpa > or = 2.00.
Fall and Spring.
COMP SCI 499. Travel Course. 1-6 Credits.
Travel courses are conducted to various parts of the world and are led by one or more faculty members. May be repeated to different locations.
P: cons of instr & prior trip arr & financial deposit.