Computational Sciences Icon

Computational Sciences Major

Computational sciences provide the scientific foundations for making sense of natural, human-mediated and social phenomena through analytics, computational methods and modeling.

In an age of ubiquitous — often overwhelming — data, the ability to harness that data to reflect, reach out and make better decisions is increasingly crucial. The Computational Sciences major prepares students to be analytics-driven and logical decision makers, innovators, and leaders.

Cornerstone Courses

In their first year, Computational Sciences majors complete their Cornerstone Courses.

Core Courses

In their second year, Computational Sciences majors enroll in core courses that provide the foundation for the Computational Sciences concentrations. They also take electives from core courses offered in other majors.

CS110 / Problem Solving with Data Structures and Algorithms

Apply core concepts in design and analysis of algorithms, data structures, and computational problem-solving techniques to address complex problems. Hashing, searching, sorting, tree algorithms, dynamic programming, greedy algorithms, divide and conquer, backtracking, random number generation, and randomized algorithms are examples of algorithms you will learn to exploit to solve problems ranging from logistics to route optimization to DNA sequencing.

Prerequisite: CS51 or FA51; CS51B or PR51

CS111 / Single and Multivariable Calculus

Learn to utilize principles of single and multivariable calculus to solve relevant problems from across STEM. Traditional calculus courses focus on the techniques needed to perform complex computations by hand, and evaluate students primarily on their ability to do so quickly. This course takes a different approach by shifting the focus to applying foundational calculus concepts to analyze and solve problems in practical contexts while building the facility to take full advantage of technologies such as Sage to perform complex computations. In addition to honing skills from critical and creative thinking, an emphasis is placed on effective collaborative problem-solving and communication of technical processes and results to appropriate audiences. Note: This course was previously CS111A.

Prerequisite: CS51 or FA51

CS113 / Theory and Applications of Linear Algebra

This course develops the tools necessary for the analysis of linear systems. The emphases are both on abstract notions such as vectors spaces, linear maps between them and their matrix representations, and concrete applications such as Markov chains and graphical network analysis. Students apply their knowledge to explore a wide variety of problems such as Page Rank, least squares fitting, and traffic modeling. Note: This course was previously CS111B. In addition to the listed prerequisites, the following courses are recommended prior to taking this course: CS111

Prerequisite: CS51 or FA51

CS114 / Probability and Statistics and the Structure of Randomness

When can you find patterns in seemingly random noise? Or determine when an observed pattern is likely due to chance? This course focuses on the concepts from probability and statistics used to extract meaning from data. In addition to building a strong, theoretical foundation, students learn how to apply these tools to understand real-world scenarios. Formal topics include Sample spaces, conditional probability and independence, Bayes’ theorem, discrete and continuous random variables, joint distributions, the law of large numbers as well as the central limit theorem among others. These techniques are then used in applications such as statistical learning, linear regression, simulation, maximum likelihood and least squares.

Prerequisite: CS111

Concentrations

In their third year, Computational Sciences majors select a concentration, begin taking courses within it and begin work on their capstone courses. They also take electives chosen from other Minerva courses (other concentration courses in Computational Sciences, core and concentration courses in other colleges). Computational Sciences offers concentrations shown in the table below.

In the fourth year, Computational Sciences majors enroll in additional electives chosen from Minerva’s course offerings within or outside the major. Additionally, they take senior tutorials in the major, and finish their capstone courses.

  Contemporary Knowledge Discovery Applied Problem Solving
Computer Science and Artificial Intelligence CS142 / Theory of Computation CS152 / Theory and Applications of Artificial Intelligence CS162 / Software Engineering: Building Powerful Applications
Mathematics  CS144 / Real Analysis CS154 / Analytical and Numerical Methods in Differential Equations CS164 / Optimization Methods
Data Science and Statistics CS146 / Computational Methods for Bayesian Statistics CS156 / Finding Patterns in Data with Machine Learning  CS166 / Modeling and Analysis of Complex Systems

Each row and each column of the matrix represent a different concentration, as noted above.

Applied Problem Solving

Apply computational and quantitative methods to solve many of the daunting problems the world faces in the 21st Century. Students choosing the APS concentration will specialize in applying computational and quantitative methods to characterize in detail, and devise tractable approaches to solving, some of the world's most challenging problems.

Career Possibilities

  • Corporate Data Manager
  • Corporate Strategist
  • Engineer
  • High Tech Entrepreneur
  • Product Designer
  • Software Developer

Computer Science and Artificial Intelligence

Learn the theory and practice of computer science, from the foundations of computation to the engineering of large scale software projects. Apply artificial intelligence and other innovative computational approaches to solve modern challenges.

Career Possibilities

  • Engineer
  • Financial Forecaster
  • Game Developer
  • Information Officer
  • Product Designer
  • Software Developer

Contemporary Knowledge Discovery

Specialize in applying computational and quantitative methods to identify and model the structures and systems shaping the world around us. Explore a wide range of applications, from understanding human intelligence and modeling physical data to predicting complex biological phenomena and controlling robotic systems. Computational scientists seek to identify emergent patterns, use those patterns to define structure, and analyze the results. Students choosing the CKD concentration will specialize in this process, applying computational and quantitative methods to discover structure in the world around us.

Career Possibilities

  • Consumer Demand Forecaster
  • Decision Scientist
  • Government or Industry Modeler
  • Information Officer
  • Intelligence Analyst
  • Privacy Officer

Data Science and Statistics

Acquire the skills necessary to analyze, interpret, and exploit massive amounts of data. Through the lenses of statistics, machine learning, and stochastic modeling learn how to draw strong inferences about the world around us.

Career Possibilities

  • Analytics Officer
  • Bioinformatics Scientist
  • Corporate Data Manager
  • Cryptanalyst
  • Data Scientist
  • Government Analyst
  • Statistician

