Academia.eduAcademia.edu

Elements of Computational Science and Engineering Education

2003, Siam Review

The multidisciplinary nature of computational science and engineering (CSE) and its relation to other disciplines is described. The stages through which CSE education is evolving, from initial recognition in the 1980s to present growth, are discussed. The challenges and benefits of different approaches to CSE education are discussed, as is the emergence of a set of core elements common to different approaches. The content of courses, curricula, and degrees offered in CSE are reviewed, and a survey is made of all undergraduate degree programs. The curricula of different programs are examined for the common "tool set" they define and analyzed for their relative weighting of computing, application, and mathematics. A trend toward a standard curriculum is noted.

c 2003 Society for Industrial and Applied Mathematics  SIAM REVIEW Vol. 45, No. 4, pp. 787–805 Elements of Computational Science and Engineering Education∗ Osman Yaşar† Rubin H. Landau‡ Abstract. The multidisciplinary nature of computational science and engineering (CSE) and its relation to other disciplines is described. The stages through which CSE education is evolving, from initial recognition in the 1980s to present growth, are discussed. The challenges and benefits of different approaches to CSE education are discussed, as is the emergence of a set of core elements common to different approaches. The content of courses, curricula, and degrees offered in CSE are reviewed, and a survey is made of all undergraduate degree programs. The curricula of different programs are examined for the common “tool set” they define and analyzed for their relative weighting of computing, application, and mathematics. A trend toward a standard curriculum is noted. Key words. computational science, education, bachelor’s degrees, curriculum, courses, tool set AMS subject classifications. Primary, 97U70; Secondary, 68U01 DOI. 10.1137/S0036144502408075 1. Nature of Computational Science and Engineering. The past decade has witnessed extraordinary advances in science and engineering that were fueled, in part, by dramatic increases in the power and pervasiveness of computers and communications. We have capitalized on those advances by developing techniques for modern computers that let us better understand systems with ever-increasing complexity and realism. Examples include climate modeling [1], quark structure of elementary particles [2], engine and vehicle design [3], materials development [4], drug development, astronomy [5, 6], nonlinear dynamics and chaotic behavior [7], biodiversity, finance, and the mining of huge data sets such as the virtual humans and the digital sky observatories [8]. 1.1. Definition of CSE. We define computational science and engineering (CSE), or computational science for short, in several ways. Sometimes it denotes the multidisciplinary combination of computational techniques, tools, and knowledge needed ∗ Received by the editors May 17, 2002; accepted for publication (in revised form) May 7, 2003; published electronically October 31, 2003. http://www.siam.org/journals/sirev/45-4/40807.html † Department of Computational Science, State University of New York College at Brockport, Brockport, NY 14420 (oyasar@brockport.edu, http://www.cps.brockport.edu). This author was supported in part by National Science Foundation grants 998094 (National Partnership for Advanced Computational Infrastructure-EOT) and 0226962 (Math and Science Partnership-MSP). ‡ Computational Physics Undergraduate Program, Oregon State University, Corvallis, OR 97331 (rubin@physics.orst.edu, http://www.physics.orst.edu/CPUG). This author was supported in part by National Science Foundation grant 998094 (Course, Curriculum and Laboratory Improvement) and the National Partnership for Advanced Computational Infrastructure-EOT. 787 788 OSMAN YAŞAR AND RUBIN H. LANDAU Fig. 1.1 CSE as a multidisciplinary endeavor connecting computation with mathematics and science. Left: Early view in which CSE is merely the overlap of other disciplines. Right: Current view in which CSE shares common concerns with these disciplines, as well as having content of its own. to solve modern scientific and engineering problems. At other times CSE denotes science or engineering that uses computer simulations as its basis, and sometimes it denotes the research and development of computational skills and tools needed for applications. The original view of CSE, shown on the left side of Figure 1.1, was as the intersection of applied mathematics, computer science, and application sciences. This early view is now being replaced by the one represented by the right side of Figure 1.1 [9, 10, 11], in which an additional, central circle reflects the recognition that, in addition to having common concerns with other disciplines, CSE also contains core elements of its own that draw together and bridge the original three disciplines. (This new view was first communicated in a 2000 article by Yaşar [10] in the IEEE Journal of Computing in Science and Engineering; Yaşar later presented it at the SIAM CSE Conference [12].) The core of CSE may be thought of as its collection of computational tools and methods and its problem-solving mindset, which uses knowledge in one discipline to solve problems in another. This CSE core is now being incorporated into computational science courses and books that combine scientific problem solving with computation [13, 14, 15, 16, 17, 18], and into curricula at various levels of education. 1.2. Value of CSE in Research. Most scientific disciplines appear to be benefiting from computer modeling, analysis, and visualization. In fact, the newfound and widespread importance of computation has shifted the paradigm of scientific research to include simulation, along with experiment and theory, as a fundamental technique of science [19]. Simulation and visualization allow us to acquire insights into real-life problems that are too complex or difficult to study analytically, or too expensive, big, small, or dangerous to access experimentally. For example, simulations permit us to study the fuel density, ignition energy, and heat waves in a combustion chamber at temperatures above 3000 Kelvin [3]; the configuration of gluon flux tubes between quarks within the proton [2]; and the possible orbits for earth–asteroid collisions [6]. ELEMENTS OF COMPUTATIONAL SCIENCE AND ENGINEERING EDUCATION 789 As more scientists incorporate computation into their work, the value of CSE to the scientific community increases. In particular, CSE working groups permit other scientists to pursue their interests in science without having to spend time developing algorithms and codes. These working groups have focused on identifying, studying, and improving computational methods and software components that are common to many applications, and on testing the performance of the related software on various hardware platforms. One accomplishment of CSE working groups is the development of mathematical libraries of subroutines for linear algebra, special functions, and other mathematical techniques. These subroutines, whose use is emphasized in the various CSE education programs, form the core of many large-scale computer calculations. Accordingly, it is in the interests of the CSE community to look after the accuracy, performance, robustness, portability, and scalability of these libraries as they are ported to different high-performance computing architectures. These accomplishments have aided the progress made with supercomputers and, with the phenomenal increases in desktop computing power, are now finding wider use. In addition to the mathematical subroutine libraries, CSE also develops and promotes simulation techniques that have widespread applicability. Consider, for example, the computational technique known as “particle dynamics” in which individual particles are created and their paths are followed in time using the appropriate equations of motion [20]. This technique is used to simulate processes as diverse as the settling of sand particles in a tank, the creation of stars and planets, the motion of molecules in gases and liquids, the growth of thin films, the dynamics of droplets in engines, and the motion of ash particles in industrial burners. Clearly, improving the technique, or educating its practitioners on how to use it better, benefits many areas of science. The growing volume of CSE techniques and associated software libraries represents a priceless wealth of tools and knowledge. There is already a heavy reliance upon them in the CSE community, and we expect that reliance to grow in the future. For these reasons, we need education in CSE to pass this wealth on to future generations of scientists and engineers. 1.3. Nature of the Job Market. The President’s Information Technology Advisory Committee (PITAC) [21] has recognized information and computational technology as one of the engines of economic growth during the last decade. The committee indicates a need for approximately one million people in information and computational technology, a need that cannot be met solely by all computer science departments working at full capacity. The National Science and Technology Council has repeatedly reported the concerns of industry and the national laboratories that they cannot satisfy their growing needs for people trained in information and computational technology. In addition, federal projects such as the Department of Energy’s Accelerated Strategic Computing Initiative (ASCI) and the Information Technology Presidential Initiative rely on people with scientific as well as computing knowledge. These needs for more people with a computational education are a consequence of the exponential growth in the power of computers occurring in this decade simultaneously with an extraordinary decrease in the cost of computers. Few other things in life change by factors of 1000 in such a short time. Children now play games on computers of a class that 10 years ago were considered supercomputers and were available only at government laboratories. 790 OSMAN YAŞAR AND RUBIN H. LANDAU Just as computers now permeate many aspects of our daily lives both at work and at home, they also profoundly affect the technical job market. One such way is by placing people in positions that require knowledge in areas beyond their education and (obsolete) job descriptions. Consequently, having multiple skills and majors is viewed as a way of improving one’s marketability and employment survival time. Employers seem to prefer people with education in multiple disciplines since they can then hire fewer of them and can retain them for longer periods of time. Yet, attaining multiple degrees is expensive and time-consuming, as is majoring in one department and minoring in several others. In contrast, a multidisciplinary CSE educational program saves time and money for those students who might otherwise follow multiple courses of study. It also provides a coherent and consistent education with minimum duplication and equips students with an interdisciplinary tool set (to be described soon) that experience has shown to be useful in a wide range of fields. 2. Nature of CSE Education. Due in part to reports and grants from the federal government, education in science and engineering has responded to the advances in computational science. In 1989, the Office of Science and Technology Policy challenged the educational system to (1) increase the supply of students prepared for careers in science, technology, engineering, and mathematics; and (2) improve the scientific, mathematical, technological, and computational literacy of all students. Recently, the National Science Foundation (NSF) has recognized and advocated computation as an appropriate pedagogy for science and mathematics education [22]. Wright and Chorin’s [23] NSF report urged the creation of mathematical modeling courses (the basic approach of CSE) even for high school students. The traditional teaching of science tends to focus on theory. In contrast, CSE education offers an understanding of science through the computer applications of mathematical models. It teaches science via the method of inquiry in which the computer serves as a virtual laboratory that simulates nature. To aid in the inquiry, facts are presented as needed rather than as individual objects to memorize [24, 25, 26, 27, 28]. As a consequence of its problem-solving nature, the CSE view complements the traditional teaching of science and mathematics. It also makes many science and mathematics concepts more easily accessible to students who may otherwise not be reached; for example, those students not interested in computer hardware, software, and algorithms for their own sake [29]. In addition, CSE enriches the science curriculum by extending the examples used in education to include problems that may not have analytic solutions, thereby extending the range of problems open to study. The National Foundation for Improving Education has examined the types of learning supported by CSE [30]. These include the learner-centered or constructivist view which suggests that students learn better when they are actively interacting with, rather than just receiving, knowledge. The CSE approach is often both projectand team-based, as well as learner-based and supportive of authentic learning. When successful, this combination of elements can transform uninvolved, at-risk students into active and invested learners. A CSE education is also well suited to a deductive pedagogy, that is, one that works from the general to the specific. Students start with an awareness that nature and its processes are governed by a small number of basic scientific laws; details and mathematical analyses are added as needed. In cases where the students’ mathematics skills are limited, the simulations can be understood via visualizations without delving into mathematical and scientific details. Accordingly, CSE education fosters a view that natural phenomena are basically simple, in contrast to the common student ELEMENTS OF COMPUTATIONAL SCIENCE AND ENGINEERING EDUCATION 791 perception of science as complex. It also provides a basic framework upon which students can build as their skills increase. This ability to stimulate the curiosity of students with interesting and realistic examples and to provide layered learning is a principal motivation for educators to apply and master technology tools. 2.1. Stages of CSE Education. Education in CSE has been evolving in stages. Originally, scientists and engineers taught themselves the computational techniques they needed in the course of solving problems or received them as hand-me-downs from their advisors. The first formal stage, ca. 1980–1990, was recognition-conception, in which practitioners recognized that they were doing something new—but not necessarily well. This stage was epitomized by the 1982 Lax report [19], with its early recognition of the paradigm shift in which computation was joining experiment and theory as a basic technique of science. The report recommended that funding agencies provide increased education in scientific computing in order to facilitate the shift. The second stage of CSE education, ca. 1990–2000, was infancy [31, 32, 33], in which the ideas of CSE started to be taught in a few existing or new courses, often by those who were familiar with the ideas through their research. The third stage, ca. 2000–2010, is early growth [10, 34]. It is the stage we are in now and is characterized by a number of courses and curricula being designed and implemented at both the graduate and undergraduate levels. While we expect the future adult stage of CSE education to resemble what we have now, it is hard to make reliable predictions in the midst of rapid change. Nevertheless, we would predict that the number of CSE programs and courses will continue to increase either as a deliberate thrust into computation or indirectly as science, technology, engineering, and mathematics disciplines hire faculty with CSE specialties. We foresee a growing number of courses in “computational X,” where X is an established discipline such as mathematics, biology, finance, physics, chemistry, or social science. The pressure for these courses may come from multiple sources. The national laboratories and industries have regularly indicated their continuing needs for scientists and mathematicians who can compute [21, 35]. In addition, there are undergraduate students in existing CSE programs who are interested in applying their newfound skills to discipline X. There are also faculty members in the X departments who want their research students to know how to compute, or who want to modernize the courses they teach. And, finally, there are the CSE educators (the present authors included) who believe as a matter of principle that computational courses are needed to serve society. It might be that a single “computational X” program will make it easier to start a “computational Y” program sharing some of the same courses. After a number of computational programs are established at any one school, they may choose to organize themselves under a CSE unit for the sake of efficiency and communication. These units may appear as interdisciplinary programs within discipline X, or as a stand-alone department of CSE. Such stand-alone departments may have a core faculty of their own and a number of associated faculty from computer science, mathematics, and other disciplines. The thrust for new CSE units may also arise from the funding agencies, who are beginning to support CSE more directly. Likewise, there are also internal thrusts from colleges and universities as they follow the movement afoot to restructure themselves into multidisciplinary units that emphasize problem solving in a societal sense [36, 37]. It is logical that these units will benefit from an association with CSE and its scientific problem-solving orientation. 792 OSMAN YAŞAR AND RUBIN H. LANDAU A stand-alone CSE unit can also offer a CSE minor that would benefit other departments. A minor in CSE should include more of the core knowledge in computational tools and methods than is normally expected of a science or engineering student, but not the full spectrum of subjects expected of a CSE major. 2.2. Demands of CSE Education. Because CSE has developed around the need to incorporate computation into modern scientific problem solving, it is a researchdriven field that connects faculty interested in computation to those interested in applications (the major disciplines symbolized in Figure 1.1). Faculty interested in the performance of computer hardware and software are to be found in both CSE and computer science; faculty interested in the performance of numerical procedures are to be found in both CSE and applied mathematics; faculty interested in finding a computer-based solution to extend theoretical and experimental efforts are common to both CSE and application areas such as physics, chemistry, biology, earth sciences, business, and finance. Faculty tend to be attracted to CSE because it provides a means for them to incorporate their research tools and developments into modern courses. It also saves faculty time by bringing students to a level where they can assist faculty in their research. The students, in turn, learn the tools and techniques needed by modern professionals and obtain valuable job skills. Although integrating your research tools into the classes you teach sounds ideal, it must be noted that the instructional, research, and administrative demands of a CSE program can be a heavy load for faculty as well as for students. Since new tools are constantly arriving in industrial and scientific work environments, we cannot maintain a static curriculum in a field that teaches the use of technology. Likewise, the development of new courses, especially ones in which there is little in the way of established texts, while being exciting, is also challenging and time-consuming. In addition to curriculum development, CSE programs often house computational laboratories with high-end PCs, workstations, supercomputers, or Beowulf clusters. Maintaining these facilities with ever-aging hardware and software can be a major chore. While a dedicated system administrator can be of great help, as can the resources of a supercomputer center, the direction, management, and continued budgeting of a computational laboratory often falls on the shoulders of a faculty member. Other demands on CSE faculty arise from students’ (quite legitimate) expectation that faculty members are knowledgable in all the CSEs courses offered, even those taught by experts from other departments. Related to this are concerns about promotion and tenure decisions when faculty (1) hold joint appointments in several departments, (2) have extra demands on their time, or (3) are undertaking multidisciplinary research or development that is hard to judge by the norms of a traditional discipline. As may be true for all multidisciplinary education, a CSE student may face more demands than a student with only one specialization. To start, CSE students need classes, assistance, and advice in more than one field. In addition, students may feel the extra pressure of having to master three fields, while their single-discipline peers need master only one. Furthermore, there is often stress involved in having to deal with an untested and rapidly changing curriculum, especially when there is no one department to call “home.” Yet interdisciplinary education can also open up new and rewarding worlds for students. If their intellectual interests are in both science and computing, then they are given the freedom to follow these interests. This should appeal to students who ELEMENTS OF COMPUTATIONAL SCIENCE AND ENGINEERING EDUCATION 793 would otherwise have been willing to face the rigors of multiple majors and degrees and to those students who realize that this is the modern approach to problem solving. 2.3. Intellectual Content of CSE Education. While there is widespread recognition that computational science is not the same as computer science, at present there is no nationally accredited CSE curriculum. The first CSE courses were taught at research institutions that recognized their growing dependency on advanced computation as a research tool. Some of these courses were adjuncts to the regular curriculum taught at local supercomputer centers and tended more toward training for the latest machine than basic education. Other courses were taught within departments as part of graduate-student research preparation, and some led to a degree containing the suffix “with computing” (the “Michigan Model” [38]). Undergraduate classes soon followed, and today there are even K–12 classes with CSE content [35, 39, 40]. Particularly at the undergraduate level, some understanding of the intellectual content of a CSE education is needed in order to appreciate the different approaches to that education. Yet there are very few undergraduate programs in computational science to generalize about, and, accordingly, the specific subjects needed to provide this intellectual content are still under active discussion (to wit, this paper). Consequently, the description to follow draws from published survey results, our own surveys, and our experiences in developing two independent degree programs. We start with a survey on the general types of skills that appear to be needed in the workplace. The data in Figure 2.1 were collected by the American Institute of Physics [41]. They indicate, for physics majors five years after graduation, which aspects of their education are most valuable in their current employment. We see that for graduates whose primary field of employment is engineering, mathematics, and science, the three most important skills are scientific problem solving, synthesizing information, and mathematical skills. These skills remain highly important for graduates who find employment related to software, with the latter group also having a high need for computer programming and software development. The importance of mathematics and computer skills was also examined in a National Science Board report [42]. It indicated that 74% of mathematics and computer-science doctorates work in the same field as their degree, in contrast to only 52% of degree holders in life and physical sciences. A similar trend is seen at the bachelor’s level (35% versus 22%). These surveys document the demand for mathematics, computer, and problemsolving skills in the workplace as well as the importance of a science education that can be applied to a variety of jobs. It appears manifest that the integration of mathematics and computer skills with a science and engineering education is a valuable investment, particularly for undergraduates, who, as a group, are more likely than graduate students to find employment outside their discipline. Deciding upon the right balance of mathematics, computing, and sciences is a question we shall discuss soon. The determination of student learning outcomes (SLOs) is an important prerequisite for the establishment of CSE programs. This is especially true for CSE, where it is (all too) easy to expect an individual course to teach students everything they need to know about the subject. Historically, SLOs have been guided by research needs, that is, in a “top-down” fashion. We are aware of only one published work [43] that suggests a set of SLOs for all levels of CSE education. From a student perspective, typical SLOs for a CSE education might include the following: • learning high-level computer languages and high-performance computing; • obtaining knowledge of applied mathematics and computational methods; 794 OSMAN YAŞAR AND RUBIN H. LANDAU W h a t's Impor tant? Percent "Very Impor tant" 0 20 40 60 80 100 Scientific problem solving Synthesizi ng info M athematical ski lls Physics principles Labor instrumentation skills Scientific softw are Sof tw a re Engr., mat h, science Knowledge of physics Modeling or simulation Product design C omp. program mi ng Softw are development Fig. 2.1 Importance of knowledge and skills for graduates, 5–7 years after receiving bachelor’s degree. The categories are listed in order of importance for physics majors whose primary field of employment is engineering, mathematics, and science (light bars); the dark bars show level of importance for graduates employed in software. (Data courtesy of the American Institute of Physics.) • learning the basics of simulation and modeling; • interpreting and analyzing data visually, both during and after computation; • applying acquired computing skills to at least one application area; • learning to communicate solution methods and results effectively. These learning outcomes are achieved by students studying various subjects and working on explicit computational problems. Because courses in different departments may well cover similar materials, rather than list individual courses, we give instead the six general areas of knowledge (details to follow) that are needed to achieve the SLOs: • computational tools; • high-performance computing; • applied mathematics and computational methods; • simulation and modeling; • visualization tools; • applications in science or engineering. Although not all of equal weight, these components are all essential and should be covered either in dedicated courses or within the context of other courses. 1. Computational Tools. Inasmuch as the computer itself is the main tool of CSE, it is essential to provide environments and situations in which students become comfortable using computers. Typical courses in which this occurs are often called “An Introduction to” or “Fundamentals in” one of the following: computational science, ELEMENTS OF COMPUTATIONAL SCIENCE AND ENGINEERING EDUCATION 795 modeling, problem solving, computational tools, or computer science. Additional knowledge can be gained through courses such as data structures, advanced software tools, and numerical linear algebra. Specific learning outcomes include • programming in a compiled language such as Fortran90, C, C++, or Java; • ability to work with UNIX and WINDOWS operating systems; • familiarity with problem-solving environments such as Maple, MATLAB, MACSYMA, and Mathematica for both numeric and symbolic computations; • familiarity with floating-point computations and numerical methods such as integration, differentiation, solutions of ordinary and partial differential equations, and Monte Carlo techniques; • use of mathematical subroutine libraries and repositories such as BLAS, ScaLAPACK, NetSolve, and JAMA; • use of two- and three-dimensional visualization software packages such as AVS, gnuplot, ACE/gr (Xmgr), and VisAD. 2. High-Performance Computing. Knowledge of high-performance computer hardware and software is important for programming of computationally intensive applications. Topics include parallel computing, high-level languages, and optimizing and tuning techniques. The related theoretical knowledge would come from courses in computer architecture and the theory of programming languages. Specific learning outcomes include • programming on supercomputers or PC clusters; • understanding of program speed, memory hierarchy, performance benchmarks, and precision; • understanding the relationship among architecture, language, and performance; • experience with industrial benchmarks such as the Linpack Benchmark; • familiarity with parallel libraries such as PVM, MPI, and MPJ. 3. Applied Mathematics and Computational Methods. Basic knowledge here derives from courses in differential, integral, and vector calculus, preferably with a focus on applications and examples. Numerical analysis and differential equations may provide more focused knowledge, as might courses such as applied and computational mathematics, computational methods in physical sciences, and computational physics. Finally, at least one course in probability and statistics is needed in which actual laboratory data are fit. Specific learning outcomes include • knowledge of computational methods for the numerical solution of differential and integral equations, such as finite-difference, finite-element, discrete particle, discrete ordinates, mesh generation, adaptive meshes, high-order ODE solvers such as Runge–Kutta, fast Fourier transforms, and Monte Carlo methods; • familiarity with partial differential equations encountered in science and engineering; • use of scientific subroutine libraries; • matrix computations with scientific subroutine libraries. 4. Simulation and Modeling. This subject is important in order to achieve CSE’s goal of realistic problem solving. The skills may be taught in a variety of courses such as simulation and modeling, dynamical systems, problem solving, and “computational X.” Specific learning outcomes include • Familiarity with exact and approximate equations of motion for natural systems. Examples include the continuity equation, equations for momentum, 796 OSMAN YAŞAR AND RUBIN H. LANDAU PhD BS MS Fig. 2.2 Perspectives on depth and breadth of computational science education. energy, and mass conservation, transport equations, population dynamics, protein folding, Newton’s laws, and the Schrödinger equation. • Familiarity with the steps (problem, theory, model, implementation, assessment) in modeling as applied to a wide range of fields. Examples include engine combustion, electromagnetics, molecular dynamics, genetics, drug design, quantum mechanics, climate modeling, dynamical systems, and finance. • Ability to carry out statistically meaningful analysis of data from both experiments and simulations. 5. Visualization Tools. Familiarity with visualization software for run-time and postsimulation data. Tools should be able to handle large data sets, permit twoand three-dimensional plots, as well as slicing and dicing for higher dimensional data sets, and produce publication-quality figures. The level should be that of AVS, MATLAB, ACE/gr, gnuplot, and OpenGL. Courses to teach these skills include scientific computing, visualization, and computational tools. 6. Applications in Science or Engineering. An essential part of CSE education is having students focus on a traditional field of interest such as chemistry, physics, biology, earth sciences, business, criminal justice, art, or engineering. This should help the students in the job market, in applying to graduate school, and in understanding different and realistic ways of looking at issues. Just which field and which courses can accomplish this goal best is probably a function of local politics, expertise, and student interest. Often a “computational X” course serves this purpose well, as it provides exposure to applications while introducing students to the computational aspects of discipline X. 2.4. Types of Programs and Degrees. We now address the (still unsettled) question of transforming the intellectual content of CSE into a curriculum of courses. Because CSE is a new and different field that may draw students away from traditional departments, the academy is naturally slow to certify any CSE program. In addition, CSE is multidisciplinary and there are no set rules that give the proper balance and depth of the four components in Figure 1.1. Finally, there remains the decision as to whether CSE should be taught at the graduate or undergraduate level, and how the content would differ for the two. Graduate Degree. Figure 2.2 represents the depth and breadth of graduate and undergraduate programs in CSE. Although it may appear that the depth needed for a Ph.D. program makes it formidable to set up, it is probably less of a challenge ELEMENTS OF COMPUTATIONAL SCIENCE AND ENGINEERING EDUCATION 797 than an undergraduate program. This is due to the dual constraints of breadth and limited credit load that are typically imposed on undergraduate degrees. Doctoral CSE programs tend to be of top-down design, with the top-level research needs dictating the courses at the bottom. If there are faculty members carrying on research with high-level computation, then their needs and knowledge tend to determine the elements of a Ph.D. program incorporating CSE at their institution. If there is a supercomputer center on campus, then it tends to naturally provide the computational expertise and resources. While it is important that individual departments offer relevant and modern courses, doctoral students have a great deal of flexibility in meeting the requirements set by their program committees since they do not have a large number of required classes to take in a fixed time period. A doctoral-level CSE education is also easier to establish than an undergraduate one by nature of the expectation that doctoral students will assume the initiative to learn requisite materials on their own. Typically, much of a CSE doctoral education is assumed to take place when a student performs the simulations that are part of the research for a computationally intensive thesis. If done properly, students should learn about performance of hardware and software, development and optimization of numerical and computational methods, and advanced visualization skills. Yet even a solid design for doctoral education does not guarantee quality. Without adequate background in all the elements of CSE, the thesis will suffer and students may end up with holes in their understanding. We recommend multidisciplinary course work, as well as a graduate committee with members from computer science, mathematics, and application sciences. Master’s Degree. It is hard to generalize about master’s degrees. Usually graduatelevel courses are required, and often a research project or thesis as well. However, many of the graduate-level classes may cover the same materials as the upper division undergraduate classes in CSE, but perhaps with deeper applications. Accordingly, it may well be that a master’s degree in CSE that does not require research or internship provides a similar education to that of an undergraduate degree. If research is required, then a master’s program can be quite intensive. In fact, some combinations of programs and advisors may require research that is nearly as significant as the doctoral research of other programs. Undergraduate Degree. The major obstacle with undergraduate CSE education is that the programs which faculty consider well-rounded combinations of disciplines tend to be so overloaded with classes that they are nearly impossible to complete in four years. With already-full curricula, it is hard to find places for challenging CSE classes, especially with university pressure to broaden the number of core courses, to cap and even decrease the number of credits needed for graduation, and to increase retention (presumably by lowering demands). Although details vary with local conditions, we conclude that it is best for the undergraduate curriculum to focus on a common tool set of subjects that have proven themselves useful in a number of specialty areas. In order to avoid overloading and to provide the needed breadth, we recommend that a B.S. or an M.S. program in CSE have fairly strict curriculum requirements. This takes the place of a high-quality thesis in a Ph.D. program and permits the marketplace and the graduate schools to expect a common preparation. In spite of the challenges, several schools have experimented with undergraduate CSE programs, and these now provide some field-tested approaches. In Table 2.1 we present a sample curriculum for the B.S. degree in the Computational Science Department at SUNY Brockport [12, 33, 43] This program was started in 1998 by 798 OSMAN YAŞAR AND RUBIN H. LANDAU Table 2.1 Sample curriculum for B.S. in computational science at SUNY Brockport. Fall Spring 1 Calculus I Application Sciences I Intro to Computational Sci 2 Electives Calculus II Application Sciences II Intro to Computer Science 2 Electives 2 Fund. Comp. Sc. I Computational Tools I Discrete Mathematics I 2 Electives Elementary Statistics Computational Tools II Calculus III 2 Electives 3 Linear Algebra High-Performance Comp Application Sciences III 2 Electives Simulation and Modeling 3 Electives 4 Applied & Comp. Mathematics Topics in Computational Sci 2 Electives Scientific Visualization Application Sciences III 2 Electives Table 2.2 Sample yearly schedule for B.S. in computational physics (CP) at Oregon State University (180 quarter credits, equivalent to 120 semester credits). CS refers to computational science. Fall Winter Spring 1 Differential Calculus Fitness General Chemistry CP/CS Seminar Perspective Sci Computing I General Chemistry Integral Calculus Perspective Computer Sci I Vector Calculus I General Physics Writing I 2 Computer Science II Writing II Vector Calculus II General Physics Discrete Math Series & Sequences General Physics Perspective Sci Computing II Linear Algebra App Diff Eqs Modern Physics 3 CP Simulations I CP Seminar Intro Probability Oscillations Static Vector Fields Writing III CP Simulations II Data Structures Waves in 1D Quantum Mech Central Forces Elective Periodic Systems Class Mech Energy & Entropy Biology Perspective 4 Num Linear Algbr Electromagnetism Math Methods Phys Electives Adv CP Lab Soc & Ethic CS Electives Synthesis Thesis Adv Web Authoring CP Seminar Electives one of the present authors, Osman Yaşar, and we believe it is the first stand-alone program to have actually issued a B.S. degree in CSE. In Table 2.2 we present a sample curriculum for the B.S. degree in computational physics (the “Perspective” courses in the table integrate fundamental knowledge from science and liberal arts disciplines to develop cultural, historic, and scientific perspectives). This CPUG (Computational Physics for Undergraduates) program was started by one of the present authors, Rubin Landau, in 2001 within the Physics Department at Oregon State University [44, 45], and granted its first degree in 2003 (to a transfer student). ELEMENTS OF COMPUTATIONAL SCIENCE AND ENGINEERING EDUCATION 799 3. Survey Results. To develop some quantitative understanding of the intellectual content of CSE programs, we have analyzed the curricula of the two programs detailed in Tables 2.1 and 2.2 as well as the handful of other CSE programs of which we are aware. Our goal is to provide materials for informed and critical discussions on the nature of CSE education. The choices of programs were guided by information we obtained at conferences, the latest version of Swanson’s survey of CSE programs [34], a recent computational science Web portal at SUNY Brockport [46], and our own Web searches. For a survey of graduate degree programs, we refer the reader to Swanson’s survey [34], the SIAM Working Group on CSE Education [11], as well as the SIAM listing of graduate CSE programs [47]. Swanson identifies one B.S. program in computational science, three B.S. programs in computational mathematics, three B.S. programs in computational physics, and several concentrations and minors. The SIAM survey [11] identifies only Brockport as a CSE degree program. We included in our analysis all of Swanson’s programs except for the University of Chicago, for which no sample curriculum could be found. Although it did not appear in any Web searches, we include here a degree program at UC Berkeley whose existence was communicated to us personally. Our analysis is comprehensive in its coverage of computational degrees, and representative of computer science and physics. The Swanson survey is particularly helpful in identifying where programs exist and in providing detailed contents of different computational classes (similar to our earlier description of a standard tool set). The analysis to follow is more general. For each program we look at four years’ worth of classes and count the number of courses that fall into the categories of computing, mathematics, applications, and other. Admittedly, our analysis is crude. We examined neither the materials actually covered in the individual classes nor the amount of “other” that may actually be computing, mathematics, or application. However, we have tried to apply the same rules to all programs (such as including chemistry in the applications category) and have used posted sample schedules as our guide. As we shall see, even though the analysis is crude, there appear to be significant trends that stand out. As interesting as it may be to see how other countries put together their CSE programs, we have restricted our survey to the United States. This is a consequence of our difficulty in deciding how to count classes and requirements for foreign systems and in extracting up-to-date data from their Web pages. We know there are high-quality CSE programs at schools such as the Australian National University [48], Kanazawa University (Japan) [49], Trinity College, Dublin [50], University of Singapore [51], and the University of Waterloo [52], and we refer the reader to Yaşar’s Web portal [46] for links to both national and international CSE programs. Figure 3.1 shows the average percent of the total curriculum dedicated to computing, mathematics, application, and other for B.S. degree programs in computer science, computational science and engineering, computational physics, and physics. The computer science average is from Carnegie-Mellon University [53], the University of Illinois at Urbana-Champaign [54], and Oregon State University [55]; the CSE average is from SUNY Brockport [56] and the University of California at Berkeley [57]; the computational physics average is from SUNY Buffalo [58], Illinois State University [59], and Oregon State University [44]; the physics average is from the University of Illinois at Urbana-Champaign [60] and Oregon State University [61]. In general we would say that the left column in Figure 3.1 shows the strong computing (black) but weak application (white) components in the computer science degree; the right column shows the strong application but weak computing components 800 OSMAN YAŞAR AND RUBIN H. LANDAU Subject Balance (% Courses) 100 80 60 40 20 0 Ot her Application Math Comp CS C SE CP PH 31 17 12 40 29 28 23 20 32 28 19 20 36 45 17 2 Fig. 3.1 The average percent of the total curriculum dedicated to computing, mathematics, application, and “other” for B.S. degree programs in (from left to right) computer science, computational science and engineering, computational physics, and physics. in the physics degree. The two versions of computational programs in the middle of Figure 3.1 are seen to provide a similar, uniform balance among the components. In contrast to our analysis, the IEEE Computer Society [62] tells a student interested in a “career in computing” to expect a curriculum in which “35% of your career will be in your major field of science or engineering, 25% in mathematics or science (outside your major field), 25% in arts and humanities, and about 15% in electives.” Our analysis indicates that an application-oriented computing education is somewhat stronger in mathematics and has a stronger computing content than the IEEE indicates. While an undergraduate CSE student may specialize by selecting options in a specific discipline, doing so makes the curriculum similar to one in “computational X” (typically offered within the department of X). Indeed, as indicated in Figure 3.1, an undergraduate degree in computational physics has a similar balance to one in CSE, namely, approximately equal weights for mathematics and computing (∼ 20%), and a higher weight for application (∼ 28%). However, a computational physics degree does contain less physics than a physics degree and less computing than a computer science degree. Of course, because computational science is still a young and developing field with no set curriculum, some variation in individual programs from these averages is to be expected. Accordingly, in Figures 3.2 and 3.3 we show the subject balance for several of the individual programs that were averaged into Figure 3.1. We see in Figure 3.2 that the CSE programs at Berkeley and Brockport have a similar balance, which is also similar to that in computational physics program at Oregon State University. In contrast, the computational mathematics program at Stanford appears much weaker in computing and application, but since it has a significantly larger fraction of other, ELEMENTS OF COMPUTATIONAL SCIENCE AND ENGINEERING EDUCATION 801 S ubj ect B alance ( % of Cur ricu lum) Interdiscipl inary Progr a ms 100 80 60 40 20 0 O ther Science Math Computing CSE (BKY) C SE (Brock) M +CSE (Stnfrd) CP (OSU) 29 30 24 17 30 26 22 22 56 12 23 9 31 26 20 23 Fig. 3.2 Subject balance for individual computational science and engineering B.S. degree programs at (from left to right) UC Berkeley and SUNY Brockport, and the mathematics plus computational science program at Stanford. The computational physics program at Oregon State is shown for comparison. S ubj ect Balance D i scipline-Based Pr ograms 100% 80% 60% 40% 20% 0% Ot her Application Math Computing CP (O SU) CP (S-Buf) CP (I SU) 31 26 20 23 30 26 22 22 35 33 16 16 P+CSE M + CSE (Cl ark) (Stnfrd) 38 34 16 13 56 12 23 9 Fig. 3.3 Subject balance for individual computational physics degree programs at (from left to right) Oregon State, SUNY Buffalo, Illinois State, and Clark (physics plus computational science concentration). The mathematics plus computational science at Stanford is shown for comparison. 802 OSMAN YAŞAR AND RUBIN H. LANDAU it may well be that a similar balance is obtained after students choose their large number of electives. We see in Figure 3.3 that the computational physics programs at Buffalo and Oregon State have essentially identical balances, while the programs at Illinois State and Clark emphasize application and other more and computing less. (The nearly exact agreement is probably accidental since we estimate a 1–2% ambiguity in our analysis arising from the choice of options and courses listed in multiple departments.) No doubt some of this uniformity arises from what might be called a “sum rule”: Because all programs are designed to have students graduate in four years with a similar set of university-wide requirements, the computational degree programs tend to replace some of what would otherwise be electives with computation and mathematics classes, and thus end up with a similar distribution. Future experience may establish a better balance than we have now, although we suspect that there is no one global solution. While we have focused here on stand-alone programs, there are other approaches that can supply a quality education. Surveys of programs described on the Web [34, 56] reveal cases in which a B.S. degree in “computational X” is close to a CSE degree with a minor in X, and others in which it is close to a degree in X with a minor in CSE or computer science. So, even though the names may differ, the contents of different programs may be much the same. 4. Summary and Conclusions. Although details vary, CSE education tends to focus on a common tool set of subjects that have proven themselves useful in solving problems in a number of disciplines. While many of these subjects may get coverage in courses taught by traditional departments, we have described the need for separate CSE classes that (1) put the tools together, (2) develop an appropriate problemsolving viewpoint, (3) glue the multiple disciplinary classes together, and (4) develop a sense of belonging to a computational community. Local politics and course offerings appear to determine how a school chooses to integrate CSE into its programs. We conclude that the CSE content of undergraduate education will continue to grow, either by integrating CSE into traditional classes, by offering specific “computational X” classes, by offering “computational X” degrees, by starting stand-alone CSE units, or by some combination of the above. No doubt, a specific degree program in CSE has the most potential to provide a coherent and well-managed education. It probably also does the most to advance the field and guarantee continuity within the institution. As campuses develop a number of “computational X” programs, it may be more efficient and simpler to unify these “computational X” programs into a CSE department. Such units may then serve even more departments by offering a minor in CSE. However, it appears that a degree in “computational X” is currently providing a very similar education. Strong links and cooperation now appear to be building up among the people directing the new CSE programs and those who want to start such programs. Indeed, efforts are being supported by the NSF [40, 63, 64] and DOE [35]. We are now sharing course materials for newly developed courses as well as giving and receiving guidance on the development of a well-balanced curriculum. Development of student learning outcomes, building a consensus on a standard CSE curriculum, and the development of some high-quality textbooks will help in the development of the field and in the placement of our graduates. While there appears to be general agreement that it is appropriate to teach CSE at the graduate level, an undergraduate education in CSE is still a new thing. A ELEMENTS OF COMPUTATIONAL SCIENCE AND ENGINEERING EDUCATION 803 decade ago, a widely held view was that undergraduates should view computational methods as just “black boxes” that should remain closed [65]. However, we believe that the pervasiveness and importance of computation throughout all of science and engineering means that even undergraduates should be able to enroll in programs that teach them what’s going on inside the black box. Time will judge the viability of these programs. Acknowledgments. We wish to thank Angela Shiflet, Charles Swanson, James Corones, Bob Panoff, and Joe Zachary for valuable suggestions and encouragements; Katie Stowe and Rachel Ivie for providing the AIP survey data; and the SIAM referees and editors for their constructive criticisms. REFERENCES [1] [2] [3] [4] [5] [6] [7] [8] [9] [10] [11] [12] [13] [14] [15] [16] [17] [18] [19] [20] [21] [22] [23] [24] [25] Climate Modeling, Comput. Sci. Engrg., 4 (2002), special issue. LATTICE97, Nuclear Phys. B, 63 (1998), p. 1. O. Yaşar, A scalable model for complex flows, Int. J. Comput. Math., 35 (1998), pp. 117–128. Materials Science, Comput. Sci. Engrg., 3 (2001), special issue. Envision, NPACI & SDSC Quarterly Science Magazine, 18 (2002). E. S. Hertel et al., CTH: A software family for multi-dimensional shock physics analysis, in Proceedings of the 19th International Symposium on Shock Waves, Vol. 1, R. Brun and L. D. Dumitrescu, eds., Marseille, France, 1993, pp. 377–382. Chaos, 12 (2002). Data Mining, Comput. Sci. Engrg., 4 (2002), special issue. K. Stewart, R. Giles, and I. Zaslavsky, Super-Partnerships: Computational Science Curricula, High Performance Computing and the Professional Organizations, EDUCAUSE ’99, http://www.educause.edu/ir/library/html/edu9928/edu9928.html. O. Yaşar, K. S. Rajasethupathy, R. E. Tuzun, R. A. McCoy, and J. Harkin, A new perspective on computational science education, Comput. Sci. Engrg., 5 (2000), pp. 74–79. SIAM Working Group on CSE Education, Graduate education in computational science and engineering, SIAM Rev., 43 (2001), pp. 163–177. O. Yaşar, Computational Science Program at SUNY Brockport, in Proceedings of the First SIAM Conference on Computational Science and Engineering, 2000, Washington, D.C., 2000. L. D. Fosdick, E. R. Jessup, C. J. C. Schauble, and G. Domik, An Introduction to HighPerformance Scientific Computing, MIT, Cambridge, MA, 1996. H. J. Gould, J. Tobochnik, and W. Christian, Simulations in Physics, 3rd ed., AddisonWesley, Reading, MA, 2003. P. Harrison, Computational Methods in Physics, Chemistry and Biology, Wiley, New York, 2001. R. H. Landau and M. J. Paez, Computational Physics, Problem Solving with Computers, Wiley-Interscience, New York, 1997. W. H. Press, B. P. Flannery, S. A. Teukolsky, and W. T. Vetterling, Numerical Recipes, Cambridge University Press, Cambridge, UK, 1994. J. L. Zachary, Introduction to Scientific Programming, Computational Problem Solving Using Maple and C, Springer/Telos, New York, 1996. P. D. Lax, Report of the Panel on Large Scale Computing in Science and Engineering, DOD, NSF, DOE, NASA, 1982. R. W. Hocknew and J. W. Eastwood, Computer Simulations Using Particles, Adam Hilger, New York, 1988. President’s Information Technology Advisory Committee, Information Technology Research: Investing in Our Future, http://www.ccic.gov/ac/. National Science Foundation, Math and Science Partnership Program, http://www.ehr. nsf.gov/msp/. M. Wright and A. Chorin, Mathematics and Science, National Science Foundation, Division of Mathematical Sciences, Washington, D.C., 1999. A. Harrison, An Exploration of the Nature and Quality of Undergraduate Education in Science, Mathematics, and Engineering, Sigma Xi, Research Triangle Park, NC, 1989. K. L. Johnston and B. G. Aldridge, The crisis in science education: What is it? How can we respond?, J. Coll. Sci. Teach., 14 (1984), p. 20. 804 OSMAN YAŞAR AND RUBIN H. LANDAU [26] F. J. Rutherford and A. Ahlgren, Science for All Americans, Oxford University Press, New York, 1990. [27] J. A. Dunkhase and J. E. Penick, Problem solving in the real world, J. Coll. Sci. Teach., 19 (1990), pp. 367–370. [28] National Research Council, National Science Education Standards, National Academy Press, Washington, D.C., 1996. [29] LEAD Center, Learning through Evaluation Adaption Dissemination, University of Wisconsin, Madison, http://www.cae.wisc.edu/∼lead/. [30] National Foundation for Improving Education, Connecting the bits: A reference for using technology in teaching and learning in K–12 schools, http://www.nfie.org/publications/ connecting.htm. [31] J. R. Rice, Academic programs in computational science and engineering, Computational Science and Engineering, 1 (1994), pp. 13–21. [32] D. E. Stevenson, Science, computational science and computer science: At a crossroads, Comm. ACM, 137 (1994), pp. 85–96. [33] M. L. Ennis, Update on the Status of Computational Science and Engineering in U.S. Graduate Programs, AHPCC99-023, Albuquerque High Performance Computing Center, University of New Mexico, Albuquerque, 1999. [34] C. D. Swanson, Computational Science Education Survey, Krell Institute, http://www. krellinst.org/learningcenter/CSE survey/. [35] The Krell Institute Learning Center, http://www.krellinst.org/learningcenter. [36] The Pew Charitable Trusts, The Responsive University: Restructuring for High Performance, http://www.pewtrusts.com, 1998. [37] The Center for Higher Education Policy Analysis, Projects/Papers, http://www.usc. edu/dept/chepa. [38] Ph.D. in Scientific Computing at The Center for Advanced Computing, College of Engineering, Univ. of Michigan, http://cac.engin.umich.edu/academics/. [39] The Education Center on Computational Science and Engineering, http://www. edcenter.sdsu.edu/. [40] National Computational Science Institute, http://www.computationalscience.net; Shodor Foundation, http://www.shodor.org; The Computational Science Education Project, http://csep1.phy.ornl.gov/csep.html. [41] R. Ivie and K. Stowe, What’s Important?, Physics Trends Flyer, American Institute of Physics, College Park, MD, 1999. [42] National Science Board, Science and Engineering Indicators, Chapters 3-2, National Science Board, Washington, D.C., 1996. [43] O. Yaşar, Computational science education: Standards, learning outcomes and assessment, in Computational Science—ICCS 2001 International Conference, V. N. Alexandrov et al., eds., Lecture Notes in Comput. Sci. 2073, Springer-Verlag, Berlin, 2001, pp. 1159–1169. [44] Computational Physics for Undergraduates (CPUG), Oregon State University, http://www.physics.orst.edu/CPUG/; sample curriculum at http://www.physics.orst.edu/ CPUG/BSCP/curricmod3.html. [45] R. H. Landau, Developing components and curricula for a research-rich undergraduate degree in computational physics, in Computational Science—ICCS 2001 International Conference, V. N. Alexandrov et al., eds., Lecture Notes in Comput. Sci. 2073, Springer-Verlag, Berlin, 2001, pp. 1051–1060. [46] O. Yaşar, Computational Science Portal, http://www.cps.brockport.edu/˜yasar/private/ cse.html. [47] Graduate Programs in Computational Science, http://www.siam.org/cse/cse programs.htm. [48] Bachelor of Computational Science, Australian National University, http://room.anu. edu.au/bcomptlsci/. [49] Department of Computational Science, Kanazawa University, Japan, http://cmpsci. s.kanazawa-u.ac.jp/English/. [50] Moderatorship in Computational Physics, Physics Department, Trinity College, Dublin, http://www.tcd.ie/Physics/Courses/page39.html. [51] Department of Computational Science, National University of Singapore, http://www.cz3. nus.edu.sg/AY2001-02handbook.html. [52] Computational Science Program, University of Waterloo, http://www.science.uwaterloo. ca/ustudent/compscience.html. [53] Computer Science Department, Carnegie Mellon University, http://www.csd.cs.cmu.edu/; sample curriculum at http://www.csd.cs.cmu.edu/education/bscs/currsequence.html. ELEMENTS OF COMPUTATIONAL SCIENCE AND ENGINEERING EDUCATION 805 [54] Department of Computer Science, University of Illinois at Urbana-Champaign, http://old-www.cs.uiuc.edu/; sample curriculum at http://old-www.cs.uiuc.edu/ education/undergrad/degrees/cs.html. [55] Department of Computer Science, Oregon State University; http://www.cs.orst.edu; sample curriculum at http://www.cs.orst.edu/info/undergrad/acsopt.html. [56] Department of Computational Science, State University of New York College at Brockport, http://www.cps.brockport.edu. [57] Engineering Science Program, University of California at Berkeley, http://www.coe.berkeley. edu/engsci/; sample curriculum at http://www.coe.berkeley.edu/CES/ces curric.html. [58] B.S. Degree in Computational Physics, Departments of Computer Science, Engineering, and Physics, State University of New York, Buffalo, http://www.physics.buffalo.edu/ undergrad/cp.html. [59] Computational Physics B.S., Illinois State University, www.phy.ilstu.edu/CompPhys/ CompPhys.html; sample curriculum at http://www.phy.ilstu.edu/CompPhys/courseq. html. [60] Department of Physics, University of Illinois at Urbana-Champaign, http://www.physics. uiuc.edu/; sample curriculum at http://www.physics.uiuc.edu/Education/undergrad/ programs. [61] Department of Physics, Oregon State University, http://www.physics.orst.edu/; sample curriculum at http://www.physics.orst.edu/Advising. [62] IEEE Computer Society, Careers in Computing, http://www.computer.org/education/ careers.htm. [63] National Partnership for Advanced Computing Infrastructure, http://www.npaci.edu. [64] Education, Outreach and Training Thrust Area, National Partnership for Advanced Computational Infrastructure, http://www.npaci.edu/Outreach/. [65] D. L. Greenwell, R. K. Kalia, P. Vashishta, and H. W. Myron, eds., Workshop Report, Undergraduate and Graduate Education in Computational Sciences, Louisiana State University and U.S. Department of Energy, 1991.