Purdue UniversityWebsiteAcademic Catalog
Computer ScienceDepartment Website
BS Degree in Artificial Intelligencesource 1source 2
CS Courses
- Data Engineering In PythonCS 17600 (3)introCS 17600: Data Engineering In Python
The course introduces students to programming fundamentals in Python, including loops, functions and different data types, and provides an introduction to data engineering including working with common data formats and learning the basics of data wrangling. Students will format, extract, clean, filter, transform, search, combine, summarize, aggregate, and visualize a diverse range of data sets. Python libraries including Matplotlib and Pandas are used.
- Problem Solving And Object-Oriented ProgrammingCS 18000 (4)introCS 18000: Problem Solving And Object-Oriented Programming
Problem solving and algorithms, implementation of algorithms in a high level programming language, conditionals, the iterative approach and debugging, collections of data, searching and sorting, solving problems by decomposition, the object-oriented approach, subclasses of existing classes, handling exceptions that occur when the program is running, graphical user interfaces (GUIs), data stored in files, abstract data types, a glimpse at topics from other CS courses.
- Foundations Of Computer ScienceCS 18200 (3)introCS 18200: Foundations Of Computer Science
Logic and proofs; sets, functions, relations, sequences and summations; number representations; counting; fundamentals of the analysis of algorithms; graphs and trees; proof techniques; recursion; Boolean logic; finite state machines; pushdown automata; computability and undecidability.
- Data Structures And AlgorithmsCS 25100 (3)introCS 25100: Data Structures And Algorithms
Running time analysis of algorithms and their implementations, one-dimensional data structures, trees, heaps, additional sorting algorithms, binary search trees, hash tables, graphs, directed graphs, weighted graph algorithms, additional topics.
- Sophomore Development Seminarornot (it's just strongly recommended)CS 29100 (1)specialCS 29100: Sophomore Development Seminar
Presentations by corporate partners about careers in computer science. Presentations by faculty about careers in academia and research. Students learn about upper-division courses, tour research laboratories, and attend job fairs.
- Information SystemsorCS 34800 (3)sysCS 34800: Information Systems
File organization and index structures; object-oriented database languages; the relational database model with introductions to SQL and DBMS; hierarchical models and network models with introductions to HDDL, HDML, and DBTG Codasyl; data mining; data warehousing; database connectivity; distributed databases; the client/server paradigm; middleware, including ODBC, JDBC, CORBA, and MOM.
Introduction To Relational Database SystemsorCS 44800 (3)sysCS 44800: Introduction To Relational Database SystemsAn in-depth examination of relational database systems including theory and concepts as well as practical issues in relational databases. Modern database technologies such as object-relational and Web-based access to relational databases. Conceptual design and entity relationship modeling, relational algebra and calculus, data definition and manipulation languages using SQL, schema and view management, query processing and optimization, transaction management, security, privacy, integrity management.
Introduction To The Theory Of ComputationorCS 48300 (3)theoryCS 48300: Introduction To The Theory Of ComputationTuring machines and the Church-Turing thesis; decidability; halting problem; reducibility; undecidable problems; decidability of logical theories; Kolmogorov complexity; time classes; P, NP, NP-complete; space classes; Savitch’s theorem, PSPACE-completeness, NL-completeness; hierarchy theorems; approximation theorems; probabilistic algorithms; applications of complexity to parallel computation and cryptography. Typically offered Fall Spring.
Social, Economic, And Legal Aspects Of SecurityorCS 52300 (3)impactCS 52300: Social, Economic, And Legal Aspects Of SecurityThis course focuses on social, legal, and economic aspects of information security and privacy, also including ethics, policies, and human behavioral issues. The course covers the interactions between non-technological aspects of information security as well as relevant technological aspects. It focuses on how non-technological facets can inform and guide technological choices, and how technological choices can enhance or detract from the broader organizational and societal goals.
Security AnalyticsCS 52900 (3)sysCS 52900: Security AnalyticsThis course focuses on applied data mining, machine learning, data analytics techniques, and their application and relevance in information security. The course covers basic concepts of data mining and machine learning, computation platforms in support of big data analytics including Map-Reduce and Spark, machine learning algorithms such as classification trees, logistic regression, naive Bayes, k Nearest Neighbors, Support Vector Machines, Artificial Neural Networks (including Feed Forward, Convolutional, and Recurrence), the application of these algorithms to security tasks such as Spam/Phishing detection, malware detection, intrusion detection, and situational awareness. The future and potential role of applying machine learning techniques in information and data security is explored.
- Data Mining And Machine LearningCS 37300 (3)aiCS 37300: Data Mining And Machine Learning
This course will introduce students to the field of data mining and machine learning, which sits at the interface between statistics and computer science. Data mining and machine learning focuses on developing algorithms to automatically discover patterns and learn models of large datasets. This course introduces students to the process and main techniques in data mining and machine learning, including exploratory data analysis, predictive modeling, descriptive modeling, and evaluation.
- Introduction To The Analysis Of AlgorithmsCS 38100 (3)algsCS 38100: Introduction To The Analysis Of Algorithms
Techniques for analyzing the time and space requirements of algorithms. Application of these techniques to sorting, searching, pattern-matching, graph problems, and other selected problems. Brief introduction to the intractable (NP-hard) problems.
- Junior Resources Seminarornot (it's just strongly recommended)CS 39100 (1)impactCS 39100: Junior Resources Seminar
This seminar course engages a number of outside speakers who typically present information on the role of research in computer science, how the research components of computer science relate to each other, approaches to software development in industry, different types of application development paradigms, technological trends, and societal, ethical, and legal issues. The credit may be used only toward free electives.
- pick 2
Introduction To Data VisualizationCS 43900 (3)sysCS 43900: Introduction To Data VisualizationThe course offers an introduction to the fundamentals principles, design strategies, and techniques needed to visually communicate, explore, and analyze data. The course focuses primarily on the visual representation of inherently non-spatial data (e.g., tables and spreadsheets, graphs and networks, trees, text, and time series), but also considers the visualization of maps and of data in geospatial context.
Large Scale Data AnalyticsCS 44000 (3)aiCS 44000: Large Scale Data AnalyticsThis course provides an integrated view of the key concepts of modern algorithmic data analytics. It focuses on teaching principles and methods needed to analyze large datasets in order to extract novel, transformative insights for the underlying application. The course emphasizes the duality between formulating questions that can be answered by statistical data analysis tools (the statistical perspective) and the algorithmic challenge of actually extracting such answers using available parallel and distributed computational resources from massive datasets. The topics cover three areas: (1) algorithmic concepts necessary for big data analytics, (2) big data systems, including data management and programming, and (3) advanced analytic methods to address characteristics of real-world big data problems.
Web Information Search And ManagementCS 47300 (3)sysCS 47300: Web Information Search And ManagementThis course teaches important concepts and knowledge of information retrieval for managing unstructured data such as text data on Web or in emails. At the same time, students will be exposed to a large number of important applications. Students in the course will get hands on experience from homework and a course project. The first part of the course focuses on general concepts/techniques such as stemming, indexing, vector space model, and feedback procedure. The second part of the course shows how to apply the set of techniques on different applications such as Web search, text categorization, and information recommendation.
Human-Computer InteractionCS 47500 (3)humansCS 47500: Human-Computer InteractionThe goal of this course is to teach students how to design useful and usable interactive systems that address important needs of people. Students will experience the entire user-centered design life cycle, from need finding to usability evaluation. Topics covered in the course include user-centered design principles, usability heuristics, need-finding methods such as semi-structured interviews and contextual inquiry, quick prototyping techniques, usability evaluation methods such as hallway testing and human-subjects user study, and theories about user interaction and decision making. As we are entering a new era of AI, the course will also include a brief introduction on how to apply the HCI principles and techniques to AI-powered systems. This course is project-based. Students will form project teams among themselves to work on a semester-long project and apply the user-centered design principles, theories, and techniques that they have learned in class to build a useful and usable interactive system such as a mobile application. This course is also highly interactive, including a series of design studios and in-class activities that require active participation, communication, and discussion with other students.
Natural Language ProcessingCS 57700 (3)aiCS 57700: Natural Language ProcessingThis course will cover the key concepts and methods used in modern Natural Language Processing (NLP). Throughout the course several core NLP tasks, such as sentiment analysis, information extraction, syntactic and semantic analysis, will be discussed. The course will emphasize machine-learning and data-driven algorithms and techniques, and will compare several different approaches to these problems in terms of their performance, supervision effort and computational complexity.
- Introduction To Artificial IntelligenceCS 47100 (3)aiCS 47100: Introduction To Artificial Intelligence
Students are expected to spend at least three hours per week gaining experience with artificial intelligence systems and developing software. Basic problem-solving strategies, heuristic search, problem reduction and AND/OR graphs, knowledge representation, expert systems, generating explanations, uncertainty reasoning, game playing, planning, machine learning, computer vision, and programming systems such as Lisp or Prolog.
Math/Stat Courses
- orPlane Analytic Geometry And Calculus IMA 16100 (5)mathMA 16100: Plane Analytic Geometry And Calculus I
Introduction to differential and integral calculus of one variable, with applications. Some schools or departments may allow only 4 credit hours toward graduation for this course. Designed for students who have not had at least a one-semester calculus course in high school, with a grade of “A” or “B”. Not open to students with credit in MA 16500. Demonstrated competence in college algebra and trigonometry.
Plane Analytic Geometry And Calculus IIMA 16200 (5)mathMA 16200: Plane Analytic Geometry And Calculus IIContinuation of MA 16100. Vectors in two and three dimensions, techniques of integration, infinite series, conic sections, polar coordinates, surfaces in three dimensions. Some schools or departments may allow only 4 credit hours toward graduation for this course.
Analytic Geometry And Calculus IMA 16500 (4)mathMA 16500: Analytic Geometry And Calculus IIntroduction to differential and integral calculus of one variable, with applications. Conic sections. Designed for students who have had at least a one-semester calculus course in high school, with a grade of “A” or “B”, but are not qualified to enter MA 16200 or MA 16600 or the advanced placement courses MA 17300 or the honors calculus course MA 18100. Demonstrated competence in college algebra and trigonometry.
- Introduction To Data ScienceSTAT 24200 (3)mathSTAT 24200: Introduction To Data Science
This course provides a broad introduction to the field of data science. The course focuses on using computational methods and statistical techniques to analyze massive amounts of data and to extract knowledge. It provides an overview of foundational computational and statistical tools for data acquisition and cleaning, data management and big data systems. The course surveys the complete data science process from data to knowledge and gives students hands-on experience with tools and methods. Basic knowledge of Python required.
- orHonors Multivariate CalculusMA 27101 (5)mathMA 27101: Honors Multivariate Calculus
This course is the Honors version of MA 26100, Multivariate Calculus; it will also include a review of infinite series. The course is intended for first-year students who have credit for Calculus I and II. There will be a significant emphasis on conceptual explanation, but not on formal proof. Permission of department is required.
- Linear AlgebraorMA 26500 (3)mathMA 26500: Linear Algebra
Introduction to linear algebra. Systems of linear equations, matrix algebra, vector spaces, determinants, eigenvalues and eigenvectors, diagonalization of matrices, applications. Not open to students with credit in MA 26200, 27200, 35000 or 35100.
- Introduction To StatisticsorSTAT 35000 (3)mathSTAT 35000: Introduction To Statistics
This course provides a data-oriented introduction to applied statistics, covering exploratory data analysis, experimental design, probability distributions, simulation, sampling distributions, and the Central Limit Theorem. Students will learn the fundamentals of statistical inference, including confidence intervals and hypothesis tests for population means, paired and independent comparisons of means, analysis of variance, and regression. The course emphasizes hands-on experience with statistical software and is primarily intended for students majoring in the mathematical sciences.
Statistical MethodsSTAT 51100 (3)mathSTAT 51100: Statistical MethodsDescriptive statistics; elementary probability; sampling distributions; inference, testing hypotheses, and estimation; normal, binomial, Poisson, hypergeometric distributions; one-way analysis of variance; contingency tables; regression. For statistics majors and minors, credit should be allowed in no more than one of STAT 30100, STAT 30301, STAT 35000, STAT 35500, STAT 50100, and in no more than one of STAT 50300 and STAT 51100.
- ProbabilityMA 41600 (3)mathMA 41600: Probability
An introduction to mathematical probability suitable as a preparation for actuarial science, statistical theory, and mathematical modeling. General probability rules, conditional probability and Bayes theorem, discrete and continuous random variables, moments and moment generating functions, joint and conditional distributions, standard discrete and continuous distributions and their properties, law of large numbers and central limit theorem.