Mathematics 

Investigate ways in which different fields of mathematics are used to analyze and address complex questions. Develop the skill to rigorously apply mathematical concepts and tools to a wide variety of problem domains. 

Career Possibilities

  • Engineer
  • Financial Forecaster
  • Game Developer
  • High Tech Entrepreneur
  • Information Officer
  • Product Designer

Concentration Courses

CS130 / Statistical Modeling: Prediction and Causal Inference

The course focuses on the application of predictive and causal statistical inference for decision making across a wide range of scenarios and contexts. The first part of the course focuses on parametric and non-parametric predictive modeling (regression, cross-validation, bootstrapping, random forests, etc.). The second part of the course focuses on causal inference in randomized control trials and observational studies (statistical matching, synthetic control methods, encouragement design/instrument variables, regression discontinuity design, etc.). Technical aspects of the course focus on computational approaches and real-world challenges, drawing cases from the life sciences, public policy and political science, education, and business. This course also emphasizes the importance of being able to articulate one’s findings effectively and tailor methodology and policy/decision-relevant recommendations for different audiences. Note: CS130 may be substituted for a tutorial in CS/NS/SS and can count like a cross-listed tutorial for double majors in SS, NS, or CS (any pairwise combination). This course was previously CS112.

Prerequisite: CS51

CS142 / Theory of Computation

Students learn about models of computation that provide the theoretical basis for modern computer science. Topics include deterministic and nondeterministic finite state machines, Turing machines, formal language theory, computational complexity and the classification of algorithms. Students practice building a variety of automata and Turing machines using Python. What are the language grammars? and what role does a grammar plays in the way we analyze problems, solve problems, communicate with the computer, and even analyze natural languages? What makes a problem difficult to solve? Are some problems intrinsically harder than others, or is it that just because we have not yet discovered more efficient solutions? What, if any, are the limits of what can be solved with a computer? The techniques presented in this course shed light on why some computational problems are hard or even tractable. Students also gain experience communicating mathematical ideas in a rigorous fashion.

Prerequisite: CS110

CS144 / Real Analysis

Students learn how to read, write, and evaluate rigorous mathematical arguments. These skills are practiced on foundational material that forms a bridge to topics in advanced mathematics—both applied and pure. Subtopics in modern algebra and real analysis are chosen to illustrate the fundamental concepts of careful bounding, counting, and the application of equivalence classes.

Prerequisite: CS111

CS146 / Computational Methods for Bayesian Statistics

Learn to apply Bayesian inference which is the mathematical framework for using observed data to update the information we have about a system. The course proceeds from the fundamentals of probability theory and Bayesian inference to the data modeling process, covering various real-world scenarios from sports, medicine, vehicle tracking, social sciences, and more. The second half of the course covers approximate methods for automating inference in the form of variational inference (approximations using functions) and Monte Carlo methods (approximations using random samples). These methods allow us to work with large models containing many unknown variables and large data sets.

Prerequisite: CS114

CS152 / Theory and Applications of Artificial Intelligence

Apply methods and algorithms from Artificial Intelligence (AI) — such as propositional logic, logic programming, predicate calculus, and computational reasoning — to a diverse range of applications from robot navigation to restaurant selection with expert systems. Discover AI in action through an exploration of robotics, and gain an appreciation of its convergence towards modern machine learning methods. NOTE: In addition to the listed prerequisites, the following courses are recommended prior to taking this course: CS113

Prerequisite: CS110

CS154 / Analytical and Numerical Methods in Differential Equations

Methods are explored to interpolate data, solve linear and non-linear systems of equations, and model dynamical systems with the use of ordinary and partial differential equations. Additionally, Fourier Analysis is applied to model and process signals. Numerical implementations of the mathematical methods are developed using MATLAB or Octave. NOTE: Students may request to take CS113 in the same semester, as a corequisite.

Prerequisite: CS111; CS113

CS156 / Finding Patterns in Data with Machine Learning 

Students learn to apply core machine learning techniques — such as classification, perceptron, neural networks, support vector machines, hidden Markov models, and nonparametric models of clustering — as well as fundamental concepts such as feature selection, cross-validation and over-fitting. Students program machine learning algorithms to make sense of a wide range of data, such as genetic data, data used to perform customer segmentation or data used to predict the outcome of elections. NOTE: In addition to the listed prerequisites, the following courses are recommended prior to taking this course: CS110

Prerequisite: CS113; CS114

CS162 / Software Engineering: Building Powerful Applications

This course is organized around the principle that the only way to learn software development is to develop software. Work together as a team to develop a significant web application. Examples include a social media application or a distributed chat system. You will have the opportunity to apply and experience all aspects of software development, including requirements analysis, design, planning, implementation, testing, and deployment.

Prerequisite: CS110

CS164 / Optimization Methods

Learn to use and analyze optimization techniques such as linear, quadratic, semidefinite and mixed-integer programming. Explore optimization algorithms such as Newton’s method, interior point methods and branch and bound methods.

Prerequisite: CS111; CS113

CS166 / Modeling and Analysis of Complex Systems

Learn how to apply advanced modeling techniques to analyze and predict the behavior of social, physical and economic systems. You will learn from specific examples applied to portfolio management, traffic flow management, and analyzing social networks. The course covers three modeling frameworks — cellular automata for modeling interactions on grids of cells, networks for more general interactions between nodes in a graph, and Monte Carlo simulations showing how we can use simulation to generate random numbers and how we can use random numbers to drive simulations of complex phenomena. The course covers the theoretical (mathematical) and practical (implementation) aspects of each of the three frameworks.

Prerequisite: CS110; CS114 or CS130

Capstone Courses

In their fourth year, Computational Sciences majors finish their Capstone Courses.